mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-11 07:34:31 +00:00
usb: mv_udc: Clean up the EP initialization
Move the constant values that are programmed into mv_ep.ep into separate static const structure so they can be memcpy()'d when the initialization happens. Moveover, we only every init NUM_ENDPOINTS, not 2 * NUM_ENDPOINTS, so fix this bug as well. Signed-off-by: Marek Vasut <marex@denx.de> Cc: Fabio Estevam <fabio.estevam@freescale.com> Cc: Lei Wen <leiwen@marvell.com> Cc: Otavio Salvador <otavio@ossystems.com.br> Cc: Stefano Babic <sbabic@denx.de>
This commit is contained in:
parent
532d846f89
commit
2ea4b44832
2 changed files with 27 additions and 13 deletions
|
@ -83,6 +83,20 @@ static struct usb_ep_ops mv_ep_ops = {
|
|||
.free_request = mv_ep_free_request,
|
||||
};
|
||||
|
||||
/* Init values for USB endpoints. */
|
||||
static const struct usb_ep mv_ep_init[2] = {
|
||||
[0] = { /* EP 0 */
|
||||
.maxpacket = 64,
|
||||
.name = "ep0",
|
||||
.ops = &mv_ep_ops,
|
||||
},
|
||||
[1] = { /* EP 1..n */
|
||||
.maxpacket = 512,
|
||||
.name = "ep-",
|
||||
.ops = &mv_ep_ops,
|
||||
},
|
||||
};
|
||||
|
||||
static struct mv_drv controller = {
|
||||
.gadget = {
|
||||
.name = "mv_udc",
|
||||
|
@ -435,21 +449,21 @@ static int mvudc_probe(void)
|
|||
}
|
||||
|
||||
INIT_LIST_HEAD(&controller.gadget.ep_list);
|
||||
controller.gadget.ep0 = &controller.ep[0].ep;
|
||||
controller.ep[0].ep.maxpacket = 64;
|
||||
controller.ep[0].ep.name = "ep0";
|
||||
|
||||
/* Init EP 0 */
|
||||
memcpy(&controller.ep[0].ep, &mv_ep_init[0], sizeof(*mv_ep_init));
|
||||
controller.ep[0].desc = &ep0_in_desc;
|
||||
controller.gadget.ep0 = &controller.ep[0].ep;
|
||||
INIT_LIST_HEAD(&controller.gadget.ep0->ep_list);
|
||||
for (i = 0; i < 2 * NUM_ENDPOINTS; i++) {
|
||||
if (i != 0) {
|
||||
controller.ep[i].ep.maxpacket = 512;
|
||||
controller.ep[i].ep.name = "ep-";
|
||||
list_add_tail(&controller.ep[i].ep.ep_list,
|
||||
&controller.gadget.ep_list);
|
||||
controller.ep[i].desc = NULL;
|
||||
}
|
||||
controller.ep[i].ep.ops = &mv_ep_ops;
|
||||
|
||||
/* Init EP 1..n */
|
||||
for (i = 1; i < NUM_ENDPOINTS; i++) {
|
||||
memcpy(&controller.ep[i].ep, &mv_ep_init[1],
|
||||
sizeof(*mv_ep_init));
|
||||
list_add_tail(&controller.ep[i].ep.ep_list,
|
||||
&controller.gadget.ep_list);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -74,7 +74,7 @@ struct mv_drv {
|
|||
struct usb_gadget gadget;
|
||||
struct usb_gadget_driver *driver;
|
||||
struct mv_udc *udc;
|
||||
struct mv_ep ep[2 * NUM_ENDPOINTS];
|
||||
struct mv_ep ep[NUM_ENDPOINTS];
|
||||
};
|
||||
|
||||
struct ept_queue_head {
|
||||
|
|
Loading…
Reference in a new issue