UCLASS_USB_DEV_GENERIC was meant for USB devices connected to host
controllers, not gadget devices.
Adding a new UCLASS for gadget devices alone.

Also move the generic DM code for USB gadgets in a separate file for
clarity.

Signed-off-by: Jean-Jacques Hiblot <jjhib...@ti.com>
---

 board/sunxi/board.c               |  2 +-
 drivers/usb/dwc3/dwc3-generic.c   |  2 +-
 drivers/usb/gadget/ether.c        |  2 +-
 drivers/usb/gadget/udc/Makefile   |  4 ++++
 drivers/usb/gadget/udc/udc-core.c | 41 ---------------------------------------
 drivers/usb/musb-new/omap2430.c   |  2 +-
 drivers/usb/musb-new/sunxi.c      |  2 +-
 include/dm/uclass-id.h            |  1 +
 8 files changed, 10 insertions(+), 46 deletions(-)

diff --git a/board/sunxi/board.c b/board/sunxi/board.c
index 64ccbc7..9b36cc7 100644
--- a/board/sunxi/board.c
+++ b/board/sunxi/board.c
@@ -663,7 +663,7 @@ int g_dnl_board_usb_cable_connected(void)
        struct phy phy;
        int ret;
 
-       ret = uclass_get_device(UCLASS_USB_DEV_GENERIC, 0, &dev);
+       ret = uclass_get_device(UCLASS_USB_GADGET_GENERIC, 0, &dev);
        if (ret) {
                pr_err("%s: Cannot find USB device\n", __func__);
                return ret;
diff --git a/drivers/usb/dwc3/dwc3-generic.c b/drivers/usb/dwc3/dwc3-generic.c
index f908d7f..bfd5bf3 100644
--- a/drivers/usb/dwc3/dwc3-generic.c
+++ b/drivers/usb/dwc3/dwc3-generic.c
@@ -101,7 +101,7 @@ static int 
dwc3_generic_peripheral_ofdata_to_platdata(struct udevice *dev)
 
 U_BOOT_DRIVER(dwc3_generic_peripheral) = {
        .name   = "dwc3-generic-peripheral",
-       .id     = UCLASS_USB_DEV_GENERIC,
+       .id     = UCLASS_USB_GADGET_GENERIC,
        .ofdata_to_platdata = dwc3_generic_peripheral_ofdata_to_platdata,
        .probe = dwc3_generic_peripheral_probe,
        .remove = dwc3_generic_peripheral_remove,
diff --git a/drivers/usb/gadget/ether.c b/drivers/usb/gadget/ether.c
index 5a9ffd7..3b3d9af 100644
--- a/drivers/usb/gadget/ether.c
+++ b/drivers/usb/gadget/ether.c
@@ -2671,7 +2671,7 @@ int usb_ether_init(void)
        struct udevice *usb_dev;
        int ret;
 
-       ret = uclass_first_device(UCLASS_USB_DEV_GENERIC, &usb_dev);
+       ret = uclass_first_device(UCLASS_USB_GADGET_GENERIC, &usb_dev);
        if (!usb_dev || ret) {
                pr_err("No USB device found\n");
                return ret;
diff --git a/drivers/usb/gadget/udc/Makefile b/drivers/usb/gadget/udc/Makefile
index 449339f..d1a5963 100644
--- a/drivers/usb/gadget/udc/Makefile
+++ b/drivers/usb/gadget/udc/Makefile
@@ -2,4 +2,8 @@
 #
 # USB peripheral controller drivers
 
+ifndef CONFIG_DM_USB_GADGET
 obj-$(CONFIG_USB_DWC3_GADGET)  += udc-core.o
+endif
+
+obj-$(CONFIG_DM_USB_GADGET)    += udc-uclass.o udc-core.o
diff --git a/drivers/usb/gadget/udc/udc-core.c 
b/drivers/usb/gadget/udc/udc-core.c
index bae71a2..62b4778 100644
--- a/drivers/usb/gadget/udc/udc-core.c
+++ b/drivers/usb/gadget/udc/udc-core.c
@@ -352,44 +352,3 @@ EXPORT_SYMBOL_GPL(usb_gadget_unregister_driver);
 MODULE_DESCRIPTION("UDC Framework");
 MODULE_AUTHOR("Felipe Balbi <ba...@ti.com>");
 MODULE_LICENSE("GPL v2");
-
-#ifdef CONFIG_DM_USB_GADGET
-#define MAX_UDC_DEVICES 4
-static struct udevice *dev_array[MAX_UDC_DEVICES];
-int usb_gadget_initialize(int index)
-{
-       int ret;
-       struct udevice *dev = NULL;
-
-       if (index < 0 || index >= ARRAY_SIZE(dev_array))
-               return -EINVAL;
-       if (dev_array[index])
-               return 0;
-       ret = uclass_get_device(UCLASS_USB_DEV_GENERIC, index, &dev);
-       if (!dev || ret) {
-               pr_err("No USB device found\n");
-               return -ENODEV;
-       }
-       dev_array[index] = dev;
-       return 0;
-}
-
-int usb_gadget_release(int index)
-{
-       int ret;
-
-       if (index < 0 || index >= ARRAY_SIZE(dev_array))
-               return -EINVAL;
-       ret = device_remove(dev_array[index], DM_REMOVE_NORMAL);
-       if (!ret)
-               dev_array[index] = NULL;
-       return ret;
-}
-
-int usb_gadget_handle_interrupts(int index)
-{
-       if (index < 0 || index >= ARRAY_SIZE(dev_array))
-               return -EINVAL;
-       return dm_usb_gadget_handle_interrupts(dev_array[index]);
-}
-#endif
diff --git a/drivers/usb/musb-new/omap2430.c b/drivers/usb/musb-new/omap2430.c
index 342d76b..971f953 100644
--- a/drivers/usb/musb-new/omap2430.c
+++ b/drivers/usb/musb-new/omap2430.c
@@ -263,7 +263,7 @@ U_BOOT_DRIVER(omap2430_musb) = {
 #ifdef CONFIG_USB_MUSB_HOST
        .id             = UCLASS_USB,
 #else
-       .id             = UCLASS_USB_DEV_GENERIC,
+       .id             = UCLASS_USB_GADGET_GENERIC,
 #endif
        .of_match = omap2430_musb_ids,
        .ofdata_to_platdata = omap2430_musb_ofdata_to_platdata,
diff --git a/drivers/usb/musb-new/sunxi.c b/drivers/usb/musb-new/sunxi.c
index 6cf9826..d7170a3 100644
--- a/drivers/usb/musb-new/sunxi.c
+++ b/drivers/usb/musb-new/sunxi.c
@@ -535,7 +535,7 @@ U_BOOT_DRIVER(usb_musb) = {
 #ifdef CONFIG_USB_MUSB_HOST
        .id             = UCLASS_USB,
 #else
-       .id             = UCLASS_USB_DEV_GENERIC,
+       .id             = UCLASS_USB_GADGET_GENERIC,
 #endif
        .of_match       = sunxi_musb_ids,
        .probe          = musb_usb_probe,
diff --git a/include/dm/uclass-id.h b/include/dm/uclass-id.h
index c91dca1..1601100 100644
--- a/include/dm/uclass-id.h
+++ b/include/dm/uclass-id.h
@@ -92,6 +92,7 @@ enum uclass_id {
        UCLASS_USB,             /* USB bus */
        UCLASS_USB_DEV_GENERIC, /* USB generic device */
        UCLASS_USB_HUB,         /* USB hub */
+       UCLASS_USB_GADGET_GENERIC,      /* USB generic device */
        UCLASS_VIDEO,           /* Video or LCD device */
        UCLASS_VIDEO_BRIDGE,    /* Video bridge, e.g. DisplayPort to LVDS */
        UCLASS_VIDEO_CONSOLE,   /* Text console driver for video device */
-- 
2.7.4

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to