On 7/22/24 10:47 AM, Zixun LI wrote:
Add controller attach/detach support by using
usb_gadget_ops.pullup() method.
Signed-off-by: Zixun LI <z...@ogga.fr>
---
drivers/usb/gadget/atmel_usba_udc.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/drivers/usb/gadget/atmel_usba_udc.c
b/drivers/usb/gadget/atmel_usba_udc.c
index 327e90a786..48d66d9774 100644
--- a/drivers/usb/gadget/atmel_usba_udc.c
+++ b/drivers/usb/gadget/atmel_usba_udc.c
@@ -1176,6 +1176,23 @@ static int usba_disable(struct usba_udc *udc)
return 0;
}
+static int usba_gadget_pullup(struct usb_gadget *g, int is_on)
+{
+ struct usba_udc *udc = controller;
+ u32 ctrl;
+
+ ctrl = usba_readl(udc, CTRL);
+
+ if (is_on)
+ ctrl &= ~USBA_DETACH;
+ else
+ ctrl |= USBA_DETACH;
+
+ usba_writel(udc, CTRL, ctrl);
+
+ return 0;
+}
+
int dm_usb_gadget_handle_interrupts(struct udevice *dev)
{
struct usba_udc *udc = controller;
@@ -1273,6 +1290,7 @@ static const struct usb_gadget_ops usba_udc_ops = {
.get_frame = usba_udc_get_frame,
.wakeup = usba_udc_wakeup,
.set_selfpowered = usba_udc_set_selfpowered,
+ .pullup = usba_gadget_pullup,
The function should probably be called usba_udc_pullup() to be
consistent with the names of the other functions.