[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <6e0ef5cc-b692-4d39-bec4-a75c1af3f0aa@arm.com>
Date: Wed, 2 Apr 2025 16:34:08 +0100
From: Robin Murphy <robin.murphy@....com>
To: Naresh Kamboju <naresh.kamboju@...aro.org>,
Linux ARM <linux-arm-kernel@...ts.infradead.org>, iommu@...ts.linux.dev,
open list <linux-kernel@...r.kernel.org>, lkft-triage@...ts.linaro.org,
Linux Regressions <regressions@...ts.linux.dev>
Cc: Lorenzo Pieralisi <lpieralisi@...nel.org>,
Bjorn Helgaas <bhelgaas@...gle.com>, Rob Herring <robh@...nel.org>,
Dan Carpenter <dan.carpenter@...aro.org>, Arnd Bergmann <arnd@...db.de>,
Anders Roxell <anders.roxell@...aro.org>
Subject: Re: arm64: juno-r2: SSD detect failed on mainline and next
On 31/03/2025 5:03 am, Naresh Kamboju wrote:
> Regressions on arm64 Juno-r2 devices detect SSD tests failed on the
> Linux next and Linux mainline.
>
> First seen on the v6.14-7245-g5c2a430e8599
> Good: v6.14
> Bad: v6.14-7422-gacb4f33713b9
Sorry, I can't seem to reproduce this on my end, both today's mainline
and acb4f33713b9 with my config, and even acb4f33713b9 with the linked
LKFT config, all work OK on my Juno r2 (using a SATA SSD and PCIe
networking). The only thing which stands out in your log is that PCI
seems to give up probing and assigning resources beyond the switch
downstream ports (so SATA and ethernet are never discovered), whereas on
mine it does[2]. However that all happens before the first IOMMU
instance probes (which conveniently is the PCIe one), so it's hard to
imagine how that could have an effect anyway...
The only obvious difference is that I'm using EDK2 rather than U-Boot,
so that's done all the PCIe configuration once already, but it doesn't
seem like that's significant - looking back at a random older log[1],
the on-board endpoints were still being picked up right after
reconfiguring the switch, well before the IOMMU comes into the picture.
Thanks,
Robin.
[1] https://lkft.validation.linaro.org/scheduler/job/8143082#L1283
[2]:
[ 1.741362] pci-host-generic 40000000.pcie: host bridge
/pcie@...00000 ranges:
[ 1.748682] pci-host-generic 40000000.pcie: IO
0x005f800000..0x005fffffff -> 0x0000000000
[ 1.757465] pci-host-generic 40000000.pcie: MEM
0x0050000000..0x0057ffffff -> 0x0050000000
[ 1.766224] pci-host-generic 40000000.pcie: MEM
0x4000000000..0x40ffffffff -> 0x4000000000
[ 1.775019] pci-host-generic 40000000.pcie: IB MEM
0x0080000000..0x00ffffffff -> 0x0080000000
[ 1.783781] pci-host-generic 40000000.pcie: IB MEM
0x0800000000..0x09ffffffff -> 0x0800000000
[ 1.792615] pci-host-generic 40000000.pcie: ECAM at [mem
0x40000000-0x4fffffff] for [bus 00-ff]
[ 1.801559] pci-host-generic 40000000.pcie: PCI host bridge to bus
0000:00
[ 1.808485] pci_bus 0000:00: root bus resource [bus 00-ff]
[ 1.814022] pci_bus 0000:00: root bus resource [io 0x0000-0x7fffff]
[ 1.820408] pci_bus 0000:00: root bus resource [mem
0x50000000-0x57ffffff]
[ 1.827314] pci_bus 0000:00: root bus resource [mem
0x4000000000-0x40ffffffff pref]
[ 1.835050] pci 0000:00:00.0: [1556:1100] type 01 class 0x060400 PCIe
Root Port
[ 1.842444] pci 0000:00:00.0: BAR 0 [mem 0x4000000000-0x4000003fff
64bit pref]
[ 1.849717] pci 0000:00:00.0: PCI bridge to [bus 01-08]
[ 1.854990] pci 0000:00:00.0: bridge window [io 0x0000-0x1fff]
[ 1.861125] pci 0000:00:00.0: bridge window [mem 0x50000000-0x501fffff]
[ 1.868099] pci 0000:00:00.0: supports D1 D2
[ 1.872393] pci 0000:00:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[ 1.881014] pci 0000:01:00.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Upstream Port
[ 1.889407] pci 0000:01:00.0: PCI bridge to [bus 02-08]
[ 1.894675] pci 0000:01:00.0: bridge window [io 0x0000-0x1fff]
[ 1.900812] pci 0000:01:00.0: bridge window [mem 0x50000000-0x501fffff]
[ 1.907690] pci 0000:01:00.0: enabling Extended Tags
[ 1.912876] pci 0000:01:00.0: PME# supported from D0 D3hot D3cold
[ 1.924459] pci 0000:02:01.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 1.933037] pci 0000:02:01.0: PCI bridge to [bus 03]
[ 1.938045] pci 0000:02:01.0: bridge window [io 0x1000-0x1fff]
[ 1.944179] pci 0000:02:01.0: bridge window [mem 0x50100000-0x501fffff]
[ 1.951060] pci 0000:02:01.0: enabling Extended Tags
[ 1.956298] pci 0000:02:01.0: PME# supported from D0 D3hot D3cold
[ 1.963053] pci 0000:02:02.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 1.971621] pci 0000:02:02.0: PCI bridge to [bus 04]
[ 1.976698] pci 0000:02:02.0: enabling Extended Tags
[ 1.981924] pci 0000:02:02.0: PME# supported from D0 D3hot D3cold
[ 1.988682] pci 0000:02:03.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 1.997272] pci 0000:02:03.0: PCI bridge to [bus 05]
[ 2.002352] pci 0000:02:03.0: enabling Extended Tags
[ 2.007578] pci 0000:02:03.0: PME# supported from D0 D3hot D3cold
[ 2.014713] pci 0000:02:0c.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 2.023303] pci 0000:02:0c.0: PCI bridge to [bus 06]
[ 2.028396] pci 0000:02:0c.0: enabling Extended Tags
[ 2.033643] pci 0000:02:0c.0: PME# supported from D0 D3hot D3cold
[ 2.040569] pci 0000:02:10.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 2.049131] pci 0000:02:10.0: PCI bridge to [bus 07]
[ 2.054220] pci 0000:02:10.0: enabling Extended Tags
[ 2.059439] pci 0000:02:10.0: PME# supported from D0 D3hot D3cold
[ 2.066798] pci 0000:02:1f.0: [111d:8090] type 01 class 0x060400 PCIe
Switch Downstream Port
[ 2.075368] pci 0000:02:1f.0: PCI bridge to [bus 08]
[ 2.080377] pci 0000:02:1f.0: bridge window [io 0x0000-0x0fff]
[ 2.086507] pci 0000:02:1f.0: bridge window [mem 0x50000000-0x500fffff]
[ 2.093397] pci 0000:02:1f.0: enabling Extended Tags
[ 2.098625] pci 0000:02:1f.0: PME# supported from D0 D3hot D3cold
[ 2.105519] pci 0000:03:00.0: [1095:3132] type 00 class 0x018000 PCIe
Legacy Endpoint
[ 2.113532] pci 0000:03:00.0: BAR 0 [mem 0x50104000-0x5010407f 64bit]
[ 2.120020] pci 0000:03:00.0: BAR 2 [mem 0x50100000-0x50103fff 64bit]
[ 2.126520] pci 0000:03:00.0: BAR 4 [io 0x1000-0x107f]
[ 2.131794] pci 0000:03:00.0: ROM [mem 0xfff80000-0xffffffff pref]
[ 2.138189] pci 0000:03:00.0: supports D1 D2
[ 2.142965] pci 0000:03:00.0: disabling ASPM on pre-1.1 PCIe device.
You can enable it with 'pcie_aspm=force'
[ 2.154011] pci 0000:08:00.0: [11ab:4380] type 00 class 0x020000 PCIe
Legacy Endpoint
[ 2.162015] pci 0000:08:00.0: BAR 0 [mem 0x50000000-0x50003fff 64bit]
[ 2.168492] pci 0000:08:00.0: BAR 2 [io 0x0000-0x00ff]
[ 2.173941] pci 0000:08:00.0: supports D1 D2
[ 2.178260] pci 0000:08:00.0: PME# supported from D0 D1 D2 D3hot D3cold
[ 2.185740] pci 0000:00:00.0: bridge window [mem
0x50000000-0x501fffff]: assigned
[ 2.193266] pci 0000:00:00.0: BAR 0 [mem 0x4000000000-0x4000003fff
64bit pref]: assigned
[ 2.201411] pci 0000:00:00.0: bridge window [io 0x1000-0x2fff]: assigned
[ 2.208235] pci 0000:01:00.0: bridge window [mem
0x50000000-0x501fffff]: assigned
[ 2.215754] pci 0000:01:00.0: bridge window [io 0x1000-0x2fff]: assigned
[ 2.222580] pci 0000:02:01.0: bridge window [mem
0x50000000-0x500fffff]: assigned
[ 2.230120] pci 0000:02:1f.0: bridge window [mem
0x50100000-0x501fffff]: assigned
[ 2.237648] pci 0000:02:01.0: bridge window [io 0x1000-0x1fff]: assigned
[ 2.244470] pci 0000:02:1f.0: bridge window [io 0x2000-0x2fff]: assigned
[ 2.251313] pci 0000:03:00.0: ROM [mem 0x50000000-0x5007ffff pref]:
assigned
[ 2.258399] pci 0000:03:00.0: BAR 2 [mem 0x50080000-0x50083fff
64bit]: assigned
[ 2.265769] pci 0000:03:00.0: BAR 0 [mem 0x50084000-0x5008407f
64bit]: assigned
[ 2.273141] pci 0000:03:00.0: BAR 4 [io 0x1000-0x107f]: assigned
[ 2.279286] pci 0000:02:01.0: PCI bridge to [bus 03]
[ 2.284289] pci 0000:02:01.0: bridge window [io 0x1000-0x1fff]
[ 2.290425] pci 0000:02:01.0: bridge window [mem 0x50000000-0x500fffff]
[ 2.297275] pci 0000:02:02.0: PCI bridge to [bus 04]
[ 2.302302] pci 0000:02:03.0: PCI bridge to [bus 05]
[ 2.307327] pci 0000:02:0c.0: PCI bridge to [bus 06]
[ 2.312353] pci 0000:02:10.0: PCI bridge to [bus 07]
[ 2.317382] pci 0000:08:00.0: BAR 0 [mem 0x50100000-0x50103fff
64bit]: assigned
[ 2.324751] pci 0000:08:00.0: BAR 2 [io 0x2000-0x20ff]: assigned
[ 2.330881] pci 0000:02:1f.0: PCI bridge to [bus 08]
[ 2.335895] pci 0000:02:1f.0: bridge window [io 0x2000-0x2fff]
[ 2.342030] pci 0000:02:1f.0: bridge window [mem 0x50100000-0x501fffff]
[ 2.348874] pci 0000:01:00.0: PCI bridge to [bus 02-08]
[ 2.354129] pci 0000:01:00.0: bridge window [io 0x1000-0x2fff]
[ 2.360270] pci 0000:01:00.0: bridge window [mem 0x50000000-0x501fffff]
[ 2.367113] pci 0000:00:00.0: PCI bridge to [bus 01-08]
[ 2.372366] pci 0000:00:00.0: bridge window [io 0x1000-0x2fff]
[ 2.378494] pci 0000:00:00.0: bridge window [mem 0x50000000-0x501fffff]
[ 2.385325] pci_bus 0000:00: resource 4 [io 0x0000-0x7fffff]
[ 2.391101] pci_bus 0000:00: resource 5 [mem 0x50000000-0x57ffffff]
[ 2.397398] pci_bus 0000:00: resource 6 [mem
0x4000000000-0x40ffffffff pref]
[ 2.404478] pci_bus 0000:01: resource 0 [io 0x1000-0x2fff]
[ 2.410078] pci_bus 0000:01: resource 1 [mem 0x50000000-0x501fffff]
[ 2.416374] pci_bus 0000:02: resource 0 [io 0x1000-0x2fff]
[ 2.421980] pci_bus 0000:02: resource 1 [mem 0x50000000-0x501fffff]
[ 2.428277] pci_bus 0000:03: resource 0 [io 0x1000-0x1fff]
[ 2.433877] pci_bus 0000:03: resource 1 [mem 0x50000000-0x500fffff]
[ 2.440195] pci_bus 0000:08: resource 0 [io 0x2000-0x2fff]
[ 2.445799] pci_bus 0000:08: resource 1 [mem 0x50100000-0x501fffff]
[ 2.519972] Serial: 8250/16550 driver, 4 ports, IRQ sharing enabled
[ 2.532646] msm_serial: driver initialized
[ 2.537422] SuperH (H)SCI(F) driver initialized
[ 2.542220] STM32 USART driver initialized
[ 2.551250] arm-smmu 2b500000.iommu: probing hardware configuration...
[ 2.557832] arm-smmu 2b500000.iommu: SMMUv1 with:
[ 2.562564] arm-smmu 2b500000.iommu: stage 2 translation
[ 2.568006] arm-smmu 2b500000.iommu: coherent table walk
[ 2.573449] arm-smmu 2b500000.iommu: stream matching with 32
register groups
[ 2.580643] arm-smmu 2b500000.iommu: 4 context banks (4 stage-2 only)
[ 2.587205] arm-smmu 2b500000.iommu: Supported page sizes: 0x60211000
[ 2.593778] arm-smmu 2b500000.iommu: Stage-2: 40-bit IPA -> 40-bit PA
[ 2.600471] arm-smmu 2b500000.iommu: preserved 0 boot mappings
[ 2.607710] pci 0000:00:00.0: Adding to iommu group 0
[ 2.613204] pci 0000:01:00.0: Adding to iommu group 0
[ 2.618588] pci 0000:02:01.0: Adding to iommu group 0
[ 2.623975] pci 0000:02:02.0: Adding to iommu group 0
[ 2.629373] pci 0000:02:03.0: Adding to iommu group 0
[ 2.634742] pci 0000:02:0c.0: Adding to iommu group 0
[ 2.640127] pci 0000:02:10.0: Adding to iommu group 0
[ 2.645531] pci 0000:02:1f.0: Adding to iommu group 0
[ 2.650952] pci 0000:03:00.0: Adding to iommu group 0
[ 2.656349] pci 0000:08:00.0: Adding to iommu group 0
>
> * Juno-r2,
> - detect-ssd
> - mkfs.ext4-ssd
>
> Regression Analysis:
> - New regression? yes
> - Reproducibility? Yes
>
> Test regression: arm64 Juno-r2 SSD detect failed
> Reported-by: Linux Kernel Functional Testing <lkft@...aro.org>
>
> Anders bisected this to,
> # first bad commit:
> [bcb81ac6ae3c2ef95b44e7b54c3c9522364a245c]
> iommu: Get DT/ACPI parsing into the proper probe path
>
> ## Test log
> mkfs.ext4 /dev/disk/by-id/ata-SanDisk_SSD_PLUS_240GB_223004A01292
> mke2fs 1.47.2 (1-Jan-2025)
> The file /dev/disk/by-id/ata-SanDisk_SSD_PLUS_240GB_223004A01292
> does not exist and no size was specified.
>
> ## Source
> * Kernel version: 6.14.0
> * Git tree: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
> * Git sha: acb4f33713b9f6cadb6143f211714c343465411c
> * Git describe: v6.14-7422-gacb4f33713b9
> * Project details:
> https://qa-reports.linaro.org/lkft/linux-mainline-master/build/v6.14-7422-gacb4f33713b9/
>
> ## Test
> * Test log: https://lkft.validation.linaro.org/scheduler/job/8188382#L1538
> * Test history:
> https://qa-reports.linaro.org/lkft/linux-mainline-master/build/v6.14/testrun/27742015/suite/ltp-cve/test/cve-2017-2671/history/
> * Test details:
> https://lkft.validation.linaro.org/scheduler/job/8188382/definition
> * Test link: https://storage.tuxsuite.com/public/linaro/lkft/builds/2uwduIsT14Pz3XEoUQQIS6ndlQK/
> * Kernel config:
> https://storage.tuxsuite.com/public/linaro/lkft/builds/2uwduIsT14Pz3XEoUQQIS6ndlQK/config
>
>
> --
> Linaro LKFT
> https://lkft.linaro.org
Powered by blists - more mailing lists