Commit d21daf1e authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Felipe Balbi

usb: isp1760: Fix USB disabled check

The isp1760 driver registration function returns an error if USB is
disabled. This made sense when the driver only supported host
controllers, but now that it supports peripheral controllers host
support isn't mandatory anymore.

Fix this by returning an error only when both the HCD and UDC functions
are disabled, either through the kernel configuration or at runtime.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 1f8d9b9b
...@@ -112,9 +112,15 @@ int isp1760_register(struct resource *mem, int irq, unsigned long irqflags, ...@@ -112,9 +112,15 @@ int isp1760_register(struct resource *mem, int irq, unsigned long irqflags,
struct device *dev, unsigned int devflags) struct device *dev, unsigned int devflags)
{ {
struct isp1760_device *isp; struct isp1760_device *isp;
bool udc_disabled = !(devflags & ISP1760_FLAG_ISP1761);
int ret; int ret;
if (usb_disabled()) /*
* If neither the HCD not the UDC is enabled return an error, as no
* device would be registered.
*/
if ((!IS_ENABLED(CONFIG_USB_ISP1760_HCD) || usb_disabled()) &&
(!IS_ENABLED(CONFIG_USB_ISP1761_UDC) || udc_disabled))
return -ENODEV; return -ENODEV;
/* prevent usb-core allocating DMA pages */ /* prevent usb-core allocating DMA pages */
...@@ -137,12 +143,14 @@ int isp1760_register(struct resource *mem, int irq, unsigned long irqflags, ...@@ -137,12 +143,14 @@ int isp1760_register(struct resource *mem, int irq, unsigned long irqflags,
isp1760_init_core(isp); isp1760_init_core(isp);
if (IS_ENABLED(CONFIG_USB_ISP1760_HCD) && !usb_disabled()) {
ret = isp1760_hcd_register(&isp->hcd, isp->regs, mem, irq, ret = isp1760_hcd_register(&isp->hcd, isp->regs, mem, irq,
irqflags | IRQF_SHARED, dev); irqflags | IRQF_SHARED, dev);
if (ret < 0) if (ret < 0)
return ret; return ret;
}
if (devflags & ISP1760_FLAG_ISP1761) { if (IS_ENABLED(CONFIG_USB_ISP1761_UDC) && !udc_disabled) {
ret = isp1760_udc_register(isp, irq, irqflags | IRQF_SHARED | ret = isp1760_udc_register(isp, irq, irqflags | IRQF_SHARED |
IRQF_DISABLED); IRQF_DISABLED);
if (ret < 0) { if (ret < 0) {
...@@ -160,9 +168,7 @@ void isp1760_unregister(struct device *dev) ...@@ -160,9 +168,7 @@ void isp1760_unregister(struct device *dev)
{ {
struct isp1760_device *isp = dev_get_drvdata(dev); struct isp1760_device *isp = dev_get_drvdata(dev);
if (isp->devflags & ISP1760_FLAG_ISP1761)
isp1760_udc_unregister(isp); isp1760_udc_unregister(isp);
isp1760_hcd_unregister(&isp->hcd); isp1760_hcd_unregister(&isp->hcd);
} }
......
...@@ -2226,6 +2226,9 @@ int isp1760_hcd_register(struct isp1760_hcd *priv, void __iomem *regs, ...@@ -2226,6 +2226,9 @@ int isp1760_hcd_register(struct isp1760_hcd *priv, void __iomem *regs,
void isp1760_hcd_unregister(struct isp1760_hcd *priv) void isp1760_hcd_unregister(struct isp1760_hcd *priv)
{ {
if (!priv->hcd)
return;
usb_remove_hcd(priv->hcd); usb_remove_hcd(priv->hcd);
usb_put_hcd(priv->hcd); usb_put_hcd(priv->hcd);
} }
...@@ -1488,6 +1488,9 @@ void isp1760_udc_unregister(struct isp1760_device *isp) ...@@ -1488,6 +1488,9 @@ void isp1760_udc_unregister(struct isp1760_device *isp)
{ {
struct isp1760_udc *udc = &isp->udc; struct isp1760_udc *udc = &isp->udc;
if (!udc->isp)
return;
usb_del_gadget_udc(&udc->gadget); usb_del_gadget_udc(&udc->gadget);
free_irq(udc->irq, udc); free_irq(udc->irq, udc);
......
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