forked from luck/tmp_suning_uos_patched
pci-v4.10-fixes-2
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJYk1mIAAoJEFmIoMA60/r8ewIQAKNyM38b/3brvxqQnTD5VvKO e1rlHuzgkTVa7RvyOM5WUdmZ9S1gQN3n6934/7pnALHitXcviLLaFEAzW43PyE7y nzBWboPaw76RRuRccNS4xtwcdQJFRN3t3GRE5cNRbXb3yxpfPumQRR9l+IF9vsdp 2GLZw4NjU5WIUAQOWd65Krnkhv4GyZNdB87e478sA6A5ht8W47O/KGUdtcy8LjBm L0CK/u1dyPAHHFZ23TlmgVhnm65VK2hL/UGVBaYvlQ5ZCeB4hu1SAq3yQYYv9TpV csmzuIzLC9H7rMjBRAMCOtSpNwVfRt3FLV8gexZ+LpwwTYIy9GhovFOdVQR48R0L +UAegIv2+W8KsaVpuCBjpuJZPRaT30s/ophCjNKZriFVBBHEoqVfXI1FLbLbMM3Q AcN+9RCEHVVLA4BAKN7Yq/AZ/qzLM+Q1DYFja38bhKbHHEIFqRyaieJ0NT/EPPgI TSZ/n6Jk+OqBhmSYHZRMNt/49iZIeSaODyYw+KdVHB7Go5MXvf4ddQS9G11rxZ0W zS9tdQEf+O3KISNAx46++gAWX457yepEbTtg/TgdGXtdSCBrjVA3KgHwDimYTmps 242//6rWQrz6FDLrGOtTG0qDhRef8QkDHx45+Cutsm45cctN+COCDmODOanX5zLs Yf2JYP0iQJ05mLfKGtle =1PX1 -----END PGP SIGNATURE----- Merge tag 'pci-v4.10-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci Pull PCI fix from Bjorn Helgaas: "Configure ASPM on the link from a PCI-to-PCIe bridge (avoids a NULL pointer dereference on topologies including these bridges)" * tag 'pci-v4.10-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: PCI/ASPM: Handle PCI-to-PCIe bridges as roots of PCIe hierarchies
This commit is contained in:
commit
f2557779e1
@ -532,25 +532,32 @@ static struct pcie_link_state *alloc_pcie_link_state(struct pci_dev *pdev)
|
|||||||
link = kzalloc(sizeof(*link), GFP_KERNEL);
|
link = kzalloc(sizeof(*link), GFP_KERNEL);
|
||||||
if (!link)
|
if (!link)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
INIT_LIST_HEAD(&link->sibling);
|
INIT_LIST_HEAD(&link->sibling);
|
||||||
INIT_LIST_HEAD(&link->children);
|
INIT_LIST_HEAD(&link->children);
|
||||||
INIT_LIST_HEAD(&link->link);
|
INIT_LIST_HEAD(&link->link);
|
||||||
link->pdev = pdev;
|
link->pdev = pdev;
|
||||||
if (pci_pcie_type(pdev) != PCI_EXP_TYPE_ROOT_PORT) {
|
|
||||||
|
/*
|
||||||
|
* Root Ports and PCI/PCI-X to PCIe Bridges are roots of PCIe
|
||||||
|
* hierarchies.
|
||||||
|
*/
|
||||||
|
if (pci_pcie_type(pdev) == PCI_EXP_TYPE_ROOT_PORT ||
|
||||||
|
pci_pcie_type(pdev) == PCI_EXP_TYPE_PCIE_BRIDGE) {
|
||||||
|
link->root = link;
|
||||||
|
} else {
|
||||||
struct pcie_link_state *parent;
|
struct pcie_link_state *parent;
|
||||||
|
|
||||||
parent = pdev->bus->parent->self->link_state;
|
parent = pdev->bus->parent->self->link_state;
|
||||||
if (!parent) {
|
if (!parent) {
|
||||||
kfree(link);
|
kfree(link);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
link->parent = parent;
|
link->parent = parent;
|
||||||
|
link->root = link->parent->root;
|
||||||
list_add(&link->link, &parent->children);
|
list_add(&link->link, &parent->children);
|
||||||
}
|
}
|
||||||
/* Setup a pointer to the root port link */
|
|
||||||
if (!link->parent)
|
|
||||||
link->root = link;
|
|
||||||
else
|
|
||||||
link->root = link->parent->root;
|
|
||||||
|
|
||||||
list_add(&link->sibling, &link_list);
|
list_add(&link->sibling, &link_list);
|
||||||
pdev->link_state = link;
|
pdev->link_state = link;
|
||||||
|
Loading…
Reference in New Issue
Block a user