Re: [PATCH V2] PCI: tegra: Enable Relaxed Ordering only for Tegra20 & Tegra30

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

 



On Thu, Jul 04, 2019 at 08:34:01PM +0530, Vidya Sagar wrote:
> On 7/4/2019 6:25 PM, Lorenzo Pieralisi wrote:
> > On Wed, Jul 03, 2019 at 10:20:23PM +0530, Vidya Sagar wrote:
> > > On 7/3/2019 10:09 PM, Lorenzo Pieralisi wrote:
> > > > On Mon, Jul 01, 2019 at 04:39:42PM +0530, Vidya Sagar wrote:
> > > > > Currently Relaxed Ordering bit in the configuration space is enabled for
> > > > > all devices, but, as per the Technical Reference Manual of Tegra20 which is
> > > > 
> > > > What devices ?
> > > All PCIe devices, because, current quirk uses PCI_ANY_ID for both Vendor-ID
> > > and Device-ID and that makes it applicable for all PCIe devices.
> > 
> > And this is true regardless of whether the PCI tegra controller is
> > *the* actual controller in the system, aka as long as the Tegra driver
> > is compiled in, relaxed ordering is forced for any PCIe device.
> > 
> > This is gross and I do believe the fix should be propagated back to
> > the commit that introduced it, it should have never been implemented
> > like this.
> Agree.
> This was there in the very first commit of this driver i.e.
> 77ffc1465cec32489889d6bc9c288b7b0d2ce9fb which added this driver for
> Tegra20 as arch/arm/mach-tegra/pcie.c Since there was no device-tree
> concept back then, could it be the case that this quirk comes into
> picture *only* if kernel is built for Tegra20 and not otherwise? Even
> then, I agree that using PCI_ANY_ID is quite wild way of applying a
> quirk.

This is an unadulterated mess. AFAICS, this quirk forces Relaxed
Ordering on any PCIe device on *any* ARM64 platform - DT and ACPI alike.

I will add a Fixes: tag and you must ensure this is backported,
I am not happy at all about this.

Lorenzo

> > > > > available at https://developer.nvidia.com/embedded/downloads#?search=tegra%202
> > > > > in Sec 34.1, it is mentioned that Relexed Ordering bit needs to be enabled in
> > > > > its root ports to avoid deadlock in hardware. The same is applicable for
> > > > > Tegra30 as well though it is not explicitly mentioned in Tegra30 TRM document,
> > > > > but the same should not be extended to root ports of other Tegra SoCs or
> > > > > other hosts.
> > > > 
> > > > Should not or must not ? What does this sentence mean ?
> > > I think it is 'must not' here. Since the hardware deadlock issue is not present
> > > in any other root ports other than Tegra20 and Tegra30, this quirk must not be
> > > extended to any other root ports.
> > > 
> > > > 
> > > > Can we try to be more precise please ?
> > > > 
> > > > As I said before the commit log must be clear to anyone reading it
> > > > even if he has no background information.
> > > Would the following work?
> > > 
> > > Currently Relaxed Ordering bit in the configuration space is enabled
> > > for all PCIe devices as the quirk uses PCI_ANY_ID for both Vendor-ID
> > > and Device-ID, but, as per the Technical Reference Manual of Tegra20
> > > which is available at
> > > https://developer.nvidia.com/embedded/downloads#?search=tegra%202 in
> > > Sec 34.1, it is mentioned that Relexed Ordering bit needs to be
> > > enabled in its root ports to avoid deadlock in hardware. The same is
> > > applicable for Tegra30 as well though it is not explicitly mentioned
> > > in Tegra30 TRM document, but the same must not be extended to root
> > > ports of other Tegra SoCs or other hosts as the same issue doesn't
> > > exist there.
> > 
> > More or less, I will tweak it myself. Regardless the way it is
> > handled at the moment is really really not acceptable, one more
> > reason why this patch should be backported IMO.
> > 
> > Lorenzo
> > 
> > > > Lorenzo
> > > > 
> > > > > Signed-off-by: Vidya Sagar <vidyas@xxxxxxxxxx>
> > > > > ---
> > > > > V2:
> > > > > * Modified commit message to include reference to Tegra20 TRM document.
> > > > > 
> > > > >    drivers/pci/controller/pci-tegra.c | 7 +++++--
> > > > >    1 file changed, 5 insertions(+), 2 deletions(-)
> > > > > 
> > > > > diff --git a/drivers/pci/controller/pci-tegra.c b/drivers/pci/controller/pci-tegra.c
> > > > > index 9cc03a2549c0..241760aa15bd 100644
> > > > > --- a/drivers/pci/controller/pci-tegra.c
> > > > > +++ b/drivers/pci/controller/pci-tegra.c
> > > > > @@ -787,12 +787,15 @@ DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_NVIDIA, 0x0bf1, tegra_pcie_fixup_class);
> > > > >    DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_NVIDIA, 0x0e1c, tegra_pcie_fixup_class);
> > > > >    DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_NVIDIA, 0x0e1d, tegra_pcie_fixup_class);
> > > > > -/* Tegra PCIE requires relaxed ordering */
> > > > > +/* Tegra20 and Tegra30 PCIE requires relaxed ordering */
> > > > >    static void tegra_pcie_relax_enable(struct pci_dev *dev)
> > > > >    {
> > > > >    	pcie_capability_set_word(dev, PCI_EXP_DEVCTL, PCI_EXP_DEVCTL_RELAX_EN);
> > > > >    }
> > > > > -DECLARE_PCI_FIXUP_FINAL(PCI_ANY_ID, PCI_ANY_ID, tegra_pcie_relax_enable);
> > > > > +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_NVIDIA, 0x0bf0, tegra_pcie_relax_enable);
> > > > > +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_NVIDIA, 0x0bf1, tegra_pcie_relax_enable);
> > > > > +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_NVIDIA, 0x0e1c, tegra_pcie_relax_enable);
> > > > > +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_NVIDIA, 0x0e1d, tegra_pcie_relax_enable);
> > > > >    static int tegra_pcie_request_resources(struct tegra_pcie *pcie)
> > > > >    {
> > > > > -- 
> > > > > 2.17.1
> > > > > 
> > > 
> 



[Index of Archives]     [DMA Engine]     [Linux Coverity]     [Linux USB]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Greybus]

  Powered by Linux