thanks both, was a bit busy, but managed to work on it again today. Solved the overlapping memory issues, got the QPIC serial nand controller working, PCIE x2 does come up, disabled PCIE x1 as it's disabled in stock FW too. I'm now stuck at initialising the switches as I'm unable to compile the QCA SSDK: Compile error on QCA SSDK - For Developers - OpenWrt Forum
@robimarko: have you been able to compile it with ipq5018 as a target? Have tried with both Debian and Ubuntu.
any pointers you or anyone else can give?
next: get the switches working (ipq5018 and qca8337 and figure out how they're connected exactly) + ath11k for ipq5018 and ipq6122.
@kirdes: to reply to your Q about whether something's connected to PCIE, in the mx5500 (slightly different version than the mx2000), I believe QCN9024 is connected.
Updated bootlog below:
[ 0.000000] Booting Linux on physical CPU 0x0000000000 [0x51af8014]
[ 0.000000] Linux version 6.1.57 (gemous@SL5-GEMOUS) (aarch64-openwrt-linux-musl-gcc (OpenWrt GCC 12.3.0 r24135-b357564463) 12.3.0, GNU ld (GNU Binutils) 2.40.0) #0 SMP Sat Oct 14 13:51:53 2023
[ 0.000000] Machine model: Linksys MX2000
[ 0.000000] Zone ranges:
[ 0.000000] DMA [mem 0x0000000040000000-0x000000005fffffff]
[ 0.000000] DMA32 empty
[ 0.000000] Normal empty
[ 0.000000] Movable zone start for each node
[ 0.000000] Early memory node ranges
[ 0.000000] node 0: [mem 0x0000000040000000-0x0000000040ffffff]
[ 0.000000] node 0: [mem 0x0000000041000000-0x000000004aafffff]
[ 0.000000] node 0: [mem 0x000000004ab00000-0x000000004adfffff]
[ 0.000000] node 0: [mem 0x000000004ae00000-0x000000004affffff]
[ 0.000000] node 0: [mem 0x000000004b000000-0x00000000503fffff]
[ 0.000000] node 0: [mem 0x0000000050400000-0x000000005fffffff]
[ 0.000000] Initmem setup node 0 [mem 0x0000000040000000-0x000000005fffffff]
[ 0.000000] psci: probing for conduit method from DT.
[ 0.000000] psci: PSCIv1.0 detected in firmware.
[ 0.000000] psci: Using standard PSCI v0.2 function IDs
[ 0.000000] psci: MIGRATE_INFO_TYPE not supported.
[ 0.000000] psci: SMC Calling Convention v1.0
[ 0.000000] psci: OSI mode supported.
[ 0.000000] psci: failed to set PC mode: -1
[ 0.000000] percpu: Embedded 17 pages/cpu s31080 r8192 d30360 u69632
[ 0.000000] pcpu-alloc: s31080 r8192 d30360 u69632 alloc=17*4096
[ 0.000000] pcpu-alloc: [0] 0 [0] 1
[ 0.000000] Detected VIPT I-cache on CPU0
[ 0.000000] CPU features: detected: Spectre-v4
[ 0.000000] alternatives: applying boot alternatives
[ 0.000000] Built 1 zonelists, mobility grouping on. Total pages: 129024
[ 0.000000] Kernel command line: console=ttyMSM0,115200n8 swiotlb=1 coherent_pool=2M root=/dev/ubiblock0_1
[ 0.000000] Dentry cache hash table entries: 65536 (order: 7, 524288 bytes, linear)
[ 0.000000] Inode-cache hash table entries: 32768 (order: 6, 262144 bytes, linear)
[ 0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
[ 0.000000] Memory: 391700K/524288K available (7744K kernel code, 842K rwdata, 2228K rodata, 5760K init, 273K bss, 132588K reserved, 0K cma-reserved)
[ 0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=2, Nodes=1
[ 0.000000] rcu: Hierarchical RCU implementation.
[ 0.000000] rcu: RCU restricting CPUs from NR_CPUS=4 to nr_cpu_ids=2.
[ 0.000000] Tracing variant of Tasks RCU enabled.
[ 0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 10 jiffies.
[ 0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=2
[ 0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
[ 0.000000] Root IRQ handler: gic_handle_irq
[ 0.000000] GICv2m: range[mem 0x0b00a000-0x0b00aff7], SPI[448:479]
[ 0.000000] GICv2m: range[mem 0x0b00b000-0x0b00bff7], SPI[480:511]
[ 0.000000] rcu: srcu_init: Setting srcu_struct sizes based on contention.
[ 0.000000] arch_timer: cp15 and mmio timer(s) running at 24.00MHz (virt/virt).
[ 0.000000] clocksource: arch_sys_counter: mask: 0xffffffffffffff max_cycles: 0x588fe9dc0, max_idle_ns: 440795202592 ns
[ 0.000001] sched_clock: 56 bits at 24MHz, resolution 41ns, wraps every 4398046511097ns
[ 0.000098] Calibrating delay loop (skipped), value calculated using timer frequency.. 48.00 BogoMIPS (lpj=240000)
[ 0.000115] pid_max: default: 32768 minimum: 301
[ 0.000640] Mount-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
[ 0.000664] Mountpoint-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
[ 0.003745] cblist_init_generic: Setting adjustable number of callback queues.
[ 0.003761] cblist_init_generic: Setting shift to 1 and lim to 1.
[ 0.004153] rcu: Hierarchical SRCU implementation.
[ 0.004164] rcu: Max phase no-delay instances is 1000.
[ 0.005177] smp: Bringing up secondary CPUs ...
[ 0.006311] Detected VIPT I-cache on CPU1
[ 0.006503] CPU1: Booted secondary processor 0x0000000001 [0x51af8014]
[ 0.006698] smp: Brought up 1 node, 2 CPUs
[ 0.006719] SMP: Total of 2 processors activated.
[ 0.006727] CPU features: detected: 32-bit EL0 Support
[ 0.006733] CPU features: detected: CRC32 instructions
[ 0.006827] CPU features: emulated: Privileged Access Never (PAN) using TTBR0_EL1 switching
[ 0.006839] CPU: All CPU(s) started at EL1
[ 0.006842] alternatives: applying system-wide alternatives
[ 0.014143] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[ 0.014176] futex hash table entries: 512 (order: 3, 32768 bytes, linear)
[ 0.014445] pinctrl core: initialized pinctrl subsystem
[ 0.016206] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[ 0.017302] DMA: preallocated 2048 KiB GFP_KERNEL pool for atomic allocations
[ 0.017653] DMA: preallocated 2048 KiB GFP_KERNEL|GFP_DMA pool for atomic allocations
[ 0.017992] DMA: preallocated 2048 KiB GFP_KERNEL|GFP_DMA32 pool for atomic allocations
[ 0.018594] thermal_sys: Registered thermal governor 'step_wise'
[ 0.018990] cpuidle: using governor menu
[ 0.019350] ASID allocator initialised with 65536 entries
[ 0.049378] SCSI subsystem initialized
[ 0.049708] usbcore: registered new interface driver usbfs
[ 0.049765] usbcore: registered new interface driver hub
[ 0.049820] usbcore: registered new device driver usb
[ 0.050252] qcom_scm: convention: smc arm 64
[ 0.052379] clocksource: Switched to clocksource arch_sys_counter
[ 0.053988] NET: Registered PF_INET protocol family
[ 0.054208] IP idents hash table entries: 8192 (order: 4, 65536 bytes, linear)
[ 0.055307] tcp_listen_portaddr_hash hash table entries: 256 (order: 0, 4096 bytes, linear)
[ 0.055342] Table-perturb hash table entries: 65536 (order: 6, 262144 bytes, linear)
[ 0.055384] TCP established hash table entries: 4096 (order: 3, 32768 bytes, linear)
[ 0.055440] TCP bind hash table entries: 4096 (order: 5, 131072 bytes, linear)
[ 0.055631] TCP: Hash tables configured (established 4096 bind 4096)
[ 0.055797] UDP hash table entries: 256 (order: 1, 8192 bytes, linear)
[ 0.055838] UDP-Lite hash table entries: 256 (order: 1, 8192 bytes, linear)
[ 0.056166] NET: Registered PF_UNIX/PF_LOCAL protocol family
[ 0.056228] PCI: CLS 0 bytes, default 64
[ 0.058766] workingset: timestamp_bits=46 max_order=17 bucket_order=0
[ 0.065321] squashfs: version 4.0 (2009/01/31) Phillip Lougher
[ 0.065347] jffs2: version 2.2 (NAND) (SUMMARY) (LZMA) (RTIME) (CMODE_PRIORITY) (c) 2001-2006 Red Hat, Inc.
[ 0.072611] qcom-m31usb-phy 5b000.phy: supply vdda-phy not found, using dummy regulator
[ 0.072846] qcom-m31usb-phy 5b000.phy: Registered M31 USB phy
[ 0.075957] qcom-pcie a0000000.pci: host bridge /soc@0/pci@a0000000 ranges:
[ 0.076036] qcom-pcie a0000000.pci: IO 0x00a0200000..0x00a02fffff -> 0x00a0200000
[ 0.076101] qcom-pcie a0000000.pci: MEM 0x00a0300000..0x00b02fffff -> 0x00a0300000
[ 0.214136] qcom-pcie a0000000.pci: iATU unroll: enabled
[ 0.214161] qcom-pcie a0000000.pci: iATU regions: 8 ob, 8 ib, align 4K, limit 1024G
[ 0.314306] qcom-pcie a0000000.pci: PCIe Gen.2 x1 link up
[ 0.314678] qcom-pcie a0000000.pci: PCI host bridge to bus 0001:00
[ 0.314699] pci_bus 0001:00: root bus resource [bus 00-ff]
[ 0.314718] pci_bus 0001:00: root bus resource [io 0x0000-0xfffff] (bus address [0xa0200000-0xa02fffff])
[ 0.314729] pci_bus 0001:00: root bus resource [mem 0xa0300000-0xb02fffff]
[ 0.314784] pci 0001:00:00.0: [17cb:1004] type 01 class 0x060400
[ 0.314809] pci 0001:00:00.0: reg 0x10: [mem 0x00000000-0x00000fff]
[ 0.314903] pci 0001:00:00.0: PME# supported from D0 D3hot D3cold
[ 0.318024] pci 0001:01:00.0: [17cb:1106] type 00 class 0x028000
[ 0.318162] pci 0001:01:00.0: reg 0x10: [mem 0x00000000-0x01ffffff 64bit]
[ 0.318241] pci 0001:01:00.0: reg 0x18: [mem 0x00000000-0x001fffff 64bit]
[ 0.318821] pci 0001:01:00.0: PME# supported from D0 D3hot D3cold
[ 0.319024] pci 0001:01:00.0: 4.000 Gb/s available PCIe bandwidth, limited by 5.0 GT/s PCIe x1 link at 0001:00:00.0 (capable of 7.876 Gb/s with 8.0 GT/s PCIe x1 link)
[ 0.319682] pci 0001:00:00.0: BAR 8: assigned [mem 0xa1000000-0xa3ffffff]
[ 0.319722] pci 0001:00:00.0: BAR 9: assigned [mem 0xa0300000-0xa04fffff 64bit pref]
[ 0.319738] pci 0001:00:00.0: BAR 0: assigned [mem 0xa0500000-0xa0500fff]
[ 0.319762] pci 0001:00:00.0: BAR 7: assigned [io 0x1000-0x1fff]
[ 0.319783] pci 0001:01:00.0: BAR 0: assigned [mem 0xa2000000-0xa3ffffff 64bit]
[ 0.319859] pci 0001:01:00.0: BAR 2: assigned [mem 0xa1000000-0xa11fffff 64bit]
[ 0.319939] pci 0001:00:00.0: PCI bridge to [bus 01-ff]
[ 0.319959] pci 0001:00:00.0: bridge window [io 0x1000-0x1fff]
[ 0.319972] pci 0001:00:00.0: bridge window [mem 0xa1000000-0xa3ffffff]
[ 0.319985] pci 0001:00:00.0: bridge window [mem 0xa0300000-0xa04fffff 64bit pref]
[ 0.323826] pcieport 0001:00:00.0: PME: Signaling with IRQ 17
[ 0.326061] pcieport 0001:00:00.0: AER: enabled with IRQ 17
[ 0.333758] Serial: 8250/16550 driver, 2 ports, IRQ sharing disabled
[ 0.334915] msm_serial 78af000.serial: msm_serial: detected port #0
[ 0.334978] msm_serial 78af000.serial: uartclk = 1843199
[ 0.335149] 78af000.serial: ttyMSM0 at MMIO 0x78af000 (irq = 21, base_baud = 115199) is a MSM
[ 0.335194] msm_serial: console setup on port #0
[ 1.170644] printk: console [ttyMSM0] enabled
[ 1.176086] msm_serial: driver initialized
[ 1.189740] loop: module loaded
[ 1.195025] nand: device found, Manufacturer ID: 0xc8, Chip ID: 0x22
[ 1.195073] nand: ESMT GD5F2GQ5REYIH SPI NAND 2G 4-bit
[ 1.200457] nand: 256 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64
[ 1.205480] QPIC controller hw version Major:2, Minor:1
[ 1.229868] 18 fixed-partitions partitions found on MTD device qcom_nand.0
[ 1.229935] Creating 18 MTD partitions on "qcom_nand.0":
[ 1.235743] 0x000000000000-0x000000080000 : "0:SBL1"
[ 1.243086] 0x000000080000-0x0000000a0000 : "0:MIBIB"
[ 1.247500] 0x000000100000-0x000000200000 : "0:QSEE"
[ 1.253561] 0x000000200000-0x000000240000 : "0:DEVCFG"
[ 1.257714] 0x000000240000-0x000000280000 : "0:CDT"
[ 1.262615] 0x000000280000-0x0000002a0000 : "0:APPSBLENV"
[ 1.267330] 0x000000300000-0x000000440000 : "0:APPSBL"
[ 1.274627] 0x000000440000-0x000000540000 : "0:ART"
[ 1.278800] 0x000000540000-0x0000005c0000 : "0:TRAINING"
[ 1.283211] 0x0000005c0000-0x000000640000 : "u_env"
[ 1.288486] 0x000000640000-0x000000680000 : "s_env"
[ 1.292964] 0x000000680000-0x0000006c0000 : "devinfo"
[ 1.297669] 0x0000006c0000-0x0000058c0000 : "kernel"
[ 1.406492] 0x000000ec0000-0x0000058c0000 : "rootfs"
[ 1.501873] mtd: setting mtd13 (rootfs) as root device
[ 1.502580] mtdsplit: no squashfs found in "rootfs"
[ 1.505957] 0x0000058c0000-0x00000aac0000 : "alt_kernel"
[ 1.614953] 0x0000060c0000-0x00000aac0000 : "alt_rootfs"
[ 1.709894] 0x00000aac0000-0x00000acc0000 : "sysdiag"
[ 1.714046] 0x00000acc0000-0x00000f0c0000 : "syscfg"
[ 1.815193] spi_qup 78b5000.spi: IN:block:16, fifo:64, OUT:block:16, fifo:64
[ 2.063616] i2c_dev: i2c /dev entries driver
[ 2.070364] cpufreq: cpufreq_online: CPU0: Running at unlisted initial frequency: 24000 KHz, changing to: 1008000 KHz
[ 2.073561] sdhci: Secure Digital Host Controller Interface driver
[ 2.079974] sdhci: Copyright(c) Pierre Ossman
[ 2.086104] sdhci-pltfm: SDHCI platform and OF driver helper
[ 2.093895] remoteproc remoteproc0: releasing cd00000.remoteproc
[ 2.099572] NET: Registered PF_INET6 protocol family
[ 2.104055] Segment Routing with IPv6
[ 2.107193] In-situ OAM (IOAM) with IPv6
[ 2.110783] NET: Registered PF_PACKET protocol family
[ 2.114865] 8021q: 802.1Q VLAN Support v1.8
[ 2.145737] debugfs: Directory '4a9000.thermal-sensor' with parent 'tsens' already present!
[ 2.151118] remoteproc remoteproc0: cd00000.remoteproc is available
[ 2.160018] Freeing unused kernel memory: 5760K
[ 2.202664] Run /init as init process
[ 2.202705] with arguments:
[ 2.202709] /init
[ 2.202713] with environment:
[ 2.202715] HOME=/
[ 2.202719] TERM=linux
[ 2.698265] init: Console is alive
[ 2.698832] init: - watchdog -
[ 2.718175] kmodloader: loading kernel modules from /etc/modules-boot.d/*
[ 2.748233] xhci-hcd xhci-hcd.1.auto: xHCI Host Controller
[ 2.748314] xhci-hcd xhci-hcd.1.auto: new USB bus registered, assigned bus number 1
[ 2.752936] xhci-hcd xhci-hcd.1.auto: hcc params 0x0220fe65 hci version 0x110 quirks 0x0000000000010010
[ 2.760241] xhci-hcd xhci-hcd.1.auto: irq 24, io mem 0x08a00000
[ 2.769760] xhci-hcd xhci-hcd.1.auto: xHCI Host Controller
[ 2.775502] xhci-hcd xhci-hcd.1.auto: new USB bus registered, assigned bus number 2
[ 2.781026] xhci-hcd xhci-hcd.1.auto: Host supports USB 3.0 SuperSpeed
[ 2.790011] hub 1-0:1.0: USB hub found
[ 2.795595] hub 1-0:1.0: 1 port detected
[ 2.800074] usb usb2: We don't know the algorithms for LPM for this host, disabling LPM.
[ 2.804275] hub 2-0:1.0: USB hub found
[ 2.811159] hub 2-0:1.0: 1 port detected
[ 2.819143] kmodloader: done loading kernel modules from /etc/modules-boot.d/*
[ 2.826284] init: - preinit -
[ 6.412352] random: crng init done
[ 8.615732] procd: - early -
[ 8.616045] procd: - watchdog -
[ 9.238304] procd: - watchdog -
[ 9.238763] procd: - ubus -
[ 9.295348] procd: - init -
[ 9.654755] kmodloader: loading kernel modules from /etc/modules.d/*
[ 9.730941] hid: raw HID events driver (C) Jiri Kosina
[ 9.739390] Loading modules backported from Linux version v6.5-0-g2dde18cd1d8f
[ 9.739435] Backport generated by backports.git v5.15.92-1-56-g5fb2ccb6b9e8
[ 9.768175] NET: Registered PF_QIPCRTR protocol family
[ 9.855061] PPP generic driver version 2.4.2
[ 9.858140] NET: Registered PF_PPPOX protocol family
[ 9.880817] kmodloader: done loading kernel modules from /etc/modules.d/*
[ 9.919151] urngd: v1.0.2 started.
BusyBox v1.36.1 (2023-10-14 13:51:53 UTC) built-in shell (ash)
_______ ________ __
| |.-----.-----.-----.| | | |.----.| |_
| - || _ | -__| || | | || _|| _|
|_______|| __|_____|__|__||________||__| |____|
|__| W I R E L E S S F R E E D O M
-----------------------------------------------------
OpenWrt SNAPSHOT, r24135-b357564463
-----------------------------------------------------
=== WARNING! =====================================
There is no root password defined on this device!
Use the "passwd" command to set up a new password
in order to prevent unauthorized SSH logins.
--------------------------------------------------
root@OpenWrt:/# cat /proc/mtd
dev: size erasesize name
mtd0: 00080000 00020000 "0:SBL1"
mtd1: 00020000 00020000 "0:MIBIB"
mtd2: 00100000 00020000 "0:QSEE"
mtd3: 00040000 00020000 "0:DEVCFG"
mtd4: 00040000 00020000 "0:CDT"
mtd5: 00020000 00020000 "0:APPSBLENV"
mtd6: 00140000 00020000 "0:APPSBL"
mtd7: 00100000 00020000 "0:ART"
mtd8: 00080000 00020000 "0:TRAINING"
mtd9: 00080000 00020000 "u_env"
mtd10: 00040000 00020000 "s_env"
mtd11: 00040000 00020000 "devinfo"
mtd12: 05200000 00020000 "kernel"
mtd13: 04a00000 00020000 "rootfs"
mtd14: 05200000 00020000 "alt_kernel"
mtd15: 04a00000 00020000 "alt_rootfs"
mtd16: 00200000 00020000 "sysdiag"
mtd17: 04400000 00020000 "syscfg"
root@OpenWrt:/# ubiattach -p /dev/mtd15
[ 577.026314] ubi0: attaching mtd15
[ 577.691522] ubi0: scanning is finished
[ 577.702918] ubi0 warning: ubi_eba_init: cannot reserve enough PEBs for bad PEB handling, reserved 34, need 40
[ 577.703976] ubi0: attached mtd15 (name "alt_rootfs", size 74 MiB)
[ 577.711837] ubi0: PEB size: 131072 bytes (128 KiB), LEB size: 126976 bytes
[ 577.717997] ubi0: min./max. I/O unit sizes: 2048/2048, sub-page size 2048
[ 577.724726] ubi0: VID header offset: 2048 (aligned 2048), data offset: 4096
[ 577.731539] ubi0: good PEBs: 592, bad PEBs: 0, corrupted PEBs: 0
[ 577.738341] ubi0: user volume: 1, internal volumes: 1, max. volumes count: 128
[ 577.744591] ubi0: max/mean erase counter: 1/0, WL threshold: 4096, image sequence number: 2086108028
[ 577.751594] ubi0: available PEBs: 0, total reserved PEBs: 592, PEBs reserved for bad PEB handling: 34
[ 577.760973] ubi0: background thread "ubi_bgt0d" started, PID 1848
UBI device number 0, total 592 LEBs (75169792 bytes, 71.6 MiB), available 0 LEBs (0 bytes), LEB size 126976 bytes (124.0 KiB)