diff options
author | Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | 2012-01-28 09:35:36 -0500 |
---|---|---|
committer | Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | 2012-03-15 12:41:00 -0400 |
commit | d1494a340807c9b77aa44bc8d8166353df4cf1c3 (patch) | |
tree | 213f831c9e3a47acb3095bef39eaf435630bebec /drivers/usb/gadget/at91_udc.c | |
parent | 62c5553ab7ecf23e7b5464a59d728ab94479adbb (diff) |
USB: at91: Device udc add dt support
Allow to compile it if AT91 is enable.
Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/gadget/at91_udc.c')
-rw-r--r-- | drivers/usb/gadget/at91_udc.c | 40 |
1 files changed, 38 insertions, 2 deletions
diff --git a/drivers/usb/gadget/at91_udc.c b/drivers/usb/gadget/at91_udc.c index f99b3dc745bd..4063209fe8da 100644 --- a/drivers/usb/gadget/at91_udc.c +++ b/drivers/usb/gadget/at91_udc.c | |||
@@ -30,6 +30,8 @@ | |||
30 | #include <linux/usb/ch9.h> | 30 | #include <linux/usb/ch9.h> |
31 | #include <linux/usb/gadget.h> | 31 | #include <linux/usb/gadget.h> |
32 | #include <linux/prefetch.h> | 32 | #include <linux/prefetch.h> |
33 | #include <linux/of.h> | ||
34 | #include <linux/of_gpio.h> | ||
33 | 35 | ||
34 | #include <asm/byteorder.h> | 36 | #include <asm/byteorder.h> |
35 | #include <mach/hardware.h> | 37 | #include <mach/hardware.h> |
@@ -1707,7 +1709,27 @@ static void at91udc_shutdown(struct platform_device *dev) | |||
1707 | spin_unlock_irqrestore(&udc->lock, flags); | 1709 | spin_unlock_irqrestore(&udc->lock, flags); |
1708 | } | 1710 | } |
1709 | 1711 | ||
1710 | static int __init at91udc_probe(struct platform_device *pdev) | 1712 | static void __devinit at91udc_of_init(struct at91_udc *udc, |
1713 | struct device_node *np) | ||
1714 | { | ||
1715 | struct at91_udc_data *board = &udc->board; | ||
1716 | u32 val; | ||
1717 | enum of_gpio_flags flags; | ||
1718 | |||
1719 | if (of_property_read_u32(np, "atmel,vbus-polled", &val) == 0) | ||
1720 | board->vbus_polled = 1; | ||
1721 | |||
1722 | board->vbus_pin = of_get_named_gpio_flags(np, "atmel,vbus-gpio", 0, | ||
1723 | &flags); | ||
1724 | board->vbus_active_low = (flags & OF_GPIO_ACTIVE_LOW) ? 1 : 0; | ||
1725 | |||
1726 | board->pullup_pin = of_get_named_gpio_flags(np, "atmel,pullup-gpio", 0, | ||
1727 | &flags); | ||
1728 | |||
1729 | board->pullup_active_low = (flags & OF_GPIO_ACTIVE_LOW) ? 1 : 0; | ||
1730 | } | ||
1731 | |||
1732 | static int __devinit at91udc_probe(struct platform_device *pdev) | ||
1711 | { | 1733 | { |
1712 | struct device *dev = &pdev->dev; | 1734 | struct device *dev = &pdev->dev; |
1713 | struct at91_udc *udc; | 1735 | struct at91_udc *udc; |
@@ -1742,7 +1764,11 @@ static int __init at91udc_probe(struct platform_device *pdev) | |||
1742 | /* init software state */ | 1764 | /* init software state */ |
1743 | udc = &controller; | 1765 | udc = &controller; |
1744 | udc->gadget.dev.parent = dev; | 1766 | udc->gadget.dev.parent = dev; |
1745 | udc->board = *(struct at91_udc_data *) dev->platform_data; | 1767 | if (pdev->dev.of_node) |
1768 | at91udc_of_init(udc, pdev->dev.of_node); | ||
1769 | else | ||
1770 | memcpy(&udc->board, dev->platform_data, | ||
1771 | sizeof(struct at91_udc_data)); | ||
1746 | udc->pdev = pdev; | 1772 | udc->pdev = pdev; |
1747 | udc->enabled = 0; | 1773 | udc->enabled = 0; |
1748 | spin_lock_init(&udc->lock); | 1774 | spin_lock_init(&udc->lock); |
@@ -1971,6 +1997,15 @@ static int at91udc_resume(struct platform_device *pdev) | |||
1971 | #define at91udc_resume NULL | 1997 | #define at91udc_resume NULL |
1972 | #endif | 1998 | #endif |
1973 | 1999 | ||
2000 | #if defined(CONFIG_OF) | ||
2001 | static const struct of_device_id at91_udc_dt_ids[] = { | ||
2002 | { .compatible = "atmel,at91rm9200-udc" }, | ||
2003 | { /* sentinel */ } | ||
2004 | }; | ||
2005 | |||
2006 | MODULE_DEVICE_TABLE(of, at91_udc_dt_ids); | ||
2007 | #endif | ||
2008 | |||
1974 | static struct platform_driver at91_udc_driver = { | 2009 | static struct platform_driver at91_udc_driver = { |
1975 | .remove = __exit_p(at91udc_remove), | 2010 | .remove = __exit_p(at91udc_remove), |
1976 | .shutdown = at91udc_shutdown, | 2011 | .shutdown = at91udc_shutdown, |
@@ -1979,6 +2014,7 @@ static struct platform_driver at91_udc_driver = { | |||
1979 | .driver = { | 2014 | .driver = { |
1980 | .name = (char *) driver_name, | 2015 | .name = (char *) driver_name, |
1981 | .owner = THIS_MODULE, | 2016 | .owner = THIS_MODULE, |
2017 | .of_match_table = of_match_ptr(at91_udc_dt_ids), | ||
1982 | }, | 2018 | }, |
1983 | }; | 2019 | }; |
1984 | 2020 | ||