Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 361242
b: refs/heads/master
c: 7597a49
h: refs/heads/master
v: v3
  • Loading branch information
Felipe Balbi committed Mar 4, 2013
1 parent 9949ead commit ffa8110
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 16 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 56aa45adcc5b793369e535a4b7177f1c7314b577
refs/heads/master: 7597a49b1e984bfb9930f832af963de1120d30e4
26 changes: 11 additions & 15 deletions trunk/drivers/usb/gadget/s3c2410_udc.c
Original file line number Diff line number Diff line change
Expand Up @@ -1669,38 +1669,24 @@ static int s3c2410_udc_start(struct usb_gadget *g,
struct usb_gadget_driver *driver)
{
struct s3c2410_udc *udc = to_s3c2410(g)
int retval;

dprintk(DEBUG_NORMAL, "%s() '%s'\n", __func__, driver->driver.name);

/* Hook the driver */
udc->driver = driver;
udc->gadget.dev.driver = &driver->driver;

/* Bind the driver */
retval = device_add(&udc->gadget.dev);
if (retval) {
dev_err(&udc->gadget.dev, "Error in device_add() : %d\n", retval);
goto register_error;
}

/* Enable udc */
s3c2410_udc_enable(udc);

return 0;

register_error:
udc->driver = NULL;
udc->gadget.dev.driver = NULL;
return retval;
}

static int s3c2410_udc_stop(struct usb_gadget *g,
struct usb_gadget_driver *driver)
{
struct s3c2410_udc *udc = to_s3c2410(g);

device_del(&udc->gadget.dev);
udc->driver = NULL;

/* Disable udc */
Expand Down Expand Up @@ -1842,6 +1828,13 @@ static int s3c2410_udc_probe(struct platform_device *pdev)
udc->gadget.dev.parent = &pdev->dev;
udc->gadget.dev.dma_mask = pdev->dev.dma_mask;

/* Bind the driver */
retval = device_add(&udc->gadget.dev);
if (retval) {
dev_err(&udc->gadget.dev, "Error in device_add() : %d\n", retval);
goto err_device_add;
}

the_controller = udc;
platform_set_drvdata(pdev, udc);

Expand Down Expand Up @@ -1930,6 +1923,8 @@ static int s3c2410_udc_probe(struct platform_device *pdev)
err_int:
free_irq(IRQ_USBD, udc);
err_map:
device_unregister(&udc->gadget.dev);
err_device_add:
iounmap(base_addr);
err_mem:
release_mem_region(rsrc_start, rsrc_len);
Expand All @@ -1947,10 +1942,11 @@ static int s3c2410_udc_remove(struct platform_device *pdev)

dev_dbg(&pdev->dev, "%s()\n", __func__);

usb_del_gadget_udc(&udc->gadget);
if (udc->driver)
return -EBUSY;

usb_del_gadget_udc(&udc->gadget);
device_unregister(&udc->gadget.dev);
debugfs_remove(udc->regs_info);

if (udc_info && !udc_info->udc_command &&
Expand Down

0 comments on commit ffa8110

Please sign in to comment.