usb: dwc_otg: support to the latest usb gadget driver.
authorFrank Wang <frank.wang@rock-chips.com>
Thu, 25 Feb 2016 07:07:33 +0000 (15:07 +0800)
committerGerrit Code Review <gerrit@rock-chips.com>
Mon, 29 Feb 2016 12:43:35 +0000 (20:43 +0800)
For gadget driver, usb_ep_caps is a new structrue in usb_ep, and its
attribute will be check in usb_ep_autoconfig method, so we need to do
some initialization work at ep creating.

Meanwhile, the process of android gadget driver have been changed,
correspondingly, udc_start and udc_stop are invoked differently from
before, so dwc_otg_gadget_stop method need to refactor and ajust
the new process.

Change-Id: Id1e20d4c265e0d382b0f36f6e729681f9c94c947
Signed-off-by: Frank Wang <frank.wang@rock-chips.com>
drivers/usb/dwc_otg_310/dwc_otg_pcd_linux.c

index a6f2ea7b849a1386318f0249036566dd00d54e54..203d3c93fa1f06e55bba044bb74fd06aaef51969 100644 (file)
@@ -777,6 +777,32 @@ static int dwc_otg_gadget_start(struct usb_gadget *g,
 
 static int dwc_otg_gadget_stop(struct usb_gadget *g)
 {
+       struct gadget_wrapper *d;
+       struct usb_ep *ep;
+       s8 dev_endpoints;
+       int i;
+
+       if (!g)
+               return -ENODEV;
+
+       d = container_of(g, struct gadget_wrapper, gadget);
+
+       /* all endpoints should be shutdown */
+       dev_endpoints = d->pcd->core_if->dev_if->num_in_eps;
+       for (i = 0; i < dev_endpoints; i++) {
+               ep = &d->in_ep[i];
+               ep_disable(ep);
+       }
+
+       dev_endpoints = d->pcd->core_if->dev_if->num_out_eps;
+       for (i = 0; i < dev_endpoints; i++) {
+               ep = &d->out_ep[i];
+               ep_disable(ep);
+       }
+
+       gadget_wrapper->driver = NULL;
+       gadget_wrapper->gadget.dev.driver = NULL;
+
        return 0;
 }
 
@@ -1139,6 +1165,7 @@ void gadget_add_eps(struct gadget_wrapper *d)
        ep = &d->ep0;
 
        /* Init the usb_ep structure. */
+       ep->caps.type_control = true;
        ep->name = names[0];
        ep->ops = (struct usb_ep_ops *)&dwc_otg_pcd_ep_ops;
 
@@ -1146,7 +1173,7 @@ void gadget_add_eps(struct gadget_wrapper *d)
         * @todo NGS: What should the max packet size be set to
         * here?  Before EP type is set?
         */
-       ep->maxpacket = MAX_PACKET_SIZE;
+       usb_ep_set_maxpacket_limit(ep, MAX_EP0_SIZE);
        dwc_otg_pcd_ep_enable(d->pcd, NULL, ep);
 
        list_add_tail(&ep->ep_list, &d->gadget.ep_list);
@@ -1160,6 +1187,10 @@ void gadget_add_eps(struct gadget_wrapper *d)
                ep = &d->in_ep[i];
 
                /* Init the usb_ep structure. */
+               ep->caps.dir_in = true;
+               ep->caps.type_iso = true;
+               ep->caps.type_bulk = true;
+               ep->caps.type_int = true;
                ep->name = names[d->pcd->in_ep[i].dwc_ep.num];
                ep->ops = (struct usb_ep_ops *)&dwc_otg_pcd_ep_ops;
 
@@ -1167,7 +1198,7 @@ void gadget_add_eps(struct gadget_wrapper *d)
                 * @todo NGS: What should the max packet size be set to
                 * here?  Before EP type is set?
                 */
-               ep->maxpacket = MAX_PACKET_SIZE;
+               usb_ep_set_maxpacket_limit(ep, MAX_PACKET_SIZE);
                list_add_tail(&ep->ep_list, &d->gadget.ep_list);
        }
 
@@ -1177,6 +1208,10 @@ void gadget_add_eps(struct gadget_wrapper *d)
                ep = &d->out_ep[i];
 
                /* Init the usb_ep structure. */
+               ep->caps.dir_out = true;
+               ep->caps.type_iso = true;
+               ep->caps.type_bulk = true;
+               ep->caps.type_int = true;
                ep->name = names[15 + d->pcd->out_ep[i].dwc_ep.num];
                ep->ops = (struct usb_ep_ops *)&dwc_otg_pcd_ep_ops;
 
@@ -1184,8 +1219,7 @@ void gadget_add_eps(struct gadget_wrapper *d)
                 * @todo NGS: What should the max packet size be set to
                 * here?  Before EP type is set?
                 */
-               ep->maxpacket = MAX_PACKET_SIZE;
-
+               usb_ep_set_maxpacket_limit(ep, MAX_PACKET_SIZE);
                list_add_tail(&ep->ep_list, &d->gadget.ep_list);
        }