Commit e3d4621c authored by Chunfeng Yun's avatar Chunfeng Yun Committed by Greg Kroah-Hartman

usb: mtu3: fix interval value for intr and isoc

Use the Interval value from isoc/intr endpoint descriptor, no need
minus one. The original code doesn't cause transfer error for
normal cases, but it may have side effect with respond time of ERDY
or tPingTimeout.
Signed-off-by: default avatarChunfeng Yun <chunfeng.yun@mediatek.com>
Link: https://lore.kernel.org/r/20211218095749.6250-1-chunfeng.yun@mediatek.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b1e08873
...@@ -77,7 +77,7 @@ static int mtu3_ep_enable(struct mtu3_ep *mep) ...@@ -77,7 +77,7 @@ static int mtu3_ep_enable(struct mtu3_ep *mep)
if (usb_endpoint_xfer_int(desc) || if (usb_endpoint_xfer_int(desc) ||
usb_endpoint_xfer_isoc(desc)) { usb_endpoint_xfer_isoc(desc)) {
interval = desc->bInterval; interval = desc->bInterval;
interval = clamp_val(interval, 1, 16) - 1; interval = clamp_val(interval, 1, 16);
if (usb_endpoint_xfer_isoc(desc) && comp_desc) if (usb_endpoint_xfer_isoc(desc) && comp_desc)
mult = comp_desc->bmAttributes; mult = comp_desc->bmAttributes;
} }
...@@ -89,7 +89,7 @@ static int mtu3_ep_enable(struct mtu3_ep *mep) ...@@ -89,7 +89,7 @@ static int mtu3_ep_enable(struct mtu3_ep *mep)
if (usb_endpoint_xfer_isoc(desc) || if (usb_endpoint_xfer_isoc(desc) ||
usb_endpoint_xfer_int(desc)) { usb_endpoint_xfer_int(desc)) {
interval = desc->bInterval; interval = desc->bInterval;
interval = clamp_val(interval, 1, 16) - 1; interval = clamp_val(interval, 1, 16);
mult = usb_endpoint_maxp_mult(desc) - 1; mult = usb_endpoint_maxp_mult(desc) - 1;
} }
break; break;
......
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