diff options
author | Boris Brezillon <boris.brezillon@free-electrons.com> | 2015-01-14 11:22:04 -0500 |
---|---|---|
committer | Nicolas Ferre <nicolas.ferre@atmel.com> | 2015-01-15 08:53:23 -0500 |
commit | a5514d142e7f5cff8e02a6fb4cfcb3e301c0eb59 (patch) | |
tree | b52226372f597201ef944a5f3dc87c2b49c922eb /drivers/usb | |
parent | 62b986cfa96072bcd365d18b2a8e42e990788b45 (diff) |
usb: gadget: at91_udc: Allocate udc instance
Allocate udc structure instead of relying on the statically declared
object.
Signed-off-by: Boris Brezillon <boris.brezillon@free-electrons.com>
Acked-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
Acked-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Diffstat (limited to 'drivers/usb')
-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); |