[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20140930170101.GW841@e106497-lin.cambridge.arm.com>
Date: Tue, 30 Sep 2014 18:01:01 +0100
From: Liviu Dudau <Liviu.Dudau@....com>
To: Bjorn Helgaas <bhelgaas@...gle.com>
Cc: Ming Lei <tom.leiming@...il.com>,
Tanmay Inamdar <tinamdar@....com>,
Arnd Bergmann <arnd@...db.de>,
Jason Gunthorpe <jgunthorpe@...idianresearch.com>,
"grant.likely@...aro.org" <grant.likely@...aro.org>,
Rob Herring <robh+dt@...nel.org>,
Catalin Marinas <Catalin.Marinas@....com>,
Rob Landley <rob@...dley.net>,
"linux-pci@...r.kernel.org" <linux-pci@...r.kernel.org>,
"devicetree@...r.kernel.org" <devicetree@...r.kernel.org>,
linux-arm-kernel <linux-arm-kernel@...ts.infradead.org>,
"linux-doc@...r.kernel.org" <linux-doc@...r.kernel.org>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
patches <patches@....com>, "jcm@...hat.com" <jcm@...hat.com>
Subject: Re: [PATCH v9 0/4] APM X-Gene PCIe host controller
On Tue, Sep 30, 2014 at 05:53:53PM +0100, Bjorn Helgaas wrote:
> On Mon, Sep 22, 2014 at 09:23:51AM +0800, Ming Lei wrote:
> > Hi Tanmay,
> >
> > On Sat, Sep 20, 2014 at 1:15 AM, Tanmay Inamdar <tinamdar@....com> wrote:
> > > Hi Ming Lei,
> > >
> > > On Thu, Sep 18, 2014 at 8:08 PM, Ming Lei <tom.leiming@...il.com> wrote:
> > >> Hi Tanmay,
> > >>
> > >> On Wed, Sep 17, 2014 at 6:33 AM, Tanmay Inamdar <tinamdar@....com> wrote:
> > >>> This patch adds support for AppliedMicro X-Gene PCIe host controller. The
> > >>> driver is tested on X-Gene platform with different gen1/2/3 PCIe endpoint
> > >>> cards.
> > >>>
> > >>> X-Gene PCIe controller driver has depedency on the pcie arm64 arch support.
> > >>> Liviu Dudau from ARM has sent a patch set for pcie arm64 arch support and
> > >>> support for creating generic pcie bridge from device tree. Liviu's patches
> > >>> are available here
> > >>> https://lkml.org/lkml/2014/9/8/333
> > >>>
> > >>> If someone wishes to test PCIe on X-Gene with this patch set, above mentioned
> > >>> patches from Liviu must be applied before the patches in this patch set. Also
> > >>> please use latest xgene u-boot firmware.
> > >>>
> > >>> changes since V8:
> > >>> 1. Add 'dma-coherent' attribute in device node.
> > >>
> > >>
> > >> I just tested your V9 patches plus Liviu's V10 PCI/ARM64 patches
> > >> against 3.17-rc5 on Mustang, and the following failure is triggered:
> > >>
> > >> [ 1.190131] bnx2x: Broadcom NetXtreme II 5771x/578xx 10/20-Gigabit
> > >> Ethernet Driver bnx2x 1.78.19-0 (2014/02/10)
> > >> [ 1.200249] tg3.c:v3.137 (May 11, 2014)
> > >> [ 1.204087] ------------[ cut here ]------------
> > >> [ 1.208682] WARNING: CPU: 1 PID: 1 at drivers/pci/pci.c:131
> > >> pci_ioremap_bar+0x70/0x78()
> > >> [ 1.216646] Modules linked in:
> > >> [ 1.219696] CPU: 1 PID: 1 Comm: swapper/0 Not tainted 3.17.0-rc5+ #1
> > >> [ 1.226018] Call trace:
> > >> [ 1.228453] [<ffffffc0000884f0>] dump_backtrace+0x0/0x16c
> > >> [ 1.233826] [<ffffffc00008866c>] show_stack+0x10/0x1c
> > >> [ 1.238851] [<ffffffc0006e3210>] dump_stack+0x74/0x94
> > >> [ 1.243878] [<ffffffc0000a934c>] warn_slowpath_common+0x88/0xb0
> > >> [ 1.249767] [<ffffffc0000a9438>] warn_slowpath_null+0x14/0x20
> > >> [ 1.255485] [<ffffffc0003994c4>] pci_ioremap_bar+0x6c/0x78
> > >> [ 1.260942] [<ffffffc0005598cc>] tg3_init_one+0x148/0x16f4
> > >> [ 1.266401] [<ffffffc00039ccf0>] pci_device_probe+0x78/0xd4
> > >> [ 1.271946] [<ffffffc00042785c>] driver_probe_device+0x94/0x390
> > >> [ 1.277834] [<ffffffc000427c44>] __driver_attach+0x98/0xa0
> > >> [ 1.283293] [<ffffffc000425a54>] bus_for_each_dev+0x54/0x98
> > >> [ 1.288835] [<ffffffc00042730c>] driver_attach+0x1c/0x28
> > >> [ 1.294121] [<ffffffc000426f04>] bus_add_driver+0x164/0x240
> > >> [ 1.299663] [<ffffffc000428430>] driver_register+0x64/0x130
> > >> [ 1.305207] [<ffffffc00039c97c>] __pci_register_driver+0x3c/0x48
> > >> [ 1.311181] [<ffffffc000aa8a5c>] tg3_driver_init+0x1c/0x28
> > >> [ 1.316640] [<ffffffc0000814e0>] do_one_initcall+0xc4/0x1b4
> > >> [ 1.322186] [<ffffffc000a74b64>] kernel_init_freeable+0x1b8/0x25c
> > >> [ 1.328246] [<ffffffc0006de318>] kernel_init+0xc/0xd4
> > >> [ 1.333278] ---[ end trace f4dca5ab5b436080 ]---
> > >> [ 1.337871] tg3 0000:01:00.0: Cannot map device registers, aborting
> > >> [ 1.344122] tg3: probe of 0000:01:00.0 failed with error -12
> > >>
> > >>
> > >
> > > Thanks for trying out the patches. Which firmware version are you
> > > using? We may have release new firmware version for PCI to work if not
> > > released yet.
> >
> > U-Boot 2013.04-mustang_sw_1.13.28-beta (Aug 25 2014 - 14:16:10)
> >
> > I will check if there is newer fw available.
> >
> > > Also can you please send out the entire boot log?
> >
> > Please see below link:
> >
> > http://pastebin.com/fLqaDn6t
>
> From Ming's log, using the v9 patches:
>
> PCI host bridge /soc/pcie@...b0000 ranges:
> No bus range found for /soc/pcie@...b0000, using [??? 0xffffffc3eb4292c0-0xffffffc0005e3b8c flags 0x40]
>
> What's going on here? It looks like it's from
> of_pci_get_host_bridge_resources(), but I don't see how this output could
> happen.
Sorry, v9 to v11 had a bug in the print message where the range was passed as a reference. I have since
fixed it in v12. I've noticed this log when preparing for v12 but somehow missed it in the change log?
Best regards,
Liviu
>
> IO 0xe010000000..0xe01000ffff -> 0x00000000
> MEM 0xe180000000..0xe1ffffffff -> 0x80000000
> xgene-pcie 1f2b0000.pcie: (rc) x1 gen-1 link up
> xgene-pcie 1f2b0000.pcie: PCI host bridge to bus 0000:00
> pci_bus 0000:00: root bus resource [bus 00-ff]
> pci_bus 0000:00: root bus resource [io 0x0000-0xffff]
> pci_bus 0000:00: root bus resource [mem 0xe180000000-0xe1ffffffff] (bus address [0x80000000-0xffffffff])
> pci_bus 0000:00: scanning bus
> pci 0000:00:00.0: [19aa:e008] type 01 class 0x060400
> pci 0000:00:00.0: reg 0x10: [mem 0x8000000000-0x807fffffff 64bit pref]
>
> I guess this is the "inbound BAR" that you hid in the v10 patches. Hiding
> it will prevent some of BAR assignment problems below. This is probably
> what caused the tg3 mapping problem Ming initially reported above. We
> tried to reassign the inbound BAR, and it took up the entire space that we
> thought was available for CPU accesses to the PCI bus, leaving none for the
> tg3 device.
>
> Was Ming just unlucky by having an unusual configuration, e.g., with a lot
> of memory or something? He certainly doesn't have a complicated PCIe
> hierarchy. I assume you've tested this and had it work *somewhere*.
>
> pci 0000:00:00.0: supports D1 D2
> pci_bus 0000:00: fixups for bus
> pci 0000:00:00.0: scanning [bus 01-01] behind bridge, pass 0
> pci_bus 0000:01: scanning bus
> pci 0000:01:00.0: [14e4:165a] type 00 class 0x020000
> pci 0000:01:00.0: reg 0x10: [mem 0x00100000-0x0010ffff 64bit]
> pci 0000:01:00.0: PME# supported from D3hot
> pci 0000:01:00.0: PME# disabled
> pci_bus 0000:01: fixups for bus
> pci_bus 0000:01: bus scan returning with max=01
> pci 0000:00:00.0: scanning [bus 01-01] behind bridge, pass 1
> pci_bus 0000:00: bus scan returning with max=01
> pci 0000:00:00.0: BAR 0: assigned [mem 0xe180000000-0xe1ffffffff 64bit pref]
> pci 0000:00:00.0: BAR 8: no space for [mem size 0x00100000]
> pci 0000:00:00.0: BAR 8: failed to assign [mem size 0x00100000]
> pci 0000:01:00.0: BAR 0: no space for [mem size 0x00010000 64bit]
> pci 0000:01:00.0: BAR 0: failed to assign [mem size 0x00010000 64bit]
> pci 0000:00:00.0: PCI bridge to [bus 01]
>
--
====================
| I would like to |
| fix the world, |
| but they're not |
| giving me the |
\ source code! /
---------------
¯\_(ツ)_/¯
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists