1 /*
2  * Copyright 2018-2023, NXP
3  * Copyright (c) 2019 PHYTEC Messtechnik GmbH
4  *
5  * SPDX-License-Identifier: Apache-2.0
6  */
7 
8 #include <soc.h>
9 #include <string.h>
10 #include <zephyr/drivers/usb/usb_dc.h>
11 #include <zephyr/usb/usb_device.h>
12 #include <soc.h>
13 #include <zephyr/init.h>
14 #include <zephyr/kernel.h>
15 #include <zephyr/drivers/pinctrl.h>
16 #include "usb.h"
17 #include "usb_device.h"
18 #include "usb_device_config.h"
19 #include "usb_device_dci.h"
20 
21 #ifdef CONFIG_USB_DC_NXP_EHCI
22 #undef DT_DRV_COMPAT
23 #define DT_DRV_COMPAT nxp_ehci
24 #include "usb_device_ehci.h"
25 #endif
26 #ifdef CONFIG_USB_DC_NXP_LPCIP3511
27 #undef DT_DRV_COMPAT
28 #define DT_DRV_COMPAT nxp_lpcip3511
29 #include "usb_device_lpcip3511.h"
30 #endif
31 #ifdef CONFIG_HAS_MCUX_CACHE
32 #include <fsl_cache.h>
33 #endif
34 
35 
36 #define LOG_LEVEL CONFIG_USB_DRIVER_LOG_LEVEL
37 #include <zephyr/logging/log.h>
38 #include <zephyr/irq.h>
39 LOG_MODULE_REGISTER(usb_dc_mcux);
40 
41 static void usb_isr_handler(void);
42 
43 /* the setup transfer state */
44 #define SETUP_DATA_STAGE_DONE	(0)
45 #define SETUP_DATA_STAGE_IN	(1)
46 #define SETUP_DATA_STAGE_OUT	(2)
47 
48 /*
49  * Endpoint absolute index calculation:
50  *
51  * MCUX EHCI USB device controller supports a specific
52  * number of bidirectional endpoints. Bidirectional means
53  * that an endpoint object is represented to the outside
54  * as an OUT and an IN Endpoint with its own buffers
55  * and control structures.
56  *
57  * EP_ABS_IDX refers to the corresponding control
58  * structure, for example:
59  *
60  *  EP addr | ep_idx | ep_abs_idx
61  * -------------------------------
62  *  0x00    | 0x00   | 0x00
63  *  0x80    | 0x00   | 0x01
64  *  0x01    | 0x01   | 0x02
65  *  0x81    | 0x01   | 0x03
66  *  ....    | ....   | ....
67  *
68  * The NUM_OF_EP_MAX (and number of s_ep_ctrl) should be double
69  * of num_bidir_endpoints.
70  */
71 #define EP_ABS_IDX(ep)		(USB_EP_GET_IDX(ep) * 2 + \
72 					(USB_EP_GET_DIR(ep) >> 7))
73 #define NUM_OF_EP_MAX		(DT_INST_PROP(0, num_bidir_endpoints) * 2)
74 
75 #define NUM_INSTS DT_NUM_INST_STATUS_OKAY(nxp_ehci) + DT_NUM_INST_STATUS_OKAY(nxp_lpcip3511)
76 BUILD_ASSERT(NUM_INSTS <= 1, "Only one USB device supported");
77 
78 /* Controller ID is for HAL usage */
79 #if defined(CONFIG_SOC_SERIES_IMXRT5XX) || \
80 	defined(CONFIG_SOC_SERIES_IMXRT6XX) || \
81 	defined(CONFIG_SOC_LPC55S26) || defined(CONFIG_SOC_LPC55S28) || \
82 	defined(CONFIG_SOC_LPC55S16)
83 #define CONTROLLER_ID	kUSB_ControllerLpcIp3511Hs0
84 #elif defined(CONFIG_SOC_LPC55S36)
85 #define CONTROLLER_ID	kUSB_ControllerLpcIp3511Fs0
86 #elif defined(CONFIG_SOC_LPC55S69_CPU0) || defined(CONFIG_SOC_LPC55S69_CPU1)
87 #if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(usbhs))
88 #define CONTROLLER_ID	kUSB_ControllerLpcIp3511Hs0
89 #elif DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(usbfs))
90 #define CONTROLLER_ID	kUSB_ControllerLpcIp3511Fs0
91 #endif /* LPC55s69 */
92 #elif defined(CONFIG_SOC_SERIES_IMXRT11XX) || \
93 	defined(CONFIG_SOC_SERIES_IMXRT10XX) || \
94 	defined(CONFIG_SOC_SERIES_MCXN)
95 #if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(usb1))
96 #define CONTROLLER_ID kUSB_ControllerEhci0
97 #elif DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(usb2))
98 #define CONTROLLER_ID kUSB_ControllerEhci1
99 #endif /* IMX RT */
100 #elif defined(CONFIG_SOC_SERIES_RW6XX)
101 #define CONTROLLER_ID kUSB_ControllerEhci0
102 #else
103 /* If SOC has EHCI or LPCIP3511 then probably just need to add controller ID to this code */
104 #error "USB driver does not yet support this SOC"
105 #endif /* CONTROLLER ID */
106 
107 /* We do not need a buffer for the write side on platforms that have USB RAM.
108  * The SDK driver will copy the data buffer to be sent to USB RAM.
109  */
110 #ifdef CONFIG_USB_DC_NXP_LPCIP3511
111 #define EP_BUF_NUMOF_BLOCKS	(NUM_OF_EP_MAX / 2)
112 #else
113 #define EP_BUF_NUMOF_BLOCKS	NUM_OF_EP_MAX
114 #endif
115 
116 /* The max MPS is 1023 for FS, 1024 for HS. */
117 #if defined(CONFIG_NOCACHE_MEMORY)
118 #define EP_BUF_NONCACHED
119 K_HEAP_DEFINE_NOCACHE(ep_buf_pool, 1024 * EP_BUF_NUMOF_BLOCKS);
120 #else
121 K_HEAP_DEFINE(ep_buf_pool, 1024 * EP_BUF_NUMOF_BLOCKS);
122 #endif
123 
124 struct usb_ep_ctrl_data {
125 	usb_device_callback_message_struct_t transfer_message;
126 	void *block;
127 	usb_dc_ep_callback callback;
128 	uint16_t ep_mps;
129 	uint8_t ep_enabled : 1;
130 	uint8_t ep_occupied : 1;
131 };
132 
133 struct usb_dc_state {
134 	usb_device_struct_t dev_struct;
135 	/* Controller handle */
136 	usb_dc_status_callback status_cb;
137 	struct usb_ep_ctrl_data *eps;
138 	bool attached;
139 	uint8_t setup_data_stage;
140 	K_KERNEL_STACK_MEMBER(thread_stack, CONFIG_USB_MCUX_THREAD_STACK_SIZE);
141 
142 	struct k_thread thread;
143 };
144 
145 static struct usb_ep_ctrl_data s_ep_ctrl[NUM_OF_EP_MAX];
146 static struct usb_dc_state dev_state;
147 
148 /* Message queue for the usb thread */
149 K_MSGQ_DEFINE(usb_dc_msgq, sizeof(usb_device_callback_message_struct_t),
150 	CONFIG_USB_DC_MSG_QUEUE_LEN, 4);
151 
152 #if defined(CONFIG_USB_DC_NXP_EHCI)
153 /* EHCI device driver interface */
154 static const usb_device_controller_interface_struct_t mcux_usb_iface = {
155 	USB_DeviceEhciInit, USB_DeviceEhciDeinit, USB_DeviceEhciSend,
156 	USB_DeviceEhciRecv, USB_DeviceEhciCancel, USB_DeviceEhciControl
157 };
158 
159 extern void USB_DeviceEhciIsrFunction(void *deviceHandle);
160 
161 #elif defined(CONFIG_USB_DC_NXP_LPCIP3511)
162 /* LPCIP3511 device driver interface */
163 static const usb_device_controller_interface_struct_t mcux_usb_iface = {
164 	USB_DeviceLpc3511IpInit, USB_DeviceLpc3511IpDeinit, USB_DeviceLpc3511IpSend,
165 	USB_DeviceLpc3511IpRecv, USB_DeviceLpc3511IpCancel, USB_DeviceLpc3511IpControl
166 };
167 
168 extern void USB_DeviceLpcIp3511IsrFunction(void *deviceHandle);
169 
170 #endif
171 
usb_dc_reset(void)172 int usb_dc_reset(void)
173 {
174 	if (dev_state.dev_struct.controllerHandle != NULL) {
175 		dev_state.dev_struct.controllerInterface->deviceControl(
176 						dev_state.dev_struct.controllerHandle,
177 						kUSB_DeviceControlSetDefaultStatus, NULL);
178 	}
179 
180 	return 0;
181 }
182 
usb_dc_attach(void)183 int usb_dc_attach(void)
184 {
185 	usb_status_t status;
186 
187 	dev_state.eps = &s_ep_ctrl[0];
188 	if (dev_state.attached) {
189 		LOG_WRN("Already attached");
190 		return 0;
191 	}
192 
193 	dev_state.dev_struct.controllerInterface = &mcux_usb_iface;
194 	status = dev_state.dev_struct.controllerInterface->deviceInit(CONTROLLER_ID,
195 						&dev_state.dev_struct,
196 						&dev_state.dev_struct.controllerHandle);
197 	if (kStatus_USB_Success != status) {
198 		return -EIO;
199 	}
200 
201 	IRQ_CONNECT(DT_INST_IRQN(0), DT_INST_IRQ(0, priority),
202 		    usb_isr_handler, 0, 0);
203 	irq_enable(DT_INST_IRQN(0));
204 	dev_state.attached = true;
205 	status = dev_state.dev_struct.controllerInterface->deviceControl(
206 						dev_state.dev_struct.controllerHandle,
207 						kUSB_DeviceControlRun, NULL);
208 
209 	LOG_DBG("Attached");
210 
211 	return 0;
212 }
213 
usb_dc_detach(void)214 int usb_dc_detach(void)
215 {
216 	usb_status_t status;
217 
218 	if (dev_state.dev_struct.controllerHandle == NULL) {
219 		LOG_WRN("Device not attached");
220 		return 0;
221 	}
222 
223 	status = dev_state.dev_struct.controllerInterface->deviceControl(
224 						   dev_state.dev_struct.controllerHandle,
225 						   kUSB_DeviceControlStop,
226 						   NULL);
227 	if (kStatus_USB_Success != status) {
228 		return -EIO;
229 	}
230 
231 	status = dev_state.dev_struct.controllerInterface->deviceDeinit(
232 						   dev_state.dev_struct.controllerHandle);
233 	if (kStatus_USB_Success != status) {
234 		return -EIO;
235 	}
236 
237 	dev_state.dev_struct.controllerHandle = NULL;
238 	dev_state.attached = false;
239 	LOG_DBG("Detached");
240 
241 	return 0;
242 }
243 
usb_dc_set_address(const uint8_t addr)244 int usb_dc_set_address(const uint8_t addr)
245 {
246 	usb_status_t status;
247 
248 	dev_state.dev_struct.deviceAddress = addr;
249 	status = dev_state.dev_struct.controllerInterface->deviceControl(
250 		dev_state.dev_struct.controllerHandle,
251 		kUSB_DeviceControlPreSetDeviceAddress,
252 		&dev_state.dev_struct.deviceAddress);
253 	if (kStatus_USB_Success != status) {
254 		LOG_ERR("Failed to set device address");
255 		return -EINVAL;
256 	}
257 	return 0;
258 }
259 
usb_dc_ep_check_cap(const struct usb_dc_ep_cfg_data * const cfg)260 int usb_dc_ep_check_cap(const struct usb_dc_ep_cfg_data *const cfg)
261 {
262 	uint8_t ep_abs_idx =  EP_ABS_IDX(cfg->ep_addr);
263 	uint8_t ep_idx = USB_EP_GET_IDX(cfg->ep_addr);
264 
265 	if ((cfg->ep_type == USB_DC_EP_CONTROL) && ep_idx) {
266 		LOG_ERR("invalid endpoint configuration");
267 		return -1;
268 	}
269 
270 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
271 		LOG_ERR("endpoint index/address out of range");
272 		return -1;
273 	}
274 
275 	return 0;
276 }
277 
usb_dc_ep_configure(const struct usb_dc_ep_cfg_data * const cfg)278 int usb_dc_ep_configure(const struct usb_dc_ep_cfg_data *const cfg)
279 {
280 	uint8_t ep_abs_idx =  EP_ABS_IDX(cfg->ep_addr);
281 	usb_device_endpoint_init_struct_t ep_init;
282 	struct usb_ep_ctrl_data *eps = &dev_state.eps[ep_abs_idx];
283 	usb_status_t status;
284 	uint8_t ep;
285 
286 	ep_init.zlt = 0U;
287 	ep_init.endpointAddress = cfg->ep_addr;
288 	ep_init.maxPacketSize = cfg->ep_mps;
289 	ep_init.transferType = cfg->ep_type;
290 
291 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
292 		LOG_ERR("Wrong endpoint index/address");
293 		return -EINVAL;
294 	}
295 
296 	if (dev_state.eps[ep_abs_idx].ep_enabled) {
297 		LOG_WRN("Endpoint already configured");
298 		return 0;
299 	}
300 
301 	ep = cfg->ep_addr;
302 	status = dev_state.dev_struct.controllerInterface->deviceControl(
303 			dev_state.dev_struct.controllerHandle,
304 			kUSB_DeviceControlEndpointDeinit, &ep);
305 	if (kStatus_USB_Success != status) {
306 		LOG_WRN("Failed to un-initialize endpoint (status=%d)", (int)status);
307 	}
308 
309 #ifdef CONFIG_USB_DC_NXP_LPCIP3511
310 	/* Allocate buffers used during read operation */
311 	if (USB_EP_DIR_IS_OUT(cfg->ep_addr)) {
312 #endif
313 		void **block;
314 
315 		block = &(eps->block);
316 		if (*block) {
317 			k_heap_free(&ep_buf_pool, *block);
318 			*block = NULL;
319 		}
320 
321 		*block = k_heap_alloc(&ep_buf_pool, cfg->ep_mps, K_NO_WAIT);
322 		if (*block == NULL) {
323 			LOG_ERR("Failed to allocate memory");
324 			return -ENOMEM;
325 		}
326 
327 		memset(*block, 0, cfg->ep_mps);
328 #ifdef CONFIG_USB_DC_NXP_LPCIP3511
329 	}
330 #endif
331 
332 	dev_state.eps[ep_abs_idx].ep_mps = cfg->ep_mps;
333 	status = dev_state.dev_struct.controllerInterface->deviceControl(
334 			dev_state.dev_struct.controllerHandle,
335 			kUSB_DeviceControlEndpointInit, &ep_init);
336 	if (kStatus_USB_Success != status) {
337 		LOG_ERR("Failed to initialize endpoint");
338 		return -EIO;
339 	}
340 
341 	/*
342 	 * If it is control endpoint, controller will prime setup
343 	 * here set the occupied flag.
344 	 */
345 	if ((USB_EP_GET_IDX(cfg->ep_addr) == USB_CONTROL_ENDPOINT) &&
346 	    (USB_EP_DIR_IS_OUT(cfg->ep_addr))) {
347 		dev_state.eps[ep_abs_idx].ep_occupied = true;
348 	}
349 	dev_state.eps[ep_abs_idx].ep_enabled = true;
350 
351 	return 0;
352 }
353 
usb_dc_ep_set_stall(const uint8_t ep)354 int usb_dc_ep_set_stall(const uint8_t ep)
355 {
356 	uint8_t endpoint = ep;
357 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
358 	usb_status_t status;
359 
360 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
361 		LOG_ERR("Wrong endpoint index/address");
362 		return -EINVAL;
363 	}
364 
365 	status = dev_state.dev_struct.controllerInterface->deviceControl(
366 			dev_state.dev_struct.controllerHandle,
367 			kUSB_DeviceControlEndpointStall, &endpoint);
368 	if (kStatus_USB_Success != status) {
369 		LOG_ERR("Failed to stall endpoint");
370 		return -EIO;
371 	}
372 
373 	return 0;
374 }
375 
usb_dc_ep_clear_stall(const uint8_t ep)376 int usb_dc_ep_clear_stall(const uint8_t ep)
377 {
378 	uint8_t endpoint = ep;
379 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
380 	usb_status_t status;
381 
382 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
383 		LOG_ERR("Wrong endpoint index/address");
384 		return -EINVAL;
385 	}
386 
387 	status = dev_state.dev_struct.controllerInterface->deviceControl(
388 			dev_state.dev_struct.controllerHandle,
389 			kUSB_DeviceControlEndpointUnstall, &endpoint);
390 	if (kStatus_USB_Success != status) {
391 		LOG_ERR("Failed to clear stall");
392 		return -EIO;
393 	}
394 
395 	if ((USB_EP_GET_IDX(ep) != USB_CONTROL_ENDPOINT) &&
396 	    (USB_EP_DIR_IS_OUT(ep))) {
397 		status = dev_state.dev_struct.controllerInterface->deviceRecv(
398 				dev_state.dev_struct.controllerHandle, ep,
399 				(uint8_t *)dev_state.eps[ep_abs_idx].block,
400 				(uint32_t)dev_state.eps[ep_abs_idx].ep_mps);
401 		if (kStatus_USB_Success != status) {
402 			LOG_ERR("Failed to enable reception on 0x%02x", ep);
403 			return -EIO;
404 		}
405 
406 		dev_state.eps[ep_abs_idx].ep_occupied = true;
407 	}
408 
409 	return 0;
410 }
411 
usb_dc_ep_is_stalled(const uint8_t ep,uint8_t * const stalled)412 int usb_dc_ep_is_stalled(const uint8_t ep, uint8_t *const stalled)
413 {
414 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
415 	usb_device_endpoint_status_struct_t ep_status;
416 	usb_status_t status;
417 
418 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
419 		LOG_ERR("Wrong endpoint index/address");
420 		return -EINVAL;
421 	}
422 
423 	if (!stalled) {
424 		return -EINVAL;
425 	}
426 
427 	*stalled = 0;
428 	ep_status.endpointAddress = ep;
429 	ep_status.endpointStatus = kUSB_DeviceEndpointStateIdle;
430 	status = dev_state.dev_struct.controllerInterface->deviceControl(
431 			dev_state.dev_struct.controllerHandle,
432 			kUSB_DeviceControlGetEndpointStatus, &ep_status);
433 	if (kStatus_USB_Success != status) {
434 		LOG_ERR("Failed to get endpoint status");
435 		return -EIO;
436 	}
437 
438 	*stalled = (uint8_t)ep_status.endpointStatus;
439 
440 	return 0;
441 }
442 
usb_dc_ep_halt(const uint8_t ep)443 int usb_dc_ep_halt(const uint8_t ep)
444 {
445 	return usb_dc_ep_set_stall(ep);
446 }
447 
usb_dc_ep_enable(const uint8_t ep)448 int usb_dc_ep_enable(const uint8_t ep)
449 {
450 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
451 	usb_status_t status;
452 
453 	/*
454 	 * endpoint 0 OUT is primed by controller driver when configure this
455 	 * endpoint.
456 	 */
457 	if (!ep_abs_idx) {
458 		return 0;
459 	}
460 
461 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
462 		LOG_ERR("Wrong endpoint index/address");
463 		return -EINVAL;
464 	}
465 
466 	if (dev_state.eps[ep_abs_idx].ep_occupied) {
467 		LOG_WRN("endpoint 0x%x already enabled", ep);
468 		return -EALREADY;
469 	}
470 
471 	if ((USB_EP_GET_IDX(ep) != USB_CONTROL_ENDPOINT) &&
472 	    (USB_EP_DIR_IS_OUT(ep))) {
473 		status = dev_state.dev_struct.controllerInterface->deviceRecv(
474 				dev_state.dev_struct.controllerHandle, ep,
475 				(uint8_t *)dev_state.eps[ep_abs_idx].block,
476 				(uint32_t)dev_state.eps[ep_abs_idx].ep_mps);
477 		if (kStatus_USB_Success != status) {
478 			LOG_ERR("Failed to enable reception on 0x%02x", ep);
479 			return -EIO;
480 		}
481 
482 		dev_state.eps[ep_abs_idx].ep_occupied = true;
483 	} else {
484 		/*
485 		 * control endpoint just be enabled before enumeration,
486 		 * when running here, setup has been primed.
487 		 */
488 		dev_state.eps[ep_abs_idx].ep_occupied = true;
489 	}
490 
491 	return 0;
492 }
493 
usb_dc_ep_disable(const uint8_t ep)494 int usb_dc_ep_disable(const uint8_t ep)
495 {
496 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
497 	usb_status_t status;
498 
499 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
500 		LOG_ERR("Wrong endpoint index/address");
501 		return -EINVAL;
502 	}
503 
504 	if (dev_state.dev_struct.controllerHandle != NULL) {
505 		status = dev_state.dev_struct.controllerInterface->deviceCancel(
506 							dev_state.dev_struct.controllerHandle,
507 							ep);
508 		if (kStatus_USB_Success != status) {
509 			LOG_ERR("Failed to disable ep 0x%02x", ep);
510 			return -EIO;
511 		}
512 	}
513 
514 	dev_state.eps[ep_abs_idx].ep_enabled = false;
515 	dev_state.eps[ep_abs_idx].ep_occupied = false;
516 
517 	return 0;
518 }
519 
usb_dc_ep_flush(const uint8_t ep)520 int usb_dc_ep_flush(const uint8_t ep)
521 {
522 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
523 
524 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
525 		LOG_ERR("Wrong endpoint index/address");
526 		return -EINVAL;
527 	}
528 
529 	LOG_DBG("Not implemented, idx 0x%02x, ep %u", ep_abs_idx, ep);
530 
531 	return 0;
532 }
533 
usb_dc_ep_write(const uint8_t ep,const uint8_t * const data,const uint32_t data_len,uint32_t * const ret_bytes)534 int usb_dc_ep_write(const uint8_t ep, const uint8_t *const data,
535 		    const uint32_t data_len, uint32_t *const ret_bytes)
536 {
537 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
538 	uint8_t *buffer;
539 	uint32_t len_to_send = data_len;
540 	usb_status_t status;
541 
542 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
543 		LOG_ERR("Wrong endpoint index/address");
544 		return -EINVAL;
545 	}
546 
547 	if (USB_EP_GET_DIR(ep) != USB_EP_DIR_IN) {
548 		LOG_ERR("Wrong endpoint direction");
549 		return -EINVAL;
550 	}
551 
552 	/* Copy the data for SoC's that do not have a USB RAM
553 	 * as the SDK driver will copy the data into USB RAM,
554 	 * if available.
555 	 */
556 #ifndef CONFIG_USB_DC_NXP_LPCIP3511
557 	buffer = (uint8_t *)dev_state.eps[ep_abs_idx].block;
558 
559 	if (data_len > dev_state.eps[ep_abs_idx].ep_mps) {
560 		len_to_send = dev_state.eps[ep_abs_idx].ep_mps;
561 	}
562 
563 	for (uint32_t n = 0; n < len_to_send; n++) {
564 		buffer[n] = data[n];
565 	}
566 #else
567 	buffer = (uint8_t *)data;
568 #endif
569 
570 #if defined(CONFIG_HAS_MCUX_CACHE) && !defined(EP_BUF_NONCACHED)
571 	DCACHE_CleanByRange((uint32_t)buffer, len_to_send);
572 #endif
573 	status = dev_state.dev_struct.controllerInterface->deviceSend(
574 						dev_state.dev_struct.controllerHandle,
575 						ep, buffer, len_to_send);
576 	if (kStatus_USB_Success != status) {
577 		LOG_ERR("Failed to fill ep 0x%02x buffer", ep);
578 		return -EIO;
579 	}
580 
581 	if (ret_bytes) {
582 		*ret_bytes = len_to_send;
583 	}
584 
585 	return 0;
586 }
587 
update_control_stage(usb_device_callback_message_struct_t * cb_msg,uint32_t data_len,uint32_t max_data_len)588 static void update_control_stage(usb_device_callback_message_struct_t *cb_msg,
589 				 uint32_t data_len, uint32_t max_data_len)
590 {
591 	struct usb_setup_packet *usbd_setup;
592 
593 	usbd_setup = (struct usb_setup_packet *)cb_msg->buffer;
594 
595 	if (cb_msg->isSetup) {
596 		if (usbd_setup->wLength == 0) {
597 			dev_state.setup_data_stage = SETUP_DATA_STAGE_DONE;
598 		} else if (usb_reqtype_is_to_host(usbd_setup)) {
599 			dev_state.setup_data_stage = SETUP_DATA_STAGE_IN;
600 		} else {
601 			dev_state.setup_data_stage = SETUP_DATA_STAGE_OUT;
602 		}
603 	} else {
604 		if (dev_state.setup_data_stage != SETUP_DATA_STAGE_DONE) {
605 			if ((data_len >= max_data_len) ||
606 			    (data_len < dev_state.eps[0].ep_mps)) {
607 				dev_state.setup_data_stage = SETUP_DATA_STAGE_DONE;
608 			}
609 		}
610 	}
611 }
612 
usb_dc_ep_read_wait(uint8_t ep,uint8_t * data,uint32_t max_data_len,uint32_t * read_bytes)613 int usb_dc_ep_read_wait(uint8_t ep, uint8_t *data, uint32_t max_data_len,
614 			uint32_t *read_bytes)
615 {
616 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
617 	uint32_t data_len;
618 	uint8_t *bufp = NULL;
619 
620 	if (dev_state.eps[ep_abs_idx].ep_occupied) {
621 		LOG_ERR("Endpoint is occupied by the controller");
622 		return -EBUSY;
623 	}
624 
625 	if ((ep_abs_idx >= NUM_OF_EP_MAX) ||
626 	    (USB_EP_GET_DIR(ep) != USB_EP_DIR_OUT)) {
627 		LOG_ERR("Wrong endpoint index/address/direction");
628 		return -EINVAL;
629 	}
630 
631 	/* Allow to read 0 bytes */
632 	if (!data && max_data_len) {
633 		LOG_ERR("Wrong arguments");
634 		return -EINVAL;
635 	}
636 
637 	/*
638 	 * It is control setup, we should use message.buffer,
639 	 * this buffer is from internal setup array.
640 	 */
641 	bufp = dev_state.eps[ep_abs_idx].transfer_message.buffer;
642 	data_len = dev_state.eps[ep_abs_idx].transfer_message.length;
643 	if (data_len == USB_UNINITIALIZED_VAL_32) {
644 		if (read_bytes) {
645 			*read_bytes = 0;
646 		}
647 		return -EINVAL;
648 	}
649 
650 	if (!data && !max_data_len) {
651 		/* When both buffer and max data to read are zero return the
652 		 * available data in buffer.
653 		 */
654 		if (read_bytes) {
655 			*read_bytes = data_len;
656 		}
657 		return 0;
658 	}
659 
660 	if (data_len > max_data_len) {
661 		LOG_WRN("Not enough room to copy all the data!");
662 		data_len = max_data_len;
663 	}
664 
665 	if (data != NULL) {
666 		for (uint32_t i = 0; i < data_len; i++) {
667 			data[i] = bufp[i];
668 		}
669 	}
670 
671 	if (read_bytes) {
672 		*read_bytes = data_len;
673 	}
674 
675 	if (USB_EP_GET_IDX(ep) == USB_ENDPOINT_CONTROL) {
676 		update_control_stage(&dev_state.eps[0].transfer_message,
677 				     data_len, max_data_len);
678 	}
679 
680 	return 0;
681 }
682 
usb_dc_ep_read_continue(uint8_t ep)683 int usb_dc_ep_read_continue(uint8_t ep)
684 {
685 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
686 	usb_status_t status;
687 
688 	if (ep_abs_idx >= NUM_OF_EP_MAX ||
689 	    USB_EP_GET_DIR(ep) != USB_EP_DIR_OUT) {
690 		LOG_ERR("Wrong endpoint index/address/direction");
691 		return -EINVAL;
692 	}
693 
694 	if (dev_state.eps[ep_abs_idx].ep_occupied) {
695 		LOG_WRN("endpoint 0x%x already occupied", ep);
696 		return -EBUSY;
697 	}
698 
699 	if (USB_EP_GET_IDX(ep) == USB_ENDPOINT_CONTROL) {
700 		if (dev_state.setup_data_stage == SETUP_DATA_STAGE_DONE) {
701 			return 0;
702 		}
703 
704 		if (dev_state.setup_data_stage == SETUP_DATA_STAGE_IN) {
705 			dev_state.setup_data_stage = SETUP_DATA_STAGE_DONE;
706 		}
707 	}
708 
709 	status = dev_state.dev_struct.controllerInterface->deviceRecv(
710 			    dev_state.dev_struct.controllerHandle, ep,
711 			    (uint8_t *)dev_state.eps[ep_abs_idx].block,
712 			    dev_state.eps[ep_abs_idx].ep_mps);
713 	if (kStatus_USB_Success != status) {
714 		LOG_ERR("Failed to enable reception on ep 0x%02x", ep);
715 		return -EIO;
716 	}
717 
718 	dev_state.eps[ep_abs_idx].ep_occupied = true;
719 
720 	return 0;
721 }
722 
usb_dc_ep_read(const uint8_t ep,uint8_t * const data,const uint32_t max_data_len,uint32_t * const read_bytes)723 int usb_dc_ep_read(const uint8_t ep, uint8_t *const data,
724 		   const uint32_t max_data_len, uint32_t *const read_bytes)
725 {
726 	int retval = usb_dc_ep_read_wait(ep, data, max_data_len, read_bytes);
727 
728 	if (retval) {
729 		return retval;
730 	}
731 
732 	if (!data && !max_data_len) {
733 		/*
734 		 * When both buffer and max data to read are zero the above
735 		 * call would fetch the data len and we simply return.
736 		 */
737 		return 0;
738 	}
739 
740 	return usb_dc_ep_read_continue(ep);
741 }
742 
usb_dc_ep_set_callback(const uint8_t ep,const usb_dc_ep_callback cb)743 int usb_dc_ep_set_callback(const uint8_t ep, const usb_dc_ep_callback cb)
744 {
745 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
746 
747 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
748 		LOG_ERR("Wrong endpoint index/address");
749 		return -EINVAL;
750 	}
751 
752 	if (!dev_state.attached) {
753 		return -EINVAL;
754 	}
755 	dev_state.eps[ep_abs_idx].callback = cb;
756 
757 	return 0;
758 }
759 
usb_dc_set_status_callback(const usb_dc_status_callback cb)760 void usb_dc_set_status_callback(const usb_dc_status_callback cb)
761 {
762 	dev_state.status_cb = cb;
763 }
764 
usb_dc_ep_mps(const uint8_t ep)765 int usb_dc_ep_mps(const uint8_t ep)
766 {
767 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
768 
769 	if (ep_abs_idx >= NUM_OF_EP_MAX) {
770 		LOG_ERR("Wrong endpoint index/address");
771 		return -EINVAL;
772 	}
773 
774 	return dev_state.eps[ep_abs_idx].ep_mps;
775 }
776 
handle_bus_reset(void)777 static void handle_bus_reset(void)
778 {
779 	usb_device_endpoint_init_struct_t ep_init;
780 	uint8_t ep_abs_idx = 0;
781 	usb_status_t status;
782 
783 	dev_state.dev_struct.deviceAddress = 0;
784 	status = dev_state.dev_struct.controllerInterface->deviceControl(
785 			dev_state.dev_struct.controllerHandle,
786 			kUSB_DeviceControlSetDefaultStatus, NULL);
787 	if (kStatus_USB_Success != status) {
788 		LOG_ERR("Failed to set default status");
789 	}
790 
791 	for (int i = 0; i < NUM_OF_EP_MAX; i++) {
792 		dev_state.eps[i].ep_occupied = false;
793 		dev_state.eps[i].ep_enabled = false;
794 	}
795 
796 	ep_init.zlt = 0U;
797 	ep_init.transferType = USB_ENDPOINT_CONTROL;
798 	ep_init.maxPacketSize = USB_CONTROL_EP_MPS;
799 	ep_init.endpointAddress = USB_CONTROL_EP_OUT;
800 
801 	ep_abs_idx =  EP_ABS_IDX(ep_init.endpointAddress);
802 	dev_state.eps[ep_abs_idx].ep_mps = USB_CONTROL_EP_MPS;
803 
804 	status = dev_state.dev_struct.controllerInterface->deviceControl(
805 			dev_state.dev_struct.controllerHandle,
806 			kUSB_DeviceControlEndpointInit, &ep_init);
807 	if (kStatus_USB_Success != status) {
808 		LOG_ERR("Failed to initialize control OUT endpoint");
809 	}
810 
811 	dev_state.eps[ep_abs_idx].ep_occupied = false;
812 	dev_state.eps[ep_abs_idx].ep_enabled = true;
813 
814 	ep_init.endpointAddress = USB_CONTROL_EP_IN;
815 	ep_abs_idx = EP_ABS_IDX(ep_init.endpointAddress);
816 	dev_state.eps[ep_abs_idx].ep_mps = USB_CONTROL_EP_MPS;
817 	status = dev_state.dev_struct.controllerInterface->deviceControl(
818 			dev_state.dev_struct.controllerHandle,
819 			kUSB_DeviceControlEndpointInit, &ep_init);
820 	if (kStatus_USB_Success != status) {
821 		LOG_ERR("Failed to initialize control IN endpoint");
822 	}
823 
824 	dev_state.eps[ep_abs_idx].ep_occupied = false;
825 	dev_state.eps[ep_abs_idx].ep_enabled = true;
826 }
827 
handle_transfer_msg(usb_device_callback_message_struct_t * cb_msg)828 static void handle_transfer_msg(usb_device_callback_message_struct_t *cb_msg)
829 {
830 	uint8_t ep_status_code = 0;
831 	uint8_t ep = cb_msg->code;
832 	uint8_t ep_abs_idx = EP_ABS_IDX(ep);
833 	usb_status_t status;
834 
835 	dev_state.eps[ep_abs_idx].ep_occupied = false;
836 
837 	if (cb_msg->length == UINT32_MAX) {
838 		/*
839 		 * Probably called from USB_DeviceEhciCancel()
840 		 * LOG_WRN("Drop message for ep 0x%02x", ep);
841 		 */
842 		return;
843 	}
844 
845 	if (cb_msg->isSetup) {
846 		ep_status_code = USB_DC_EP_SETUP;
847 	} else {
848 		/* IN TOKEN */
849 		if (USB_EP_DIR_IS_IN(ep)) {
850 			if ((dev_state.dev_struct.deviceAddress != 0) && (ep_abs_idx == 1)) {
851 				/*
852 				 * Set Address in the status stage in
853 				 * the IN transfer.
854 				 */
855 				status = dev_state.dev_struct.controllerInterface->deviceControl(
856 					dev_state.dev_struct.controllerHandle,
857 					kUSB_DeviceControlSetDeviceAddress,
858 					&dev_state.dev_struct.deviceAddress);
859 				if (kStatus_USB_Success != status) {
860 					LOG_ERR("Failed to set device address");
861 					return;
862 				}
863 				dev_state.dev_struct.deviceAddress = 0;
864 			}
865 			ep_status_code = USB_DC_EP_DATA_IN;
866 		}
867 		/* OUT TOKEN */
868 		else {
869 			ep_status_code = USB_DC_EP_DATA_OUT;
870 		}
871 	}
872 
873 	if (dev_state.eps[ep_abs_idx].callback) {
874 #if defined(CONFIG_HAS_MCUX_CACHE) && !defined(EP_BUF_NONCACHED)
875 		if (cb_msg->length) {
876 			DCACHE_InvalidateByRange((uint32_t)cb_msg->buffer,
877 						 cb_msg->length);
878 		}
879 #endif
880 		dev_state.eps[ep_abs_idx].callback(ep, ep_status_code);
881 	} else {
882 		LOG_ERR("No cb pointer for endpoint 0x%02x", ep);
883 	}
884 }
885 
886 /**
887  * Similar to the kinetis driver, this thread is used to not run the USB device
888  * stack/endpoint callbacks in the ISR context. This is because callbacks from
889  * the USB stack may use mutexes, or other kernel functions not supported from
890  * an interrupt context.
891  */
usb_mcux_thread_main(void * arg1,void * arg2,void * arg3)892 static void usb_mcux_thread_main(void *arg1, void *arg2, void *arg3)
893 {
894 	ARG_UNUSED(arg1);
895 	ARG_UNUSED(arg2);
896 	ARG_UNUSED(arg3);
897 
898 	uint8_t ep_abs_idx;
899 	usb_device_callback_message_struct_t msg;
900 
901 	while (1) {
902 		k_msgq_get(&usb_dc_msgq, &msg, K_FOREVER);
903 		switch (msg.code) {
904 		case kUSB_DeviceNotifyBusReset:
905 			handle_bus_reset();
906 			dev_state.status_cb(USB_DC_RESET, NULL);
907 			break;
908 		case kUSB_DeviceNotifyError:
909 			dev_state.status_cb(USB_DC_ERROR, NULL);
910 			break;
911 		case kUSB_DeviceNotifySuspend:
912 			dev_state.status_cb(USB_DC_SUSPEND, NULL);
913 			break;
914 		case kUSB_DeviceNotifyResume:
915 			dev_state.status_cb(USB_DC_RESUME, NULL);
916 			break;
917 		default:
918 			ep_abs_idx = EP_ABS_IDX(msg.code);
919 
920 			if (ep_abs_idx >= NUM_OF_EP_MAX) {
921 				LOG_ERR("Wrong endpoint index/address");
922 				return;
923 			}
924 
925 			memcpy(&dev_state.eps[ep_abs_idx].transfer_message, &msg,
926 			       sizeof(usb_device_callback_message_struct_t));
927 			handle_transfer_msg(&dev_state.eps[ep_abs_idx].transfer_message);
928 		}
929 	}
930 }
931 
932 /* Notify the up layer the KHCI status changed. */
USB_DeviceNotificationTrigger(void * handle,void * msg)933 usb_status_t USB_DeviceNotificationTrigger(void *handle, void *msg)
934 {
935 	/* Submit to message queue */
936 	k_msgq_put(&usb_dc_msgq,
937 		(usb_device_callback_message_struct_t *)msg, K_NO_WAIT);
938 	return kStatus_USB_Success;
939 }
940 
usb_isr_handler(void)941 static void usb_isr_handler(void)
942 {
943 #if defined(CONFIG_USB_DC_NXP_EHCI)
944 	USB_DeviceEhciIsrFunction(&dev_state);
945 #elif defined(CONFIG_USB_DC_NXP_LPCIP3511)
946 	USB_DeviceLpcIp3511IsrFunction(&dev_state);
947 #endif
948 }
949 
usb_mcux_init(void)950 static int usb_mcux_init(void)
951 {
952 	int err;
953 
954 	k_thread_create(&dev_state.thread, dev_state.thread_stack,
955 			CONFIG_USB_MCUX_THREAD_STACK_SIZE,
956 			usb_mcux_thread_main, NULL, NULL, NULL,
957 			K_PRIO_COOP(2), 0, K_NO_WAIT);
958 	k_thread_name_set(&dev_state.thread, "usb_mcux");
959 
960 	PINCTRL_DT_INST_DEFINE(0);
961 
962 	/* Apply pinctrl state */
963 	err = pinctrl_apply_state(PINCTRL_DT_INST_DEV_CONFIG_GET(0), PINCTRL_STATE_DEFAULT);
964 	if (err) {
965 		return err;
966 	}
967 
968 	return 0;
969 }
970 
971 SYS_INIT(usb_mcux_init, POST_KERNEL, CONFIG_KERNEL_INIT_PRIORITY_DEVICE);
972