Lines Matching +full:re +full:- +full:clocked
1 // SPDX-License-Identifier: GPL-2.0+
20 #include <linux/dma-mapping.h>
78 #define DATA_IN 1 /* Expect dev->host transfer */
79 #define DATA_OUT 2 /* Expect host->dev transfer */
161 /* USB device peripheral - various */
164 bool clocked; member
188 dev_dbg(epp->udc->dev, "%s: " fmt, __func__, ## arg)
190 dev_err(epp->udc->dev, "%s: " fmt, __func__, ## arg)
192 dev_info(epp->udc->dev, "%s: " fmt, __func__, ## arg)
194 dev_warn(epp->udc->dev, "%s:" fmt, __func__, ## arg)
479 ep->ep.name, ep->ep.maxpacket, in proc_ep_show()
480 ep->is_in ? "in" : "out"); in proc_ep_show()
481 seq_printf(s, " type %4s", epnames[ep->eptype]); in proc_ep_show()
482 seq_printf(s, " ints: %12d", ep->totalints); in proc_ep_show()
484 if (list_empty(&ep->queue)) in proc_ep_show()
487 list_for_each_entry(req, &ep->queue, queue) { in proc_ep_show()
488 u32 length = req->req.actual; in proc_ep_show()
491 &req->req, length, in proc_ep_show()
492 req->req.length, req->req.buf); in proc_ep_show()
499 struct lpc32xx_udc *udc = s->private; in udc_show()
505 spin_lock_irqsave(&udc->lock, flags); in udc_show()
508 udc->vbus ? "present" : "off", in udc_show()
509 udc->enabled ? (udc->vbus ? "active" : "enabled") : in udc_show()
511 udc->gadget.is_selfpowered ? "self" : "VBUS", in udc_show()
512 udc->suspended ? ", suspended" : "", in udc_show()
513 udc->driver ? udc->driver->driver.name : "(none)"); in udc_show()
515 if (udc->enabled && udc->vbus) { in udc_show()
516 proc_ep_show(s, &udc->ep[0]); in udc_show()
517 list_for_each_entry(ep, &udc->gadget.ep_list, ep.ep_list) in udc_show()
521 spin_unlock_irqrestore(&udc->lock, flags); in udc_show()
549 vendor = i2c_smbus_read_word_data(udc->isp1301_i2c_client, 0x00); in isp1301_udc_configure()
550 product = i2c_smbus_read_word_data(udc->isp1301_i2c_client, 0x02); in isp1301_udc_configure()
553 udc->atx = STOTG04; in isp1301_udc_configure()
559 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
564 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
566 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
572 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
576 if (udc->atx != STOTG04) in isp1301_udc_configure()
578 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
582 if (udc->board->vbus_drv_pol != 0) in isp1301_udc_configure()
583 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
586 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
590 /* Bi-directional mode with suspend control in isp1301_udc_configure()
591 * Enable both pulldowns for now - the pullup will be enable when VBUS in isp1301_udc_configure()
593 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
595 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
600 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
603 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
607 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
610 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
612 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_udc_configure()
615 dev_info(udc->dev, "ISP1301 Vendor ID : 0x%04x\n", vendor); in isp1301_udc_configure()
616 dev_info(udc->dev, "ISP1301 Product ID : 0x%04x\n", product); in isp1301_udc_configure()
617 dev_info(udc->dev, "ISP1301 Version ID : 0x%04x\n", in isp1301_udc_configure()
618 i2c_smbus_read_word_data(udc->isp1301_i2c_client, 0x14)); in isp1301_udc_configure()
625 if (udc->pullup) in isp1301_pullup_set()
627 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_pullup_set()
631 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_pullup_set()
647 if (en_pullup == udc->pullup) in isp1301_pullup_enable()
650 udc->pullup = en_pullup; in isp1301_pullup_enable()
655 schedule_work(&udc->pullup_job); in isp1301_pullup_enable()
663 if (udc->atx == STOTG04) in isp1301_set_powerstate()
667 /* Power up ISP1301 - this ISP1301 will automatically wakeup in isp1301_set_powerstate()
669 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_set_powerstate()
674 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in isp1301_set_powerstate()
683 isp1301_set_powerstate(udc, udc->poweron); in power_work()
699 u32 tmp = readl(USBD_DEVINTST(udc->udp_baseaddr)); in udc_protocol_cmd_w()
703 writel(USBD_CCEMPTY, USBD_DEVINTCLR(udc->udp_baseaddr)); in udc_protocol_cmd_w()
706 writel(cmd, USBD_CMDCODE(udc->udp_baseaddr)); in udc_protocol_cmd_w()
708 while (((readl(USBD_DEVINTST(udc->udp_baseaddr)) & in udc_protocol_cmd_w()
710 to--; in udc_protocol_cmd_w()
736 USBD_DEVINTCLR(udc->udp_baseaddr)); in udc_protocol_cmd_r()
741 while ((!(readl(USBD_DEVINTST(udc->udp_baseaddr)) & USBD_CDFULL)) in udc_protocol_cmd_r()
743 to--; in udc_protocol_cmd_r()
745 dev_dbg(udc->dev, in udc_protocol_cmd_r()
748 return readl(USBD_CMDDATA(udc->udp_baseaddr)); in udc_protocol_cmd_r()
759 udc->enabled_devints |= devmask; in uda_enable_devint()
760 writel(udc->enabled_devints, USBD_DEVINTEN(udc->udp_baseaddr)); in uda_enable_devint()
766 udc->enabled_devints &= ~mask; in uda_disable_devint()
767 writel(udc->enabled_devints, USBD_DEVINTEN(udc->udp_baseaddr)); in uda_disable_devint()
773 writel(mask, USBD_DEVINTCLR(udc->udp_baseaddr)); in uda_clear_devint()
784 udc->enabled_hwepints |= (1 << hwep); in uda_enable_hwepint()
785 writel(udc->enabled_hwepints, USBD_EPINTEN(udc->udp_baseaddr)); in uda_enable_hwepint()
791 udc->enabled_hwepints &= ~(1 << hwep); in uda_disable_hwepint()
792 writel(udc->enabled_hwepints, USBD_EPINTEN(udc->udp_baseaddr)); in uda_disable_hwepint()
798 writel((1 << hwep), USBD_EPINTCLR(udc->udp_baseaddr)); in uda_clear_hwepint()
804 writel((1 << hwep), USBD_EPDMAEN(udc->udp_baseaddr)); in udc_ep_dma_enable()
810 writel((1 << hwep), USBD_EPDMADIS(udc->udp_baseaddr)); in udc_ep_dma_disable()
819 * in the USB protocol engine - this realizes the endpoint.
826 writel(USBD_EP_RLZED, USBD_DEVINTCLR(udc->udp_baseaddr)); in udc_realize_hwep()
827 writel(hwep, USBD_EPIND(udc->udp_baseaddr)); in udc_realize_hwep()
828 udc->realized_eps |= (1 << hwep); in udc_realize_hwep()
829 writel(udc->realized_eps, USBD_REEP(udc->udp_baseaddr)); in udc_realize_hwep()
830 writel(maxpacket, USBD_EPMAXPSIZE(udc->udp_baseaddr)); in udc_realize_hwep()
833 while ((!(readl(USBD_DEVINTST(udc->udp_baseaddr)) & in udc_realize_hwep()
835 to--; in udc_realize_hwep()
837 dev_dbg(udc->dev, "EP not correctly realized in hardware\n"); in udc_realize_hwep()
839 writel(USBD_EP_RLZED, USBD_DEVINTCLR(udc->udp_baseaddr)); in udc_realize_hwep()
845 udc->realized_eps &= ~(1 << hwep); in udc_unrealize_hwep()
846 writel(udc->realized_eps, USBD_REEP(udc->udp_baseaddr)); in udc_unrealize_hwep()
868 /* Stalls the endpoint - endpoint will return STALL */
925 dd = dma_pool_alloc(udc->dd_cache, GFP_ATOMIC | GFP_DMA, &dma); in udc_dd_alloc()
927 dd->this_dma = dma; in udc_dd_alloc()
935 dma_pool_free(udc->dd_cache, dd, dd->this_dma); in udc_dd_free()
949 if (udc->clocked) in udc_clk_set()
952 udc->clocked = 1; in udc_clk_set()
953 clk_prepare_enable(udc->usb_slv_clk); in udc_clk_set()
955 if (!udc->clocked) in udc_clk_set()
958 udc->clocked = 0; in udc_clk_set()
959 clk_disable_unprepare(udc->usb_slv_clk); in udc_clk_set()
972 /* Setup up a IN request for DMA transfer - this consists of determining the
978 u32 hwep = ep->hwep_num; in udc_ep_in_req_dma()
980 ep->req_pending = 1; in udc_ep_in_req_dma()
983 req = list_entry(ep->queue.next, struct lpc32xx_request, queue); in udc_ep_in_req_dma()
986 udc->udca_v_base[hwep] = req->dd_desc_ptr->this_dma; in udc_ep_in_req_dma()
992 if (req->req.length % ep->ep.maxpacket) in udc_ep_in_req_dma()
993 req->send_zlp = 0; in udc_ep_in_req_dma()
998 /* Setup up a OUT request for DMA transfer - this consists of determining the
1004 u32 hwep = ep->hwep_num; in udc_ep_out_req_dma()
1006 ep->req_pending = 1; in udc_ep_out_req_dma()
1009 req = list_entry(ep->queue.next, struct lpc32xx_request, queue); in udc_ep_out_req_dma()
1012 udc->udca_v_base[hwep] = req->dd_desc_ptr->this_dma; in udc_ep_out_req_dma()
1036 udc->udca_v_base[i] = 0; in udc_disable()
1040 writel((1 << i), USBD_EOTINTCLR(udc->udp_baseaddr)); in udc_disable()
1041 writel((1 << i), USBD_NDDRTINTCLR(udc->udp_baseaddr)); in udc_disable()
1042 writel((1 << i), USBD_SYSERRTINTCLR(udc->udp_baseaddr)); in udc_disable()
1043 writel((1 << i), USBD_DMARCLR(udc->udp_baseaddr)); in udc_disable()
1047 writel(0, USBD_DMAINTEN(udc->udp_baseaddr)); in udc_disable()
1049 writel(0, USBD_UDCAH(udc->udp_baseaddr)); in udc_disable()
1055 struct lpc32xx_ep *ep = &udc->ep[0]; in udc_enable()
1064 writel(USBD_EP_FAST, USBD_DEVINTPRI(udc->udp_baseaddr)); in udc_enable()
1065 writel(0xFFFF, USBD_EPINTPRI(udc->udp_baseaddr)); in udc_enable()
1068 writel(0x3FF, USBD_DEVINTCLR(udc->udp_baseaddr)); in udc_enable()
1070 /* Setup UDCA - not yet used (DMA) */ in udc_enable()
1071 writel(udc->udca_p_base, USBD_UDCAH(udc->udp_baseaddr)); in udc_enable()
1075 udc_realize_hwep(udc, i, ep->ep.maxpacket); in udc_enable()
1088 /* Set device address to 0 - called twice to force a latch in the USB in udc_enable()
1095 USBD_DMAINTEN(udc->udp_baseaddr)); in udc_enable()
1097 udc->dev_status = 0; in udc_enable()
1105 /* Connection change event - notify board function of change */
1109 if (udc->board->conn_chgb != NULL) in uda_power_event()
1110 udc->board->conn_chgb(conn); in uda_power_event()
1113 /* Suspend/resume event - notify board function of change */
1117 if (udc->board->susp_chgb != NULL) in uda_resm_susp_event()
1118 udc->board->susp_chgb(conn); in uda_resm_susp_event()
1121 udc->suspended = 0; in uda_resm_susp_event()
1123 udc->suspended = 1; in uda_resm_susp_event()
1126 /* Remote wakeup enable/disable - notify board function of change */
1129 if (udc->board->rmwk_chgb != NULL) in uda_remwkp_cgh()
1130 udc->board->rmwk_chgb(udc->dev_status & in uda_remwkp_cgh()
1143 case 0: /* 32-bit aligned */ in udc_pop_fifo()
1147 /* Copy 32-bit aligned data first */ in udc_pop_fifo()
1149 *p32++ = readl(USBD_RXDATA(udc->udp_baseaddr)); in udc_pop_fifo()
1152 bl = bytes - cbytes; in udc_pop_fifo()
1154 tmp = readl(USBD_RXDATA(udc->udp_baseaddr)); in udc_pop_fifo()
1161 case 1: /* 8-bit aligned */ in udc_pop_fifo()
1165 tmp = readl(USBD_RXDATA(udc->udp_baseaddr)); in udc_pop_fifo()
1167 bl = bytes - n; in udc_pop_fifo()
1176 case 2: /* 16-bit aligned */ in udc_pop_fifo()
1180 /* Copy 32-bit sized objects first with 16-bit alignment */ in udc_pop_fifo()
1182 tmp = readl(USBD_RXDATA(udc->udp_baseaddr)); in udc_pop_fifo()
1188 bl = bytes - cbytes; in udc_pop_fifo()
1190 tmp = readl(USBD_RXDATA(udc->udp_baseaddr)); in udc_pop_fifo()
1210 writel(hwrep, USBD_CTRL(udc->udp_baseaddr)); in udc_read_hwep()
1213 while ((((tmpv = readl(USBD_RXPLEN(udc->udp_baseaddr))) & in udc_read_hwep()
1215 to--; in udc_read_hwep()
1217 dev_dbg(udc->dev, "No packet ready on FIFO EP read\n"); in udc_read_hwep()
1227 writel(((hwep & 0x1E) << 1), USBD_CTRL(udc->udp_baseaddr)); in udc_read_hwep()
1244 case 0: /* 32-bit aligned */ in udc_stuff_fifo()
1248 /* Copy 32-bit aligned data first */ in udc_stuff_fifo()
1250 writel(*p32++, USBD_TXDATA(udc->udp_baseaddr)); in udc_stuff_fifo()
1253 bl = bytes - cbytes; in udc_stuff_fifo()
1259 writel(tmp, USBD_TXDATA(udc->udp_baseaddr)); in udc_stuff_fifo()
1263 case 1: /* 8-bit aligned */ in udc_stuff_fifo()
1267 bl = bytes - n; in udc_stuff_fifo()
1275 writel(tmp, USBD_TXDATA(udc->udp_baseaddr)); in udc_stuff_fifo()
1279 case 2: /* 16-bit aligned */ in udc_stuff_fifo()
1283 /* Copy 32-bit aligned data first */ in udc_stuff_fifo()
1287 writel(tmp, USBD_TXDATA(udc->udp_baseaddr)); in udc_stuff_fifo()
1291 bl = bytes - cbytes; in udc_stuff_fifo()
1297 writel(tmp, USBD_TXDATA(udc->udp_baseaddr)); in udc_stuff_fifo()
1315 writel(hwwep, USBD_CTRL(udc->udp_baseaddr)); in udc_write_hwep()
1317 writel(bytes, USBD_TXPLEN(udc->udp_baseaddr)); in udc_write_hwep()
1321 writel(0, USBD_TXDATA(udc->udp_baseaddr)); in udc_write_hwep()
1325 writel(((hwep & 0x1E) << 1), USBD_CTRL(udc->udp_baseaddr)); in udc_write_hwep()
1330 /* USB device reset - resets USB to a default state with just EP0
1335 /* Re-init device controller and EP0 */ in uda_usb_reset()
1337 udc->gadget.speed = USB_SPEED_FULL; in uda_usb_reset()
1340 struct lpc32xx_ep *ep = &udc->ep[i]; in uda_usb_reset()
1341 ep->req_pending = 0; in uda_usb_reset()
1363 /* Set the device as configured - enables all endpoints */
1369 /* Set the device as unconfigured - disables all endpoints */
1380 INIT_LIST_HEAD(&udc->gadget.ep_list); in udc_reinit()
1381 INIT_LIST_HEAD(&udc->gadget.ep0->ep_list); in udc_reinit()
1384 struct lpc32xx_ep *ep = &udc->ep[i]; in udc_reinit()
1387 list_add_tail(&ep->ep.ep_list, &udc->gadget.ep_list); in udc_reinit()
1388 usb_ep_set_maxpacket_limit(&ep->ep, ep->maxpacket); in udc_reinit()
1389 INIT_LIST_HEAD(&ep->queue); in udc_reinit()
1390 ep->req_pending = 0; in udc_reinit()
1393 udc->ep0state = WAIT_FOR_SETUP; in udc_reinit()
1399 struct lpc32xx_udc *udc = ep->udc; in done()
1401 list_del_init(&req->queue); in done()
1402 if (req->req.status == -EINPROGRESS) in done()
1403 req->req.status = status; in done()
1405 status = req->req.status; in done()
1407 if (ep->lep) { in done()
1408 usb_gadget_unmap_request(&udc->gadget, &req->req, ep->is_in); in done()
1411 udc_dd_free(udc, req->dd_desc_ptr); in done()
1414 if (status && status != -ESHUTDOWN) in done()
1415 ep_dbg(ep, "%s done %p, status %d\n", ep->ep.name, req, status); in done()
1417 ep->req_pending = 0; in done()
1418 spin_unlock(&udc->lock); in done()
1419 usb_gadget_giveback_request(&ep->ep, &req->req); in done()
1420 spin_lock(&udc->lock); in done()
1428 while (!list_empty(&ep->queue)) { in nuke()
1429 req = list_entry(ep->queue.next, struct lpc32xx_request, queue); in nuke()
1433 if (status == -ESHUTDOWN) { in nuke()
1434 uda_disable_hwepint(ep->udc, ep->hwep_num); in nuke()
1435 udc_disable_hwep(ep->udc, ep->hwep_num); in nuke()
1443 struct lpc32xx_ep *ep0 = &udc->ep[0]; in udc_ep0_in_req()
1446 if (list_empty(&ep0->queue)) in udc_ep0_in_req()
1450 req = list_entry(ep0->queue.next, struct lpc32xx_request, in udc_ep0_in_req()
1453 tsend = ts = req->req.length - req->req.actual; in udc_ep0_in_req()
1459 } else if (ts > ep0->ep.maxpacket) in udc_ep0_in_req()
1460 ts = ep0->ep.maxpacket; /* Just send what we can */ in udc_ep0_in_req()
1463 udc_write_hwep(udc, EP_IN, (req->req.buf + req->req.actual), ts); in udc_ep0_in_req()
1466 req->req.actual += ts; in udc_ep0_in_req()
1468 if (tsend >= ep0->ep.maxpacket) in udc_ep0_in_req()
1472 udc->ep0state = WAIT_FOR_SETUP; in udc_ep0_in_req()
1481 struct lpc32xx_ep *ep0 = &udc->ep[0]; in udc_ep0_out_req()
1484 if (list_empty(&ep0->queue)) in udc_ep0_out_req()
1487 req = list_entry(ep0->queue.next, struct lpc32xx_request, in udc_ep0_out_req()
1491 if (req->req.length == 0) { in udc_ep0_out_req()
1494 udc->ep0state = WAIT_FOR_SETUP; in udc_ep0_out_req()
1499 bufferspace = req->req.length - req->req.actual; in udc_ep0_out_req()
1500 if (bufferspace > ep0->ep.maxpacket) in udc_ep0_out_req()
1501 bufferspace = ep0->ep.maxpacket; in udc_ep0_out_req()
1504 prefetchw(req->req.buf + req->req.actual); in udc_ep0_out_req()
1505 tr = udc_read_hwep(udc, EP_OUT, req->req.buf + req->req.actual, in udc_ep0_out_req()
1507 req->req.actual += bufferspace; in udc_ep0_out_req()
1509 if (tr < ep0->ep.maxpacket) { in udc_ep0_out_req()
1512 udc->ep0state = WAIT_FOR_SETUP; in udc_ep0_out_req()
1523 struct usb_gadget_driver *driver = udc->driver; in stop_activity()
1526 if (udc->gadget.speed == USB_SPEED_UNKNOWN) in stop_activity()
1529 udc->gadget.speed = USB_SPEED_UNKNOWN; in stop_activity()
1530 udc->suspended = 0; in stop_activity()
1533 struct lpc32xx_ep *ep = &udc->ep[i]; in stop_activity()
1534 nuke(ep, -ESHUTDOWN); in stop_activity()
1537 spin_unlock(&udc->lock); in stop_activity()
1538 driver->disconnect(&udc->gadget); in stop_activity()
1539 spin_lock(&udc->lock); in stop_activity()
1553 if (!udc->clocked) in pullup()
1556 if (!udc->enabled || !udc->vbus) in pullup()
1559 if (is_on != udc->pullup) in pullup()
1567 struct lpc32xx_udc *udc = ep->udc; in lpc32xx_ep_disable()
1570 if ((ep->hwep_num_base == 0) || (ep->hwep_num == 0)) in lpc32xx_ep_disable()
1571 return -EINVAL; in lpc32xx_ep_disable()
1572 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_ep_disable()
1574 nuke(ep, -ESHUTDOWN); in lpc32xx_ep_disable()
1577 udc_ep_dma_disable(udc, ep->hwep_num); in lpc32xx_ep_disable()
1578 writel(1 << ep->hwep_num, USBD_EOTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_disable()
1579 writel(1 << ep->hwep_num, USBD_NDDRTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_disable()
1580 writel(1 << ep->hwep_num, USBD_SYSERRTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_disable()
1581 writel(1 << ep->hwep_num, USBD_DMARCLR(udc->udp_baseaddr)); in lpc32xx_ep_disable()
1584 udc->udca_v_base[ep->hwep_num] = 0; in lpc32xx_ep_disable()
1587 uda_clear_hwepint(udc, ep->hwep_num); in lpc32xx_ep_disable()
1588 udc_unrealize_hwep(udc, ep->hwep_num); in lpc32xx_ep_disable()
1590 ep->hwep_num = 0; in lpc32xx_ep_disable()
1592 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_ep_disable()
1594 atomic_dec(&udc->enabled_ep_cnt); in lpc32xx_ep_disable()
1595 wake_up(&udc->ep_disable_wait_queue); in lpc32xx_ep_disable()
1612 (desc->bDescriptorType != USB_DT_ENDPOINT)) in lpc32xx_ep_enable()
1613 return -EINVAL; in lpc32xx_ep_enable()
1615 udc = ep->udc; in lpc32xx_ep_enable()
1617 if ((maxpacket == 0) || (maxpacket > ep->maxpacket)) { in lpc32xx_ep_enable()
1618 dev_dbg(udc->dev, "bad ep descriptor's packet size\n"); in lpc32xx_ep_enable()
1619 return -EINVAL; in lpc32xx_ep_enable()
1623 if (ep->hwep_num_base == 0) { in lpc32xx_ep_enable()
1624 dev_dbg(udc->dev, "Can't re-enable EP0!!!\n"); in lpc32xx_ep_enable()
1625 return -EINVAL; in lpc32xx_ep_enable()
1629 if ((!udc->driver) || (udc->gadget.speed == USB_SPEED_UNKNOWN)) { in lpc32xx_ep_enable()
1630 dev_dbg(udc->dev, "bogus device state\n"); in lpc32xx_ep_enable()
1631 return -ESHUTDOWN; in lpc32xx_ep_enable()
1634 tmp = desc->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK; in lpc32xx_ep_enable()
1637 return -EINVAL; in lpc32xx_ep_enable()
1640 if (maxpacket > ep->maxpacket) { in lpc32xx_ep_enable()
1641 dev_dbg(udc->dev, in lpc32xx_ep_enable()
1643 return -EINVAL; in lpc32xx_ep_enable()
1656 dev_dbg(udc->dev, in lpc32xx_ep_enable()
1658 return -EINVAL; in lpc32xx_ep_enable()
1665 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_ep_enable()
1668 ep->is_in = (desc->bEndpointAddress & USB_DIR_IN) != 0; in lpc32xx_ep_enable()
1669 ep->ep.maxpacket = maxpacket; in lpc32xx_ep_enable()
1672 if (ep->is_in) in lpc32xx_ep_enable()
1674 ep->hwep_num = ep->hwep_num_base + EP_IN; in lpc32xx_ep_enable()
1676 ep->hwep_num = ep->hwep_num_base; in lpc32xx_ep_enable()
1678 ep_dbg(ep, "EP enabled: %s, HW:%d, MP:%d IN:%d\n", ep->ep.name, in lpc32xx_ep_enable()
1679 ep->hwep_num, maxpacket, (ep->is_in == 1)); in lpc32xx_ep_enable()
1683 udc_realize_hwep(udc, ep->hwep_num, ep->ep.maxpacket); in lpc32xx_ep_enable()
1684 udc_clr_buffer_hwep(udc, ep->hwep_num); in lpc32xx_ep_enable()
1685 uda_disable_hwepint(udc, ep->hwep_num); in lpc32xx_ep_enable()
1686 udc_clrstall_hwep(udc, ep->hwep_num); in lpc32xx_ep_enable()
1689 udc_ep_dma_disable(udc, ep->hwep_num); in lpc32xx_ep_enable()
1690 writel(1 << ep->hwep_num, USBD_EOTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_enable()
1691 writel(1 << ep->hwep_num, USBD_NDDRTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_enable()
1692 writel(1 << ep->hwep_num, USBD_SYSERRTINTCLR(udc->udp_baseaddr)); in lpc32xx_ep_enable()
1693 writel(1 << ep->hwep_num, USBD_DMARCLR(udc->udp_baseaddr)); in lpc32xx_ep_enable()
1695 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_ep_enable()
1697 atomic_inc(&udc->enabled_ep_cnt); in lpc32xx_ep_enable()
1714 INIT_LIST_HEAD(&req->queue); in lpc32xx_ep_alloc_request()
1715 return &req->req; in lpc32xx_ep_alloc_request()
1719 * De-allocate a USB request list
1728 BUG_ON(!list_empty(&req->queue)); in lpc32xx_ep_free_request()
1745 if (!_ep || !_req || !_req->complete || !_req->buf || in lpc32xx_ep_queue()
1746 !list_empty(&req->queue)) in lpc32xx_ep_queue()
1747 return -EINVAL; in lpc32xx_ep_queue()
1749 udc = ep->udc; in lpc32xx_ep_queue()
1751 if (udc->gadget.speed == USB_SPEED_UNKNOWN) in lpc32xx_ep_queue()
1752 return -EPIPE; in lpc32xx_ep_queue()
1754 if (ep->lep) { in lpc32xx_ep_queue()
1757 status = usb_gadget_map_request(&udc->gadget, _req, ep->is_in); in lpc32xx_ep_queue()
1765 return -ENOMEM; in lpc32xx_ep_queue()
1767 req->dd_desc_ptr = dd; in lpc32xx_ep_queue()
1770 dd->dd_next_phy = dd->dd_next_v = 0; in lpc32xx_ep_queue()
1771 dd->dd_buffer_addr = req->req.dma; in lpc32xx_ep_queue()
1772 dd->dd_status = 0; in lpc32xx_ep_queue()
1775 if (ep->eptype == EP_ISO_TYPE) { in lpc32xx_ep_queue()
1776 dd->dd_setup = DD_SETUP_ISO_EP | in lpc32xx_ep_queue()
1779 dd->dd_iso_ps_mem_addr = dd->this_dma + 24; in lpc32xx_ep_queue()
1780 if (ep->is_in) in lpc32xx_ep_queue()
1781 dd->iso_status[0] = req->req.length; in lpc32xx_ep_queue()
1783 dd->iso_status[0] = 0; in lpc32xx_ep_queue()
1785 dd->dd_setup = DD_SETUP_PACKETLEN(ep->ep.maxpacket) | in lpc32xx_ep_queue()
1786 DD_SETUP_DMALENBYTES(req->req.length); in lpc32xx_ep_queue()
1789 ep_dbg(ep, "%s queue req %p len %d buf %p (in=%d) z=%d\n", _ep->name, in lpc32xx_ep_queue()
1790 _req, _req->length, _req->buf, ep->is_in, _req->zero); in lpc32xx_ep_queue()
1792 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_ep_queue()
1794 _req->status = -EINPROGRESS; in lpc32xx_ep_queue()
1795 _req->actual = 0; in lpc32xx_ep_queue()
1796 req->send_zlp = _req->zero; in lpc32xx_ep_queue()
1799 if (list_empty(&ep->queue)) { in lpc32xx_ep_queue()
1800 list_add_tail(&req->queue, &ep->queue); in lpc32xx_ep_queue()
1802 if (ep->hwep_num_base == 0) { in lpc32xx_ep_queue()
1804 if (ep->is_in) { in lpc32xx_ep_queue()
1806 udc->ep0state = DATA_IN; in lpc32xx_ep_queue()
1810 udc->ep0state = DATA_OUT; in lpc32xx_ep_queue()
1813 } else if (ep->is_in) { in lpc32xx_ep_queue()
1815 if (!ep->req_pending) in lpc32xx_ep_queue()
1819 if (!ep->req_pending) in lpc32xx_ep_queue()
1822 list_add_tail(&req->queue, &ep->queue); in lpc32xx_ep_queue()
1824 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_ep_queue()
1837 if (!_ep || ep->hwep_num_base == 0) in lpc32xx_ep_dequeue()
1838 return -EINVAL; in lpc32xx_ep_dequeue()
1840 spin_lock_irqsave(&ep->udc->lock, flags); in lpc32xx_ep_dequeue()
1843 list_for_each_entry(iter, &ep->queue, queue) { in lpc32xx_ep_dequeue()
1844 if (&iter->req != _req) in lpc32xx_ep_dequeue()
1850 spin_unlock_irqrestore(&ep->udc->lock, flags); in lpc32xx_ep_dequeue()
1851 return -EINVAL; in lpc32xx_ep_dequeue()
1854 done(ep, req, -ECONNRESET); in lpc32xx_ep_dequeue()
1856 spin_unlock_irqrestore(&ep->udc->lock, flags); in lpc32xx_ep_dequeue()
1868 if ((!ep) || (ep->hwep_num <= 1)) in lpc32xx_ep_set_halt()
1869 return -EINVAL; in lpc32xx_ep_set_halt()
1872 if (ep->is_in) in lpc32xx_ep_set_halt()
1873 return -EAGAIN; in lpc32xx_ep_set_halt()
1875 udc = ep->udc; in lpc32xx_ep_set_halt()
1876 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_ep_set_halt()
1880 udc_protocol_cmd_data_w(udc, CMD_SET_EP_STAT(ep->hwep_num), in lpc32xx_ep_set_halt()
1884 ep->wedge = 0; in lpc32xx_ep_set_halt()
1885 udc_protocol_cmd_data_w(udc, CMD_SET_EP_STAT(ep->hwep_num), in lpc32xx_ep_set_halt()
1889 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_ep_set_halt()
1899 if (!_ep || !ep->udc) in lpc32xx_ep_set_wedge()
1900 return -EINVAL; in lpc32xx_ep_set_wedge()
1902 ep->wedge = 1; in lpc32xx_ep_set_wedge()
1918 /* Send a ZLP on a non-0 IN EP */
1922 udc_clearep_getsts(udc, ep->hwep_num); in udc_send_in_zlp()
1925 udc_write_hwep(udc, ep->hwep_num, NULL, 0); in udc_send_in_zlp()
1938 if (ep->hwep_num <= 0) in udc_handle_eps()
1941 uda_clear_hwepint(udc, ep->hwep_num); in udc_handle_eps()
1944 if (!(udc->enabled_hwepints & (1 << ep->hwep_num))) in udc_handle_eps()
1948 epstatus = udc_clearep_getsts(udc, ep->hwep_num); in udc_handle_eps()
1957 if (ep->is_in) { in udc_handle_eps()
1959 uda_disable_hwepint(udc, ep->hwep_num); in udc_handle_eps()
1964 req = list_entry(ep->queue.next, struct lpc32xx_request, queue); in udc_handle_eps()
1969 if (!list_empty(&ep->queue)) { in udc_handle_eps()
1970 if (ep->is_in) in udc_handle_eps()
1975 ep->req_pending = 0; in udc_handle_eps()
1988 ep->totalints++; in udc_handle_dma_ep()
1991 req = list_entry(ep->queue.next, struct lpc32xx_request, queue); in udc_handle_dma_ep()
1996 dd = req->dd_desc_ptr; in udc_handle_dma_ep()
1999 if (!(dd->dd_status & DD_STATUS_DD_RETIRED)) in udc_handle_dma_ep()
2003 udc_ep_dma_disable(udc, ep->hwep_num); in udc_handle_dma_ep()
2004 writel((1 << ep->hwep_num), USBD_EOTINTCLR(udc->udp_baseaddr)); in udc_handle_dma_ep()
2005 writel((1 << ep->hwep_num), USBD_NDDRTINTCLR(udc->udp_baseaddr)); in udc_handle_dma_ep()
2008 if (readl(USBD_SYSERRTINTST(udc->udp_baseaddr)) & in udc_handle_dma_ep()
2009 (1 << ep->hwep_num)) { in udc_handle_dma_ep()
2010 writel((1 << ep->hwep_num), in udc_handle_dma_ep()
2011 USBD_SYSERRTINTCLR(udc->udp_baseaddr)); in udc_handle_dma_ep()
2013 ep->req_pending = 0; in udc_handle_dma_ep()
2018 done(ep, req, -ECONNABORTED); in udc_handle_dma_ep()
2023 status = dd->dd_status; in udc_handle_dma_ep()
2027 ep->req_pending = 0; in udc_handle_dma_ep()
2031 done(ep, req, -ECONNABORTED); in udc_handle_dma_ep()
2035 /* Interrupt only fires on EOT - This shouldn't happen! */ in udc_handle_dma_ep()
2036 ep->req_pending = 0; in udc_handle_dma_ep()
2039 done(ep, req, -ECONNABORTED); in udc_handle_dma_ep()
2050 ep->req_pending = 0; in udc_handle_dma_ep()
2053 done(ep, req, -ECONNABORTED); in udc_handle_dma_ep()
2058 if (ep->eptype == EP_ISO_TYPE) { in udc_handle_dma_ep()
2059 if (ep->is_in) in udc_handle_dma_ep()
2060 req->req.actual = req->req.length; in udc_handle_dma_ep()
2062 req->req.actual = dd->iso_status[0] & 0xFFFF; in udc_handle_dma_ep()
2064 req->req.actual += DD_STATUS_CURDMACNT(status); in udc_handle_dma_ep()
2066 /* Send a ZLP if necessary. This will be done for non-int in udc_handle_dma_ep()
2068 if (req->send_zlp) { in udc_handle_dma_ep()
2074 if (udc_clearep_getsts(udc, ep->hwep_num) & EP_SEL_F) { in udc_handle_dma_ep()
2075 udc_clearep_getsts(udc, ep->hwep_num); in udc_handle_dma_ep()
2076 uda_enable_hwepint(udc, ep->hwep_num); in udc_handle_dma_ep()
2077 udc_clearep_getsts(udc, ep->hwep_num); in udc_handle_dma_ep()
2089 udc_clearep_getsts(udc, ep->hwep_num); in udc_handle_dma_ep()
2090 if (!list_empty((&ep->queue))) { in udc_handle_dma_ep()
2091 if (ep->is_in) in udc_handle_dma_ep()
2096 ep->req_pending = 0; in udc_handle_dma_ep()
2118 if (udc->vbus == 0) in udc_handle_dev()
2120 else if ((udc->gadget.speed != USB_SPEED_UNKNOWN) && in udc_handle_dev()
2121 udc->driver) { in udc_handle_dev()
2123 udc->poweron = 0; in udc_handle_dev()
2124 schedule_work(&udc->pullup_job); in udc_handle_dev()
2127 } else if ((udc->gadget.speed != USB_SPEED_UNKNOWN) && in udc_handle_dev()
2128 udc->driver && udc->vbus) { in udc_handle_dev()
2131 udc->poweron = 1; in udc_handle_dev()
2132 schedule_work(&udc->pullup_job); in udc_handle_dev()
2147 ep0buff = udc->gadget.is_selfpowered; in udc_get_status()
2148 if (udc->dev_status & (1 << USB_DEVICE_REMOTE_WAKEUP)) in udc_get_status()
2154 ep = &udc->ep[tmp]; in udc_get_status()
2156 return -EOPNOTSUPP; in udc_get_status()
2159 if (!ep->is_in) in udc_get_status()
2160 return -EOPNOTSUPP; /* Something's wrong */ in udc_get_status()
2161 } else if (ep->is_in) in udc_get_status()
2162 return -EOPNOTSUPP; /* Not an IN endpoint */ in udc_get_status()
2165 udc_protocol_cmd_w(udc, CMD_SEL_EP(ep->hwep_num)); in udc_get_status()
2166 tmp = udc_protocol_cmd_r(udc, DAT_SEL_EP(ep->hwep_num)); in udc_get_status()
2186 struct lpc32xx_ep *ep, *ep0 = &udc->ep[0]; in udc_handle_ep0_setup()
2192 nuke(ep0, -EPROTO); in udc_handle_ep0_setup()
2209 ep0->is_in = 1; in udc_handle_ep0_setup()
2211 ep0->is_in = 0; in udc_handle_ep0_setup()
2225 udc->dev_status &= in udc_handle_ep0_setup()
2228 udc->dev_status |= in udc_handle_ep0_setup()
2240 ep = &udc->ep[tmp]; in udc_handle_ep0_setup()
2241 tmp = ep->hwep_num; in udc_handle_ep0_setup()
2247 else if (!ep->wedge) in udc_handle_ep0_setup()
2272 if (likely(udc->driver)) { in udc_handle_ep0_setup()
2273 /* device-2-host (IN) or no data setup command, process in udc_handle_ep0_setup()
2275 spin_unlock(&udc->lock); in udc_handle_ep0_setup()
2276 i = udc->driver->setup(&udc->gadget, &ctrlpkt); in udc_handle_ep0_setup()
2278 spin_lock(&udc->lock); in udc_handle_ep0_setup()
2300 dev_dbg(udc->dev, in udc_handle_ep0_setup()
2303 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_setup()
2308 if (!ep0->is_in) in udc_handle_ep0_setup()
2325 struct lpc32xx_ep *ep0 = &udc->ep[0]; in udc_handle_ep0_in()
2332 ep0->totalints++; in udc_handle_ep0_in()
2338 nuke(ep0, -ECONNABORTED); in udc_handle_ep0_in()
2339 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_in()
2346 if (udc->ep0state == DATA_IN) in udc_handle_ep0_in()
2350 nuke(ep0, -ECONNABORTED); in udc_handle_ep0_in()
2351 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_in()
2359 struct lpc32xx_ep *ep0 = &udc->ep[0]; in udc_handle_ep0_out()
2367 ep0->totalints++; in udc_handle_ep0_out()
2373 nuke(ep0, -ECONNABORTED); in udc_handle_ep0_out()
2374 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_out()
2384 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_out()
2390 switch (udc->ep0state) { in udc_handle_ep0_out()
2401 nuke(ep0, -ECONNABORTED); in udc_handle_ep0_out()
2402 udc->ep0state = WAIT_FOR_SETUP; in udc_handle_ep0_out()
2413 if (!udc->clocked) in lpc32xx_get_frame()
2414 return -EINVAL; in lpc32xx_get_frame()
2416 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_get_frame()
2420 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_get_frame()
2427 return -ENOTSUPP; in lpc32xx_wakeup()
2432 gadget->is_selfpowered = (is_on != 0); in lpc32xx_set_selfpowered()
2446 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_vbus_session()
2449 if (udc->driver) { in lpc32xx_vbus_session()
2457 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_vbus_session()
2463 if (atomic_read(&udc->enabled_ep_cnt)) in lpc32xx_vbus_session()
2464 wait_event_interruptible(udc->ep_disable_wait_queue, in lpc32xx_vbus_session()
2465 (atomic_read(&udc->enabled_ep_cnt) == 0)); in lpc32xx_vbus_session()
2467 spin_lock_irqsave(&udc->lock, flags); in lpc32xx_vbus_session()
2472 spin_unlock_irqrestore(&udc->lock, flags); in lpc32xx_vbus_session()
2530 .name = "ep1-int",
2543 .name = "ep2-bulk",
2556 .name = "ep3-iso",
2569 .name = "ep4-int",
2582 .name = "ep5-bulk",
2595 .name = "ep6-iso",
2608 .name = "ep7-int",
2621 .name = "ep8-bulk",
2634 .name = "ep9-iso",
2647 .name = "ep10-int",
2660 .name = "ep11-bulk",
2673 .name = "ep12-iso",
2686 .name = "ep13-int",
2699 .name = "ep14-bulk",
2712 .name = "ep15-bulk",
2731 spin_lock(&udc->lock); in lpc32xx_usb_lp_irq()
2734 devstat = readl(USBD_DEVINTST(udc->udp_baseaddr)); in lpc32xx_usb_lp_irq()
2737 writel(devstat, USBD_DEVINTCLR(udc->udp_baseaddr)); in lpc32xx_usb_lp_irq()
2738 devstat = devstat & udc->enabled_devints; in lpc32xx_usb_lp_irq()
2756 dev_dbg(udc->dev, "Device error (0x%x)!\n", tmp); in lpc32xx_usb_lp_irq()
2759 spin_unlock(&udc->lock); in lpc32xx_usb_lp_irq()
2770 spin_lock(&udc->lock); in lpc32xx_usb_hp_irq()
2773 writel(USBD_EP_FAST, USBD_DEVINTCLR(udc->udp_baseaddr)); in lpc32xx_usb_hp_irq()
2776 tmp = readl(USBD_EPINTST(udc->udp_baseaddr)); in lpc32xx_usb_hp_irq()
2795 if (tmp & (1 << udc->ep[i].hwep_num)) in lpc32xx_usb_hp_irq()
2796 udc_handle_eps(udc, &udc->ep[i]); in lpc32xx_usb_hp_irq()
2800 spin_unlock(&udc->lock); in lpc32xx_usb_hp_irq()
2812 spin_lock(&udc->lock); in lpc32xx_usb_devdma_irq()
2815 tmp = readl(USBD_EOTINTST(udc->udp_baseaddr)) | in lpc32xx_usb_devdma_irq()
2816 (readl(USBD_EPDMAST(udc->udp_baseaddr)) & in lpc32xx_usb_devdma_irq()
2817 readl(USBD_NDDRTINTST(udc->udp_baseaddr))) | in lpc32xx_usb_devdma_irq()
2818 readl(USBD_SYSERRTINTST(udc->udp_baseaddr)); in lpc32xx_usb_devdma_irq()
2820 if (tmp & (1 << udc->ep[i].hwep_num)) in lpc32xx_usb_devdma_irq()
2821 udc_handle_dma_ep(udc, &udc->ep[i]); in lpc32xx_usb_devdma_irq()
2824 spin_unlock(&udc->lock); in lpc32xx_usb_devdma_irq()
2838 if (udc->enabled != 0) { in vbus_work()
2840 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in vbus_work()
2847 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in vbus_work()
2852 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in vbus_work()
2857 value = i2c_smbus_read_byte_data(udc->isp1301_i2c_client, in vbus_work()
2862 udc->vbus = 1; in vbus_work()
2864 udc->vbus = 0; in vbus_work()
2867 if (udc->last_vbus != udc->vbus) { in vbus_work()
2868 udc->last_vbus = udc->vbus; in vbus_work()
2869 lpc32xx_vbus_session(&udc->gadget, udc->vbus); in vbus_work()
2888 if (!driver || driver->max_speed < USB_SPEED_FULL || !driver->setup) { in lpc32xx_start()
2889 dev_err(udc->dev, "bad parameter.\n"); in lpc32xx_start()
2890 return -EINVAL; in lpc32xx_start()
2893 if (udc->driver) { in lpc32xx_start()
2894 dev_err(udc->dev, "UDC already has a gadget driver\n"); in lpc32xx_start()
2895 return -EBUSY; in lpc32xx_start()
2898 udc->driver = driver; in lpc32xx_start()
2899 udc->gadget.dev.of_node = udc->dev->of_node; in lpc32xx_start()
2900 udc->enabled = 1; in lpc32xx_start()
2901 udc->gadget.is_selfpowered = 1; in lpc32xx_start()
2902 udc->vbus = 0; in lpc32xx_start()
2905 udc->last_vbus = udc->vbus = 0; in lpc32xx_start()
2909 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in lpc32xx_start()
2911 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in lpc32xx_start()
2921 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in lpc32xx_stop()
2923 i2c_smbus_write_byte_data(udc->isp1301_i2c_client, in lpc32xx_stop()
2926 if (udc->clocked) { in lpc32xx_stop()
2927 spin_lock(&udc->lock); in lpc32xx_stop()
2929 spin_unlock(&udc->lock); in lpc32xx_stop()
2936 if (atomic_read(&udc->enabled_ep_cnt)) in lpc32xx_stop()
2937 wait_event_interruptible(udc->ep_disable_wait_queue, in lpc32xx_stop()
2938 (atomic_read(&udc->enabled_ep_cnt) == 0)); in lpc32xx_stop()
2940 spin_lock(&udc->lock); in lpc32xx_stop()
2942 spin_unlock(&udc->lock); in lpc32xx_stop()
2945 udc->enabled = 0; in lpc32xx_stop()
2946 udc->driver = NULL; in lpc32xx_stop()
2991 struct device *dev = &pdev->dev; in lpc32xx_udc_probe()
2999 return -ENOMEM; in lpc32xx_udc_probe()
3002 udc->ep[i].udc = udc; in lpc32xx_udc_probe()
3003 udc->gadget.ep0 = &udc->ep[0].ep; in lpc32xx_udc_probe()
3006 udc->gadget.dev.parent = dev; in lpc32xx_udc_probe()
3007 udc->pdev = pdev; in lpc32xx_udc_probe()
3008 udc->dev = &pdev->dev; in lpc32xx_udc_probe()
3009 udc->enabled = 0; in lpc32xx_udc_probe()
3011 if (pdev->dev.of_node) { in lpc32xx_udc_probe()
3012 isp1301_node = of_parse_phandle(pdev->dev.of_node, in lpc32xx_udc_probe()
3018 udc->isp1301_i2c_client = isp1301_get_client(isp1301_node); in lpc32xx_udc_probe()
3020 if (!udc->isp1301_i2c_client) { in lpc32xx_udc_probe()
3021 return -EPROBE_DEFER; in lpc32xx_udc_probe()
3024 dev_info(udc->dev, "ISP1301 I2C device at address 0x%x\n", in lpc32xx_udc_probe()
3025 udc->isp1301_i2c_client->addr); in lpc32xx_udc_probe()
3027 pdev->dev.dma_mask = &lpc32xx_usbd_dmamask; in lpc32xx_udc_probe()
3028 retval = dma_set_coherent_mask(&pdev->dev, DMA_BIT_MASK(32)); in lpc32xx_udc_probe()
3032 udc->board = &lpc32xx_usbddata; in lpc32xx_udc_probe()
3043 spin_lock_init(&udc->lock); in lpc32xx_udc_probe()
3047 udc->udp_irq[i] = platform_get_irq(pdev, i); in lpc32xx_udc_probe()
3048 if (udc->udp_irq[i] < 0) in lpc32xx_udc_probe()
3049 return udc->udp_irq[i]; in lpc32xx_udc_probe()
3052 udc->udp_baseaddr = devm_platform_ioremap_resource(pdev, 0); in lpc32xx_udc_probe()
3053 if (IS_ERR(udc->udp_baseaddr)) { in lpc32xx_udc_probe()
3054 dev_err(udc->dev, "IO map failure\n"); in lpc32xx_udc_probe()
3055 return PTR_ERR(udc->udp_baseaddr); in lpc32xx_udc_probe()
3059 udc->usb_slv_clk = devm_clk_get(&pdev->dev, NULL); in lpc32xx_udc_probe()
3060 if (IS_ERR(udc->usb_slv_clk)) { in lpc32xx_udc_probe()
3061 dev_err(udc->dev, "failed to acquire USB device clock\n"); in lpc32xx_udc_probe()
3062 return PTR_ERR(udc->usb_slv_clk); in lpc32xx_udc_probe()
3066 retval = clk_prepare_enable(udc->usb_slv_clk); in lpc32xx_udc_probe()
3068 dev_err(udc->dev, "failed to start USB device clock\n"); in lpc32xx_udc_probe()
3073 udc->poweron = udc->pullup = 0; in lpc32xx_udc_probe()
3074 INIT_WORK(&udc->pullup_job, pullup_work); in lpc32xx_udc_probe()
3076 INIT_WORK(&udc->power_job, power_work); in lpc32xx_udc_probe()
3080 udc->clocked = 1; in lpc32xx_udc_probe()
3084 udc->udca_v_base = dma_alloc_coherent(&pdev->dev, UDCA_BUFF_SIZE, in lpc32xx_udc_probe()
3087 if (!udc->udca_v_base) { in lpc32xx_udc_probe()
3088 dev_err(udc->dev, "error getting UDCA region\n"); in lpc32xx_udc_probe()
3089 retval = -ENOMEM; in lpc32xx_udc_probe()
3092 udc->udca_p_base = dma_handle; in lpc32xx_udc_probe()
3093 dev_dbg(udc->dev, "DMA buffer(0x%x bytes), P:0x%08x, V:0x%p\n", in lpc32xx_udc_probe()
3094 UDCA_BUFF_SIZE, udc->udca_p_base, udc->udca_v_base); in lpc32xx_udc_probe()
3097 udc->dd_cache = dma_pool_create("udc_dd", udc->dev, in lpc32xx_udc_probe()
3100 if (!udc->dd_cache) { in lpc32xx_udc_probe()
3101 dev_err(udc->dev, "error getting DD DMA region\n"); in lpc32xx_udc_probe()
3102 retval = -ENOMEM; in lpc32xx_udc_probe()
3110 /* Request IRQs - low and high priority USB device IRQs are routed to in lpc32xx_udc_probe()
3112 retval = devm_request_irq(dev, udc->udp_irq[IRQ_USB_LP], in lpc32xx_udc_probe()
3115 dev_err(udc->dev, "LP request irq %d failed\n", in lpc32xx_udc_probe()
3116 udc->udp_irq[IRQ_USB_LP]); in lpc32xx_udc_probe()
3119 retval = devm_request_irq(dev, udc->udp_irq[IRQ_USB_HP], in lpc32xx_udc_probe()
3122 dev_err(udc->dev, "HP request irq %d failed\n", in lpc32xx_udc_probe()
3123 udc->udp_irq[IRQ_USB_HP]); in lpc32xx_udc_probe()
3127 retval = devm_request_irq(dev, udc->udp_irq[IRQ_USB_DEVDMA], in lpc32xx_udc_probe()
3130 dev_err(udc->dev, "DEV request irq %d failed\n", in lpc32xx_udc_probe()
3131 udc->udp_irq[IRQ_USB_DEVDMA]); in lpc32xx_udc_probe()
3137 retval = devm_request_threaded_irq(dev, udc->udp_irq[IRQ_USB_ATX], NULL, in lpc32xx_udc_probe()
3141 dev_err(udc->dev, "VBUS request irq %d failed\n", in lpc32xx_udc_probe()
3142 udc->udp_irq[IRQ_USB_ATX]); in lpc32xx_udc_probe()
3147 init_waitqueue_head(&udc->ep_disable_wait_queue); in lpc32xx_udc_probe()
3148 atomic_set(&udc->enabled_ep_cnt, 0); in lpc32xx_udc_probe()
3150 retval = usb_add_gadget_udc(dev, &udc->gadget); in lpc32xx_udc_probe()
3161 dev_info(udc->dev, "%s version %s\n", driver_name, DRIVER_VERSION); in lpc32xx_udc_probe()
3166 dma_pool_destroy(udc->dd_cache); in lpc32xx_udc_probe()
3168 dma_free_coherent(&pdev->dev, UDCA_BUFF_SIZE, in lpc32xx_udc_probe()
3169 udc->udca_v_base, udc->udca_p_base); in lpc32xx_udc_probe()
3171 clk_disable_unprepare(udc->usb_slv_clk); in lpc32xx_udc_probe()
3172 dev_err(udc->dev, "%s probe failed, %d\n", driver_name, retval); in lpc32xx_udc_probe()
3181 usb_del_gadget_udc(&udc->gadget); in lpc32xx_udc_remove()
3182 if (udc->driver) in lpc32xx_udc_remove()
3183 return -EBUSY; in lpc32xx_udc_remove()
3189 device_init_wakeup(&pdev->dev, 0); in lpc32xx_udc_remove()
3192 dma_pool_destroy(udc->dd_cache); in lpc32xx_udc_remove()
3193 dma_free_coherent(&pdev->dev, UDCA_BUFF_SIZE, in lpc32xx_udc_remove()
3194 udc->udca_v_base, udc->udca_p_base); in lpc32xx_udc_remove()
3196 clk_disable_unprepare(udc->usb_slv_clk); in lpc32xx_udc_remove()
3206 if (udc->clocked) { in lpc32xx_udc_suspend()
3208 udc->poweron = 0; in lpc32xx_udc_suspend()
3214 /* Keep clock flag on, so we know to re-enable clocks in lpc32xx_udc_suspend()
3216 udc->clocked = 1; in lpc32xx_udc_suspend()
3219 clk_disable_unprepare(udc->usb_slv_clk); in lpc32xx_udc_suspend()
3229 if (udc->clocked) { in lpc32xx_udc_resume()
3231 clk_prepare_enable(udc->usb_slv_clk); in lpc32xx_udc_resume()
3237 udc->poweron = 1; in lpc32xx_udc_resume()
3250 { .compatible = "nxp,lpc3220-udc", },