mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-09 20:32:04 +09:00
usb: gadget: function: f_fs: pass companion descriptor along
commit 2bfa0719ac upstream.
If we're dealing with SuperSpeed endpoints, we need
to make sure to pass along the companion descriptor
and initialize fields needed by the Gadget
API. Eventually, f_fs.c should be converted to use
config_ep_by_speed() like all other functions,
though.
Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
10af248565
commit
4a1a3bb70f
@@ -1643,11 +1643,14 @@ static int ffs_func_eps_enable(struct ffs_function *func)
|
|||||||
spin_lock_irqsave(&func->ffs->eps_lock, flags);
|
spin_lock_irqsave(&func->ffs->eps_lock, flags);
|
||||||
do {
|
do {
|
||||||
struct usb_endpoint_descriptor *ds;
|
struct usb_endpoint_descriptor *ds;
|
||||||
|
struct usb_ss_ep_comp_descriptor *comp_desc = NULL;
|
||||||
|
int needs_comp_desc = false;
|
||||||
int desc_idx;
|
int desc_idx;
|
||||||
|
|
||||||
if (ffs->gadget->speed == USB_SPEED_SUPER)
|
if (ffs->gadget->speed == USB_SPEED_SUPER) {
|
||||||
desc_idx = 2;
|
desc_idx = 2;
|
||||||
else if (ffs->gadget->speed == USB_SPEED_HIGH)
|
needs_comp_desc = true;
|
||||||
|
} else if (ffs->gadget->speed == USB_SPEED_HIGH)
|
||||||
desc_idx = 1;
|
desc_idx = 1;
|
||||||
else
|
else
|
||||||
desc_idx = 0;
|
desc_idx = 0;
|
||||||
@@ -1664,6 +1667,14 @@ static int ffs_func_eps_enable(struct ffs_function *func)
|
|||||||
|
|
||||||
ep->ep->driver_data = ep;
|
ep->ep->driver_data = ep;
|
||||||
ep->ep->desc = ds;
|
ep->ep->desc = ds;
|
||||||
|
|
||||||
|
comp_desc = (struct usb_ss_ep_comp_descriptor *)(ds +
|
||||||
|
USB_DT_ENDPOINT_SIZE);
|
||||||
|
ep->ep->maxburst = comp_desc->bMaxBurst + 1;
|
||||||
|
|
||||||
|
if (needs_comp_desc)
|
||||||
|
ep->ep->comp_desc = comp_desc;
|
||||||
|
|
||||||
ret = usb_ep_enable(ep->ep);
|
ret = usb_ep_enable(ep->ep);
|
||||||
if (likely(!ret)) {
|
if (likely(!ret)) {
|
||||||
epfile->ep = ep;
|
epfile->ep = ep;
|
||||||
|
|||||||
Reference in New Issue
Block a user