Commit f4426dac authored by Oliver Neukum's avatar Oliver Neukum Committed by Kamal Mostafa

xhci: refuse loading if nousb is used

commit 1eaf35e4 upstream.

The module should fail to load.
Signed-off-by: default avatarOliver Neukum <oneukum@suse.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
[ gregkh: xhci: fix placement of call to usb_disabled()
    In the backport of 1eaf35e4, the call to
    usb_disabled() was too late, after we had already done some allocation.
    Move that call to the top of the function instead, making the logic
    match what is intended and is in the original patch. ]
Reported-by: default avatarLuis Henriques <luis.henriques@canonical.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
parent 621a626e
...@@ -4857,6 +4857,9 @@ static int __init xhci_hcd_init(void) ...@@ -4857,6 +4857,9 @@ static int __init xhci_hcd_init(void)
{ {
int retval; int retval;
if (usb_disabled())
return -ENODEV;
retval = xhci_register_pci(); retval = xhci_register_pci();
if (retval < 0) { if (retval < 0) {
pr_debug("Problem registering PCI driver.\n"); pr_debug("Problem registering PCI driver.\n");
...@@ -4884,6 +4887,7 @@ static int __init xhci_hcd_init(void) ...@@ -4884,6 +4887,7 @@ static int __init xhci_hcd_init(void)
BUILD_BUG_ON(sizeof(struct xhci_intr_reg) != 8*32/8); BUILD_BUG_ON(sizeof(struct xhci_intr_reg) != 8*32/8);
/* xhci_run_regs has eight fields and embeds 128 xhci_intr_regs */ /* xhci_run_regs has eight fields and embeds 128 xhci_intr_regs */
BUILD_BUG_ON(sizeof(struct xhci_run_regs) != (8+8*128)*32/8); BUILD_BUG_ON(sizeof(struct xhci_run_regs) != (8+8*128)*32/8);
return 0; return 0;
unreg_pci: unreg_pci:
xhci_unregister_pci(); xhci_unregister_pci();
......
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