Re: [PATCH] PCI/ASPM: Fix a NULL pointer crash on sparc64

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Aug 20, 2015 at 01:58:32PM -0700, David Miller wrote:
> From: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
> Date: Thu, 20 Aug 2015 15:21:35 -0500
> 
> > On Thu, Aug 20, 2015 at 11:40:42AM -0700, David Miller wrote:
> >> From: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
> >> Date: Thu, 20 Aug 2015 11:23:43 -0700
> >> 
> >> > On Thu, Aug 20, 2015 at 10:47 AM, David Miller <davem@xxxxxxxxxxxxx> wrote:
> >> >> From: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
> >> >> Date: Thu, 20 Aug 2015 00:48:00 -0500
> >> >>
> >> >>> [+cc Dave, Eric, Ben, sparclinux]
> >> >>
> >> >> I think the comment is terrible.
> >> > 
> >> > I'll update the comment if you suggest some text.  Do you object
> >> > mainly to the mention of the specific systems?
> >> 
> >> "PCI root complex can not be assumed to be instantiated in the PCI bus
> >>  hierarchy."
> > 
> > AIUI, the root complex itself (as distinct from root ports) doesn't
> > normally appear in the PCI hierarchy, so I reworded it as follows.  I hope
> > this helps address your objection, but if not, I can try again.
> 
> This is fine, but it was the comment we were talking about adjusting not
> the commit message :-)

Oh, sorry!  I totally misread that.  Here's another try.

commit 27ff9f3e0ab34a75a3420bffd3eb5316de2e4d92
Author: Yijing Wang <wangyijing@xxxxxxxxxx>
Date:   Mon Aug 17 18:47:58 2015 +0800

    PCI: Tolerate hierarchies with no Root Port
    
    We should not assume any particular hardware topology.  Commit d0751b98dfa3
    ("PCI: Add dev->has_secondary_link to track downstream PCIe links") relied
    on the assumption that every PCIe hierarchy is rooted at a Root Port.  But
    we can't rely on any assumption about what hardware we will find; we just
    have to deal with the world as it is.
    
    On some platforms, PCIe devices (endpoints, switch upstream ports, etc.)
    appear directly on the root bus, and there is no Root Port in the PCI bus
    hierarchy.  For example, Meelis observed these top-level devices on a
    Sparc V245:
    
      0000:02:00.0 PCI bridge to [bus 03-0d]    Switch Upstream Port
      0001:02:00.0 PCI bridge to [bus 03]       PCIe to PCI/PCI-X Bridge
    
    These devices *look* like they have links going upstream, but there really
    are no upstream devices.
    
    In set_pcie_port_type(), we used the parent device to figure out which side
    of a switch port has a link, so if the parent device did not exist, we
    dereferenced a NULL parent pointer.
    
    Check whether the parent device exists before dereferencing it.
    
    Meelis observed this oops on Sparc V245 and T2000.  Ben Herrenschmidt says
    this is also possible on IBM PowerVM guests on PowerPC.
    
    [bhelgaas: changelog, comment]
    Link: http://lkml.kernel.org/r/alpine.LRH.2.20.1508122118210.18637@xxxxxxxxxx
    Reported-by: Meelis Roos <mroos@xxxxxxxx>
    Tested-by: Meelis Roos <mroos@xxxxxxxx>
    Signed-off-by: Yijing Wang <wangyijing@xxxxxxxxxx>
    Signed-off-by: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>

diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index cefd636..b978bbf 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -997,7 +997,12 @@ void set_pcie_port_type(struct pci_dev *pdev)
 	else if (type == PCI_EXP_TYPE_UPSTREAM ||
 		 type == PCI_EXP_TYPE_DOWNSTREAM) {
 		parent = pci_upstream_bridge(pdev);
-		if (!parent->has_secondary_link)
+
+		/*
+		 * Usually there's a parent device (Root Port or Switch
+		 * Downstream Port), but we can't assume one exists.
+		 */
+		if (parent && !parent->has_secondary_link)
 			pdev->has_secondary_link = 1;
 	}
 }
--
To unsubscribe from this list: send the line "unsubscribe sparclinux" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Kernel Development]     [DCCP]     [Linux ARM Development]     [Linux]     [Photo]     [Yosemite Help]     [Linux ARM Kernel]     [Linux SCSI]     [Linux x86_64]     [Linux Hams]

  Powered by Linux