[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20160311215819.GB16257@localhost>
Date: Fri, 11 Mar 2016 15:58:19 -0600
From: Bjorn Helgaas <helgaas@...nel.org>
To: Bharat Kumar Gogada <bharat.kumar.gogada@...inx.com>
Cc: robh+dt@...nel.org, pawel.moll@....com, mark.rutland@....com,
ijc+devicetree@...lion.org.uk, galak@...eaurora.org,
michals@...inx.com, sorenb@...inx.com, bhelgaas@...gle.com,
arnd@...db.de, tinamdar@....com, treding@...dia.com,
rjui@...adcom.com, Minghuan.Lian@...escale.com,
m-karicheri2@...com, hauke@...ke-m.de, marc.zyngier@....com,
dhdang@....com, sbranden@...adcom.com, devicetree@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org, linux-kernel@...r.kernel.org,
linux-pci@...r.kernel.org,
Bharat Kumar Gogada <bharatku@...inx.com>,
Ravi Kiran Gummaluri <rgummal@...inx.com>
Subject: Re: [PATCH v12] [PATCH] PCI: Xilinx-NWL-PCIe: Adding support for
Xilinx NWL PCIe Host Controller
Hi Bharat,
I forgot I still have one question here:
On Sun, Mar 06, 2016 at 10:02:14PM +0530, Bharat Kumar Gogada wrote:
> Adding PCIe Root Port driver for Xilinx PCIe NWL bridge IP.
> +static bool nwl_pcie_valid_device(struct pci_bus *bus, unsigned int devfn)
> +{
> + struct nwl_pcie *pcie = bus->sysdata;
> +
> + /* Check link,before accessing downstream ports */
> + if (bus->number != pcie->root_busno) {
> + if (!nwl_pcie_link_up(pcie))
> + return false;
> + }
This seems racy. What if we check, and the link is up, but the link
goes down before we actually complete the config access?
I'm suggesting that this check for the link being up might be
superfluous.
The hardware should do something reasonable with the config access if
it can't send it down the link.
> +
> + /* Only one device down on each root port */
> + if (bus->number == pcie->root_busno && devfn > 0)
> + return false;
> +
> + return true;
> +}
Powered by blists - more mailing lists