Commit 4dcf4bab authored by Yoshihiro Shimoda's avatar Yoshihiro Shimoda Committed by Felipe Balbi

usb: gadget: udc: renesas_usb3: fix for no-data control transfer

When bRequestType & USB_DIR_IN is false and req.length is 0 in control
transfer, since it means non-data, this driver should not set the mode
as control write. So, this patch fixes it.

Fixes: 746bfe63 ("usb: gadget: renesas_usb3: add support for Renesas USB3.0 peripheral controller")
Cc: <stable@vger.kernel.org> # v4.5+
Signed-off-by: default avatarYoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@linux.intel.com>
parent 7dbd8f4c
...@@ -1150,6 +1150,7 @@ static void usb3_start_pipe0(struct renesas_usb3_ep *usb3_ep, ...@@ -1150,6 +1150,7 @@ static void usb3_start_pipe0(struct renesas_usb3_ep *usb3_ep,
usb3_set_p0_con_for_ctrl_read_data(usb3); usb3_set_p0_con_for_ctrl_read_data(usb3);
} else { } else {
usb3_clear_bit(usb3, P0_MOD_DIR, USB3_P0_MOD); usb3_clear_bit(usb3, P0_MOD_DIR, USB3_P0_MOD);
if (usb3_req->req.length)
usb3_set_p0_con_for_ctrl_write_data(usb3); usb3_set_p0_con_for_ctrl_write_data(usb3);
} }
......
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