Commit b7d9c861 authored by Larry Finger's avatar Larry Finger Committed by Greg Kroah-Hartman

rtlwifi: Fix kernel oops on ARM SOC

commit b6b67df3 upstream.

This driver uses information from the self member of the pci_bus struct to
get information regarding the bridge to which the PCIe device is attached.
Unfortunately, this member is not established on all architectures, which
leads to a kernel oops.

Skipping the entire block that uses the self member to determine the bridge
vendor will only affect RTL8192DE devices as that driver sets the ASPM support
flag differently when the bridge vendor is Intel. If the self member is
available, there is no functional change.

This patch fixes Bugzilla No. 40212.
Reported-by: default avatarHubert Liao <liao.hubertt@gmail.com>
Signed-off-by: default avatarLarry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 07e1a60a
...@@ -1709,15 +1709,17 @@ static bool _rtl_pci_find_adapter(struct pci_dev *pdev, ...@@ -1709,15 +1709,17 @@ static bool _rtl_pci_find_adapter(struct pci_dev *pdev,
pcipriv->ndis_adapter.devnumber = PCI_SLOT(pdev->devfn); pcipriv->ndis_adapter.devnumber = PCI_SLOT(pdev->devfn);
pcipriv->ndis_adapter.funcnumber = PCI_FUNC(pdev->devfn); pcipriv->ndis_adapter.funcnumber = PCI_FUNC(pdev->devfn);
/*find bridge info */ if (bridge_pdev) {
pcipriv->ndis_adapter.pcibridge_vendorid = bridge_pdev->vendor; /*find bridge info if available */
for (tmp = 0; tmp < PCI_BRIDGE_VENDOR_MAX; tmp++) { pcipriv->ndis_adapter.pcibridge_vendorid = bridge_pdev->vendor;
if (bridge_pdev->vendor == pcibridge_vendors[tmp]) { for (tmp = 0; tmp < PCI_BRIDGE_VENDOR_MAX; tmp++) {
pcipriv->ndis_adapter.pcibridge_vendor = tmp; if (bridge_pdev->vendor == pcibridge_vendors[tmp]) {
RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG, pcipriv->ndis_adapter.pcibridge_vendor = tmp;
("Pci Bridge Vendor is found index: %d\n", RT_TRACE(rtlpriv, COMP_INIT, DBG_DMESG,
tmp)); ("Pci Bridge Vendor is found index:"
break; " %d\n", tmp));
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