Commit ab142308 authored by Kuninori Morimoto's avatar Kuninori Morimoto Committed by Felipe Balbi

usb: gadget: renesas_usbhs: check device0 status when alloc

device0 was treated without checking in usbhsh_device_alloc().
but "udev->usbv" and "dev_set_drvdata()" will be overwritten
if device0  was multi-allocated.
This patch fixes this issue.
Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent c5b963f8
...@@ -153,6 +153,7 @@ static const char usbhsh_hcd_name[] = "renesas_usbhs host"; ...@@ -153,6 +153,7 @@ static const char usbhsh_hcd_name[] = "renesas_usbhs host";
#define usbhsh_usbv_to_udev(d) dev_get_drvdata(&(d)->dev) #define usbhsh_usbv_to_udev(d) dev_get_drvdata(&(d)->dev)
#define usbhsh_udev_to_usbv(h) ((h)->usbv) #define usbhsh_udev_to_usbv(h) ((h)->usbv)
#define usbhsh_udev_is_used(h) usbhsh_udev_to_usbv(h)
#define usbhsh_pipe_info(p) ((p)->mod_private) #define usbhsh_pipe_info(p) ((p)->mod_private)
...@@ -231,27 +232,34 @@ static struct usbhsh_device *usbhsh_device_alloc(struct usbhsh_hpriv *hpriv, ...@@ -231,27 +232,34 @@ static struct usbhsh_device *usbhsh_device_alloc(struct usbhsh_hpriv *hpriv,
int i; int i;
/* /*
* device 0 * find device
*/ */
if (0 == usb_pipedevice(urb->pipe)) { if (0 == usb_pipedevice(urb->pipe)) {
/*
* device0 is special case
*/
udev = usbhsh_device0(hpriv); udev = usbhsh_device0(hpriv);
goto usbhsh_device_find; if (usbhsh_udev_is_used(udev))
} udev = NULL;
} else {
struct usbhsh_device *pos;
/* /*
* find unused device * find unused device
*/ */
usbhsh_for_each_udev(udev, hpriv, i) { usbhsh_for_each_udev(pos, hpriv, i) {
if (usbhsh_udev_to_usbv(udev)) if (usbhsh_udev_is_used(pos))
continue; continue;
goto usbhsh_device_find; udev = pos;
break;
}
} }
dev_err(dev, "no free usbhsh_device\n"); if (!udev) {
dev_err(dev, "no free usbhsh_device\n");
return NULL; return NULL;
}
usbhsh_device_find:
if (usbhsh_device_has_endpoint(udev)) if (usbhsh_device_has_endpoint(udev))
dev_warn(dev, "udev have old endpoint\n"); dev_warn(dev, "udev have old endpoint\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment