提交 1b68a4ca 编写于 作者: S Sebastian Andrzej Siewior 提交者: Felipe Balbi

usb: gadget: dummy_hcd: fixup error probe path

If USB2 host controller probes fine but USB3 does not then we don't
remove the USB controller properly and lock up the system while the HUB
code will try to enumerate the USB2 controller and access memory which
is no longer available in case the dummy_hcd was compiled as a module.

This is a problem since 448b6eb1 ("USB: Make sure to fetch the BOS desc
for roothubs.) if used in USB3 mode because dummy does not provide this
descriptor and explodes later.

Cc: stable@vger.kernel.org # v3.5
Signed-off-by: NSebastian Andrzej Siewior <sebastian@breakpoint.cc>
Signed-off-by: NFelipe Balbi <balbi@ti.com>
上级 c8e6507b
...@@ -2503,10 +2503,8 @@ static int dummy_hcd_probe(struct platform_device *pdev) ...@@ -2503,10 +2503,8 @@ static int dummy_hcd_probe(struct platform_device *pdev)
hs_hcd->has_tt = 1; hs_hcd->has_tt = 1;
retval = usb_add_hcd(hs_hcd, 0, 0); retval = usb_add_hcd(hs_hcd, 0, 0);
if (retval != 0) { if (retval)
usb_put_hcd(hs_hcd); goto put_usb2_hcd;
return retval;
}
if (mod_data.is_super_speed) { if (mod_data.is_super_speed) {
ss_hcd = usb_create_shared_hcd(&dummy_hcd, &pdev->dev, ss_hcd = usb_create_shared_hcd(&dummy_hcd, &pdev->dev,
...@@ -2525,6 +2523,8 @@ static int dummy_hcd_probe(struct platform_device *pdev) ...@@ -2525,6 +2523,8 @@ static int dummy_hcd_probe(struct platform_device *pdev)
put_usb3_hcd: put_usb3_hcd:
usb_put_hcd(ss_hcd); usb_put_hcd(ss_hcd);
dealloc_usb2_hcd: dealloc_usb2_hcd:
usb_remove_hcd(hs_hcd);
put_usb2_hcd:
usb_put_hcd(hs_hcd); usb_put_hcd(hs_hcd);
the_controller.hs_hcd = the_controller.ss_hcd = NULL; the_controller.hs_hcd = the_controller.ss_hcd = NULL;
return retval; return retval;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册