IPQ5018: Support for Linksys MX2000 Atlas 6 & MX5500 Atlas 6 Pro

so added earlycon to the bootargs, enabled earlycon in kernel config, and set CONFIG_CMDLINE_FORCE=y in .config.set and .config.target. Am I still missing something?

still stuck at, thanks for your patience with me:

IPQ5018# bootm
## Loading kernel from FIT Image at 44000000 ...
   Using 'config@1' configuration
   Trying 'kernel-1' kernel subimage
     Description:  ARM64 OpenWrt Linux-6.1.55
     Type:         Kernel Image
     Compression:  gzip compressed
     Data Start:   0x440000e8
     Data Size:    12493716 Bytes = 11.9 MiB
     Architecture: AArch64
     OS:           Linux
     Load Address: 0x41000000
     Entry Point:  0x41000000
     Hash algo:    crc32
     Hash value:   8c13a9a8
     Hash algo:    sha1
     Hash value:   6976f78ea151af15adfb8068d1dd5edf1addc2ab
   Verifying Hash Integrity ... crc32+ sha1+ OK
## Loading fdt from FIT Image at 44000000 ...
   Using 'config@1' configuration
   Trying 'fdt-1' fdt subimage
     Description:  ARM64 OpenWrt linksys_mx2000 device tree blob
     Type:         Flat Device Tree
     Compression:  uncompressed
     Data Start:   0x44bea5bc
     Data Size:    21909 Bytes = 21.4 KiB
     Architecture: AArch64
     Hash algo:    crc32
     Hash value:   5fef33f0
     Hash algo:    sha1
     Hash value:   36ef7277b96e445a9737bd91b9f7765c573b63fb
   Verifying Hash Integrity ... crc32+ sha1+ OK
   Booting using the fdt blob at 0x44bea5bc
   Uncompressing Kernel Image ... OK
   Loading Device Tree to 4a3f7000, end 4a3ff594 ... OK
Using machid 0x8040004 from environment

Starting kernel ...

Jumping to AARCH64 kernel via monitor

Did you also set the actual command line in CONFIG_CMDLINE? Use the line from the dts bootargs entry.

Just use kernel_menuconfig - boot options and set both options.

Update:

BTW is your dts node "blsp1_uart1" actually enabled?

That needs to enabled to get serial output from the kernel

Like that:

thanks a lot Kirdes, made some progress in the meantime. Am able to initiate the boot sequence now.. next, troubleshooting and trying to get all device nodes in the DT properly working.

update:
OpenWRT with kernel 6.1.55 boots with working uart, gcc, pinctrl, spi, i2c, mdio0/mdio1, remoteproc (q6v5), tsens, pcie phy x1. x2 doesn't come up for some reason although regs are the same with a different base/lane offset.

any pointers on how to initialize the switches (ipq5018 and qca8337) properly and on the issue with the x2 pcie phy?

the qpic nand controller lacks an upstream driver, but I'll give this rejected patch a go, though not having any high hopes.
[0/5] mtd: rawnand: qcom: Add support for QSPI nand - Patchwork (kernel.org)

ipq5018.dtsi: https://pastebin.com/edYF2dbK
ipq5018-mx2000.dts: https://pastebin.com/d2ChJdy1

IPQ5018# bootm
## Loading kernel from FIT Image at 44000000 ...
   Using 'config@1' configuration
   Trying 'kernel-1' kernel subimage
     Description:  ARM64 OpenWrt Linux-6.1.55
     Type:         Kernel Image
     Compression:  gzip compressed
     Data Start:   0x440000e8
     Data Size:    12193694 Bytes = 11.6 MiB
     Architecture: AArch64
     OS:           Linux
     Load Address: 0x41000000
     Entry Point:  0x41000000
     Hash algo:    crc32
     Hash value:   e3174baf
     Hash algo:    sha1
     Hash value:   7284626987b56938e1827af1230fb14190d05f87
   Verifying Hash Integrity ... crc32+ sha1+ OK
## Loading fdt from FIT Image at 44000000 ...
   Using 'config@1' configuration
   Trying 'fdt-1' fdt subimage
     Description:  ARM64 OpenWrt linksys_mx2000 device tree blob
     Type:         Flat Device Tree
     Compression:  uncompressed
     Data Start:   0x44ba11c8
     Data Size:    24182 Bytes = 23.6 KiB
     Architecture: AArch64
     Hash algo:    crc32
     Hash value:   4c38789d
     Hash algo:    sha1
     Hash value:   c8a17e89c937de037de25ed9680faabf589bbf88
   Verifying Hash Integrity ... crc32+ sha1+ OK
   Booting using the fdt blob at 0x44ba11c8
   Uncompressing Kernel Image ... OK
   Loading Device Tree to 4a3f7000, end 4a3ffe75 ... OK
fdt_fixup_qpic: QPIC: unable to find node '/soc/qpic-nand@79b0000'
Using machid 0x8040004 from environment

Starting kernel ...

Jumping to AARCH64 kernel via monitor
[    0.000000] Booting Linux on physical CPU 0x0000000000 [0x51af8014]
[    0.000000] Linux version 6.1.55 (gemous@SL5-GEMOUS) (aarch64-openwrt-linux-musl-gcc (OpenWrt GCC 12.3.0 r23884-36746893ac) 12.3.0, GNU ld (GNU Binutils) 2.40.0) #0 SMP Sun Sep 24 17:33:53 2023
[    0.000000] Machine model: Linksys MX2000
[    0.000000] OF: reserved mem: OVERLAP DETECTED!
[    0.000000] q6_code_data@4b000000 (0x000000004b000000--0x000000004b060000) overlaps with q6_mem_regions@4b000000 (0x000000004b000000--0x0000000050400000)
[    0.000000] OF: reserved mem: OVERLAP DETECTED!
[    0.000000] q6_mem_regions@4b000000 (0x000000004b000000--0x0000000050400000) overlaps with q6_ipq5018_data@4c400000 (0x000000004c400000--0x000000004d200000)
[    0.000000] OF: reserved mem: OVERLAP DETECTED!
[    0.000000] q6_qcn6122_caldb_1@4e800000 (0x000000004e800000--0x000000004ed00000) overlaps with q6_qcn6122_data2@4e900000 (0x000000004e900000--0x000000004f900000)
[    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] 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: 389072K/524288K available (7680K kernel code, 844K rwdata, 2208K rodata, 8512K init, 275K bss, 135216K 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.000100] Calibrating delay loop (skipped), value calculated using timer frequency.. 48.00 BogoMIPS (lpj=240000)
[    0.000119] pid_max: default: 32768 minimum: 301
[    0.000641] Mount-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
[    0.000667] Mountpoint-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
[    0.003635] cblist_init_generic: Setting adjustable number of callback queues.
[    0.003651] cblist_init_generic: Setting shift to 1 and lim to 1.
[    0.004026] rcu: Hierarchical SRCU implementation.
[    0.004037] rcu:     Max phase no-delay instances is 1000.
[    0.005049] smp: Bringing up secondary CPUs ...
[    0.006131] Detected VIPT I-cache on CPU1
[    0.006321] CPU1: Booted secondary processor 0x0000000001 [0x51af8014]
[    0.006508] smp: Brought up 1 node, 2 CPUs
[    0.006528] SMP: Total of 2 processors activated.
[    0.006535] CPU features: detected: 32-bit EL0 Support
[    0.006541] CPU features: detected: CRC32 instructions
[    0.006628] CPU features: emulated: Privileged Access Never (PAN) using TTBR0_EL1 switching
[    0.006638] CPU: All CPU(s) started at EL1
[    0.006641] alternatives: applying system-wide alternatives
[    0.014230] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
[    0.014264] futex hash table entries: 512 (order: 3, 32768 bytes, linear)
[    0.014537] pinctrl core: initialized pinctrl subsystem
[    0.016304] NET: Registered PF_NETLINK/PF_ROUTE protocol family
[    0.017404] DMA: preallocated 2048 KiB GFP_KERNEL pool for atomic allocations
[    0.017755] DMA: preallocated 2048 KiB GFP_KERNEL|GFP_DMA pool for atomic allocations
[    0.018112] DMA: preallocated 2048 KiB GFP_KERNEL|GFP_DMA32 pool for atomic allocations
[    0.018705] thermal_sys: Registered thermal governor 'step_wise'
[    0.019092] cpuidle: using governor menu
[    0.019455] ASID allocator initialised with 65536 entries
[    0.049942] SCSI subsystem initialized
[    0.050360] usbcore: registered new interface driver usbfs
[    0.050421] usbcore: registered new interface driver hub
[    0.050480] usbcore: registered new device driver usb
[    0.050852] qcom_scm: convention: smc arm 64
[    0.053035] clocksource: Switched to clocksource arch_sys_counter
[    0.054537] NET: Registered PF_INET protocol family
[    0.054755] IP idents hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.055846] tcp_listen_portaddr_hash hash table entries: 256 (order: 0, 4096 bytes, linear)
[    0.055883] Table-perturb hash table entries: 65536 (order: 6, 262144 bytes, linear)
[    0.055905] TCP established hash table entries: 4096 (order: 3, 32768 bytes, linear)
[    0.055956] TCP bind hash table entries: 4096 (order: 5, 131072 bytes, linear)
[    0.056145] TCP: Hash tables configured (established 4096 bind 4096)
[    0.056313] UDP hash table entries: 256 (order: 1, 8192 bytes, linear)
[    0.056356] UDP-Lite hash table entries: 256 (order: 1, 8192 bytes, linear)
[    0.056854] NET: Registered PF_UNIX/PF_LOCAL protocol family
[    0.056944] PCI: CLS 0 bytes, default 64
[    0.058989] workingset: timestamp_bits=46 max_order=17 bucket_order=0
[    0.065830] squashfs: version 4.0 (2009/01/31) Phillip Lougher
[    0.065853] jffs2: version 2.2 (NAND) (SUMMARY) (LZMA) (RTIME) (CMODE_PRIORITY) (c) 2001-2006 Red Hat, Inc.
[    0.076985] qcom-pcie 80000000.pci: host bridge /soc@0/pci@80000000 ranges:
[    0.077068] qcom-pcie 80000000.pci:       IO 0x0080200000..0x00802fffff -> 0x0080200000
[    0.077106] qcom-pcie 80000000.pci:      MEM 0x0080300000..0x00902fffff -> 0x0080300000
[    0.204851] qcom-pcie 80000000.pci: iATU unroll: enabled
[    0.204881] qcom-pcie 80000000.pci: iATU regions: 8 ob, 8 ib, align 4K, limit 1024G
**[    1.203183] qcom-pcie 80000000.pci: Phy link never came up**
[    1.203446] qcom-pcie 80000000.pci: PCI host bridge to bus 0000:00
[    1.203471] pci_bus 0000:00: root bus resource [bus 00-ff]
[    1.203495] pci_bus 0000:00: root bus resource [io  0x0000-0xfffff] (bus address [0x80200000-0x802fffff])
[    1.203507] pci_bus 0000:00: root bus resource [mem 0x80300000-0x902fffff]
[    1.203571] pci 0000:00:00.0: [17cb:1004] type 01 class 0x060400
[    1.203604] pci 0000:00:00.0: reg 0x10: [mem 0x00000000-0x00000fff]
[    1.203716] pci 0000:00:00.0: PME# supported from D0 D3hot D3cold
[    1.206761] pci 0000:00:00.0: BAR 8: assigned [mem 0x80300000-0x804fffff]
[    1.206805] pci 0000:00:00.0: BAR 9: assigned [mem 0x80500000-0x806fffff 64bit pref]
[    1.206821] pci 0000:00:00.0: BAR 0: assigned [mem 0x80700000-0x80700fff]
[    1.206839] pci 0000:00:00.0: BAR 7: assigned [io  0x1000-0x1fff]
[    1.206859] pci 0000:00:00.0: PCI bridge to [bus 01-ff]
[    1.206870] pci 0000:00:00.0:   bridge window [io  0x1000-0x1fff]
[    1.206882] pci 0000:00:00.0:   bridge window [mem 0x80300000-0x804fffff]
[    1.206892] pci 0000:00:00.0:   bridge window [mem 0x80500000-0x806fffff 64bit pref]
[    1.209764] pcieport 0000:00:00.0: PME: Signaling with IRQ 17
[    1.210964] pcieport 0000:00:00.0: AER: enabled with IRQ 17
[    1.212568] qcom-pcie a0000000.pci: host bridge /soc@0/pci@a0000000 ranges:
[    1.212668] qcom-pcie a0000000.pci:       IO 0x00a0200000..0x00a02fffff -> 0x00a0200000
[    1.212715] qcom-pcie a0000000.pci:      MEM 0x00a0300000..0x00b02fffff -> 0x00a0300000
[    1.344651] qcom-pcie a0000000.pci: iATU unroll: enabled
[    1.344670] qcom-pcie a0000000.pci: iATU regions: 8 ob, 8 ib, align 4K, limit 1024G
[    1.444766] qcom-pcie a0000000.pci: PCIe Gen.2 x1 link up
[    1.445013] qcom-pcie a0000000.pci: PCI host bridge to bus 0001:00
[    1.445036] pci_bus 0001:00: root bus resource [bus 00-ff]
[    1.445062] pci_bus 0001:00: root bus resource [io  0x100000-0x1fffff] (bus address [0xa0200000-0xa02fffff])
[    1.445075] pci_bus 0001:00: root bus resource [mem 0xa0300000-0xb02fffff]
[    1.445138] pci 0001:00:00.0: [17cb:1004] type 01 class 0x060400
[    1.445167] pci 0001:00:00.0: reg 0x10: [mem 0x00000000-0x00000fff]
[    1.445271] pci 0001:00:00.0: PME# supported from D0 D3hot D3cold
[    1.447900] pci 0001:01:00.0: [17cb:1106] type 00 class 0x028000
[    1.448020] pci 0001:01:00.0: reg 0x10: [mem 0x00000000-0x01ffffff 64bit]
[    1.448090] pci 0001:01:00.0: reg 0x18: [mem 0x00000000-0x001fffff 64bit]
[    1.448609] pci 0001:01:00.0: PME# supported from D0 D3hot D3cold
[    1.448786] 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)
[    1.449313] pci 0001:00:00.0: BAR 8: assigned [mem 0xa1000000-0xa3ffffff]
[    1.449337] pci 0001:00:00.0: BAR 9: assigned [mem 0xa0300000-0xa04fffff 64bit pref]
[    1.449350] pci 0001:00:00.0: BAR 0: assigned [mem 0xa0500000-0xa0500fff]
[    1.449364] pci 0001:00:00.0: BAR 7: assigned [io  0x100000-0x100fff]
[    1.449381] pci 0001:01:00.0: BAR 0: assigned [mem 0xa2000000-0xa3ffffff 64bit]
[    1.449439] pci 0001:01:00.0: BAR 2: assigned [mem 0xa1000000-0xa11fffff 64bit]
[    1.449497] pci 0001:00:00.0: PCI bridge to [bus 01-ff]
[    1.449506] pci 0001:00:00.0:   bridge window [io  0x100000-0x100fff]
[    1.449516] pci 0001:00:00.0:   bridge window [mem 0xa1000000-0xa3ffffff]
[    1.449525] pci 0001:00:00.0:   bridge window [mem 0xa0300000-0xa04fffff 64bit pref]
[    1.452205] pcieport 0001:00:00.0: PME: Signaling with IRQ 18
[    1.454195] pcieport 0001:00:00.0: AER: enabled with IRQ 18
[    1.463439] Serial: 8250/16550 driver, 2 ports, IRQ sharing disabled
[    1.464813] msm_serial 78af000.serial: msm_serial: detected port #0
[    1.464886] msm_serial 78af000.serial: uartclk = 1843199
[    1.465124] 78af000.serial: ttyMSM0 at MMIO 0x78af000 (irq = 22, base_baud = 115199) is a MSM
[    1.465189] msm_serial: console setup on port #0
[    2.490268] printk: console [ttyMSM0] enabled
[    2.495649] msm_serial: driver initialized
[    2.509520] loop: module loaded
[    2.511676] spi_qup 78b5000.spi: IN:block:16, fifo:64, OUT:block:16, fifo:64
[    2.514434] spi-nor spi0.0: unrecognized JEDEC id bytes: 00 00 00 00 00 00
[    2.649521] i2c_dev: i2c /dev entries driver
[    2.655564] cpufreq: cpufreq_online: CPU0: Running at unlisted initial frequency: 24000 KHz, changing to: 800000 KHz
[    2.658221] sdhci: Secure Digital Host Controller Interface driver
[    2.665291] sdhci: Copyright(c) Pierre Ossman
[    2.671177] sdhci-pltfm: SDHCI platform and OF driver helper
[    2.678676] remoteproc remoteproc0: releasing cd00000.q6v5_wcss
[    2.685122] NET: Registered PF_INET6 protocol family
[    2.689470] Segment Routing with IPv6
[    2.692225] In-situ OAM (IOAM) with IPv6
[    2.696013] NET: Registered PF_PACKET protocol family
[    2.699789] 8021q: 802.1Q VLAN Support v1.8
[    2.732813] debugfs: Directory '4a9000.thermal-sensor' with parent 'tsens' already present!
[    2.738674] remotepro▒[    2.748990] Freeing unused kernel memory: 8512K
[    2.793282] Run /init as init process
[    3.328000] init: Console is alive
[    3.328528] init: - watchdog -
[    3.350068] kmodloader: loading kernel modules from /etc/modules-boot.d/*
[    3.389736] kmodloader: done loading kernel modules from /etc/modules-boot.d/*
[    3.392732] init: - preinit -
[    8.683033] random: crng init done
Press the [f] key and hit [enter] to enter failsafe mode
Press the [1], [2], [3] or [4] key and hit [enter] to select the debug level
[   10.870430] procd: - early -
[   10.870734] procd: - watchdog -
[   11.439726] procd: - watchdog -
[   11.440915] procd: - ubus -
[   11.596716] procd: - init -
Please press Enter to activate this console.
[   11.966522] kmodloader: loading kernel modules from /etc/modules.d/*
[   12.058395] hid: raw HID events driver (C) Jiri Kosina
[   12.066148] Loading modules backported from Linux version v6.5-0-g2dde18cd1d8f
[   12.066192] Backport generated by backports.git v5.15.92-1-56-g5fb2ccb6b9e8
[   12.093940] NET: Registered PF_QIPCRTR protocol family
[   12.178354] PPP generic driver version 2.4.2
[   12.180884] NET: Registered PF_PPPOX protocol family
[   12.205128] kmodloader: done loading kernel modules from /etc/modules.d/*
[   12.389996] urngd: v1.0.2 started.



BusyBox v1.36.1 (2023-09-24 17:33:53 UTC) built-in shell (ash)

  _______                     ________        __
 |       |.-----.-----.-----.|  |  |  |.----.|  |_
 |   -   ||  _  |  -__|     ||  |  |  ||   _||   _|
 |_______||   __|_____|__|__||________||__|  |____|
          |__| W I R E L E S S   F R E E D O M
 -----------------------------------------------------
 OpenWrt SNAPSHOT, r24024-6585498372
 -----------------------------------------------------
=== 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:/#
1 Like

Is the x2 pcie even connected to something?

You should first fix the reserved memory overlap warnings.

For ethernet/switch support you need the OpenWrt qca-ssdk and qca-nss-dp packages, and a lot of dts nodes (mdio, ess-switch, dp etc.)
Example from the ipq-5.4 downstream kernel

Please note, OpenWrt qca-ssdk and qca-nss-dp packages doesn't have ipq50xx support ad the moment, that needs to be added to the Makefiles as well.

Look in the the Makefiles from qsdk how to properly add the ipq50xx config

x2 works for me on Motorola Q14, did you set the PERST GPIO?

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)

been wrestling with ssdk today to try and bring up the switches (ipq50xx + qca83xx) and would kindly request an extra pair of eyes pls:

stock dts specifies gpio39 as the 'phy-reset-gpio'. When I specify reset-gpios under the mdio in openwrt, it doesn't properly reset and causes ssdk initialization of the second switch - qca83xx - to fail as the mdio bus it's connected to reports the mdio device is missing:

[    1.973087] mdio_bus 90000.mdio-1: MDIO device at address 0 is missing.
[    1.973233] mdio_bus 90000.mdio-1: MDIO device at address 1 is missing.
[    1.978628] mdio_bus 90000.mdio-1: MDIO device at address 2 is missing.
[    1.985232] mdio_bus 90000.mdio-1: MDIO device at address 3 is missing.
[    1.991779] mdio_bus 90000.mdio-1: MDIO device at address 4 is missing.
....
[    9.846098] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[    9.852238] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[    9.858796] ssdk_dt_parse_port_bmp[898]:INFO:port_bmp doesn't exist!
[    9.865199] ssdk_dt_parse_led[1095]:INFO:current dts led_source_num is 1
[    9.917546] urngd: v1.0.2 started.
[   12.343652] ssdk_mp_reset_init[839]:INFO:MP reset successfully!
[   12.345435] mpge_phy_api_ops_init[1092]:INFO:qca probe mpge phy driver succeeded!
[   12.724695] _adpt_mp_uniphy_clk_output_ctrl_set[255]:INFO:uniphy will output clock as 25000000Hz
[   12.724887] ssdk_led_init[151]:INFO:ssdk_led_mode:3, ssdk_led_map:ffc, ssdk_led_src_id:0
[   12.734721] regi_init[4036]:INFO:Initializing SCOMPHY Done!!
[   12.763827] ssdk_dt_parse_mac_mode[275]:INFO:mac mode doesn't exit!
[   12.769970] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[   12.776154] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[   12.782772] ssdk_dt_parse[1227]:INFO:switch node is qca83xx!
[   12.794794] regi_init[4066]:INFO:qca-ssdk module init, no device found!

when I leave the reset-gpios property out, the log shows:

[    9.855075] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[    9.861215] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[    9.867768] ssdk_dt_parse_port_bmp[898]:INFO:port_bmp doesn't exist!
[    9.874147] ssdk_dt_parse_led[1095]:INFO:current dts led_source_num is 1
[    9.933715] urngd: v1.0.2 started.
[   12.354359] ssdk_mp_reset_init[839]:INFO:MP reset successfully!
[   12.356021] mpge_phy_api_ops_init[1092]:INFO:qca probe mpge phy driver succeeded!
[   12.735378] _adpt_mp_uniphy_clk_output_ctrl_set[255]:INFO:uniphy will output clock as 25000000Hz
[   12.735569] ssdk_led_init[151]:INFO:ssdk_led_mode:3, ssdk_led_map:ffc, ssdk_led_src_id:0
[   12.745378] regi_init[4036]:INFO:Initializing SCOMPHY Done!!
[   12.768442] ssdk_dt_parse[1163]:INFO:parse_access_mode 1 completed
[   12.774504] ssdk_dt_parse_mac_mode[275]:INFO:mac mode doesn't exit!
[   12.780650] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[   12.786850] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[   12.793457] ssdk_dt_parse[1227]:INFO:switch node is qca83xx!
[   12.869744] f1_phy_api_ops_init[1606]:INFO:qca probe f1 phy driver succeeded!
[   12.879868] OF: /soc@0/ess-instance/ess-switch1@1: could not get #gpio-cells for /reserved-memory/q6_mem_regions@4b000000
**[   12.884030] qca_ar8327_gpio_reset[3871]:INFO:1. reset_gpio -22**
**[   12.894988] qca_ar8327_gpio_reset[3890]:ERROR:gpio39 request failed, ret:-517**
[   12.900690] regi_init[3971]:INFO:and here
[   12.908150] regi_init[3973]:INFO:registered switch
[   14.674349] regi_init[3976]:INFO:Initializing ISISC Done!!
[   14.674390] regi_init[4046]:INFO:ssdk_fs_init start
[   14.679166] regi_init[4062]:INFO:qca-ssdk module init succeeded!

mdio-tool shows the correct phy id of ipq50xx (codename MP) on port 7 (as per both stock and openwrt dts):

root@OpenWrt:/# mdio 8*
 DEV      PHY-ID  LINK
0x00  0x00000000  down
0x01  0x00000000  down
0x02  0x00000000  down
0x03  0x00000000  down
0x04  0x00000000  down
0x05  0x00000000  down
0x06  0x00000000  down
0x07  0x004dd0c0  down     <-- ID: #define MP_GEPHY 0x004DD0C0 (from SSDK )

and the phys on the other mdio bus only when the reset-gpios property is omitted (else empty):

root@OpenWrt:/# mdio 9*
 DEV      PHY-ID  LINK
0x00  0x004dd036  down        <-- ID: #define F1V4_PHY 0x004DD036 (from SSDK)
0x01  0x004dd036  up          //WAN
0x02  0x004dd036  down        //LAN1
0x03  0x004dd036  down        //LAN2
0x04  0x004dd036  down        //LAN3

tested LAN and WAN ports by connecting and changing a cable

dts file: ipq5018-mx2000.dts

stock dts: snippet from stock dts (mx2000) let me know if you need the whole dts

How would I proceed and initialize and connect the two switches properly? I'd assume the reset gpios are required?

According to https://git.codelinaro.org/clo/qsdk/oss/kernel/linux-ipq-5.4/-/blob/NHSS.QSDK.12.4.r1/arch/arm64/boot/dts/qcom/ipq5018-mp03.1.dts

There are two different reset gpios.

In the mdio1 node its gpio 39, but in the switch1 node it's gpio27. You have the same gpio 39 in both the mdio1 and switch1 node.

BTW the correct syntax would be: <&tlmm 39 GPIO_ACTIVE_LOW>;

Thanks for the quick response, will try it tomorrow morning. I actually thought about this earlier and figured that 0x27 hex is 39 which made me think it couldn’t be a coincidence. Will try nonetheless and update the thread.

Other Q: how would one go about setting up ethernet devices and assign labels for wan and lan1/lan2/lan3 in this configuration having 2 switches?

Yes you are right, it's 0x27 in the switch node. So it's working if you only use the reset_gpio property at the switch node?

I've no experience with ipq50xx, my best guess is, this is just one switch with 2 different dts nodes to configure the cpu-port and the other node for the actual switch ports from the external switch.

For me it looks like it's a AR8337 compatible switch connected the the uniphy-port of the ipq50xx.

May be @robimarko can shed some light.

AFAIK, IPQ50xx has no built-in switch so it has to be external.

If it is QCA8337 then qca8k can be used for the switch instead of SSDK

At least the switch1 node looks like AR8337

But I guess ssdk ist still needed to configure the uniphy port?

Yes, UNIPHY needs to be configured by SSDK, I doubt it will be as simple as adding qca8k node.

so I think I've made 'some progress', the external switch (qca8337) resets properly by setting the reset gpio in the switch node as:

reset_gpio = <&tlmm 39 GPIO_ACTIVE_LOW>;

While digging into the SSDK source, I found the correct property name while it's iterating through the port nodes defined in the switch node:

for_each_available_child_of_node(phy_info_node, port_node) {
		if (of_property_read_u32(port_node, "port_id", &port_id))
			return SW_BAD_VALUE;
		if (!cfg->port_cfg.wan_bmp) {
			cfg->port_cfg.wan_bmp = BIT(port_id);
		} else {
			cfg->port_cfg.lan_bmp |= BIT(port_id);
		}

		/* initialize phy_addr in case of undefined dts field */
		mdio_node = of_parse_phandle(port_node, "mdiobus", 0);
		if (mdio_node)
		{
			ssdk_miibus_add(dev_id, of_mdio_find_bus(mdio_node), &miibus_index);
			phy_reset_gpio = of_get_named_gpio(mdio_node, "phy-reset-gpio",
				SSDK_PHY_RESET_GPIO_INDEX);
			if(phy_reset_gpio > 0)
			{
				hsl_port_phy_reset_gpio_set(dev_id, port_id,
					(a_uint32_t)phy_reset_gpio);
			}
		}

so I renamed the property in the mdio node from reset-gpios to phy-reset-pgio:

phy-reset-pgio = <&tlmm 39 GPIO_ACTIVE_LOW>;

The two switches initialize correctly now:

[   10.067997] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[   10.068048] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[   10.073661] ssdk_dt_parse_port_bmp[898]:INFO:port_bmp doesn't exist!
[   10.079852] ssdk_dt_parse_led[1095]:INFO:current dts led_source_num is 1
[   10.188792] urngd: v1.0.2 started.
[   12.583390] ssdk_mp_reset_init[839]:INFO:MP reset successfully!
[   12.585148] mpge_phy_api_ops_init[1092]:INFO:qca probe mpge phy driver succeeded!
[   12.964407] _adpt_mp_uniphy_clk_output_ctrl_set[255]:INFO:uniphy will output clock as 25000000Hz
[   12.964601] ssdk_led_init[151]:INFO:ssdk_led_mode:3, ssdk_led_map:ffc, ssdk_led_src_id:0
[   12.974396] regi_init[4023]:INFO:Initializing SCOMPHY Done!!
[   12.980442] ssdk_dt_parse_mac_mode[275]:INFO:mac mode doesn't exit!
[   12.986044] ssdk_dt_parse_mac_mode[283]:INFO:mac mode1 doesn't exit!
[   12.991973] ssdk_dt_parse_mac_mode[291]:INFO:mac mode2 doesn't exit!
[   12.998634] ssdk_dt_parse[1223]:INFO:switch node is qca83xx!
[   13.074691] f1_phy_api_ops_init[1606]:INFO:qca probe f1 phy driver succeeded!
[   13.323402] qca_ar8327_gpio_reset[3892]:INFO:GPIO504 reset switch done
[   15.073399] regi_init[3963]:INFO:Initializing ISISC Done!!
[   15.073887] regi_init[4049]:INFO:qca-ssdk module init succeeded!

I can now see the phy status changing on mdio1 (connected to the qca8337 switch) between UP/DOWN when connecting a UTP cable in the different external ports so the reset is working.

root@OpenWrt:/# mdio 9*            (<-- mdio1 bus)
 DEV      PHY-ID  LINK
0x00  0x004dd036  down           //GE Phy I suppose?
0x01  0x004dd036  up             //WAN
0x02  0x004dd036  down           //LAN1
0x03  0x004dd036  down           //LAN2
0x04  0x004dd036  down           //LAN3

qca8337 switch ports are configured as follows (as per stock DTS):

switch_cpu_bmp = <0x40>;  	/* cpu port bitmap: port 6 */
switch_lan_bmp = <0x38>; 	/* lan port bitmap: port 3 4 5 */
switch_wan_bmp = <0x04>;  	/* wan port bitmap: port 2 */

Problem I have now is that the GE Phy connecting the 2 switches doesn't come up on either of the mdio buses. The phy correctly is successfully probed though based on above logs.
Any ideas?

updated DTS: ipq5018-mx2000.dts

think I know what's going on, as @kirdes pointed out, qca-nss-dp fails to compile. I suspect in previous compilations it used the already compiled version of qca-nss-dp before switching target to MP for ipq50xx so the dp (MAC1 on ipq5018 switch) never initializes and stays down..

compiler chokes on: Compile error on QCA SSDK - #14 by georgem83

both qca-ssdk and qca-nss-dp compile now and I'm able to initialize the 2 switches + dp.
I can ping eth0 from the terminal, but pinging other devices fails.

I've setup the config of the switches and mdio buses as defined in the stock dts, but that doesn't work.

eth0 comes up, but I probably am not configuring it right.

this is how the output of swconfig and ipconfig in stock (removed lines for brevity):

~ # swconfig list
Found: switch0 - QCA MP
Found: switch1 - QCA AR8337

swconfig dev switch0 show
Global attributes:
        enable_vlan: 0
        max_frame_size: 1526
        dump_arl:
        switch_ext: ???
Port 0:
        mib: Port 0 MIB counters
..
        enable_eee: ???
        pvid: 0
        link: port:0 link:down
Port 1:
        mib: Port 1 MIB counters
...
        enable_eee: 0
        pvid: 0
        link: port:1 link:down


~ # swconfig dev switch1 show
Global attributes:
        enable_vlan: 0
        max_frame_size: 1518
        dump_arl: MAC: b8:31:b5:37:62:ad PORTMAP: 0x10 VID: 0x2 STATUS: 0x0
MAC: d8:ec:5e:fe:a1:31 PORTMAP: 0x40 VID: 0x2 STATUS: 0x0

        switch_ext: ???
Port 0:
        mib: Port 0 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:0 link:up speed:1000baseT full-duplex
Port 1:
        mib: Port 1 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:1 link:down
Port 2:
        mib: Port 2 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:2 link:down
Port 3:
        mib: Port 3 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:3 link:down
Port 4:
        mib: Port 4 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:4 link:up speed:1000baseT full-duplex txflow rxflow
Port 5:
        mib: Port 5 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:5 link:down
Port 6:
        mib: Port 6 MIB counters
...
        enable_eee: ???
        pvid: 0
        link: port:6 link:up speed:1000baseT full-duplex txflow rxflow
~ # ifconfig

br0       Link encap:Ethernet  HWaddr D8:EC:5E:FE:A1:31
          inet addr:192.168.1.1  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::daec:5eff:fefe:a131/64 Scope:Link
          UP BROADCAST RUNNING ALLMULTI MULTICAST  MTU:1500  Metric:1
          RX packets:115 errors:0 dropped:0 overruns:0 frame:0
          TX packets:78 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:11724 (11.4 KiB)  TX bytes:17695 (17.2 KiB)

br2       Link encap:Ethernet  HWaddr D8:EC:5E:FE:A1:32
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

eth0      Link encap:Ethernet  HWaddr 00:03:7F:BA:DB:AD
          inet6 addr: fe80::203:7fff:feba:dbad/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:199 errors:0 dropped:0 overruns:0 frame:0
          TX packets:129 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:22076 (21.5 KiB)  TX bytes:23848 (23.2 KiB)

eth0.1    Link encap:Ethernet  HWaddr D8:EC:5E:FE:A1:31
          inet6 addr: fe80::daec:5eff:fefe:a131/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:10 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 (0.0 B)  TX bytes:908 (908.0 B)

eth0.2    Link encap:Ethernet  HWaddr D8:EC:5E:FE:A1:31
          inet6 addr: fe80::daec:5eff:fefe:a131/64 Scope:Link
          UP BROADCAST RUNNING ALLMULTI MULTICAST  MTU:1500  Metric:1
          RX packets:199 errors:0 dropped:14 overruns:0 frame:0
          TX packets:109 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:18494 (18.0 KiB)  TX bytes:21556 (21.0 KiB)

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:110 errors:0 dropped:0 overruns:0 frame:0
          TX packets:110 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1
          RX bytes:12233 (11.9 KiB)  TX bytes:12233 (11.9 KiB)

what command do I use in openwrt to check status of the ports? (after moving away from swconfig)

I suppose I have to use ucidef_add_switch or a similar command in the 02_network file?
if so, can you tell me what and how?

There is no way to look into port status for the switch drivers provided by SSDK other than swconfig, however if you want to enable it then you must add stuff from QSDK that OpenWrt doesn't support in its swconfig.

Proper solution would be to run away from SSDK for the switch support, if its just QC8337 then you can use qca8k for it.

another of this kind of configuration... did qcom suggest this by design if device needs extra port? o.O

the router contains two switches:
1: 2-port ipq50xx in the soc itself
2: qca8337

AFAIK ipq50xx GMAC0/phy7 is connected over MDIO to phy0/MAC1 on qca8337
the SSDK is needed for at least the first switch

On qca8337, based on the LAN/WAN bitmap:
MAC2/phy1 -> WAN
MAC3/phy2 -> LAN1
MAC4/phy3 -> LAN2
MAC5/phy4 -> LAN3
MAC6 -> CPU (SGMII)