diff options
| -rw-r--r-- | drivers/usb/gadget/udc/at91_udc.c | 96 |
1 files changed, 26 insertions, 70 deletions
diff --git a/drivers/usb/gadget/udc/at91_udc.c b/drivers/usb/gadget/udc/at91_udc.c index c0abb9bc76a9..6d285226ab94 100644 --- a/drivers/usb/gadget/udc/at91_udc.c +++ b/drivers/usb/gadget/udc/at91_udc.c | |||
| @@ -59,7 +59,15 @@ | |||
| 59 | #define DRIVER_VERSION "3 May 2006" | 59 | #define DRIVER_VERSION "3 May 2006" |
| 60 | 60 | ||
| 61 | static const char driver_name [] = "at91_udc"; | 61 | static const char driver_name [] = "at91_udc"; |
| 62 | static const char ep0name[] = "ep0"; | 62 | static const char * const ep_names[] = { |
| 63 | "ep0", | ||
| 64 | "ep1", | ||
| 65 | "ep2", | ||
| 66 | "ep3-int", | ||
| 67 | "ep4", | ||
| 68 | "ep5", | ||
| 69 | }; | ||
| 70 | #define ep0name ep_names[0] | ||
| 63 | 71 | ||
| 64 | #define VBUS_POLL_TIMEOUT msecs_to_jiffies(1000) | 72 | #define VBUS_POLL_TIMEOUT msecs_to_jiffies(1000) |
| 65 | 73 | ||
| @@ -1497,74 +1505,6 @@ static irqreturn_t at91_udc_irq (int irq, void *_udc) | |||
| 1497 | 1505 | ||
| 1498 | /*-------------------------------------------------------------------------*/ | 1506 | /*-------------------------------------------------------------------------*/ |
| 1499 | 1507 | ||
| 1500 | static struct at91_udc controller = { | ||
| 1501 | .gadget = { | ||
| 1502 | .ops = &at91_udc_ops, | ||
| 1503 | .ep0 = &controller.ep[0].ep, | ||
| 1504 | .name = driver_name, | ||
| 1505 | }, | ||
| 1506 | .ep[0] = { | ||
| 1507 | .ep = { | ||
| 1508 | .name = ep0name, | ||
| 1509 | .ops = &at91_ep_ops, | ||
| 1510 | }, | ||
| 1511 | .udc = &controller, | ||
| 1512 | .maxpacket = 8, | ||
| 1513 | .int_mask = 1 << 0, | ||
| 1514 | }, | ||
| 1515 | .ep[1] = { | ||
| 1516 | .ep = { | ||
| 1517 | .name = "ep1", | ||
| 1518 | .ops = &at91_ep_ops, | ||
| 1519 | }, | ||
| 1520 | .udc = &controller, | ||
| 1521 | .is_pingpong = 1, | ||
| 1522 | .maxpacket = 64, | ||
| 1523 | .int_mask = 1 << 1, | ||
| 1524 | }, | ||
| 1525 | .ep[2] = { | ||
| 1526 | .ep = { | ||
| 1527 | .name = "ep2", | ||
| 1528 | .ops = &at91_ep_ops, | ||
| 1529 | }, | ||
| 1530 | .udc = &controller, | ||
| 1531 | .is_pingpong = 1, | ||
| 1532 | .maxpacket = 64, | ||
| 1533 | .int_mask = 1 << 2, | ||
| 1534 | }, | ||
| 1535 | .ep[3] = { | ||
| 1536 | .ep = { | ||
| 1537 | /* could actually do bulk too */ | ||
| 1538 | .name = "ep3-int", | ||
| 1539 | .ops = &at91_ep_ops, | ||
| 1540 | }, | ||
| 1541 | .udc = &controller, | ||
| 1542 | .maxpacket = 8, | ||
| 1543 | .int_mask = 1 << 3, | ||
| 1544 | }, | ||
| 1545 | .ep[4] = { | ||
| 1546 | .ep = { | ||
| 1547 | .name = "ep4", | ||
| 1548 | .ops = &at91_ep_ops, | ||
| 1549 | }, | ||
| 1550 | .udc = &controller, | ||
| 1551 | .is_pingpong = 1, | ||
| 1552 | .maxpacket = 256, | ||
| 1553 | .int_mask = 1 << 4, | ||
| 1554 | }, | ||
| 1555 | .ep[5] = { | ||
| 1556 | .ep = { | ||
| 1557 | .name = "ep5", | ||
| 1558 | .ops = &at91_ep_ops, | ||
| 1559 | }, | ||
| 1560 | .udc = &controller, | ||
| 1561 | .is_pingpong = 1, | ||
| 1562 | .maxpacket = 256, | ||
| 1563 | .int_mask = 1 << 5, | ||
| 1564 | }, | ||
| 1565 | /* ep6 and ep7 are also reserved (custom silicon might use them) */ | ||
| 1566 | }; | ||
| 1567 | |||
| 1568 | static void at91_vbus_update(struct at91_udc *udc, unsigned value) | 1508 | static void at91_vbus_update(struct at91_udc *udc, unsigned value) |
| 1569 | { | 1509 | { |
| 1570 | value ^= udc->board.vbus_active_low; | 1510 | value ^= udc->board.vbus_active_low; |
| @@ -1872,15 +1812,31 @@ static int at91udc_probe(struct platform_device *pdev) | |||
| 1872 | struct at91_ep *ep; | 1812 | struct at91_ep *ep; |
| 1873 | int i; | 1813 | int i; |
| 1874 | 1814 | ||
| 1815 | udc = devm_kzalloc(dev, sizeof(*udc), GFP_KERNEL); | ||
| 1816 | if (!udc) | ||
| 1817 | return -ENOMEM; | ||
| 1818 | |||
| 1875 | /* init software state */ | 1819 | /* init software state */ |
| 1876 | udc = &controller; | ||
| 1877 | udc->gadget.dev.parent = dev; | 1820 | udc->gadget.dev.parent = dev; |
| 1878 | at91udc_of_init(udc, pdev->dev.of_node); | 1821 | at91udc_of_init(udc, pdev->dev.of_node); |
| 1879 | udc->pdev = pdev; | 1822 | udc->pdev = pdev; |
| 1880 | udc->enabled = 0; | 1823 | udc->enabled = 0; |
| 1881 | spin_lock_init(&udc->lock); | 1824 | spin_lock_init(&udc->lock); |
| 1882 | 1825 | ||
| 1826 | udc->gadget.ops = &at91_udc_ops; | ||
| 1827 | udc->gadget.ep0 = &udc->ep[0].ep; | ||
| 1828 | udc->gadget.name = driver_name; | ||
| 1829 | udc->gadget.dev.init_name = "gadget"; | ||
| 1883 | 1830 | ||
| 1831 | for (i = 0; i < NUM_ENDPOINTS; i++) { | ||
| 1832 | ep = &udc->ep[i]; | ||
| 1833 | ep->ep.name = ep_names[i]; | ||
| 1834 | ep->ep.ops = &at91_ep_ops; | ||
| 1835 | ep->udc = udc; | ||
| 1836 | ep->int_mask = BIT(i); | ||
| 1837 | if (i != 0 && i != 3) | ||
| 1838 | ep->is_pingpong = 1; | ||
| 1839 | } | ||
| 1884 | 1840 | ||
| 1885 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 1841 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
| 1886 | udc->udp_baseaddr = devm_ioremap_resource(dev, res); | 1842 | udc->udp_baseaddr = devm_ioremap_resource(dev, res); |
