mirror of
https://github.com/Telecominfraproject/wlan-ap.git
synced 2025-10-29 17:42:41 +00:00
35924 lines
796 KiB
Diff
35924 lines
796 KiB
Diff
From 27708df2e1adb8c23ed756e99ac5dd2baff08b36 Mon Sep 17 00:00:00 2001
|
|
From: John Crispin <john@phrozen.org>
|
|
Date: Tue, 3 Oct 2023 07:08:28 +0200
|
|
Subject: [PATCH] ipq40xx: drop upstream target
|
|
|
|
Signed-off-by: John Crispin <john@phrozen.org>
|
|
---
|
|
target/linux/ipq40xx/Makefile | 23 -
|
|
.../ipq40xx/base-files/etc/board.d/01_leds | 123 --
|
|
.../ipq40xx/base-files/etc/board.d/02_network | 238 ---
|
|
.../base-files/etc/board.d/03_gpio_switches | 47 -
|
|
.../base-files/etc/board.d/05_compat-version | 18 -
|
|
.../etc/hotplug.d/firmware/11-ath10k-caldata | 280 ---
|
|
.../ipq40xx/base-files/etc/init.d/bootcount | 22 -
|
|
target/linux/ipq40xx/base-files/etc/inittab | 5 -
|
|
.../etc/uci-defaults/04_led_migration | 25 -
|
|
.../etc/uci-defaults/05_fix-compat-version | 13 -
|
|
.../lib/preinit/05_set_iface_mac_ipq40xx.sh | 47 -
|
|
.../lib/upgrade/dualboot_datachk.sh | 108 --
|
|
.../ipq40xx/base-files/lib/upgrade/linksys.sh | 125 --
|
|
.../ipq40xx/base-files/lib/upgrade/netgear.sh | 76 -
|
|
.../base-files/lib/upgrade/platform.sh | 239 ---
|
|
.../ipq40xx/base-files/lib/upgrade/sony.sh | 91 -
|
|
target/linux/ipq40xx/chromium/config-default | 10 -
|
|
target/linux/ipq40xx/chromium/target.mk | 3 -
|
|
target/linux/ipq40xx/config-5.15 | 508 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-a42.dts | 233 ---
|
|
.../arm/boot/dts/qcom-ipq4018-ap120c-ac.dts | 353 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-cap-ac.dts | 253 ---
|
|
.../dts/qcom-ipq4018-cs-w3-wd1200g-eup.dts | 290 ---
|
|
.../arm/boot/dts/qcom-ipq4018-dap-2610.dts | 232 ---
|
|
.../arm/boot/dts/qcom-ipq4018-ea6350v3.dts | 307 ---
|
|
.../arm/boot/dts/qcom-ipq4018-eap1300.dts | 230 ---
|
|
.../arm/boot/dts/qcom-ipq4018-ecw5211.dts | 329 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-emd1.dts | 210 ---
|
|
.../arm/boot/dts/qcom-ipq4018-emr3500.dts | 215 ---
|
|
.../arm/boot/dts/qcom-ipq4018-ens620ext.dts | 249 ---
|
|
.../arm/boot/dts/qcom-ipq4018-ex6100v2.dts | 31 -
|
|
.../arm/boot/dts/qcom-ipq4018-ex6150v2.dts | 31 -
|
|
.../arm/boot/dts/qcom-ipq4018-ex61x0v2.dtsi | 339 ----
|
|
.../boot/dts/qcom-ipq4018-fritzbox-4040.dts | 324 ----
|
|
.../arm/boot/dts/qcom-ipq4018-gl-a1300.dts | 334 ----
|
|
.../arm/boot/dts/qcom-ipq4018-gl-ap1300.dts | 302 ---
|
|
.../arm/boot/dts/qcom-ipq4018-hap-ac2.dts | 296 ---
|
|
.../arm/boot/dts/qcom-ipq4018-jalapeno.dts | 9 -
|
|
.../arm/boot/dts/qcom-ipq4018-jalapeno.dtsi | 276 ---
|
|
.../dts/qcom-ipq4018-magic-2-wifi-next.dts | 233 ---
|
|
.../boot/dts/qcom-ipq4018-meshpoint-one.dts | 81 -
|
|
.../arch/arm/boot/dts/qcom-ipq4018-mf287.dts | 221 ---
|
|
.../boot/dts/qcom-ipq4018-mf287_common.dtsi | 191 --
|
|
.../arm/boot/dts/qcom-ipq4018-mf287plus.dts | 221 ---
|
|
.../arm/boot/dts/qcom-ipq4018-mf287pro.dts | 268 ---
|
|
.../arm/boot/dts/qcom-ipq4018-nbg6617.dts | 361 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-pa1200.dts | 225 ---
|
|
.../arm/boot/dts/qcom-ipq4018-rt-ac58u.dts | 316 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-rutx.dtsi | 210 ---
|
|
.../arch/arm/boot/dts/qcom-ipq4018-rutx10.dts | 73 -
|
|
.../arch/arm/boot/dts/qcom-ipq4018-rutx50.dts | 181 --
|
|
.../arm/boot/dts/qcom-ipq4018-sxtsq-5-ac.dts | 239 ---
|
|
.../arch/arm/boot/dts/qcom-ipq4018-wac510.dts | 380 ----
|
|
.../arm/boot/dts/qcom-ipq4018-wap-ac-lte.dts | 45 -
|
|
.../arch/arm/boot/dts/qcom-ipq4018-wap-ac.dts | 9 -
|
|
.../arm/boot/dts/qcom-ipq4018-wap-ac.dtsi | 215 ---
|
|
.../arm/boot/dts/qcom-ipq4018-wap-r-ac.dts | 45 -
|
|
.../arch/arm/boot/dts/qcom-ipq4018-whw01.dts | 336 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4018-wr-1.dts | 292 ---
|
|
.../arm/boot/dts/qcom-ipq4018-wre6606.dts | 252 ---
|
|
.../arm/boot/dts/qcom-ipq4018-wrtq-329acn.dts | 302 ---
|
|
.../arch/arm/boot/dts/qcom-ipq4019-a62.dts | 269 ---
|
|
.../arm/boot/dts/qcom-ipq4019-cm520-79f.dts | 387 ----
|
|
.../arm/boot/dts/qcom-ipq4019-e2600ac-c1.dts | 136 --
|
|
.../arm/boot/dts/qcom-ipq4019-e2600ac-c2.dts | 179 --
|
|
.../arm/boot/dts/qcom-ipq4019-e2600ac.dtsi | 244 ---
|
|
.../arch/arm/boot/dts/qcom-ipq4019-ea8300.dts | 95 -
|
|
.../arm/boot/dts/qcom-ipq4019-eap2200.dts | 286 ---
|
|
.../boot/dts/qcom-ipq4019-fritzbox-7530.dts | 321 ----
|
|
.../dts/qcom-ipq4019-fritzrepeater-1200.dts | 290 ---
|
|
.../dts/qcom-ipq4019-fritzrepeater-3000.dts | 272 ---
|
|
.../arm/boot/dts/qcom-ipq4019-gl-b2200.dts | 386 ----
|
|
.../boot/dts/qcom-ipq4019-habanero-dvk.dts | 387 ----
|
|
.../dts/qcom-ipq4019-hap-ac3-lte6-kit.dts | 312 ----
|
|
.../arm/boot/dts/qcom-ipq4019-hap-ac3.dts | 351 ----
|
|
.../arm/boot/dts/qcom-ipq4019-lhgg-60ad.dts | 281 ---
|
|
.../arm/boot/dts/qcom-ipq4019-map-ac2200.dts | 363 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-mf18a.dts | 483 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-mf286d.dts | 448 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-mf289f.dts | 440 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-mr8300.dts | 80 -
|
|
.../dts/qcom-ipq4019-ncp-hg100-cellular.dts | 635 -------
|
|
.../arch/arm/boot/dts/qcom-ipq4019-oap100.dts | 339 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-orbi.dtsi | 338 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-pa2200.dts | 250 ---
|
|
.../arm/boot/dts/qcom-ipq4019-r619ac-128m.dts | 18 -
|
|
.../arm/boot/dts/qcom-ipq4019-r619ac-64m.dts | 12 -
|
|
.../arm/boot/dts/qcom-ipq4019-r619ac.dtsi | 387 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-rbr50.dts | 30 -
|
|
.../arch/arm/boot/dts/qcom-ipq4019-rbs50.dts | 30 -
|
|
.../arm/boot/dts/qcom-ipq4019-rt-ac42u.dts | 325 ----
|
|
.../arm/boot/dts/qcom-ipq4019-rtl30vw.dts | 393 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-srr60.dts | 12 -
|
|
.../arch/arm/boot/dts/qcom-ipq4019-srs60.dts | 12 -
|
|
.../arm/boot/dts/qcom-ipq4019-u4019-32m.dts | 88 -
|
|
.../arch/arm/boot/dts/qcom-ipq4019-u4019.dtsi | 216 ---
|
|
.../arm/boot/dts/qcom-ipq4019-whw03v2.dts | 519 ------
|
|
.../arch/arm/boot/dts/qcom-ipq4019-wifi.dts | 447 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-wpj419.dts | 370 ----
|
|
.../arm/boot/dts/qcom-ipq4019-wtr-m2133hp.dts | 462 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4019-x1pro.dts | 89 -
|
|
.../arch/arm/boot/dts/qcom-ipq4019-x1pro.dtsi | 216 ---
|
|
.../arm/boot/dts/qcom-ipq4019-xx8300.dtsi | 326 ----
|
|
.../arch/arm/boot/dts/qcom-ipq4028-wpj428.dts | 304 ---
|
|
.../arch/arm/boot/dts/qcom-ipq4029-ap-303.dts | 196 --
|
|
.../arm/boot/dts/qcom-ipq4029-ap-303h.dts | 472 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4029-ap-365.dts | 219 ---
|
|
.../dts/qcom-ipq4029-aruba-glenmorangie.dtsi | 272 ---
|
|
.../arm/boot/dts/qcom-ipq4029-gl-b1300.dts | 322 ----
|
|
.../arm/boot/dts/qcom-ipq4029-gl-s1300.dts | 357 ----
|
|
.../boot/dts/qcom-ipq4029-insect-common.dtsi | 444 -----
|
|
.../arch/arm/boot/dts/qcom-ipq4029-mr33.dts | 13 -
|
|
.../arch/arm/boot/dts/qcom-ipq4029-mr74.dts | 13 -
|
|
.../arm/boot/dts/qcom-ipq4029-ws-ap3915i.dts | 262 ---
|
|
.../arch/arm/boot/dts/qcom-ipq40x9-dr40x9.dts | 422 -----
|
|
.../files/drivers/net/dsa/qca/qca8k-ipq4019.c | 1655 -----------------
|
|
.../files/drivers/net/dsa/qca/qca8k-ipq4019.h | 289 ---
|
|
.../net/ethernet/qualcomm/ipqess/Makefile | 8 -
|
|
.../net/ethernet/qualcomm/ipqess/ipqess.c | 1336 -------------
|
|
.../net/ethernet/qualcomm/ipqess/ipqess.h | 530 ------
|
|
.../ethernet/qualcomm/ipqess/ipqess_ethtool.c | 175 --
|
|
.../ipq40xx/files/drivers/net/phy/qca807x.c | 839 ---------
|
|
target/linux/ipq40xx/generic/target.mk | 3 -
|
|
target/linux/ipq40xx/image/Makefile | 19 -
|
|
target/linux/ipq40xx/image/chromium.mk | 40 -
|
|
target/linux/ipq40xx/image/generic.mk | 1241 ------------
|
|
target/linux/ipq40xx/image/mikrotik.mk | 100 -
|
|
target/linux/ipq40xx/mikrotik/config-default | 5 -
|
|
target/linux/ipq40xx/mikrotik/target.mk | 4 -
|
|
.../104-clk-fix-apss-cpu-overclocking.patch | 115 --
|
|
.../300-clk-qcom-ipq4019-add-ess-reset.patch | 52 -
|
|
...-compressed-add-appended-DTB-section.patch | 48 -
|
|
...d-set-ipq40xx-watchdog-to-allow-boot.patch | 66 -
|
|
...msm-use-sdhci_set_clock-instead-of-s.patch | 24 -
|
|
...m-comment-unused-sdhci_msm_set_clock.patch | 108 --
|
|
.../420-firmware-qcom-scm-disable-SDI.patch | 47 -
|
|
...-firmware-qcom-scm-cold-boot-address.patch | 121 --
|
|
...-add-support-for-Toshiba-TC58NVG0S3H.patch | 29 -
|
|
...pecific-data-to-struct-skb_shared_in.patch | 43 -
|
|
...019-add-shinfo-based-tagging-driver-.patch | 187 --
|
|
...ethernet-qualcomm-add-IPQESS-support.patch | 43 -
|
|
...4019-add-ethernet-controller-DT-node.patch | 81 -
|
|
...phy-define-PSGMII-PHY-interface-mode.patch | 69 -
|
|
...comm-IPQ4019-built-in-switch-support.patch | 57 -
|
|
.../706-arm-dts-ipq4019-add-switch-node.patch | 98 -
|
|
.../707-dt-bindings-net-add-QCA807x-PHY.patch | 61 -
|
|
...8-net-phy-Add-Qualcom-QCA807x-driver.patch | 50 -
|
|
...9-arm-dts-ipq4019-QCA807x-properties.patch | 61 -
|
|
.../850-soc-add-qualcomm-syscon.patch | 180 --
|
|
.../900-dts-ipq4019-ap-dk01.1.patch | 164 --
|
|
.../902-dts-ipq4019-ap-dk04.1.patch | 164 --
|
|
...qcom_scm-Clear-download-bit-during-r.patch | 27 -
|
|
.../patches-5.15/998-lantiq-atm-hacks.patch | 43 -
|
|
.../999-atm-mpoa-intel-dsl-phy-support.patch | 137 --
|
|
154 files changed, 34679 deletions(-)
|
|
delete mode 100644 target/linux/ipq40xx/Makefile
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/board.d/01_leds
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/board.d/02_network
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/board.d/03_gpio_switches
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/board.d/05_compat-version
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
|
|
delete mode 100755 target/linux/ipq40xx/base-files/etc/init.d/bootcount
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/inittab
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/uci-defaults/04_led_migration
|
|
delete mode 100644 target/linux/ipq40xx/base-files/etc/uci-defaults/05_fix-compat-version
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/preinit/05_set_iface_mac_ipq40xx.sh
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/upgrade/dualboot_datachk.sh
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/upgrade/linksys.sh
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/upgrade/netgear.sh
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/upgrade/platform.sh
|
|
delete mode 100644 target/linux/ipq40xx/base-files/lib/upgrade/sony.sh
|
|
delete mode 100644 target/linux/ipq40xx/chromium/config-default
|
|
delete mode 100644 target/linux/ipq40xx/chromium/target.mk
|
|
delete mode 100644 target/linux/ipq40xx/config-5.15
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-a42.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ap120c-ac.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cap-ac.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cs-w3-wd1200g-eup.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-dap-2610.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ea6350v3.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-eap1300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ecw5211.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emd1.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emr3500.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ens620ext.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6100v2.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6150v2.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex61x0v2.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-fritzbox-4040.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-a1300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-ap1300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-hap-ac2.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-magic-2-wifi-next.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-meshpoint-one.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287_common.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287plus.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287pro.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-nbg6617.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-pa1200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rt-ac58u.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx10.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx50.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-sxtsq-5-ac.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wac510.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac-lte.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-r-ac.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-whw01.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wr-1.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wre6606.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wrtq-329acn.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-a62.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-cm520-79f.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c1.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c2.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ea8300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-eap2200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzbox-7530.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-1200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-3000.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-gl-b2200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-habanero-dvk.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3-lte6-kit.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-lhgg-60ad.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-map-ac2200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf18a.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf286d.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf289f.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mr8300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ncp-hg100-cellular.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-oap100.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-orbi.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-pa2200.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-128m.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-64m.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbr50.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbs50.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rt-ac42u.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rtl30vw.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srr60.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srs60.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019-32m.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-whw03v2.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wifi.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wpj419.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wtr-m2133hp.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-xx8300.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4028-wpj428.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303h.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-365.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-aruba-glenmorangie.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-b1300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-s1300.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-insect-common.dtsi
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr33.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr74.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ws-ap3915i.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq40x9-dr40x9.dts
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.c
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.h
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/Makefile
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.c
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.h
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess_ethtool.c
|
|
delete mode 100644 target/linux/ipq40xx/files/drivers/net/phy/qca807x.c
|
|
delete mode 100644 target/linux/ipq40xx/generic/target.mk
|
|
delete mode 100644 target/linux/ipq40xx/image/Makefile
|
|
delete mode 100644 target/linux/ipq40xx/image/chromium.mk
|
|
delete mode 100644 target/linux/ipq40xx/image/generic.mk
|
|
delete mode 100644 target/linux/ipq40xx/image/mikrotik.mk
|
|
delete mode 100644 target/linux/ipq40xx/mikrotik/config-default
|
|
delete mode 100644 target/linux/ipq40xx/mikrotik/target.mk
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/104-clk-fix-apss-cpu-overclocking.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/300-clk-qcom-ipq4019-add-ess-reset.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/301-arm-compressed-add-appended-DTB-section.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/302-arm-compressed-set-ipq40xx-watchdog-to-allow-boot.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/400-mmc-sdhci-sdhci-msm-use-sdhci_set_clock-instead-of-s.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/401-mmc-sdhci-msm-comment-unused-sdhci_msm_set_clock.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/420-firmware-qcom-scm-disable-SDI.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/421-firmware-qcom-scm-cold-boot-address.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/444-mtd-nand-rawnand-add-support-for-Toshiba-TC58NVG0S3H.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/700-skbuff-add-DSA-specific-data-to-struct-skb_shared_in.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/701-net-dsa-tag_ipq4019-add-shinfo-based-tagging-driver-.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/702-net-ethernet-qualcomm-add-IPQESS-support.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/703-arm-dts-ipq4019-add-ethernet-controller-DT-node.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/704-net-phy-define-PSGMII-PHY-interface-mode.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/705-net-dsa-add-Qualcomm-IPQ4019-built-in-switch-support.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/706-arm-dts-ipq4019-add-switch-node.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/707-dt-bindings-net-add-QCA807x-PHY.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/708-net-phy-Add-Qualcom-QCA807x-driver.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/709-arm-dts-ipq4019-QCA807x-properties.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/850-soc-add-qualcomm-syscon.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/900-dts-ipq4019-ap-dk01.1.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/902-dts-ipq4019-ap-dk04.1.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/910-Revert-firmware-qcom_scm-Clear-download-bit-during-r.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/998-lantiq-atm-hacks.patch
|
|
delete mode 100644 target/linux/ipq40xx/patches-5.15/999-atm-mpoa-intel-dsl-phy-support.patch
|
|
|
|
diff --git a/target/linux/ipq40xx/Makefile b/target/linux/ipq40xx/Makefile
|
|
deleted file mode 100644
|
|
index 53b2f909ae..0000000000
|
|
--- a/target/linux/ipq40xx/Makefile
|
|
+++ /dev/null
|
|
@@ -1,23 +0,0 @@
|
|
-include $(TOPDIR)/rules.mk
|
|
-
|
|
-ARCH:=arm
|
|
-BOARD:=ipq40xx
|
|
-BOARDNAME:=Qualcomm Atheros IPQ40XX
|
|
-FEATURES:=squashfs fpu ramdisk nand
|
|
-CPU_TYPE:=cortex-a7
|
|
-CPU_SUBTYPE:=neon-vfpv4
|
|
-SUBTARGETS:=generic chromium mikrotik
|
|
-
|
|
-KERNEL_PATCHVER:=5.15
|
|
-
|
|
-KERNELNAME:=zImage Image dtbs
|
|
-
|
|
-include $(INCLUDE_DIR)/target.mk
|
|
-DEFAULT_PACKAGES += \
|
|
- kmod-usb-dwc3-qcom \
|
|
- kmod-leds-gpio kmod-gpio-button-hotplug \
|
|
- kmod-ath10k-ct wpad-basic-mbedtls \
|
|
- kmod-usb3 kmod-usb-dwc3 ath10k-firmware-qca4019-ct \
|
|
- uboot-envtools
|
|
-
|
|
-$(eval $(call BuildTarget))
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/board.d/01_leds b/target/linux/ipq40xx/base-files/etc/board.d/01_leds
|
|
deleted file mode 100644
|
|
index 1ba5d2b1a7..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/board.d/01_leds
|
|
+++ /dev/null
|
|
@@ -1,123 +0,0 @@
|
|
-#
|
|
-# Copyright (C) 2015 OpenWrt.org
|
|
-#
|
|
-
|
|
-. /lib/functions/uci-defaults.sh
|
|
-
|
|
-board_config_update
|
|
-
|
|
-board=$(board_name)
|
|
-
|
|
-case "$board" in
|
|
-alfa-network,ap120c-ac)
|
|
- ucidef_set_led_netdev "wan" "WAN" "amber:wan" "wan"
|
|
- ;;
|
|
-asus,rt-ac42u)
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "blue:lan-1" "lan1"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "blue:lan-2" "lan2"
|
|
- ucidef_set_led_netdev "lan3" "LAN3" "blue:lan-3" "lan3"
|
|
- ucidef_set_led_netdev "lan4" "LAN4" "blue:lan-4" "lan4"
|
|
- ucidef_set_led_netdev "wan" "WAN" "blue:wan" "wan"
|
|
- ;;
|
|
-asus,rt-ac58u)
|
|
- ucidef_set_led_netdev "wan" "WAN" "blue:wan" "eth1"
|
|
- ucidef_set_led_switch "lan" "LAN" "blue:lan" "switch0" "0x1e"
|
|
- ;;
|
|
-avm,fritzbox-4040)
|
|
- ucidef_set_led_wlan "wlan" "WLAN" "green:wlan" "phy0tpt" "phy1tpt"
|
|
- ucidef_set_led_netdev "wan" "WAN" "green:wan" "wan"
|
|
- ucidef_set_led_switch "lan" "LAN" "green:lan" "switch0" "0x1e"
|
|
- ;;
|
|
-avm,fritzbox-7530)
|
|
- ucidef_set_led_netdev "dsl" "DSL" "green:info" "dsl0"
|
|
- ucidef_set_led_wlan "wlan" "WLAN" "green:wlan" "phy0tpt"
|
|
- ;;
|
|
-edgecore,oap100)
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "blue:wlan2g" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "blue:wlan5g" "phy1tpt"
|
|
- ;;
|
|
-engenius,eap1300)
|
|
- ucidef_set_led_netdev "lan" "LAN" "blue:lan" "eth0"
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "blue:wlan2g" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "yellow:wlan5g" "phy1tpt"
|
|
- ucidef_set_led_default "mesh" "MESH" "blue:mesh" "0"
|
|
- ;;
|
|
-engenius,eap2200)
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "blue:lan1" "eth0"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "blue:lan2" "eth1"
|
|
- ;;
|
|
-engenius,ens620ext)
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "green:wlan2g" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wlan5g" "phy1tpt"
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "green:lan1" "eth0"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "green:lan2" "eth1"
|
|
- ;;
|
|
-glinet,gl-ap1300)
|
|
- ucidef_set_led_netdev "wan" "WAN" "white:wan" "wan"
|
|
- ;;
|
|
-glinet,gl-b1300 |\
|
|
-mikrotik,lhgg-60ad)
|
|
- ucidef_set_led_wlan "wlan" "WLAN" "green:wlan" "phy0tpt"
|
|
- ;;
|
|
-mikrotik,cap-ac)
|
|
- ucidef_set_led_default "power" "POWER" "blue:power" "1"
|
|
- ucidef_set_led_default "user" "USER" "green:user" "0"
|
|
- ucidef_set_led_netdev "eth1" "ETH1" "green:eth1" "wan"
|
|
- ucidef_set_led_netdev "eth2" "ETH2" "green:eth2" "lan"
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "green:wlan2g" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wlan5g" "phy1tpt"
|
|
- ;;
|
|
-mikrotik,hap-ac3)
|
|
- ucidef_set_led_netdev "wan" "WAN" "green:wan" "eth0"
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "green:lan1" "lan1"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "green:lan2" "lan2"
|
|
- ucidef_set_led_netdev "lan3" "LAN3" "green:lan3" "lan3"
|
|
- ucidef_set_led_netdev "lan4" "LAN4" "green:lan4" "lan4"
|
|
- ucidef_set_led_gpio "poe" "POE" "red:poe" "452" "0"
|
|
- ;;
|
|
-mikrotik,hap-ac3-lte6-kit)
|
|
- ucidef_set_led_netdev "wan" "WAN" "green:wan" "wan"
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "green:lan1" "lan1"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "green:lan2" "lan2"
|
|
- ucidef_set_led_netdev "lan3" "LAN3" "green:lan3" "lan3"
|
|
- ucidef_set_led_netdev "lan4" "LAN4" "green:lan4" "lan4"
|
|
- ;;
|
|
-
|
|
-mikrotik,sxtsq-5-ac)
|
|
- ucidef_set_rssimon "wlan0" "200000" "1"
|
|
- ucidef_set_led_rssi "rssilow" "rssilow" "green:rssilow" "wlan0" "1" "100"
|
|
- ucidef_set_led_rssi "rssimediumlow" "rssimediumlow" "green:rssimediumlow" "wlan0" "21" "100"
|
|
- ucidef_set_led_rssi "rssimedium" "rssimedium" "green:rssimedium" "wlan0" "41" "100"
|
|
- ucidef_set_led_rssi "rssimediumhigh" "rssimediumhigh" "green:rssimediumhigh" "wlan0" "61" "100"
|
|
- ucidef_set_led_rssi "rssihigh" "rssihigh" "green:rssihigh" "wlan0" "81" "100"
|
|
- ;;
|
|
-mobipromo,cm520-79f)
|
|
- ucidef_set_led_netdev "wan" "WAN" "blue:wan" "wan"
|
|
- ucidef_set_led_netdev "lan1" "LAN1" "blue:lan1" "lan1"
|
|
- ucidef_set_led_netdev "lan2" "LAN2" "blue:lan2" "lan2"
|
|
- ;;
|
|
-netgear,ex6100v2 |\
|
|
-netgear,ex6150v2)
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "green:router" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:client" "phy1tpt"
|
|
- ;;
|
|
-qxwlan,e2600ac-c1 |\
|
|
-qxwlan,e2600ac-c2)
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN0" "green:wlan0" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN1" "green:wlan1" "phy1tpt"
|
|
- ;;
|
|
-sony,ncp-hg100-cellular)
|
|
- ucidef_set_led_netdev "lan" "LAN" "green:lan" "lan"
|
|
- ucidef_set_led_netdev "wan" "WAN" "green:wan" "wan"
|
|
- ucidef_set_led_netdev "wwan" "WWAN" "green:wan-4" "wwan0"
|
|
- ;;
|
|
-zyxel,nbg6617 |\
|
|
-zyxel,wre6606)
|
|
- ucidef_set_led_wlan "wlan2g" "WLAN2G" "green:wlan2g" "phy0tpt"
|
|
- ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wlan5g" "phy1tpt"
|
|
- ;;
|
|
-esac
|
|
-
|
|
-board_config_flush
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/board.d/02_network b/target/linux/ipq40xx/base-files/etc/board.d/02_network
|
|
deleted file mode 100644
|
|
index 5de62f1d7d..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/board.d/02_network
|
|
+++ /dev/null
|
|
@@ -1,238 +0,0 @@
|
|
-#
|
|
-# Copyright (c) 2015 The Linux Foundation. All rights reserved.
|
|
-# Copyright (c) 2011-2015 OpenWrt.org
|
|
-#
|
|
-
|
|
-. /lib/functions/uci-defaults.sh
|
|
-. /lib/functions/system.sh
|
|
-
|
|
-ipq40xx_setup_interfaces()
|
|
-{
|
|
- local board="$1"
|
|
-
|
|
- case "$board" in
|
|
- 8dev,habanero-dvk|\
|
|
- avm,fritzbox-4040|\
|
|
- asus,rt-ac42u|\
|
|
- asus,rt-ac58u|\
|
|
- linksys,ea6350v3|\
|
|
- linksys,ea8300|\
|
|
- linksys,mr8300|\
|
|
- mikrotik,hap-ac2|\
|
|
- mikrotik,hap-ac3|\
|
|
- mikrotik,hap-ac3-lte6-kit|\
|
|
- p2w,r619ac-64m|\
|
|
- p2w,r619ac-128m|\
|
|
- pakedge,wr-1|\
|
|
- teltonika,rutx50|\
|
|
- zyxel,nbg6617)
|
|
- ucidef_set_interfaces_lan_wan "lan1 lan2 lan3 lan4" "wan"
|
|
- ;;
|
|
- 8dev,jalapeno|\
|
|
- alfa-network,ap120c-ac|\
|
|
- asus,map-ac2200|\
|
|
- cilab,meshpoint-one|\
|
|
- edgecore,ecw5211|\
|
|
- glinet,gl-ap1300|\
|
|
- glinet,gl-b2200|\
|
|
- google,wifi|\
|
|
- linksys,whw03v2|\
|
|
- luma,wrtq-329acn|\
|
|
- mikrotik,cap-ac|\
|
|
- netgear,wac510|\
|
|
- sony,ncp-hg100-cellular|\
|
|
- wallys,dr40x9|\
|
|
- zte,mf18a|\
|
|
- zte,mf289f)
|
|
- ucidef_set_interfaces_lan_wan "lan" "wan"
|
|
- ;;
|
|
- aruba,ap-303|\
|
|
- aruba,ap-365|\
|
|
- avm,fritzrepeater-1200|\
|
|
- dlink,dap-2610|\
|
|
- extreme-networks,ws-ap3915i|\
|
|
- meraki,mr33|\
|
|
- meraki,mr74|\
|
|
- mikrotik,lhgg-60ad|\
|
|
- mikrotik,sxtsq-5-ac|\
|
|
- netgear,ex6100v2|\
|
|
- netgear,ex6150v2)
|
|
- ucidef_set_interface_lan "lan"
|
|
- ;;
|
|
- avm,fritzbox-7530)
|
|
- ucidef_set_interface_lan "lan1 lan2 lan3 lan4"
|
|
- ;;
|
|
- avm,fritzrepeater-3000|\
|
|
- cellc,rtl30vw)
|
|
- ucidef_set_interface_lan "lan1 lan2"
|
|
- ;;
|
|
- compex,wpj428)
|
|
- ucidef_set_interface_lan "lan1 lan2"
|
|
- ;;
|
|
- linksys,whw01)
|
|
- ucidef_set_interface_lan "eth1 eth2"
|
|
- ;;
|
|
- glinet,gl-a1300|\
|
|
- glinet,gl-b1300|\
|
|
- mobipromo,cm520-79f)
|
|
- ucidef_set_interfaces_lan_wan "lan1 lan2" "wan"
|
|
- ;;
|
|
- mikrotik,wap-ac|\
|
|
- mikrotik,wap-ac-lte|\
|
|
- mikrotik,wap-r-ac)
|
|
- ucidef_set_interface_lan "sw-eth1 sw-eth2"
|
|
- ;;
|
|
- aruba,ap-303h|\
|
|
- buffalo,wtr-m2133hp|\
|
|
- ezviz,cs-w3-wd1200g-eup|\
|
|
- netgear,rbr50|\
|
|
- netgear,rbs50|\
|
|
- netgear,srr60|\
|
|
- netgear,srs60)
|
|
- ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" "wan"
|
|
- ;;
|
|
- openmesh,a42|\
|
|
- openmesh,a62)
|
|
- ucidef_set_interfaces_lan_wan "ethernet2" "ethernet1"
|
|
- ;;
|
|
- plasmacloud,pa1200|\
|
|
- plasmacloud,pa2200)
|
|
- ucidef_set_interfaces_lan_wan "ethernet1" "ethernet2"
|
|
- ;;
|
|
- qxwlan,e2600ac-c1)
|
|
- ucidef_set_interfaces_lan_wan "sw-eth1" "sw-eth2"
|
|
- ;;
|
|
- qxwlan,e2600ac-c2)
|
|
- ucidef_set_interfaces_lan_wan "sw-eth1 sw-eth2" "sw-eth3"
|
|
- ;;
|
|
- zte,mf286d)
|
|
- ucidef_set_interfaces_lan_wan "lan2 lan3 lan4" "wan"
|
|
- ;;
|
|
- zte,mf287|\
|
|
- zte,mf287plus|\
|
|
- zte,mf287pro)
|
|
- ucidef_set_interface_lan "lan1 lan2 lan3 lan4"
|
|
- ucidef_set_interface "wan" device "/dev/cdc-wdm0" protocol "qmi"
|
|
- ;;
|
|
- *)
|
|
- echo "Unsupported hardware. Network interfaces not initialized"
|
|
- ;;
|
|
- esac
|
|
-}
|
|
-
|
|
-ipq40xx_setup_dsl()
|
|
-{
|
|
- local board="$1"
|
|
- local annex="j"
|
|
- local tone="b"
|
|
- local xfer_mode=""
|
|
-
|
|
- case "$board" in
|
|
- avm,fritzbox-7530)
|
|
- ;;
|
|
- *)
|
|
- return 0
|
|
- ;;
|
|
- esac
|
|
-
|
|
- ucidef_add_atm_bridge "1" "32" "llc" "bridged" "dsl"
|
|
- ucidef_add_vdsl_modem "$annex" "$tone" "$xfer_mode"
|
|
- ucidef_set_interface_wan "dsl0" "pppoe"
|
|
-}
|
|
-
|
|
-ipq40xx_setup_macs()
|
|
-{
|
|
- local board="$1"
|
|
- local lan_mac=""
|
|
- local wan_mac=""
|
|
- local label_mac=""
|
|
-
|
|
- case "$board" in
|
|
- 8dev,habanero-dvk)
|
|
- label_mac=$(mtd_get_mac_binary "ART" 0x1006)
|
|
- ;;
|
|
- asus,rt-ac42u)
|
|
- label_mac=$(mtd_get_mac_binary_ubi Factory 0x1006)
|
|
- ;;
|
|
- asus,rt-ac58u)
|
|
- wan_mac=$(mtd_get_mac_binary_ubi Factory 0x1006)
|
|
- lan_mac=$(mtd_get_mac_binary_ubi Factory 0x5006)
|
|
- label_mac=$wan_mac
|
|
- ;;
|
|
- avm,fritzbox-7530)
|
|
- local tffsdev=$(find_mtd_chardev "nand-tffs")
|
|
- wan_mac=$(/usr/bin/fritz_tffs_nand -b -d $tffsdev -n macdsl)
|
|
- ;;
|
|
- cilab,meshpoint-one)
|
|
- label_mac=$(mtd_get_mac_binary "ART" 0x1006)
|
|
- ;;
|
|
- devolo,magic-2-wifi-next)
|
|
- lan_mac=$(mtd_get_mac_ascii APPSBLENV MacAddress0)
|
|
- label_mac=$lan_mac
|
|
- ;;
|
|
- dlink,dap-2610)
|
|
- lan_mac=$(mtd_get_mac_ascii bdcfg lanmac)
|
|
- label_mac=$lan_mac
|
|
- ;;
|
|
- engenius,eap2200|\
|
|
- engenius,emd1)
|
|
- lan_mac=$(mtd_get_mac_ascii 0:APPSBLENV ethaddr)
|
|
- label_mac=$lan_mac
|
|
- ;;
|
|
- engenius,emr3500)
|
|
- wan_mac=$(mtd_get_mac_ascii 0:APPSBLENV wanaddr)
|
|
- lan_mac=$(mtd_get_mac_ascii 0:APPSBLENV ethaddr)
|
|
- label_mac=$wan_mac
|
|
- ;;
|
|
- engenius,ens620ext)
|
|
- wan_mac=$(mtd_get_mac_ascii u-boot-env ethaddr)
|
|
- lan_mac=$(macaddr_add "$wan_mac" 1)
|
|
- ;;
|
|
- ezviz,cs-w3-wd1200g-eup)
|
|
- label_mac=$(mtd_get_mac_binary "ART" 0x6)
|
|
- ;;
|
|
- google,wifi)
|
|
- wan_mac=$(get_mac_label)
|
|
- lan_mac=$(macaddr_add "$wan_mac" 1)
|
|
- ;;
|
|
- linksys,ea6350v3|\
|
|
- linksys,ea8300 |\
|
|
- linksys,mr8300)
|
|
- wan_mac=$(mtd_get_mac_ascii devinfo hw_mac_addr)
|
|
- lan_mac=$(macaddr_add "$wan_mac" 1)
|
|
- ;;
|
|
- mikrotik,cap-ac |\
|
|
- mikrotik,hap-ac2|\
|
|
- mikrotik,hap-ac3|\
|
|
- mikrotik,hap-ac3-lte6-kit)
|
|
- wan_mac=$(cat /sys/firmware/mikrotik/hard_config/mac_base)
|
|
- lan_mac=$(macaddr_add $wan_mac 1)
|
|
- label_mac="$wan_mac"
|
|
- ;;
|
|
- mikrotik,lhgg-60ad|\
|
|
- mikrotik,sxtsq-5-ac)
|
|
- lan_mac=$(cat /sys/firmware/mikrotik/hard_config/mac_base)
|
|
- label_mac="$lan_mac"
|
|
- ;;
|
|
- netgear,rbr50|\
|
|
- netgear,rbs50|\
|
|
- netgear,srr60|\
|
|
- netgear,srs60|\
|
|
- pakedge,wr-1)
|
|
- wan_mac=$(macaddr_add $(get_mac_label) 1)
|
|
- ;;
|
|
- esac
|
|
-
|
|
- [ -n "$lan_mac" ] && ucidef_set_interface_macaddr "lan" $lan_mac
|
|
- [ -n "$wan_mac" ] && ucidef_set_interface_macaddr "wan" $wan_mac
|
|
- [ -n "$label_mac" ] && ucidef_set_label_macaddr $label_mac
|
|
-}
|
|
-
|
|
-board_config_update
|
|
-board=$(board_name)
|
|
-ipq40xx_setup_interfaces $board
|
|
-ipq40xx_setup_dsl $board
|
|
-ipq40xx_setup_macs $board
|
|
-board_config_flush
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/board.d/03_gpio_switches b/target/linux/ipq40xx/base-files/etc/board.d/03_gpio_switches
|
|
deleted file mode 100644
|
|
index 2035d84993..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/board.d/03_gpio_switches
|
|
+++ /dev/null
|
|
@@ -1,47 +0,0 @@
|
|
-
|
|
-. /lib/functions/uci-defaults.sh
|
|
-
|
|
-board_config_update
|
|
-
|
|
-board=$(board_name)
|
|
-
|
|
-case "$board" in
|
|
-cellc,rtl30vw)
|
|
- ucidef_add_gpio_switch "w_disable" "W_DISABLE mPCIE pin" "398" "1"
|
|
- ucidef_add_gpio_switch "pmd_resin_n" "PMD_RESIN_N pin" "399" "1"
|
|
- ucidef_add_gpio_switch "mcpie_vcc" "LTE power" "400" "0"
|
|
- ucidef_add_gpio_switch "usb_vcc" "USB power" "401" "0"
|
|
- ;;
|
|
-cilab,meshpoint-one)
|
|
- ucidef_add_gpio_switch "poe_passtrough" "POE passtrough enable" "413" "1"
|
|
- ;;
|
|
-compex,wpj428)
|
|
- ucidef_add_gpio_switch "sim_card_select" "SIM card select" "3" "0"
|
|
- ;;
|
|
-mikrotik,cap-ac)
|
|
- ucidef_add_gpio_switch "poe_passtrough" "POE passtrough enable" "414" "0"
|
|
- ;;
|
|
-mikrotik,hap-ac3)
|
|
- ucidef_add_gpio_switch "poe_passtrough" "PoE Passthrough" "452" "0"
|
|
- ;;
|
|
-mikrotik,hap-ac3-lte6-kit)
|
|
- ucidef_add_gpio_switch "lte_ant_sw1" "LTE Antenna SW 1" "457" "0"
|
|
- ucidef_add_gpio_switch "lte_ant_sw2" "LTE Antenna SW 2" "458" "0"
|
|
- ucidef_add_gpio_switch "lte_reset" "LTE reset" "461" "0"
|
|
- ;;
|
|
-sony,ncp-hg100-cellular)
|
|
- ucidef_add_gpio_switch "uart_dbgcon_en" "debug console enable" "427" "1"
|
|
- ;;
|
|
-wallys,dr40x9)
|
|
- ucidef_add_gpio_switch "sim_card_select" "SIM card select" "423" "0"
|
|
- ;;
|
|
-zte,mf286d|\
|
|
-zte,mf287pro|\
|
|
-zte,mf289f)
|
|
- ucidef_add_gpio_switch "power_btn_block" "Power button blocker" "421" "0"
|
|
- ;;
|
|
-esac
|
|
-
|
|
-board_config_flush
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/board.d/05_compat-version b/target/linux/ipq40xx/base-files/etc/board.d/05_compat-version
|
|
deleted file mode 100644
|
|
index 70272f99ed..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/board.d/05_compat-version
|
|
+++ /dev/null
|
|
@@ -1,18 +0,0 @@
|
|
-#
|
|
-# Copyright (C) 2022 OpenWrt.org
|
|
-#
|
|
-
|
|
-. /lib/functions.sh
|
|
-. /lib/functions/uci-defaults.sh
|
|
-
|
|
-board_config_update
|
|
-
|
|
-case "$(board_name)" in
|
|
- *)
|
|
- ucidef_set_compat_version "1.1"
|
|
- ;;
|
|
-esac
|
|
-
|
|
-board_config_flush
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata b/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
|
|
deleted file mode 100644
|
|
index c8cf297e81..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
|
|
+++ /dev/null
|
|
@@ -1,280 +0,0 @@
|
|
-#!/bin/sh
|
|
-
|
|
-[ -e /lib/firmware/$FIRMWARE ] && exit 0
|
|
-
|
|
-. /lib/functions/caldata.sh
|
|
-
|
|
-board=$(board_name)
|
|
-
|
|
-case "$FIRMWARE" in
|
|
-"ath10k/cal-pci-0000:01:00.0.bin")
|
|
- case "$board" in
|
|
- meraki,mr33 |\
|
|
- meraki,mr74)
|
|
- caldata_extract_ubi "ART" 0x9000 0x844
|
|
- caldata_valid "4408" || caldata_extract "ART" 0x9000 0x844
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-"ath10k/pre-cal-pci-0000:01:00.0.bin")
|
|
- case "$board" in
|
|
- asus,map-ac2200)
|
|
- caldata_extract_ubi "Factory" 0x9000 0x2f20
|
|
- ln -sf /lib/firmware/ath10k/pre-cal-pci-0000\:00\:00.0.bin \
|
|
- /lib/firmware/ath10k/QCA9888/hw2.0/board.bin
|
|
- ;;
|
|
- asus,rt-ac42u)
|
|
- caldata_extract_ubi "Factory" 0x9000 0x2f20
|
|
- ;;
|
|
- avm,fritzrepeater-3000)
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x212 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1")
|
|
- ;;
|
|
- linksys,ea8300 |\
|
|
- linksys,mr8300)
|
|
- caldata_extract "ART" 0x9000 0x2f20
|
|
- # OEM assigns 4 sequential MACs
|
|
- ath10k_patch_mac $(macaddr_setbit_la $(macaddr_add "$(cat /sys/class/net/eth0/address)" 4))
|
|
- ;;
|
|
- netgear,rbr50|\
|
|
- netgear,rbs50|\
|
|
- netgear,srr60|\
|
|
- netgear,srs60)
|
|
- caldata_extract_mmc "0:ART" 0x9000 0x2f20
|
|
- ath10k_patch_mac $(mmc_get_mac_binary ARTMTD 0x12)
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-"ath10k/pre-cal-ahb-a000000.wifi.bin")
|
|
- case "$board" in
|
|
- qcom,ap-dk01.1-c1)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ;;
|
|
- asus,map-ac2200|\
|
|
- asus,rt-ac42u|\
|
|
- asus,rt-ac58u)
|
|
- caldata_extract_ubi "Factory" 0x1000 0x2f20
|
|
- ;;
|
|
- avm,fritzbox-4040)
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x400 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader_config")
|
|
- ;;
|
|
- avm,fritzbox-7530 |\
|
|
- avm,fritzrepeater-1200 |\
|
|
- avm,fritzrepeater-3000)
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x207 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1")
|
|
- ;;
|
|
- cellc,rtl30vw)
|
|
- caldata_extract "0:ART" 0x1000 0x2f20
|
|
- ;;
|
|
- devolo,magic-2-wifi-next)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii APPSBLENV WiFiMacAddress0)
|
|
- ;;
|
|
- dlink,dap-2610)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii bdcfg wlanmac)
|
|
- ;;
|
|
- engenius,emd1)
|
|
- caldata_extract "0:ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii 0:APPSBLENV wlanaddr)
|
|
- ;;
|
|
- engenius,emr3500)
|
|
- caldata_extract "0:ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii 0:APPSBLENV ethaddr)
|
|
- ;;
|
|
- engenius,ens620ext)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii u-boot-env ethaddr) 2)
|
|
- ;;
|
|
- extreme-networks,ws-ap3915i)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii CFG1 RADIOADDR0)
|
|
- ;;
|
|
- linksys,ea8300 |\
|
|
- linksys,mr8300)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add "$(cat /sys/class/net/eth0/address)" 2)
|
|
- ;;
|
|
- meraki,mr33 |\
|
|
- meraki,mr74)
|
|
- caldata_extract_ubi "ART" 0x1000 0x2f20
|
|
- caldata_valid "202f" || caldata_extract "ART" 0x1000 0x2f20
|
|
- ;;
|
|
- mikrotik,cap-ac |\
|
|
- mikrotik,hap-ac2 |\
|
|
- mikrotik,hap-ac3 |\
|
|
- mikrotik,hap-ac3-lte6-kit |\
|
|
- mikrotik,wap-ac |\
|
|
- mikrotik,wap-ac-lte |\
|
|
- mikrotik,wap-r-ac)
|
|
- wlan_data="/sys/firmware/mikrotik/hard_config/wlan_data"
|
|
- ( [ -f "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data" 0x0 0x2f20 ) || \
|
|
- ( [ -d "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data/data_0" 0x0 0x2f20 )
|
|
- ;;
|
|
- netgear,rbr50|\
|
|
- netgear,rbs50|\
|
|
- netgear,srr60|\
|
|
- netgear,srs60)
|
|
- caldata_extract_mmc "0:ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(mmc_get_mac_binary ARTMTD 0x0)
|
|
- ;;
|
|
- pakedge,wr-1)
|
|
- caldata_extract "0:ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(get_mac_label) 2)
|
|
- ;;
|
|
- teltonika,rutx10|\
|
|
- teltonika,rutx50)
|
|
- caldata_extract "0:ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary "0:CONFIG" 0x0) 2)
|
|
- ;;
|
|
- sony,ncp-hg100-cellular)
|
|
- caldata_extract_mmc "0:ART" 0x1000 0x2f20
|
|
- ;;
|
|
- zyxel,nbg6617 |\
|
|
- zyxel,wre6606)
|
|
- caldata_extract "ART" 0x1000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) -2)
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-"ath10k/pre-cal-ahb-a800000.wifi.bin")
|
|
- case "$board" in
|
|
- qcom,ap-dk01.1-c1)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ;;
|
|
- asus,map-ac2200|\
|
|
- asus,rt-ac58u)
|
|
- caldata_extract_ubi "Factory" 0x5000 0x2f20
|
|
- ;;
|
|
- avm,fritzbox-4040)
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x400 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader_config")
|
|
- ;;
|
|
- avm,fritzbox-7530 |\
|
|
- avm,fritzrepeater-1200 |\
|
|
- avm,fritzrepeater-3000)
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader0") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C800 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3D000 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1") || \
|
|
- /usr/bin/fritz_cal_extract -i 1 -s 0x3C000 -e 0x208 -l 12064 -o /lib/firmware/$FIRMWARE $(find_mtd_chardev "urlader1")
|
|
- ;;
|
|
- cellc,rtl30vw)
|
|
- caldata_extract "0:ART" 0x5000 0x2f20
|
|
- ;;
|
|
- devolo,magic-2-wifi-next)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii APPSBLENV WiFiMacAddress1)
|
|
- ;;
|
|
- dlink,dap-2610)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii bdcfg wlanmac_a)
|
|
- ;;
|
|
- engenius,emd1)
|
|
- caldata_extract "0:ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii 0:APPSBLENV wlanaddr) 1)
|
|
- ;;
|
|
- engenius,emr3500)
|
|
- caldata_extract "0:ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii 0:APPSBLENV ethaddr) 1)
|
|
- ;;
|
|
- engenius,ens620ext)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_ascii u-boot-env ethaddr) 3)
|
|
- ;;
|
|
- extreme-networks,ws-ap3915i)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(mtd_get_mac_ascii CFG1 RADIOADDR1)
|
|
- ;;
|
|
- linksys,ea8300 |\
|
|
- linksys,mr8300)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add "$(cat /sys/class/net/eth0/address)" 3)
|
|
- ;;
|
|
- meraki,mr33 |\
|
|
- meraki,mr74)
|
|
- caldata_extract_ubi "ART" 0x5000 0x2f20
|
|
- caldata_valid "202f" || caldata_extract "ART" 0x5000 0x2f20
|
|
- ;;
|
|
- mikrotik,cap-ac |\
|
|
- mikrotik,hap-ac2 |\
|
|
- mikrotik,hap-ac3 |\
|
|
- mikrotik,hap-ac3-lte6-kit |\
|
|
- mikrotik,sxtsq-5-ac |\
|
|
- mikrotik,wap-ac |\
|
|
- mikrotik,wap-ac-lte |\
|
|
- mikrotik,wap-r-ac)
|
|
- wlan_data="/sys/firmware/mikrotik/hard_config/wlan_data"
|
|
- ( [ -f "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data" 0x8000 0x2f20 ) || \
|
|
- ( [ -d "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data/data_2" 0x0 0x2f20 )
|
|
- ;;
|
|
- netgear,rbr50|\
|
|
- netgear,rbs50|\
|
|
- netgear,srr60|\
|
|
- netgear,srs60)
|
|
- caldata_extract_mmc "0:ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(mmc_get_mac_binary ARTMTD 0xc)
|
|
- ;;
|
|
- pakedge,wr-1)
|
|
- caldata_extract "0:ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(get_mac_label) 4)
|
|
- ;;
|
|
- teltonika,rutx10|\
|
|
- teltonika,rutx50)
|
|
- caldata_extract "0:ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(mtd_get_mac_binary "0:CONFIG" 0x0) 3)
|
|
- ;;
|
|
- sony,ncp-hg100-cellular)
|
|
- caldata_extract_mmc "0:ART" 0x5000 0x2f20
|
|
- ;;
|
|
- zyxel,nbg6617 |\
|
|
- zyxel,wre6606)
|
|
- caldata_extract "ART" 0x5000 0x2f20
|
|
- ath10k_patch_mac $(macaddr_add $(cat /sys/class/net/eth0/address) -1)
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-"ath10k/QCA4019/hw1.0/board-ahb-a000000.wifi.bin")
|
|
- case "$board" in
|
|
- mikrotik,cap-ac |\
|
|
- mikrotik,hap-ac2 |\
|
|
- mikrotik,hap-ac3 |\
|
|
- mikrotik,hap-ac3-lte6-kit |\
|
|
- mikrotik,wap-ac |\
|
|
- mikrotik,wap-ac-lte |\
|
|
- mikrotik,wap-r-ac)
|
|
- wlan_data="/sys/firmware/mikrotik/hard_config/wlan_data"
|
|
- ( [ -f "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data" 0x2f20 0x2f20 ) || \
|
|
- ( [ -d "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data/data_0" 0x2f20 0x2f20 )
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-"ath10k/QCA4019/hw1.0/board-ahb-a800000.wifi.bin")
|
|
- case "$board" in
|
|
- mikrotik,cap-ac |\
|
|
- mikrotik,hap-ac2 |\
|
|
- mikrotik,hap-ac3 |\
|
|
- mikrotik,hap-ac3-lte6-kit |\
|
|
- mikrotik,sxtsq-5-ac |\
|
|
- mikrotik,wap-ac |\
|
|
- mikrotik,wap-ac-lte |\
|
|
- mikrotik,wap-r-ac)
|
|
- wlan_data="/sys/firmware/mikrotik/hard_config/wlan_data"
|
|
- ( [ -f "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data" 0xaf20 0x2f20 ) || \
|
|
- ( [ -d "$wlan_data" ] && caldata_sysfsload_from_file "$wlan_data/data_2" 0x2f20 0x2f20 )
|
|
- ;;
|
|
- esac
|
|
- ;;
|
|
-*)
|
|
- exit 1
|
|
- ;;
|
|
-esac
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/init.d/bootcount b/target/linux/ipq40xx/base-files/etc/init.d/bootcount
|
|
deleted file mode 100755
|
|
index df656c9b85..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/init.d/bootcount
|
|
+++ /dev/null
|
|
@@ -1,22 +0,0 @@
|
|
-#!/bin/sh /etc/rc.common
|
|
-
|
|
-START=99
|
|
-
|
|
-boot() {
|
|
- case $(board_name) in
|
|
- alfa-network,ap120c-ac)
|
|
- [ -n "$(fw_printenv bootcount changed 2>/dev/null)" ] &&\
|
|
- echo -e "bootcount\nchanged\n" | /usr/sbin/fw_setenv -s -
|
|
- ;;
|
|
- linksys,ea6350v3|\
|
|
- linksys,ea8300|\
|
|
- linksys,mr8300|\
|
|
- linksys,whw01|\
|
|
- linksys,whw03v2)
|
|
- mtd resetbc s_env || true
|
|
- ;;
|
|
- netgear,wac510)
|
|
- fw_setenv boot_cnt=0
|
|
- ;;
|
|
- esac
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/inittab b/target/linux/ipq40xx/base-files/etc/inittab
|
|
deleted file mode 100644
|
|
index 3181021a05..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/inittab
|
|
+++ /dev/null
|
|
@@ -1,5 +0,0 @@
|
|
-# Copyright (c) 2013 The Linux Foundation. All rights reserved.
|
|
-::sysinit:/etc/init.d/rcS S boot
|
|
-::shutdown:/etc/init.d/rcS K shutdown
|
|
-ttyMSM0::askfirst:/usr/libexec/login.sh
|
|
-ttyMSM1::askfirst:/usr/libexec/login.sh
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/uci-defaults/04_led_migration b/target/linux/ipq40xx/base-files/etc/uci-defaults/04_led_migration
|
|
deleted file mode 100644
|
|
index e8818a41ed..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/uci-defaults/04_led_migration
|
|
+++ /dev/null
|
|
@@ -1,25 +0,0 @@
|
|
-. /lib/functions/migrations.sh
|
|
-
|
|
-board=$(board_name)
|
|
-
|
|
-case "$board" in
|
|
-asus,map-ac2200)
|
|
- migrate_leds ':chan=-'
|
|
- ;;
|
|
-engenius,emr3500)
|
|
- migrate_leds "emr3500:="
|
|
- ;;
|
|
-engenius,ens620ext|\
|
|
-zyxel,nbg6617)
|
|
- migrate_leds ":wlan2G=:wlan2g" ":wlan5G=:wlan5g"
|
|
- ;;
|
|
-netgear,wac510)
|
|
- migrate_leds ":wlan2g=:wlan-0" ":wlan5g=:wlan-1" ":act=:activity"
|
|
- ;;
|
|
-esac
|
|
-
|
|
-remove_devicename_leds
|
|
-
|
|
-migrations_apply system
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/etc/uci-defaults/05_fix-compat-version b/target/linux/ipq40xx/base-files/etc/uci-defaults/05_fix-compat-version
|
|
deleted file mode 100644
|
|
index c011920897..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/etc/uci-defaults/05_fix-compat-version
|
|
+++ /dev/null
|
|
@@ -1,13 +0,0 @@
|
|
-. /lib/functions.sh
|
|
-
|
|
-case "$(board_name)" in
|
|
-linksys,ea6350v3|\
|
|
-linksys,ea8300|\
|
|
-linksys,mr8300|\
|
|
-ezviz,cs-w3-wd1200g-eup)
|
|
- uci set system.@system[0].compat_version="2.0"
|
|
- uci commit system
|
|
- ;;
|
|
-esac
|
|
-
|
|
-exit 0
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/preinit/05_set_iface_mac_ipq40xx.sh b/target/linux/ipq40xx/base-files/lib/preinit/05_set_iface_mac_ipq40xx.sh
|
|
deleted file mode 100644
|
|
index ce0b55bb80..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/preinit/05_set_iface_mac_ipq40xx.sh
|
|
+++ /dev/null
|
|
@@ -1,47 +0,0 @@
|
|
-. /lib/functions.sh
|
|
-
|
|
-preinit_set_mac_address() {
|
|
- case $(board_name) in
|
|
- asus,map-ac2200)
|
|
- base_mac=$(mtd_get_mac_binary_ubi Factory 0x1006)
|
|
- ip link set dev eth0 address $(macaddr_add "$base_mac" 1)
|
|
- ip link set dev eth1 address $(macaddr_add "$base_mac" 3)
|
|
- ;;
|
|
- asus,rt-ac42u)
|
|
- base_mac=$(mtd_get_mac_binary_ubi Factory 0x1006)
|
|
- ip link set dev eth0 address $base_mac
|
|
- ip link set dev lan1 address $base_mac
|
|
- ip link set dev lan2 address $base_mac
|
|
- ip link set dev lan3 address $base_mac
|
|
- ip link set dev lan4 address $base_mac
|
|
- ip link set dev wan address $(mtd_get_mac_binary_ubi Factory 0x9006)
|
|
- ;;
|
|
- engenius,eap2200)
|
|
- base_mac=$(cat /sys/class/net/eth0/address)
|
|
- ip link set dev eth1 address $(macaddr_add "$base_mac" 1)
|
|
- ;;
|
|
- extreme-networks,ws-ap3915i)
|
|
- ip link set dev eth0 address $(mtd_get_mac_ascii CFG1 ethaddr)
|
|
- ;;
|
|
- linksys,ea8300|\
|
|
- linksys,mr8300)
|
|
- base_mac=$(mtd_get_mac_ascii devinfo hw_mac_addr)
|
|
- ip link set dev lan1 address $(macaddr_add "$base_mac" 1)
|
|
- ip link set dev eth0 address $(macaddr_setbit "$base_mac" 7)
|
|
- ;;
|
|
- mikrotik,wap-ac|\
|
|
- mikrotik,wap-ac-lte|\
|
|
- mikrotik,wap-r-ac)
|
|
- base_mac=$(cat /sys/firmware/mikrotik/hard_config/mac_base)
|
|
- ip link set dev sw-eth1 address "$base_mac"
|
|
- ip link set dev sw-eth2 address $(macaddr_add "$base_mac" 1)
|
|
- ;;
|
|
- zyxel,nbg6617)
|
|
- base_mac=$(cat /sys/class/net/eth0/address)
|
|
- ip link set dev eth0 address $(macaddr_add "$base_mac" 2)
|
|
- ip link set dev eth1 address $(macaddr_add "$base_mac" 3)
|
|
- ;;
|
|
- esac
|
|
-}
|
|
-
|
|
-boot_hook_add preinit_main preinit_set_mac_address
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/upgrade/dualboot_datachk.sh b/target/linux/ipq40xx/base-files/lib/upgrade/dualboot_datachk.sh
|
|
deleted file mode 100644
|
|
index 81418fe0ba..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/upgrade/dualboot_datachk.sh
|
|
+++ /dev/null
|
|
@@ -1,108 +0,0 @@
|
|
-# The U-Boot loader with the datachk patchset for dualbooting requires image
|
|
-# sizes and checksums to be provided in the U-Boot environment.
|
|
-# The devices come with 2 main partitions - while one is active
|
|
-# sysupgrade will flash the other. The boot order is changed to boot the
|
|
-# newly flashed partition. If the new partition can't be booted due to
|
|
-# upgrade failures the previously used partition is loaded.
|
|
-
|
|
-platform_do_upgrade_dualboot_datachk() {
|
|
- local tar_file="$1"
|
|
- local restore_backup
|
|
- local primary_kernel_mtd
|
|
-
|
|
- local setenv_script="/tmp/fw_env_upgrade"
|
|
-
|
|
- local kernel_mtd="$(find_mtd_index $PART_NAME)"
|
|
- local kernel_offset="$(cat /sys/class/mtd/mtd${kernel_mtd}/offset)"
|
|
- local total_size="$(cat /sys/class/mtd/mtd${kernel_mtd}/size)"
|
|
-
|
|
- # detect to which flash region the new image is written to.
|
|
- #
|
|
- # 1. check what is the mtd index for the first flash region on this
|
|
- # device
|
|
- # 2. check if the target partition ("inactive") has the mtd index of
|
|
- # the first flash region
|
|
- #
|
|
- # - when it is: the new bootseq will be 1,2 and the first region is
|
|
- # modified
|
|
- # - when it isnt: bootseq will be 2,1 and the second region is
|
|
- # modified
|
|
- #
|
|
- # The detection has to be done via the hardcoded mtd partition because
|
|
- # the current boot might be done with the fallback region. Let us
|
|
- # assume that the current bootseq is 1,2. The bootloader detected that
|
|
- # the image in flash region 1 is corrupt and thus switches to flash
|
|
- # region 2. The bootseq in the u-boot-env is now still the same and
|
|
- # the sysupgrade code can now only rely on the actual mtd indexes and
|
|
- # not the bootseq variable to detect the currently booted flash
|
|
- # region/image.
|
|
- #
|
|
- # In the above example, an implementation which uses bootseq ("1,2") to
|
|
- # detect the currently booted image would assume that region 1 is booted
|
|
- # and then overwrite the variables for the wrong flash region (aka the
|
|
- # one which isn't modified). This could result in a device which doesn't
|
|
- # boot anymore to Linux until it was reflashed with ap51-flash.
|
|
- local next_boot_part="1"
|
|
- case "$(board_name)" in
|
|
- plasmacloud,pa1200|\
|
|
- openmesh,a42)
|
|
- primary_kernel_mtd=8
|
|
- ;;
|
|
- plasmacloud,pa2200|\
|
|
- openmesh,a62)
|
|
- primary_kernel_mtd=10
|
|
- ;;
|
|
- *)
|
|
- echo "failed to detect primary kernel mtd partition for board"
|
|
- return 1
|
|
- ;;
|
|
- esac
|
|
- [ "$kernel_mtd" = "$primary_kernel_mtd" ] || next_boot_part="2"
|
|
-
|
|
- local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
-
|
|
- local kernel_length=$(tar xf $tar_file ${board_dir}/kernel -O | wc -c)
|
|
- local rootfs_length=$(tar xf $tar_file ${board_dir}/root -O | wc -c)
|
|
- # rootfs without EOF marker
|
|
- rootfs_length=$((rootfs_length-4))
|
|
-
|
|
- local kernel_md5=$(tar xf $tar_file ${board_dir}/kernel -O | md5sum); kernel_md5="${kernel_md5%% *}"
|
|
- # md5 checksum of rootfs with EOF marker
|
|
- local rootfs_md5=$(tar xf $tar_file ${board_dir}/root -O | dd bs=1 count=$rootfs_length | md5sum); rootfs_md5="${rootfs_md5%% *}"
|
|
-
|
|
- #
|
|
- # add tar support to get_image() to use default_do_upgrade() instead?
|
|
- #
|
|
-
|
|
- # take care of restoring a saved config
|
|
- [ -n "$UPGRADE_BACKUP" ] && restore_backup="${MTD_CONFIG_ARGS} -j ${UPGRADE_BACKUP}"
|
|
-
|
|
- mtd -q erase inactive
|
|
- tar xf $tar_file ${board_dir}/root -O | mtd -n -p $kernel_length $restore_backup write - $PART_NAME
|
|
- tar xf $tar_file ${board_dir}/kernel -O | mtd -n write - $PART_NAME
|
|
-
|
|
- # prepare new u-boot env
|
|
- if [ "$next_boot_part" = "1" ]; then
|
|
- echo "bootseq 1,2" > $setenv_script
|
|
- else
|
|
- echo "bootseq 2,1" > $setenv_script
|
|
- fi
|
|
-
|
|
- printf "kernel_size_%i 0x%08x\n" $next_boot_part $kernel_length >> $setenv_script
|
|
- printf "vmlinux_start_addr 0x%08x\n" ${kernel_offset} >> $setenv_script
|
|
- printf "vmlinux_size 0x%08x\n" ${kernel_length} >> $setenv_script
|
|
- printf "vmlinux_checksum %s\n" ${kernel_md5} >> $setenv_script
|
|
-
|
|
- printf "rootfs_size_%i 0x%08x\n" $next_boot_part $((total_size-kernel_length)) >> $setenv_script
|
|
- printf "rootfs_start_addr 0x%08x\n" $((kernel_offset+kernel_length)) >> $setenv_script
|
|
- printf "rootfs_size 0x%08x\n" ${rootfs_length} >> $setenv_script
|
|
- printf "rootfs_checksum %s\n" ${rootfs_md5} >> $setenv_script
|
|
-
|
|
- # store u-boot env changes
|
|
- mkdir -p /var/lock
|
|
- fw_setenv -s $setenv_script || {
|
|
- echo "failed to update U-Boot environment"
|
|
- return 1
|
|
- }
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/upgrade/linksys.sh b/target/linux/ipq40xx/base-files/lib/upgrade/linksys.sh
|
|
deleted file mode 100644
|
|
index 18366fc622..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/upgrade/linksys.sh
|
|
+++ /dev/null
|
|
@@ -1,125 +0,0 @@
|
|
-linksys_get_target_firmware() {
|
|
- local cur_boot_part mtd_ubi0
|
|
-
|
|
- cur_boot_part="$(/usr/sbin/fw_printenv -n boot_part)"
|
|
- if [ -z "${cur_boot_part}" ]; then
|
|
- mtd_ubi0=$(cat /sys/class/ubi/ubi0/mtd_num)
|
|
- case "$(grep -E "^mtd${mtd_ubi0}:" /proc/mtd | cut -d '"' -f 2)" in
|
|
- kernel|rootfs)
|
|
- cur_boot_part=1
|
|
- ;;
|
|
- alt_kernel|alt_rootfs)
|
|
- cur_boot_part=2
|
|
- ;;
|
|
- esac
|
|
- >&2 printf "Current boot_part='%s' selected from ubi0/mtd_num='%s'" \
|
|
- "${cur_boot_part}" "${mtd_ubi0}"
|
|
- fi
|
|
-
|
|
- # OEM U-Boot for EA6350v3, EA8300 and MR8300; bootcmd=
|
|
- # if test $auto_recovery = no;
|
|
- # then bootipq;
|
|
- # elif test $boot_part = 1;
|
|
- # then run bootpart1;
|
|
- # else run bootpart2;
|
|
- # fi
|
|
-
|
|
- case "$cur_boot_part" in
|
|
- 1)
|
|
- fw_setenv -s - <<-EOF
|
|
- boot_part 2
|
|
- auto_recovery yes
|
|
- EOF
|
|
- printf "alt_kernel"
|
|
- return
|
|
- ;;
|
|
- 2)
|
|
- fw_setenv -s - <<-EOF
|
|
- boot_part 1
|
|
- auto_recovery yes
|
|
- EOF
|
|
- printf "kernel"
|
|
- return
|
|
- ;;
|
|
- *)
|
|
- return
|
|
- ;;
|
|
- esac
|
|
-}
|
|
-
|
|
-linksys_is_factory_image() {
|
|
- local board=$(board_name)
|
|
- board=${board##*,}
|
|
-
|
|
- # check matching footer signature
|
|
- tail -c 256 $1 | grep -q -i "\.LINKSYS\.........${board}"
|
|
-}
|
|
-
|
|
-platform_do_upgrade_linksys() {
|
|
- local magic_long="$(get_magic_long "$1")"
|
|
-
|
|
- local rm_oem_fw_vols="squashfs ubifs" # from OEM [alt_]rootfs UBI
|
|
- local vol
|
|
-
|
|
- mkdir -p /var/lock
|
|
- local part_label="$(linksys_get_target_firmware)"
|
|
- touch /var/lock/fw_printenv.lock
|
|
-
|
|
- if [ -z "$part_label" ]; then
|
|
- echo "cannot find target partition"
|
|
- exit 1
|
|
- fi
|
|
-
|
|
- local target_mtd=$(find_mtd_part "$part_label")
|
|
-
|
|
- [ "$magic_long" = "73797375" ] && {
|
|
- CI_KERNPART="$part_label"
|
|
- if [ "$part_label" = "kernel" ]; then
|
|
- CI_UBIPART="rootfs"
|
|
- else
|
|
- CI_UBIPART="alt_rootfs"
|
|
- fi
|
|
-
|
|
- local mtdnum="$(find_mtd_index "$CI_UBIPART")"
|
|
- if [ ! "$mtdnum" ]; then
|
|
- echo "cannot find ubi mtd partition $CI_UBIPART"
|
|
- return 1
|
|
- fi
|
|
-
|
|
- local ubidev="$(nand_find_ubi "$CI_UBIPART")"
|
|
- if [ ! "$ubidev" ]; then
|
|
- ubiattach -m "$mtdnum"
|
|
- sync
|
|
- ubidev="$(nand_find_ubi "$CI_UBIPART")"
|
|
- fi
|
|
-
|
|
- if [ "$ubidev" ]; then
|
|
- for vol in $rm_oem_fw_vols; do
|
|
- ubirmvol "/dev/$ubidev" -N "$vol" 2>/dev/null
|
|
- done
|
|
- fi
|
|
-
|
|
- # complete std upgrade
|
|
- if nand_upgrade_tar "$1" ; then
|
|
- nand_do_upgrade_success
|
|
- else
|
|
- nand_do_upgrade_failed
|
|
- fi
|
|
-
|
|
- }
|
|
-
|
|
- [ "$magic_long" = "27051956" ] && {
|
|
- echo "writing \"$1\" image to \"$part_label\""
|
|
- get_image "$1" | mtd write - "$part_label"
|
|
- }
|
|
-
|
|
- [ "$magic_long" = "d00dfeed" ] && {
|
|
- if ! linksys_is_factory_image "$1"; then
|
|
- echo "factory image doesn't match device"
|
|
- return 1
|
|
- fi
|
|
-
|
|
- echo "writing \"$1\" factory image to \"$part_label\""
|
|
- get_image "$1" | mtd -e "$part_label" write - "$part_label"
|
|
- }
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/upgrade/netgear.sh b/target/linux/ipq40xx/base-files/lib/upgrade/netgear.sh
|
|
deleted file mode 100644
|
|
index f3fb626d1f..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/upgrade/netgear.sh
|
|
+++ /dev/null
|
|
@@ -1,76 +0,0 @@
|
|
-# SPDX-License-Identifier: GPL-2.0-only
|
|
-. /lib/functions.sh
|
|
-
|
|
-platform_do_upgrade_netgear_orbi_upgrade() {
|
|
- command -v losetup >/dev/null || {
|
|
- logger -s "Upgrade failed: 'losetup' not installed."
|
|
- return 1
|
|
- }
|
|
-
|
|
- local tar_file=$1
|
|
- local kernel=$2
|
|
- local rootfs=$3
|
|
-
|
|
- [ -z "$kernel" ] && kernel=$(find_mmc_part "kernel")
|
|
- [ -z "$rootfs" ] && rootfs=$(find_mmc_part "rootfs")
|
|
-
|
|
- [ -z "$kernel" ] && echo "Upgrade failed: kernel partition not found! Rebooting..." && reboot -f
|
|
- [ -z "$rootfs" ] && echo "Upgrade failed: rootfs partition not found! Rebooting..." && reboot -f
|
|
-
|
|
- netgear_orbi_do_flash $tar_file $kernel $rootfs
|
|
-
|
|
- echo "sysupgrade successful"
|
|
- umount -a
|
|
- reboot -f
|
|
-}
|
|
-
|
|
-netgear_orbi_do_flash() {
|
|
- local tar_file=$1
|
|
- local kernel=$2
|
|
- local rootfs=$3
|
|
-
|
|
- # keep sure its unbound
|
|
- losetup --detach-all || {
|
|
- echo "Failed to detach all loop devices. Skip this try."
|
|
- reboot -f
|
|
- }
|
|
-
|
|
- # use the first found directory in the tar archive
|
|
- local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
-
|
|
- echo "flashing kernel to $kernel"
|
|
- tar xf $tar_file ${board_dir}/kernel -O >$kernel
|
|
-
|
|
- echo "flashing rootfs to ${rootfs}"
|
|
- tar xf $tar_file ${board_dir}/root -O >"${rootfs}"
|
|
-
|
|
- # a padded rootfs is needed for overlay fs creation
|
|
- local offset=$(tar xf $tar_file ${board_dir}/root -O | wc -c)
|
|
- [ $offset -lt 65536 ] && {
|
|
- echo "Wrong size for rootfs: $offset"
|
|
- sleep 10
|
|
- reboot -f
|
|
- }
|
|
-
|
|
- # Mount loop for rootfs_data
|
|
- local loopdev="$(losetup -f)"
|
|
- losetup -o $offset $loopdev $rootfs || {
|
|
- echo "Failed to mount looped rootfs_data."
|
|
- sleep 10
|
|
- reboot -f
|
|
- }
|
|
-
|
|
- echo "Format new rootfs_data at position ${offset}."
|
|
- mkfs.ext4 -F -L rootfs_data $loopdev
|
|
- mkdir /tmp/new_root
|
|
- mount -t ext4 $loopdev /tmp/new_root && {
|
|
- echo "Saving config to rootfs_data at position ${offset}."
|
|
- cp -v "$UPGRADE_BACKUP" "/tmp/new_root/$BACKUP_FILE"
|
|
- umount /tmp/new_root
|
|
- }
|
|
-
|
|
- # Cleanup
|
|
- losetup -d $loopdev >/dev/null 2>&1
|
|
- sync
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/upgrade/platform.sh b/target/linux/ipq40xx/base-files/lib/upgrade/platform.sh
|
|
deleted file mode 100644
|
|
index 647ffc5c43..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/upgrade/platform.sh
|
|
+++ /dev/null
|
|
@@ -1,239 +0,0 @@
|
|
-PART_NAME=firmware
|
|
-REQUIRE_IMAGE_METADATA=1
|
|
-
|
|
-RAMFS_COPY_BIN='fw_printenv fw_setenv'
|
|
-RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock'
|
|
-
|
|
-platform_check_image() {
|
|
- case "$(board_name)" in
|
|
- asus,rt-ac42u |\
|
|
- asus,rt-ac58u)
|
|
- local ubidev=$(nand_find_ubi $CI_UBIPART)
|
|
- local asus_root=$(nand_find_volume $ubidev jffs2)
|
|
-
|
|
- [ -n "$asus_root" ] || return 0
|
|
-
|
|
- cat << EOF
|
|
-jffs2 partition is still present.
|
|
-There's probably no space left
|
|
-to install the filesystem.
|
|
-
|
|
-You need to delete the jffs2 partition first:
|
|
-# ubirmvol /dev/ubi0 --name=jffs2
|
|
-
|
|
-Once this is done. Retry.
|
|
-EOF
|
|
- return 1
|
|
- ;;
|
|
- zte,mf18a |\
|
|
- zte,mf286d |\
|
|
- zte,mf287|\
|
|
- zte,mf287plus |\
|
|
- zte,mf287pro |\
|
|
- zte,mf289f)
|
|
- CI_UBIPART="rootfs"
|
|
- local mtdnum="$( find_mtd_index $CI_UBIPART )"
|
|
- [ ! "$mtdnum" ] && return 1
|
|
- ubiattach -m "$mtdnum" || true
|
|
- local ubidev="$( nand_find_ubi $CI_UBIPART )"
|
|
- local ubi_rootfs=$(nand_find_volume $ubidev ubi_rootfs)
|
|
- local ubi_rootfs_data=$(nand_find_volume $ubidev ubi_rootfs_data)
|
|
-
|
|
- [ -n "$ubi_rootfs" ] || [ -n "$ubi_rootfs_data" ] || return 0
|
|
-
|
|
- cat << EOF
|
|
-ubi_rootfs partition is still present.
|
|
-
|
|
-You need to delete the stock partition first:
|
|
-# ubirmvol /dev/ubi0 -N ubi_rootfs
|
|
-Please also delete ubi_rootfs_data, if exist:
|
|
-# ubirmvol /dev/ubi0 -N ubi_rootfs_data
|
|
-
|
|
-Once this is done. Retry.
|
|
-EOF
|
|
- return 1
|
|
- ;;
|
|
- esac
|
|
- return 0;
|
|
-}
|
|
-
|
|
-askey_do_upgrade() {
|
|
- local tar_file="$1"
|
|
-
|
|
- local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
-
|
|
- tar Oxf $tar_file ${board_dir}/root | mtd write - rootfs
|
|
-
|
|
- nand_do_upgrade "$1"
|
|
-}
|
|
-
|
|
-zyxel_do_upgrade() {
|
|
- local tar_file="$1"
|
|
-
|
|
- local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
-
|
|
- tar Oxf $tar_file ${board_dir}/kernel | mtd write - kernel
|
|
-
|
|
- if [ -n "$UPGRADE_BACKUP" ]; then
|
|
- tar Oxf $tar_file ${board_dir}/root | mtd -j "$UPGRADE_BACKUP" write - rootfs
|
|
- else
|
|
- tar Oxf $tar_file ${board_dir}/root | mtd write - rootfs
|
|
- fi
|
|
-}
|
|
-
|
|
-platform_do_upgrade_mikrotik_nand() {
|
|
- local fw_mtd=$(find_mtd_part kernel)
|
|
- fw_mtd="${fw_mtd/block/}"
|
|
- [ -n "$fw_mtd" ] || return
|
|
-
|
|
- local board_dir=$(tar tf "$1" | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
- [ -n "$board_dir" ] || return
|
|
-
|
|
- local kernel_len=$(tar xf "$1" ${board_dir}/kernel -O | wc -c)
|
|
- [ -n "$kernel_len" ] || return
|
|
-
|
|
- tar xf "$1" ${board_dir}/kernel -O | ubiformat "$fw_mtd" -y -S $kernel_len -f -
|
|
-
|
|
- CI_KERNPART="none"
|
|
- nand_do_upgrade "$1"
|
|
-}
|
|
-
|
|
-platform_do_upgrade() {
|
|
- case "$(board_name)" in
|
|
- 8dev,jalapeno |\
|
|
- aruba,ap-303 |\
|
|
- aruba,ap-303h |\
|
|
- aruba,ap-365 |\
|
|
- avm,fritzbox-7530 |\
|
|
- avm,fritzrepeater-1200 |\
|
|
- avm,fritzrepeater-3000 |\
|
|
- buffalo,wtr-m2133hp |\
|
|
- cilab,meshpoint-one |\
|
|
- edgecore,ecw5211 |\
|
|
- edgecore,oap100 |\
|
|
- engenius,eap2200 |\
|
|
- glinet,gl-a1300 |\
|
|
- glinet,gl-ap1300 |\
|
|
- luma,wrtq-329acn |\
|
|
- mobipromo,cm520-79f |\
|
|
- netgear,wac510 |\
|
|
- p2w,r619ac-64m |\
|
|
- p2w,r619ac-128m |\
|
|
- qxwlan,e2600ac-c2 |\
|
|
- wallys,dr40x9)
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- glinet,gl-b2200)
|
|
- CI_KERNPART="0:HLOS"
|
|
- CI_ROOTPART="rootfs"
|
|
- CI_DATAPART="rootfs_data"
|
|
- emmc_do_upgrade "$1"
|
|
- ;;
|
|
- alfa-network,ap120c-ac)
|
|
- part="$(awk -F 'ubi.mtd=' '{printf $2}' /proc/cmdline | sed -e 's/ .*$//')"
|
|
- if [ "$part" = "rootfs1" ]; then
|
|
- fw_setenv active 2 || exit 1
|
|
- CI_UBIPART="rootfs2"
|
|
- else
|
|
- fw_setenv active 1 || exit 1
|
|
- CI_UBIPART="rootfs1"
|
|
- fi
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- asus,map-ac2200)
|
|
- CI_KERNPART="linux"
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- asus,rt-ac42u |\
|
|
- asus,rt-ac58u)
|
|
- CI_KERNPART="linux"
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- cellc,rtl30vw)
|
|
- CI_UBIPART="ubifs"
|
|
- askey_do_upgrade "$1"
|
|
- ;;
|
|
- compex,wpj419)
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- google,wifi)
|
|
- export_bootdevice
|
|
- export_partdevice CI_ROOTDEV 0
|
|
- CI_KERNPART="kernel"
|
|
- CI_ROOTPART="rootfs"
|
|
- emmc_do_upgrade "$1"
|
|
- ;;
|
|
- linksys,ea6350v3 |\
|
|
- linksys,ea8300 |\
|
|
- linksys,mr8300 |\
|
|
- linksys,whw01 |\
|
|
- linksys,whw03v2)
|
|
- platform_do_upgrade_linksys "$1"
|
|
- ;;
|
|
- meraki,mr33 |\
|
|
- meraki,mr74)
|
|
- CI_KERNPART="part.safe"
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- mikrotik,cap-ac|\
|
|
- mikrotik,hap-ac2|\
|
|
- mikrotik,hap-ac3-lte6-kit|\
|
|
- mikrotik,lhgg-60ad|\
|
|
- mikrotik,sxtsq-5-ac|\
|
|
- mikrotik,wap-ac|\
|
|
- mikrotik,wap-ac-lte|\
|
|
- mikrotik,wap-r-ac)
|
|
- [ "$(rootfs_type)" = "tmpfs" ] && mtd erase firmware
|
|
- default_do_upgrade "$1"
|
|
- ;;
|
|
- mikrotik,hap-ac3)
|
|
- platform_do_upgrade_mikrotik_nand "$1"
|
|
- ;;
|
|
- netgear,rbr50 |\
|
|
- netgear,rbs50 |\
|
|
- netgear,srr60 |\
|
|
- netgear,srs60)
|
|
- platform_do_upgrade_netgear_orbi_upgrade "$1"
|
|
- ;;
|
|
- openmesh,a42 |\
|
|
- openmesh,a62 |\
|
|
- plasmacloud,pa1200 |\
|
|
- plasmacloud,pa2200)
|
|
- PART_NAME="inactive"
|
|
- platform_do_upgrade_dualboot_datachk "$1"
|
|
- ;;
|
|
- sony,ncp-hg100-cellular)
|
|
- sony_emmc_do_upgrade "$1"
|
|
- ;;
|
|
- teltonika,rutx10 |\
|
|
- teltonika,rutx50 |\
|
|
- zte,mf18a |\
|
|
- zte,mf286d |\
|
|
- zte,mf287 |\
|
|
- zte,mf287plus |\
|
|
- zte,mf287pro |\
|
|
- zte,mf289f)
|
|
- CI_UBIPART="rootfs"
|
|
- nand_do_upgrade "$1"
|
|
- ;;
|
|
- zyxel,nbg6617)
|
|
- zyxel_do_upgrade "$1"
|
|
- ;;
|
|
- *)
|
|
- default_do_upgrade "$1"
|
|
- ;;
|
|
- esac
|
|
-}
|
|
-
|
|
-platform_copy_config() {
|
|
- case "$(board_name)" in
|
|
- glinet,gl-b2200 |\
|
|
- google,wifi)
|
|
- emmc_copy_config
|
|
- ;;
|
|
- esac
|
|
- return 0;
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/base-files/lib/upgrade/sony.sh b/target/linux/ipq40xx/base-files/lib/upgrade/sony.sh
|
|
deleted file mode 100644
|
|
index 8ff9df0fac..0000000000
|
|
--- a/target/linux/ipq40xx/base-files/lib/upgrade/sony.sh
|
|
+++ /dev/null
|
|
@@ -1,91 +0,0 @@
|
|
-. /lib/functions.sh
|
|
-
|
|
-update_bootconfig() {
|
|
- local offset=$1
|
|
- local index="$2"
|
|
- local cfgpart=$(find_mmc_part "0:BOOTCONFIG")
|
|
- local cur_index
|
|
-
|
|
- if [ -z "$cfgpart" ]; then
|
|
- echo "failed to get the partition: \"0:BOOTCONFIG\""
|
|
- return 1
|
|
- fi
|
|
-
|
|
- cur_index=$(dd if=${cfgpart} bs=1 count=1 skip=$offset 2> /dev/null | hexdump -e '"%d"')
|
|
- if [ ${index} != ${cur_index} ]; then
|
|
- echo "updating \"0:BOOTCONFIG\""
|
|
- echo -en "\x0${index}" | \
|
|
- dd of=${cfgpart} bs=1 count=1 seek=$offset conv=notrunc 2>/dev/null
|
|
- fi
|
|
-
|
|
- # also update 0:BOOTCONFIG1 if exists
|
|
- cfgpart=$(find_mmc_part "0:BOOTCONFIG1")
|
|
- [ -z "$cfgpart" ] && return
|
|
-
|
|
- cur_index=$(dd if=${cfgpart} bs=1 count=1 skip=$offset 2> /dev/null | hexdump -e '"%d"')
|
|
- if [ ${index} != ${cur_index} ]; then
|
|
- echo "updating \"0:BOOTCONFIG1\""
|
|
- echo -en "\x0${index}" | \
|
|
- dd of=${cfgpart} bs=1 count=1 seek=$offset conv=notrunc 2>/dev/null
|
|
- fi
|
|
-}
|
|
-
|
|
-### Note ###
|
|
-# After the commit bad1835f27ec31dbc30060b03cc714212275168a in fstools,
|
|
-# p17 (label: "rootfs_data") is mounted as a rootfs_data on boot instead
|
|
-# of the loop device labeled as "rootfs_data" in p15 (label: "rootfs").
|
|
-#
|
|
-# cmdline flag is added to avoid mount "rootfs_data" partition by the
|
|
-# commit 964d1e3af0e111bad6d393f8a3be702e334c2398 in fstools, but
|
|
-# NCP-HG100 doesn't use it because it has a large (abount 1.6GB)
|
|
-# "rootfs_data" partition and the advantage is larger than the
|
|
-# disadvantages, such as overwriting the stock data in "rootfs_data"
|
|
-# partition.
|
|
-sony_emmc_do_upgrade() {
|
|
- local tar_file=$1
|
|
- local kernel_dev
|
|
- local rootfs_dev
|
|
- local board_dir
|
|
-
|
|
- kernel_dev=$(find_mmc_part "0:HLOS")
|
|
- rootfs_dev=$(find_mmc_part "rootfs")
|
|
- rootfs_data_dev=$(find_mmc_part "rootfs_data")
|
|
-
|
|
- if [ -z "$kernel_dev" ] || [ -z "$rootfs_dev" ] || [ -z "$rootfs_data_dev" ]; then
|
|
- echo "The partition name for kernel or rootfs or rootfs_data is not specified or failed to get the mmc device."
|
|
- exit 1
|
|
- fi
|
|
-
|
|
- # use first partitions of kernel/rootfs for NCP-HG100
|
|
- # - offset 88 (0x58): 0:HLOS (kernel)
|
|
- # - offset 108 (0x6c): rootfs
|
|
- update_bootconfig 88 0 || exit 1
|
|
- update_bootconfig 108 0 || exit 1
|
|
-
|
|
- board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$')
|
|
- board_dir=${board_dir%/}
|
|
-
|
|
- echo "Flashing kernel to ${kernel_dev}"
|
|
- tar xf $tar_file ${board_dir}/kernel -O > $kernel_dev
|
|
-
|
|
- echo "Flashing rootfs to ${rootfs_dev}"
|
|
- tar xf $tar_file ${board_dir}/root -O > $rootfs_dev
|
|
-
|
|
- echo "Format new rootfs_data"
|
|
- mkfs.ext4 -F -L rootfs_data $rootfs_data_dev
|
|
-
|
|
- if [ -e "$UPGRADE_BACKUP" ]; then
|
|
- mkdir /tmp/new_root
|
|
- mount -t ext4 $rootfs_data_dev /tmp/new_root && {
|
|
- echo "Saving configurations to rootfs_data"
|
|
- cp "$UPGRADE_BACKUP" "/tmp/new_root/$BACKUP_FILE"
|
|
- umount /tmp/new_root
|
|
- }
|
|
- fi
|
|
-
|
|
- echo "sysupgrade successful"
|
|
-
|
|
- sync
|
|
- umount -a
|
|
- reboot -f
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/chromium/config-default b/target/linux/ipq40xx/chromium/config-default
|
|
deleted file mode 100644
|
|
index d78ca0ab28..0000000000
|
|
--- a/target/linux/ipq40xx/chromium/config-default
|
|
+++ /dev/null
|
|
@@ -1,10 +0,0 @@
|
|
-CONFIG_BLK_DEV_SD=y
|
|
-CONFIG_SCSI=y
|
|
-CONFIG_SCSI_COMMON=y
|
|
-CONFIG_SG_POOL=y
|
|
-CONFIG_USB_DWC3=y
|
|
-CONFIG_USB_DWC3_HOST=y
|
|
-CONFIG_USB_DWC3_QCOM=y
|
|
-CONFIG_USB_STORAGE=y
|
|
-CONFIG_USB_XHCI_HCD=y
|
|
-CONFIG_USB_XHCI_PLATFORM=y
|
|
diff --git a/target/linux/ipq40xx/chromium/target.mk b/target/linux/ipq40xx/chromium/target.mk
|
|
deleted file mode 100644
|
|
index 98bd37ed71..0000000000
|
|
--- a/target/linux/ipq40xx/chromium/target.mk
|
|
+++ /dev/null
|
|
@@ -1,3 +0,0 @@
|
|
-BOARDNAME:=Google Chromium
|
|
-FEATURES += emmc boot-part rootfs-part
|
|
-DEFAULT_PACKAGES += ath10k-board-qca4019
|
|
diff --git a/target/linux/ipq40xx/config-5.15 b/target/linux/ipq40xx/config-5.15
|
|
deleted file mode 100644
|
|
index 0acc013a81..0000000000
|
|
--- a/target/linux/ipq40xx/config-5.15
|
|
+++ /dev/null
|
|
@@ -1,508 +0,0 @@
|
|
-CONFIG_ALIGNMENT_TRAP=y
|
|
-# CONFIG_APQ_GCC_8084 is not set
|
|
-# CONFIG_APQ_MMCC_8084 is not set
|
|
-CONFIG_ARCH_32BIT_OFF_T=y
|
|
-CONFIG_ARCH_HIBERNATION_POSSIBLE=y
|
|
-CONFIG_ARCH_IPQ40XX=y
|
|
-CONFIG_ARCH_KEEP_MEMBLOCK=y
|
|
-# CONFIG_ARCH_MDM9615 is not set
|
|
-CONFIG_ARCH_MIGHT_HAVE_PC_PARPORT=y
|
|
-# CONFIG_ARCH_MSM8960 is not set
|
|
-# CONFIG_ARCH_MSM8974 is not set
|
|
-# CONFIG_ARCH_MSM8X60 is not set
|
|
-CONFIG_ARCH_MULTIPLATFORM=y
|
|
-CONFIG_ARCH_MULTI_V6_V7=y
|
|
-CONFIG_ARCH_MULTI_V7=y
|
|
-CONFIG_ARCH_NR_GPIO=0
|
|
-CONFIG_ARCH_OPTIONAL_KERNEL_RWX=y
|
|
-CONFIG_ARCH_OPTIONAL_KERNEL_RWX_DEFAULT=y
|
|
-CONFIG_ARCH_QCOM=y
|
|
-CONFIG_ARCH_SELECT_MEMORY_MODEL=y
|
|
-CONFIG_ARCH_SPARSEMEM_ENABLE=y
|
|
-CONFIG_ARCH_SUSPEND_POSSIBLE=y
|
|
-CONFIG_ARM=y
|
|
-CONFIG_ARM_AMBA=y
|
|
-CONFIG_ARM_APPENDED_DTB=y
|
|
-CONFIG_ARM_ARCH_TIMER=y
|
|
-CONFIG_ARM_ARCH_TIMER_EVTSTREAM=y
|
|
-# CONFIG_ARM_ATAG_DTB_COMPAT is not set
|
|
-CONFIG_ARM_CPUIDLE=y
|
|
-# CONFIG_ARM_CPU_TOPOLOGY is not set
|
|
-CONFIG_ARM_CRYPTO=y
|
|
-CONFIG_ARM_GIC=y
|
|
-CONFIG_ARM_HAS_SG_CHAIN=y
|
|
-CONFIG_ARM_L1_CACHE_SHIFT=6
|
|
-CONFIG_ARM_L1_CACHE_SHIFT_6=y
|
|
-CONFIG_ARM_PATCH_IDIV=y
|
|
-CONFIG_ARM_PATCH_PHYS_VIRT=y
|
|
-# CONFIG_ARM_QCOM_CPUFREQ_HW is not set
|
|
-# CONFIG_ARM_QCOM_CPUFREQ_NVMEM is not set
|
|
-# CONFIG_ARM_QCOM_SPM_CPUIDLE is not set
|
|
-# CONFIG_ARM_SMMU is not set
|
|
-CONFIG_ARM_THUMB=y
|
|
-CONFIG_ARM_UNWIND=y
|
|
-CONFIG_ARM_VIRT_EXT=y
|
|
-CONFIG_AT803X_PHY=y
|
|
-CONFIG_AUTO_ZRELADDR=y
|
|
-CONFIG_BCH=y
|
|
-CONFIG_BINFMT_FLAT_ARGVP_ENVP_ON_STACK=y
|
|
-CONFIG_BLK_DEV_LOOP=y
|
|
-CONFIG_BLK_MQ_PCI=y
|
|
-CONFIG_BOUNCE=y
|
|
-# CONFIG_CACHE_L2X0 is not set
|
|
-CONFIG_CLKSRC_QCOM=y
|
|
-CONFIG_CLONE_BACKWARDS=y
|
|
-CONFIG_CMDLINE_PARTITION=y
|
|
-CONFIG_COMMON_CLK=y
|
|
-CONFIG_COMMON_CLK_QCOM=y
|
|
-CONFIG_COMPAT_32BIT_TIME=y
|
|
-CONFIG_CPUFREQ_DT=y
|
|
-CONFIG_CPUFREQ_DT_PLATDEV=y
|
|
-CONFIG_CPU_32v6K=y
|
|
-CONFIG_CPU_32v7=y
|
|
-CONFIG_CPU_ABRT_EV7=y
|
|
-CONFIG_CPU_CACHE_V7=y
|
|
-CONFIG_CPU_CACHE_VIPT=y
|
|
-CONFIG_CPU_COPY_V6=y
|
|
-CONFIG_CPU_CP15=y
|
|
-CONFIG_CPU_CP15_MMU=y
|
|
-CONFIG_CPU_FREQ=y
|
|
-CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND=y
|
|
-# CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE is not set
|
|
-CONFIG_CPU_FREQ_GOV_ATTR_SET=y
|
|
-CONFIG_CPU_FREQ_GOV_COMMON=y
|
|
-# CONFIG_CPU_FREQ_GOV_CONSERVATIVE is not set
|
|
-CONFIG_CPU_FREQ_GOV_ONDEMAND=y
|
|
-CONFIG_CPU_FREQ_GOV_PERFORMANCE=y
|
|
-# CONFIG_CPU_FREQ_GOV_POWERSAVE is not set
|
|
-# CONFIG_CPU_FREQ_GOV_USERSPACE is not set
|
|
-CONFIG_CPU_FREQ_STAT=y
|
|
-CONFIG_CPU_HAS_ASID=y
|
|
-CONFIG_CPU_IDLE=y
|
|
-CONFIG_CPU_IDLE_GOV_LADDER=y
|
|
-CONFIG_CPU_IDLE_GOV_MENU=y
|
|
-CONFIG_CPU_IDLE_MULTIPLE_DRIVERS=y
|
|
-CONFIG_CPU_PABRT_V7=y
|
|
-CONFIG_CPU_PM=y
|
|
-CONFIG_CPU_RMAP=y
|
|
-CONFIG_CPU_SPECTRE=y
|
|
-CONFIG_CPU_THERMAL=y
|
|
-CONFIG_CPU_THUMB_CAPABLE=y
|
|
-CONFIG_CPU_TLB_V7=y
|
|
-CONFIG_CPU_V7=y
|
|
-CONFIG_CRC16=y
|
|
-# CONFIG_CRC32_SARWATE is not set
|
|
-CONFIG_CRC32_SLICEBY8=y
|
|
-CONFIG_CRC8=y
|
|
-CONFIG_CRYPTO_AES_ARM=y
|
|
-CONFIG_CRYPTO_AES_ARM_BS=y
|
|
-CONFIG_CRYPTO_BLAKE2S_ARM=y
|
|
-CONFIG_CRYPTO_CBC=y
|
|
-CONFIG_CRYPTO_CRYPTD=y
|
|
-CONFIG_CRYPTO_DEFLATE=y
|
|
-CONFIG_CRYPTO_DES=y
|
|
-CONFIG_CRYPTO_DEV_QCE=y
|
|
-# CONFIG_CRYPTO_DEV_QCE_ENABLE_AEAD is not set
|
|
-# CONFIG_CRYPTO_DEV_QCE_ENABLE_ALL is not set
|
|
-# CONFIG_CRYPTO_DEV_QCE_ENABLE_SHA is not set
|
|
-CONFIG_CRYPTO_DEV_QCE_ENABLE_SKCIPHER=y
|
|
-CONFIG_CRYPTO_DEV_QCE_SKCIPHER=y
|
|
-CONFIG_CRYPTO_DEV_QCE_SW_MAX_LEN=512
|
|
-CONFIG_CRYPTO_DEV_QCOM_RNG=y
|
|
-CONFIG_CRYPTO_DRBG=y
|
|
-CONFIG_CRYPTO_DRBG_HMAC=y
|
|
-CONFIG_CRYPTO_DRBG_MENU=y
|
|
-CONFIG_CRYPTO_ECB=y
|
|
-CONFIG_CRYPTO_HASH_INFO=y
|
|
-CONFIG_CRYPTO_HMAC=y
|
|
-CONFIG_CRYPTO_HW=y
|
|
-CONFIG_CRYPTO_JITTERENTROPY=y
|
|
-CONFIG_CRYPTO_LIB_BLAKE2S_GENERIC=y
|
|
-CONFIG_CRYPTO_LIB_DES=y
|
|
-CONFIG_CRYPTO_LIB_SHA256=y
|
|
-CONFIG_CRYPTO_LZO=y
|
|
-CONFIG_CRYPTO_RNG=y
|
|
-CONFIG_CRYPTO_RNG2=y
|
|
-CONFIG_CRYPTO_RNG_DEFAULT=y
|
|
-CONFIG_CRYPTO_SEQIV=y
|
|
-CONFIG_CRYPTO_SHA1=y
|
|
-CONFIG_CRYPTO_SHA256=y
|
|
-CONFIG_CRYPTO_SHA256_ARM=y
|
|
-CONFIG_CRYPTO_SHA512=y
|
|
-CONFIG_CRYPTO_SIMD=y
|
|
-CONFIG_CRYPTO_XTS=y
|
|
-CONFIG_CRYPTO_ZSTD=y
|
|
-CONFIG_DCACHE_WORD_ACCESS=y
|
|
-CONFIG_DEBUG_LL_INCLUDE="mach/debug-macro.S"
|
|
-CONFIG_DEBUG_MISC=y
|
|
-CONFIG_DMADEVICES=y
|
|
-CONFIG_DMA_ENGINE=y
|
|
-CONFIG_DMA_OF=y
|
|
-CONFIG_DMA_OPS=y
|
|
-CONFIG_DMA_REMAP=y
|
|
-CONFIG_DMA_SHARED_BUFFER=y
|
|
-CONFIG_DMA_VIRTUAL_CHANNELS=y
|
|
-CONFIG_DTC=y
|
|
-CONFIG_DT_IDLE_STATES=y
|
|
-CONFIG_EDAC_ATOMIC_SCRUB=y
|
|
-CONFIG_EDAC_SUPPORT=y
|
|
-CONFIG_EEPROM_AT24=y
|
|
-CONFIG_EXTCON=y
|
|
-CONFIG_FIXED_PHY=y
|
|
-CONFIG_FIX_EARLYCON_MEM=y
|
|
-CONFIG_FWNODE_MDIO=y
|
|
-CONFIG_FW_LOADER_PAGED_BUF=y
|
|
-CONFIG_GENERIC_ALLOCATOR=y
|
|
-CONFIG_GENERIC_BUG=y
|
|
-CONFIG_GENERIC_CLOCKEVENTS=y
|
|
-CONFIG_GENERIC_CLOCKEVENTS_BROADCAST=y
|
|
-CONFIG_GENERIC_CPU_AUTOPROBE=y
|
|
-CONFIG_GENERIC_CPU_VULNERABILITIES=y
|
|
-CONFIG_GENERIC_EARLY_IOREMAP=y
|
|
-CONFIG_GENERIC_GETTIMEOFDAY=y
|
|
-CONFIG_GENERIC_IDLE_POLL_SETUP=y
|
|
-CONFIG_GENERIC_IRQ_EFFECTIVE_AFF_MASK=y
|
|
-CONFIG_GENERIC_IRQ_MULTI_HANDLER=y
|
|
-CONFIG_GENERIC_IRQ_SHOW=y
|
|
-CONFIG_GENERIC_IRQ_SHOW_LEVEL=y
|
|
-CONFIG_GENERIC_LIB_DEVMEM_IS_ALLOWED=y
|
|
-CONFIG_GENERIC_MSI_IRQ=y
|
|
-CONFIG_GENERIC_MSI_IRQ_DOMAIN=y
|
|
-CONFIG_GENERIC_PCI_IOMAP=y
|
|
-CONFIG_GENERIC_PHY=y
|
|
-CONFIG_GENERIC_PINCONF=y
|
|
-CONFIG_GENERIC_PINCTRL_GROUPS=y
|
|
-CONFIG_GENERIC_PINMUX_FUNCTIONS=y
|
|
-CONFIG_GENERIC_SCHED_CLOCK=y
|
|
-CONFIG_GENERIC_SMP_IDLE_THREAD=y
|
|
-CONFIG_GENERIC_STRNCPY_FROM_USER=y
|
|
-CONFIG_GENERIC_STRNLEN_USER=y
|
|
-CONFIG_GENERIC_TIME_VSYSCALL=y
|
|
-CONFIG_GENERIC_VDSO_32=y
|
|
-CONFIG_GPIOLIB_IRQCHIP=y
|
|
-CONFIG_GPIO_74X164=y
|
|
-CONFIG_GPIO_CDEV=y
|
|
-CONFIG_GPIO_WATCHDOG=y
|
|
-CONFIG_GPIO_WATCHDOG_ARCH_INITCALL=y
|
|
-CONFIG_GRO_CELLS=y
|
|
-CONFIG_HANDLE_DOMAIN_IRQ=y
|
|
-CONFIG_HARDEN_BRANCH_PREDICTOR=y
|
|
-CONFIG_HARDIRQS_SW_RESEND=y
|
|
-CONFIG_HAS_DMA=y
|
|
-CONFIG_HAS_IOMEM=y
|
|
-CONFIG_HAS_IOPORT_MAP=y
|
|
-CONFIG_HAVE_SMP=y
|
|
-CONFIG_HIGHMEM=y
|
|
-# CONFIG_HIGHPTE is not set
|
|
-CONFIG_HWSPINLOCK=y
|
|
-CONFIG_HWSPINLOCK_QCOM=y
|
|
-CONFIG_HW_RANDOM=y
|
|
-CONFIG_HW_RANDOM_OPTEE=y
|
|
-CONFIG_HZ_FIXED=0
|
|
-CONFIG_I2C=y
|
|
-CONFIG_I2C_BOARDINFO=y
|
|
-CONFIG_I2C_CHARDEV=y
|
|
-CONFIG_I2C_HELPER_AUTO=y
|
|
-# CONFIG_I2C_QCOM_CCI is not set
|
|
-CONFIG_I2C_QUP=y
|
|
-CONFIG_INITRAMFS_SOURCE=""
|
|
-# CONFIG_IOMMU_DEBUGFS is not set
|
|
-# CONFIG_IOMMU_IO_PGTABLE_ARMV7S is not set
|
|
-# CONFIG_IOMMU_IO_PGTABLE_LPAE is not set
|
|
-CONFIG_IOMMU_SUPPORT=y
|
|
-# CONFIG_IPQ_APSS_PLL is not set
|
|
-CONFIG_IPQ_GCC_4019=y
|
|
-# CONFIG_IPQ_GCC_6018 is not set
|
|
-# CONFIG_IPQ_GCC_806X is not set
|
|
-# CONFIG_IPQ_GCC_8074 is not set
|
|
-# CONFIG_IPQ_LCC_806X is not set
|
|
-CONFIG_IRQCHIP=y
|
|
-CONFIG_IRQ_DOMAIN=y
|
|
-CONFIG_IRQ_DOMAIN_HIERARCHY=y
|
|
-CONFIG_IRQ_FASTEOI_HIERARCHY_HANDLERS=y
|
|
-CONFIG_IRQ_FORCED_THREADING=y
|
|
-CONFIG_IRQ_WORK=y
|
|
-CONFIG_KMAP_LOCAL=y
|
|
-CONFIG_KMAP_LOCAL_NON_LINEAR_PTE_ARRAY=y
|
|
-# CONFIG_KPSS_XCC is not set
|
|
-# CONFIG_KRAITCC is not set
|
|
-CONFIG_LEDS_LP5523=y
|
|
-CONFIG_LEDS_LP5562=y
|
|
-CONFIG_LEDS_LP55XX_COMMON=y
|
|
-CONFIG_LEDS_TLC591XX=y
|
|
-CONFIG_LIBFDT=y
|
|
-CONFIG_LOCK_DEBUGGING_SUPPORT=y
|
|
-CONFIG_LOCK_SPIN_ON_OWNER=y
|
|
-CONFIG_LZO_COMPRESS=y
|
|
-CONFIG_LZO_DECOMPRESS=y
|
|
-CONFIG_MDIO_BITBANG=y
|
|
-CONFIG_MDIO_BUS=y
|
|
-CONFIG_MDIO_DEVICE=y
|
|
-CONFIG_MDIO_DEVRES=y
|
|
-CONFIG_MDIO_GPIO=y
|
|
-CONFIG_MDIO_IPQ4019=y
|
|
-# CONFIG_MDM_GCC_9615 is not set
|
|
-# CONFIG_MDM_LCC_9615 is not set
|
|
-CONFIG_MEMFD_CREATE=y
|
|
-# CONFIG_MFD_HI6421_SPMI is not set
|
|
-# CONFIG_MFD_QCOM_RPM is not set
|
|
-# CONFIG_MFD_SPMI_PMIC is not set
|
|
-CONFIG_MFD_SYSCON=y
|
|
-CONFIG_MIGHT_HAVE_CACHE_L2X0=y
|
|
-CONFIG_MIGRATION=y
|
|
-CONFIG_MMC=y
|
|
-CONFIG_MMC_BLOCK=y
|
|
-CONFIG_MMC_CQHCI=y
|
|
-CONFIG_MMC_SDHCI=y
|
|
-CONFIG_MMC_SDHCI_IO_ACCESSORS=y
|
|
-CONFIG_MMC_SDHCI_MSM=y
|
|
-# CONFIG_MMC_SDHCI_PCI is not set
|
|
-CONFIG_MMC_SDHCI_PLTFM=y
|
|
-CONFIG_MODULES_USE_ELF_REL=y
|
|
-# CONFIG_MSM_GCC_8660 is not set
|
|
-# CONFIG_MSM_GCC_8916 is not set
|
|
-# CONFIG_MSM_GCC_8939 is not set
|
|
-# CONFIG_MSM_GCC_8960 is not set
|
|
-# CONFIG_MSM_GCC_8974 is not set
|
|
-# CONFIG_MSM_GCC_8994 is not set
|
|
-# CONFIG_MSM_GCC_8996 is not set
|
|
-# CONFIG_MSM_GCC_8998 is not set
|
|
-# CONFIG_MSM_GPUCC_8998 is not set
|
|
-# CONFIG_MSM_LCC_8960 is not set
|
|
-# CONFIG_MSM_MMCC_8960 is not set
|
|
-# CONFIG_MSM_MMCC_8974 is not set
|
|
-# CONFIG_MSM_MMCC_8996 is not set
|
|
-# CONFIG_MSM_MMCC_8998 is not set
|
|
-CONFIG_MTD_CMDLINE_PARTS=y
|
|
-CONFIG_MTD_NAND_CORE=y
|
|
-CONFIG_MTD_NAND_ECC=y
|
|
-CONFIG_MTD_NAND_ECC_SW_BCH=y
|
|
-CONFIG_MTD_NAND_ECC_SW_HAMMING=y
|
|
-CONFIG_MTD_NAND_QCOM=y
|
|
-# CONFIG_MTD_QCOMSMEM_PARTS is not set
|
|
-CONFIG_MTD_RAW_NAND=y
|
|
-CONFIG_MTD_SPI_NAND=y
|
|
-CONFIG_MTD_SPI_NOR=y
|
|
-CONFIG_MTD_SPLIT_FIRMWARE=y
|
|
-CONFIG_MTD_SPLIT_FIT_FW=y
|
|
-CONFIG_MTD_SPLIT_WRGG_FW=y
|
|
-CONFIG_MTD_UBI=y
|
|
-CONFIG_MTD_UBI_BEB_LIMIT=20
|
|
-CONFIG_MTD_UBI_BLOCK=y
|
|
-CONFIG_MTD_UBI_WL_THRESHOLD=4096
|
|
-CONFIG_MUTEX_SPIN_ON_OWNER=y
|
|
-CONFIG_NEED_DMA_MAP_STATE=y
|
|
-CONFIG_NEON=y
|
|
-CONFIG_NET_DEVLINK=y
|
|
-CONFIG_NET_DSA=y
|
|
-CONFIG_NET_DSA_QCA8K_IPQ4019=y
|
|
-CONFIG_NET_DSA_TAG_IPQ4019=y
|
|
-CONFIG_NET_FLOW_LIMIT=y
|
|
-CONFIG_NET_PTP_CLASSIFY=y
|
|
-CONFIG_NET_SELFTESTS=y
|
|
-CONFIG_NET_SWITCHDEV=y
|
|
-CONFIG_NLS=y
|
|
-CONFIG_NO_HZ=y
|
|
-CONFIG_NO_HZ_COMMON=y
|
|
-CONFIG_NO_HZ_IDLE=y
|
|
-CONFIG_NR_CPUS=4
|
|
-CONFIG_NVMEM=y
|
|
-CONFIG_NVMEM_QCOM_QFPROM=y
|
|
-# CONFIG_NVMEM_SPMI_SDAM is not set
|
|
-CONFIG_NVMEM_SYSFS=y
|
|
-CONFIG_OF=y
|
|
-CONFIG_OF_ADDRESS=y
|
|
-CONFIG_OF_EARLY_FLATTREE=y
|
|
-CONFIG_OF_FLATTREE=y
|
|
-CONFIG_OF_GPIO=y
|
|
-CONFIG_OF_IRQ=y
|
|
-CONFIG_OF_KOBJ=y
|
|
-CONFIG_OF_MDIO=y
|
|
-CONFIG_OLD_SIGACTION=y
|
|
-CONFIG_OLD_SIGSUSPEND3=y
|
|
-CONFIG_OPTEE=y
|
|
-CONFIG_OPTEE_SHM_NUM_PRIV_PAGES=1
|
|
-CONFIG_PADATA=y
|
|
-CONFIG_PAGE_OFFSET=0xC0000000
|
|
-CONFIG_PCI=y
|
|
-CONFIG_PCIEAER=y
|
|
-CONFIG_PCIEPORTBUS=y
|
|
-CONFIG_PCIE_DW=y
|
|
-CONFIG_PCIE_DW_HOST=y
|
|
-CONFIG_PCIE_QCOM=y
|
|
-CONFIG_PCI_DISABLE_COMMON_QUIRKS=y
|
|
-CONFIG_PCI_DOMAINS=y
|
|
-CONFIG_PCI_DOMAINS_GENERIC=y
|
|
-CONFIG_PCI_MSI=y
|
|
-CONFIG_PCI_MSI_IRQ_DOMAIN=y
|
|
-CONFIG_PERF_USE_VMALLOC=y
|
|
-CONFIG_PGTABLE_LEVELS=2
|
|
-CONFIG_PHYLIB=y
|
|
-CONFIG_PHYLINK=y
|
|
-# CONFIG_PHY_QCOM_APQ8064_SATA is not set
|
|
-CONFIG_PHY_QCOM_IPQ4019_USB=y
|
|
-# CONFIG_PHY_QCOM_IPQ806X_SATA is not set
|
|
-# CONFIG_PHY_QCOM_IPQ806X_USB is not set
|
|
-# CONFIG_PHY_QCOM_PCIE2 is not set
|
|
-# CONFIG_PHY_QCOM_QMP is not set
|
|
-# CONFIG_PHY_QCOM_QUSB2 is not set
|
|
-# CONFIG_PHY_QCOM_USB_HS_28NM is not set
|
|
-# CONFIG_PHY_QCOM_USB_SNPS_FEMTO_V2 is not set
|
|
-# CONFIG_PHY_QCOM_USB_SS is not set
|
|
-CONFIG_PINCTRL=y
|
|
-# CONFIG_PINCTRL_APQ8064 is not set
|
|
-# CONFIG_PINCTRL_APQ8084 is not set
|
|
-CONFIG_PINCTRL_IPQ4019=y
|
|
-# CONFIG_PINCTRL_IPQ6018 is not set
|
|
-# CONFIG_PINCTRL_IPQ8064 is not set
|
|
-# CONFIG_PINCTRL_IPQ8074 is not set
|
|
-# CONFIG_PINCTRL_MDM9615 is not set
|
|
-CONFIG_PINCTRL_MSM=y
|
|
-# CONFIG_PINCTRL_MSM8226 is not set
|
|
-# CONFIG_PINCTRL_MSM8660 is not set
|
|
-# CONFIG_PINCTRL_MSM8916 is not set
|
|
-# CONFIG_PINCTRL_MSM8960 is not set
|
|
-# CONFIG_PINCTRL_MSM8976 is not set
|
|
-# CONFIG_PINCTRL_MSM8994 is not set
|
|
-# CONFIG_PINCTRL_MSM8996 is not set
|
|
-# CONFIG_PINCTRL_MSM8998 is not set
|
|
-# CONFIG_PINCTRL_QCOM_SPMI_PMIC is not set
|
|
-# CONFIG_PINCTRL_QCOM_SSBI_PMIC is not set
|
|
-# CONFIG_PINCTRL_QCS404 is not set
|
|
-# CONFIG_PINCTRL_SC7180 is not set
|
|
-# CONFIG_PINCTRL_SDM660 is not set
|
|
-# CONFIG_PINCTRL_SDM845 is not set
|
|
-# CONFIG_PINCTRL_SM8150 is not set
|
|
-# CONFIG_PINCTRL_SM8250 is not set
|
|
-CONFIG_PM_OPP=y
|
|
-CONFIG_POWER_RESET=y
|
|
-CONFIG_POWER_RESET_GPIO_RESTART=y
|
|
-CONFIG_POWER_RESET_MSM=y
|
|
-CONFIG_POWER_SUPPLY=y
|
|
-CONFIG_PPS=y
|
|
-CONFIG_PRINTK_TIME=y
|
|
-CONFIG_PTP_1588_CLOCK=y
|
|
-CONFIG_PTP_1588_CLOCK_OPTIONAL=y
|
|
-CONFIG_QCA807X_PHY=y
|
|
-CONFIG_QCOM_A53PLL=y
|
|
-# CONFIG_QCOM_ADM is not set
|
|
-CONFIG_QCOM_BAM_DMA=y
|
|
-# CONFIG_QCOM_COMMAND_DB is not set
|
|
-# CONFIG_QCOM_CPR is not set
|
|
-# CONFIG_QCOM_EBI2 is not set
|
|
-# CONFIG_QCOM_GENI_SE is not set
|
|
-# CONFIG_QCOM_GSBI is not set
|
|
-# CONFIG_QCOM_HFPLL is not set
|
|
-# CONFIG_QCOM_IOMMU is not set
|
|
-CONFIG_QCOM_IPQ4019_ESS_EDMA=y
|
|
-# CONFIG_QCOM_LLCC is not set
|
|
-# CONFIG_QCOM_OCMEM is not set
|
|
-# CONFIG_QCOM_PDC is not set
|
|
-# CONFIG_QCOM_RMTFS_MEM is not set
|
|
-# CONFIG_QCOM_RPMH is not set
|
|
-CONFIG_QCOM_SCM=y
|
|
-# CONFIG_QCOM_SCM_DOWNLOAD_MODE_DEFAULT is not set
|
|
-CONFIG_QCOM_SMEM=y
|
|
-# CONFIG_QCOM_SMSM is not set
|
|
-# CONFIG_QCOM_SOCINFO is not set
|
|
-CONFIG_QCOM_TCSR=y
|
|
-# CONFIG_QCOM_TSENS is not set
|
|
-CONFIG_QCOM_WDT=y
|
|
-# CONFIG_QCS_GCC_404 is not set
|
|
-# CONFIG_QCS_Q6SSTOP_404 is not set
|
|
-# CONFIG_QCS_TURING_404 is not set
|
|
-CONFIG_RAS=y
|
|
-CONFIG_RATIONAL=y
|
|
-CONFIG_REGMAP=y
|
|
-CONFIG_REGMAP_I2C=y
|
|
-CONFIG_REGMAP_MMIO=y
|
|
-CONFIG_REGULATOR=y
|
|
-CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
|
-# CONFIG_REGULATOR_QCOM_LABIBB is not set
|
|
-# CONFIG_REGULATOR_QCOM_SPMI is not set
|
|
-# CONFIG_REGULATOR_QCOM_USB_VBUS is not set
|
|
-CONFIG_REGULATOR_VCTRL=y
|
|
-CONFIG_REGULATOR_VQMMC_IPQ4019=y
|
|
-CONFIG_RESET_CONTROLLER=y
|
|
-# CONFIG_RESET_QCOM_AOSS is not set
|
|
-# CONFIG_RESET_QCOM_PDC is not set
|
|
-CONFIG_RFS_ACCEL=y
|
|
-CONFIG_RPS=y
|
|
-CONFIG_RTC_CLASS=y
|
|
-CONFIG_RTC_I2C_AND_SPI=y
|
|
-CONFIG_RTC_MC146818_LIB=y
|
|
-CONFIG_RWSEM_SPIN_ON_OWNER=y
|
|
-# CONFIG_SC_DISPCC_7180 is not set
|
|
-# CONFIG_SC_GCC_7180 is not set
|
|
-# CONFIG_SC_GPUCC_7180 is not set
|
|
-# CONFIG_SC_LPASS_CORECC_7180 is not set
|
|
-# CONFIG_SC_MSS_7180 is not set
|
|
-# CONFIG_SC_VIDEOCC_7180 is not set
|
|
-# CONFIG_SDM_CAMCC_845 is not set
|
|
-# CONFIG_SDM_DISPCC_845 is not set
|
|
-# CONFIG_SDM_GCC_660 is not set
|
|
-# CONFIG_SDM_GCC_845 is not set
|
|
-# CONFIG_SDM_GPUCC_845 is not set
|
|
-# CONFIG_SDM_LPASSCC_845 is not set
|
|
-# CONFIG_SDM_VIDEOCC_845 is not set
|
|
-CONFIG_SERIAL_8250_FSL=y
|
|
-CONFIG_SERIAL_MCTRL_GPIO=y
|
|
-CONFIG_SERIAL_MSM=y
|
|
-CONFIG_SERIAL_MSM_CONSOLE=y
|
|
-CONFIG_SGL_ALLOC=y
|
|
-CONFIG_SMP=y
|
|
-CONFIG_SMP_ON_UP=y
|
|
-# CONFIG_SM_GCC_8150 is not set
|
|
-# CONFIG_SM_GCC_8250 is not set
|
|
-# CONFIG_SM_GPUCC_8150 is not set
|
|
-# CONFIG_SM_GPUCC_8250 is not set
|
|
-# CONFIG_SM_VIDEOCC_8150 is not set
|
|
-# CONFIG_SM_VIDEOCC_8250 is not set
|
|
-CONFIG_SOCK_RX_QUEUE_MAPPING=y
|
|
-CONFIG_SPARSE_IRQ=y
|
|
-CONFIG_SPI=y
|
|
-CONFIG_SPI_BITBANG=y
|
|
-CONFIG_SPI_GPIO=y
|
|
-CONFIG_SPI_MASTER=y
|
|
-CONFIG_SPI_MEM=y
|
|
-CONFIG_SPI_QUP=y
|
|
-CONFIG_SPMI=y
|
|
-# CONFIG_SPMI_HISI3670 is not set
|
|
-CONFIG_SPMI_MSM_PMIC_ARB=y
|
|
-# CONFIG_SPMI_PMIC_CLKDIV is not set
|
|
-CONFIG_SRCU=y
|
|
-CONFIG_SWPHY=y
|
|
-CONFIG_SWP_EMULATE=y
|
|
-CONFIG_SYS_SUPPORTS_APM_EMULATION=y
|
|
-CONFIG_TEE=y
|
|
-CONFIG_THERMAL=y
|
|
-CONFIG_THERMAL_DEFAULT_GOV_STEP_WISE=y
|
|
-CONFIG_THERMAL_EMERGENCY_POWEROFF_DELAY_MS=0
|
|
-CONFIG_THERMAL_GOV_STEP_WISE=y
|
|
-CONFIG_THERMAL_OF=y
|
|
-CONFIG_TICK_CPU_ACCOUNTING=y
|
|
-CONFIG_TIMER_OF=y
|
|
-CONFIG_TIMER_PROBE=y
|
|
-CONFIG_TREE_RCU=y
|
|
-CONFIG_TREE_SRCU=y
|
|
-CONFIG_UBIFS_FS=y
|
|
-CONFIG_UEVENT_HELPER_PATH=""
|
|
-CONFIG_UNCOMPRESS_INCLUDE="debug/uncompress.h"
|
|
-CONFIG_UNWINDER_ARM=y
|
|
-CONFIG_USB=y
|
|
-CONFIG_USB_COMMON=y
|
|
-CONFIG_USB_SUPPORT=y
|
|
-CONFIG_USE_OF=y
|
|
-CONFIG_VFP=y
|
|
-CONFIG_VFPv3=y
|
|
-CONFIG_WATCHDOG_CORE=y
|
|
-CONFIG_XPS=y
|
|
-CONFIG_XXHASH=y
|
|
-CONFIG_XZ_DEC_ARM=y
|
|
-CONFIG_XZ_DEC_BCJ=y
|
|
-CONFIG_ZBOOT_ROM_BSS=0
|
|
-CONFIG_ZBOOT_ROM_TEXT=0
|
|
-CONFIG_ZLIB_DEFLATE=y
|
|
-CONFIG_ZLIB_INFLATE=y
|
|
-CONFIG_ZSTD_COMPRESS=y
|
|
-CONFIG_ZSTD_DECOMPRESS=y
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-a42.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-a42.dts
|
|
deleted file mode 100644
|
|
index b6ff09a042..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-a42.dts
|
|
+++ /dev/null
|
|
@@ -1,233 +0,0 @@
|
|
-// SPDX-License-Identifier: ISC
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017, Sven Eckelmann <sven.eckelmann@openmesh.com>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "OpenMesh A42";
|
|
- compatible = "openmesh,a42";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_green;
|
|
- led-failsafe = &led_status_green;
|
|
- led-running = &led_status_green;
|
|
- led-upgrade = &led_status_green;
|
|
- label-mac-device = &swport5;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- status_red {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_green: status_green {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- status_blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- watchdog {
|
|
- compatible = "linux,wdt-gpio";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- hw_algo = "toggle";
|
|
- /* hw_margin_ms is actually 300s but driver limits it to 60s */
|
|
- hw_margin_ms = <60000>;
|
|
- always-running;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- /* partitions are passed via bootloader */
|
|
- partitions {
|
|
- partition-art {
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "0:ART";
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "ethernet2";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "ethernet1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "OM-A42";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "OM-A42";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ap120c-ac.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ap120c-ac.dts
|
|
deleted file mode 100644
|
|
index def0401ac5..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ap120c-ac.dts
|
|
+++ /dev/null
|
|
@@ -1,353 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "ALFA Network AP120C-AC";
|
|
- compatible = "alfa-network,ap120c-ac";
|
|
-
|
|
- aliases {
|
|
- led-boot = &status;
|
|
- led-failsafe = &status;
|
|
- led-running = &status;
|
|
- led-upgrade = &status;
|
|
- ethernet1 = &swport5;
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- status: status {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "amber:wan";
|
|
- gpios = <ðphy4 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "red:wlan5g";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- phys = <&usb3_hs_phy>;
|
|
- phy-names = "usb2-phy";
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&i2c0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- tpm@29 {
|
|
- compatible = "atmel,at97sc3204t";
|
|
- reg = <0x29>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "priv_data1";
|
|
- reg = <0x00180000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@190000 {
|
|
- label = "priv_data2";
|
|
- reg = <0x00190000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- nand@1 {
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs1";
|
|
- reg = <0x00000000 0x04000000>;
|
|
- };
|
|
-
|
|
- partition@4000000 {
|
|
- label = "rootfs2";
|
|
- reg = <0x04000000 0x04000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial0_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c0_pins: i2c0_pinmux {
|
|
- mux_i2c {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio58", "gpio59";
|
|
- drive-strength = <16>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_mdio {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_mdc {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial0_pins: serial0_pinmux {
|
|
- mux_uart {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi0_pins: spi0_pinmux {
|
|
- mux_spi {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio4";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ALFA-Network-AP120C-AC";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cap-ac.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cap-ac.dts
|
|
deleted file mode 100644
|
|
index 0609324310..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cap-ac.dts
|
|
+++ /dev/null
|
|
@@ -1,253 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MikroTik cAP ac";
|
|
- compatible = "mikrotik,cap-ac";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x08000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_user;
|
|
- led-failsafe = &led_user;
|
|
- led-running = &led_user;
|
|
- led-upgrade = &led_user;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- mode {
|
|
- label = "mode";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_LIGHTS_TOGGLE>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- led_user: user {
|
|
- label = "green:user";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- eth1 {
|
|
- label = "green:eth1";
|
|
- gpios = <ðphy4 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- eth2 {
|
|
- label = "green:eth2";
|
|
- gpios = <ðphy3 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <40000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x100000 0xf00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-cAP-ac";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-cAP-ac";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cs-w3-wd1200g-eup.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cs-w3-wd1200g-eup.dts
|
|
deleted file mode 100644
|
|
index 22a48c12c4..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-cs-w3-wd1200g-eup.dts
|
|
+++ /dev/null
|
|
@@ -1,290 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EZVIZ CS-W3-WD1200G EUP";
|
|
- compatible = "ezviz,cs-w3-wd1200g-eup";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_green;
|
|
- led-failsafe = &led_status_red;
|
|
- led-running = &led_status_blue;
|
|
- led-upgrade = &led_status_green;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <5000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status_red: status_red {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_status_green: status_green {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_status_blue: status_blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition1@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition2@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition3@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition4@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition5@E0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition6@F0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition7@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
-
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_art_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_6: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition9@580000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x00180000 0x00e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cells = <&macaddr_art_0>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "wan";
|
|
- nvmem-cells = <&macaddr_art_6>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ezviz-cs-w3-wd1200g-eup";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ezviz-cs-w3-wd1200g-eup";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-dap-2610.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-dap-2610.dts
|
|
deleted file mode 100644
|
|
index 493905d56d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-dap-2610.dts
|
|
+++ /dev/null
|
|
@@ -1,232 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "D-Link DAP 2610";
|
|
- compatible = "dlink,dap-2610";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_red;
|
|
- led-failsafe = &led_red;
|
|
- led-running = &led_green;
|
|
- led-upgrade = &led_red;
|
|
- };
|
|
-
|
|
- soc {
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_red: red {
|
|
- label = "red:power";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_green: green {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "fixed-partitions";
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@180000 {
|
|
- compatible = "wrg";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0xdc0000>;
|
|
- };
|
|
- partition@fb0000 {
|
|
- label = "rgbd";
|
|
- reg = <0xfb0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@fc0000 {
|
|
- label = "bdcfg";
|
|
- reg = <0xfc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@fd0000 {
|
|
- label = "langpack";
|
|
- reg = <0xfd0000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@ff0000 {
|
|
- label = "certificate";
|
|
- reg = <0xff0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f40000 {
|
|
- label = "captival";
|
|
- reg = <0xf40000 0x70000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "dlink,dap-2610";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "dlink,dap-2610";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ea6350v3.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ea6350v3.dts
|
|
deleted file mode 100644
|
|
index cd5b4c6ccc..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ea6350v3.dts
|
|
+++ /dev/null
|
|
@@ -1,307 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Linksys EA6350v3";
|
|
- compatible = "linksys,ea6350v3";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: status {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-ea6350v3";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-ea6350v3";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 { /* BLSP1 QUP1 */
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- SBL1@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- MBIB@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- QSEE@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- CDT@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- APPSBLENV@d0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- APPSBL@e0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000e0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- ART@160000 {
|
|
- label = "ART";
|
|
- reg = <0x00160000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- u_env@170000 {
|
|
- label = "u_env";
|
|
- reg = <0x00170000 0x00020000>;
|
|
- };
|
|
- s_env@190000 {
|
|
- label = "s_env";
|
|
- reg = <0x00190000 0x00020000>;
|
|
- };
|
|
- devinfo@1b0000 {
|
|
- label = "devinfo";
|
|
- reg = <0x001b0000 0x00010000>;
|
|
- };
|
|
- /* 0x001c0000 - 0x00200000 unused */
|
|
- };
|
|
- };
|
|
-
|
|
- flash@1 {
|
|
- status = "okay";
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- kernel@0 {
|
|
- label = "kernel";
|
|
- reg = <0x00000000 0x02800000>;
|
|
- };
|
|
- rootfs@500000 {
|
|
- label = "rootfs";
|
|
- reg = <0x00500000 0x02300000>;
|
|
- };
|
|
- alt_kernel@2800000 {
|
|
- label = "alt_kernel";
|
|
- reg = <0x02800000 0x02800000>;
|
|
- };
|
|
- alt_rootfs@2d00000 {
|
|
- label = "alt_rootfs";
|
|
- reg = <0x02d00000 0x02300000>;
|
|
- };
|
|
- sysdiag@5000000 {
|
|
- label = "sysdiag";
|
|
- reg = <0x05000000 0x00100000>;
|
|
- };
|
|
- syscfg@5100000 {
|
|
- label = "syscfg";
|
|
- reg = <0x05100000 0x02F00000>;
|
|
- };
|
|
- /* 0x00000000 - 0x08000000: 128 MiB */
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-eap1300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-eap1300.dts
|
|
deleted file mode 100644
|
|
index a8f24aa00e..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-eap1300.dts
|
|
+++ /dev/null
|
|
@@ -1,230 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EnGenius EAP1300";
|
|
- compatible = "engenius,eap1300";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_HIGH>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: orange {
|
|
- label = "orange:power";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan {
|
|
- label = "blue:lan";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- mesh {
|
|
- label = "blue:mesh";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "yellow:wlan5g";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio54", "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- m25p80@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition6@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x00090000>;
|
|
- read-only;
|
|
- };
|
|
- partition7@180000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00180000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- partition8@190000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x190000 0x1dc0000>;
|
|
- };
|
|
- partition9@1f50000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0x01f50000 0x00010000>;
|
|
- };
|
|
- partition10@1f60000 {
|
|
- label = "userconfig";
|
|
- reg = <0x01f60000 0x000a0000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EAP1300";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EAP1300";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ecw5211.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ecw5211.dts
|
|
deleted file mode 100644
|
|
index 3060b7bd1c..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ecw5211.dts
|
|
+++ /dev/null
|
|
@@ -1,329 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Edgecore ECW5211";
|
|
- compatible = "edgecore,ecw5211";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- ethernet0 = &swport5;
|
|
- ethernet1 = &gmac;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: power {
|
|
- label = "yellow:power";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- phys = <&usb3_hs_phy>;
|
|
- phy-names = "usb2-phy";
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_mdio {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_mdc {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi0_pins: spi0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio4";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c0_pins: i2c0_pinmux {
|
|
- mux_i2c {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio58", "gpio59";
|
|
- drive-strength = <16>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV"; /* uboot env */
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- flash@1 {
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs";
|
|
- reg = <0x00000000 0x04000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&i2c0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- tpm@29 {
|
|
- compatible = "atmel,at97sc3204t";
|
|
- reg = <0x29>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "ALFA-Network-AP120C-AC";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emd1.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emd1.dts
|
|
deleted file mode 100644
|
|
index 396595ba51..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emd1.dts
|
|
+++ /dev/null
|
|
@@ -1,210 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EnGenius EMD1";
|
|
- compatible = "engenius,emd1";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: power {
|
|
- label = "white:power";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "red:wlan2g";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "blue:wlan5g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- mesh {
|
|
- label = "orange:mesh";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio54", "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition6@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition7@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition8@180000 {
|
|
- label = "userconfig";
|
|
- reg = <0x00180000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition9@200000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x200000 0x01e00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EMD1";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EMD1";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emr3500.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emr3500.dts
|
|
deleted file mode 100644
|
|
index 3616149451..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-emr3500.dts
|
|
+++ /dev/null
|
|
@@ -1,215 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EnGenius EMR3500";
|
|
- compatible = "engenius,emr3500";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2_hs_phy: hsphy@a8000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: white {
|
|
- label = "white:power";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- blue {
|
|
- label = "blue";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- red {
|
|
- label = "red";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- orange {
|
|
- label = "orange";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio54", "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- m25p80@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@180000 {
|
|
- label = "userconfig";
|
|
- reg = <0x00180000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@200000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x200000 0x1e00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EMR3500";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EMR3500";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ens620ext.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ens620ext.dts
|
|
deleted file mode 100644
|
|
index 69275e24b8..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ens620ext.dts
|
|
+++ /dev/null
|
|
@@ -1,249 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EnGenius ENS620EXT";
|
|
- compatible = "engenius,ens620ext";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- /*
|
|
- * Disable the broken restart as a workaround for the buggy
|
|
- * 3.0.0/3.0.1 U-boots that ship with the device.
|
|
- * Note: The watchdog is now used to restart this device.
|
|
- */
|
|
- restart@4ab000 {
|
|
- status = "disabled";
|
|
- };
|
|
- };
|
|
-
|
|
- buttons {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: power {
|
|
- label = "amber:power";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan1 {
|
|
- label = "green:lan1";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan2 {
|
|
- label = "green:lan2";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 { /* BLSP1 QUP1 */
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <50000000>;
|
|
- m25p,fast-read;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00090000>;
|
|
- read-only;
|
|
- };
|
|
- partition@180000 {
|
|
- label = "ART";
|
|
- reg = <0x00180000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@190000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x00190000 0x14d0000>;
|
|
- };
|
|
- partition@1660000 {
|
|
- label = "failsafe";
|
|
- reg = <0x01660000 0x008F0000>;
|
|
- read-only;
|
|
- };
|
|
- partition@1f50000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0x01f50000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@1f60000 {
|
|
- label = "userconfig";
|
|
- reg = <0x01f60000 0x000a0000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-ENS620EXT";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "EnGenius-ENS620EXT";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6100v2.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6100v2.dts
|
|
deleted file mode 100644
|
|
index 1495c64da9..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6100v2.dts
|
|
+++ /dev/null
|
|
@@ -1,31 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2018, David Bauer <mail@david-bauer.net>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4018-ex61x0v2.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Netgear EX6100v2";
|
|
- compatible = "netgear,ex6100v2";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "Netgear-EX6100v2";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- qcom,ath10k-calibration-variant = "Netgear-EX6100v2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6150v2.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6150v2.dts
|
|
deleted file mode 100644
|
|
index ce24466e54..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex6150v2.dts
|
|
+++ /dev/null
|
|
@@ -1,31 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2018, David Bauer <mail@david-bauer.net>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4018-ex61x0v2.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Netgear EX6150v2";
|
|
- compatible = "netgear,ex6150v2";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "Netgear-EX6150v2";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- qcom,ath10k-calibration-variant = "Netgear-EX6150v2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex61x0v2.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex61x0v2.dtsi
|
|
deleted file mode 100644
|
|
index dc5c25c84a..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-ex61x0v2.dtsi
|
|
+++ /dev/null
|
|
@@ -1,339 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2018, David Bauer <mail@david-bauer.net>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Netgear EX61X0v2";
|
|
- compatible = "netgear,ex61x0v2";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power_amber;
|
|
- led-failsafe = &power_amber;
|
|
- led-running = &power_green;
|
|
- led-upgrade = &power_amber;
|
|
- label-mac-device = &gmac;
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- led_spi {
|
|
- compatible = "spi-gpio";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- sck-gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- mosi-gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- num-chipselects = <0>;
|
|
-
|
|
- led_gpio: led_gpio@0 {
|
|
- compatible = "fairchild,74hc595";
|
|
- reg = <0>;
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
- registers-number = <1>;
|
|
- spi-max-frequency = <1000000>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power_amber: power_amber {
|
|
- label = "amber:power";
|
|
- gpios = <&led_gpio 7 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- power_green: power_green {
|
|
- label = "green:power";
|
|
- gpios = <&led_gpio 6 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- right {
|
|
- label = "blue:right";
|
|
- gpios = <&led_gpio 5 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- left {
|
|
- label = "blue:left";
|
|
- gpios = <&led_gpio 4 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- client_green {
|
|
- label = "green:client";
|
|
- gpios = <&led_gpio 3 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- client_red {
|
|
- label = "red:client";
|
|
- gpios = <&led_gpio 2 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- router_green {
|
|
- label = "green:router";
|
|
- gpios = <&led_gpio 1 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- router_red {
|
|
- label = "red:router";
|
|
- gpios = <&led_gpio 0 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "green:wps";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- mx25l12805d@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <45000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition1@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition2@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition3@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition4@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition5@E0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition6@F0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition7@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- compatible = "nvmem-cells";
|
|
- read-only;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition8@180000 {
|
|
- label = "config";
|
|
- reg = <0x00180000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition9@190000 {
|
|
- label = "pot";
|
|
- reg = <0x00190000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition10@1a0000 {
|
|
- compatible = "nvmem-cells";
|
|
- label = "dnidata";
|
|
- reg = <0x001a0000 0x00010000>;
|
|
- read-only;
|
|
-
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_dnidata_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_dnidata_c: macaddr@c {
|
|
- reg = <0xc 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition11@1b0000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x001b0000 0x00e10000>;
|
|
- };
|
|
-
|
|
- partition12@fc0000 {
|
|
- label = "language";
|
|
- reg = <0x00fc0000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_dnidata_0>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_dnidata_c>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-fritzbox-4040.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-fritzbox-4040.dts
|
|
deleted file mode 100644
|
|
index e448206c36..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-fritzbox-4040.dts
|
|
+++ /dev/null
|
|
@@ -1,324 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "AVM FRITZ!Box 4040";
|
|
- compatible = "avm,fritzbox-4040";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &flash;
|
|
- led-running = &power;
|
|
- led-upgrade = &flash;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wlan {
|
|
- label = "wlan";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RFKILL>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- switch-leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <ðphy0 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- panic: info_red {
|
|
- label = "red:info";
|
|
- gpios = <ðphy0 1 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "green:wan";
|
|
- gpios = <ðphy1 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- power: power {
|
|
- label = "green:power";
|
|
- gpios = <ðphy2 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan {
|
|
- label = "green:lan";
|
|
- gpios = <ðphy3 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- flash: info_amber {
|
|
- label = "amber:info";
|
|
- gpios = <ðphy3 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 { /* BLSP1 QUP1 */
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- status = "okay";
|
|
- m25p,fast-read;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env - empty */
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition6@f0000 {
|
|
- label = "urlader"; /* APPSBL */
|
|
- reg = <0x000f0000 0x0002dc000>;
|
|
- read-only;
|
|
- };
|
|
- partition7@11dc00 {
|
|
- /* make a backup of this partition! */
|
|
- label = "urlader_config";
|
|
- reg = <0x0011dc00 0x00002400>;
|
|
- read-only;
|
|
- };
|
|
- partition8@120000 {
|
|
- label = "tffs1";
|
|
- reg = <0x00120000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition9@1a0000 {
|
|
- label = "tffs2";
|
|
- reg = <0x001a0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition10@220000 {
|
|
- label = "uboot";
|
|
- reg = <0x00220000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition11@2A0000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x002a0000 0x01c60000>;
|
|
- };
|
|
- partition12@1f00000 {
|
|
- label = "jffs2";
|
|
- reg = <0x01f00000 0x00100000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- line-name = "enable USB3 power";
|
|
- gpios = <1 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZBox-4040";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZBox-4040";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-a1300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-a1300.dts
|
|
deleted file mode 100644
|
|
index ad3d1ac120..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-a1300.dts
|
|
+++ /dev/null
|
|
@@ -1,334 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "GL.iNet GL-A1300";
|
|
- compatible = "glinet,gl-a1300", "qcom,ipq4019";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_run;
|
|
- led-failsafe = &led_run;
|
|
- led-running = &led_run;
|
|
- led-upgrade = &led_run;
|
|
- label-mac-device = &swport4;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- switch {
|
|
- label = "switch-button";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_SETUP>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_run: blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- white {
|
|
- label = "white:status";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- gpio_export {
|
|
- compatible = "gpio-export";
|
|
-
|
|
- usb {
|
|
- gpio-export,name = "usb_power";
|
|
- gpio-export,output = <1>;
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "log";
|
|
- reg = <0x00180000 0x00020000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 {
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x08000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- pinmux {
|
|
- pins = "gpio58", "gpio59";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi0_pins: spi0_pinmux {
|
|
- mux_spi {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio5";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
- mac-address-increment = <2>;
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "GL-A1300";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "GL-A1300";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-ap1300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-ap1300.dts
|
|
deleted file mode 100644
|
|
index 6f5d4d8a57..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-gl-ap1300.dts
|
|
+++ /dev/null
|
|
@@ -1,302 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "GL.iNet GL-AP1300";
|
|
- compatible = "glinet,gl-ap1300";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: power {
|
|
- label = "white:power";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "on";
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "white:wan";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_art_0: mac-address@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_6: mac-address@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x08000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi0_pins: spi0_pinmux {
|
|
- mux_spi {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio5";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_0>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "wan";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_6>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "GL-AP1300";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "GL-AP1300";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-hap-ac2.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-hap-ac2.dts
|
|
deleted file mode 100644
|
|
index c8868d8b30..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-hap-ac2.dts
|
|
+++ /dev/null
|
|
@@ -1,296 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MikroTik hAP ac2";
|
|
- compatible = "mikrotik,hap-ac2";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x08000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_user;
|
|
- led-failsafe = &led_user;
|
|
- led-running = &led_user;
|
|
- led-upgrade = &led_user;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- phys = <&usb3_hs_phy>;
|
|
- phy-names = "usb2-phy";
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- mode {
|
|
- label = "mode";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RFKILL>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_user: user {
|
|
- label = "green:user";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <2 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable USB power";
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <40000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- size = <0x2000>;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x100000 0xf00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-hAP-ac2";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-hAP-ac2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dts
|
|
deleted file mode 100644
|
|
index 988b86b68d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dts
|
|
+++ /dev/null
|
|
@@ -1,9 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2018, Robert Marko <robimarko@gmail.com>
|
|
-
|
|
-#include "qcom-ipq4018-jalapeno.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "8devices Jalapeno";
|
|
- compatible = "8dev,jalapeno";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dtsi
|
|
deleted file mode 100644
|
|
index 4d09e86dd6..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-jalapeno.dtsi
|
|
+++ /dev/null
|
|
@@ -1,276 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2018, Robert Marko <robimarko@gmail.com>
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- aliases {
|
|
- ethernet1 = &swport5;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3: usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- pinmux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- };
|
|
-
|
|
- pinmux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- };
|
|
-
|
|
- pinconf {
|
|
- pins = "gpio52", "gpio53";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x08000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "8devices-Jalapeno";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "8devices-Jalapeno";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-magic-2-wifi-next.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-magic-2-wifi-next.dts
|
|
deleted file mode 100644
|
|
index 29d51aa9e1..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-magic-2-wifi-next.dts
|
|
+++ /dev/null
|
|
@@ -1,233 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "devolo Magic 2 WiFi next";
|
|
- compatible = "devolo,magic-2-wifi-next";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- gpio_export {
|
|
- compatible = "gpio-export";
|
|
- #size-cells = <0>;
|
|
-
|
|
- plc {
|
|
- gpio-export,name = "plc-enable";
|
|
- gpio-export,output = <1>;
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wlan {
|
|
- label = "WLAN";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "Reset";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- status_dlan {
|
|
- label = "white:dlan";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- status_wlan {
|
|
- label = "white:wlan";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- error_dlan {
|
|
- label = "red:dlan";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio61", "gpio60";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- button_pins: button_pinmux {
|
|
- mux {
|
|
- function = "gpio";
|
|
- pins = "gpio0", "gpio5";
|
|
- bias-disable;
|
|
- input;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "devolo,magic-2-wifi-next";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "devolo,magic-2-wifi-next";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- linux,modalias = "n25q128a11";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- firmware@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x00180000 0x01a80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-meshpoint-one.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-meshpoint-one.dts
|
|
deleted file mode 100644
|
|
index 62ba76802d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-meshpoint-one.dts
|
|
+++ /dev/null
|
|
@@ -1,81 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2019, CRISIS INNOVATION LAB d.o.o.
|
|
- * Author: Robert Marko <robert@meshpoint.me>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4018-jalapeno.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Crisis Innovation Lab MeshPoint.One";
|
|
- compatible = "cilab,meshpoint-one";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_status;
|
|
- };
|
|
-
|
|
- soc {
|
|
- i2c-gpio {
|
|
- status = "okay";
|
|
-
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- compatible = "i2c-gpio";
|
|
- gpios = <&tlmm 0 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN) /* sda */
|
|
- &tlmm 4 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN) /* scl */
|
|
- >;
|
|
-
|
|
- bme280@76 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "bosch,bme280";
|
|
- reg = <0x76>;
|
|
- };
|
|
-
|
|
- pcf2129@51 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "nxp,pcf2129";
|
|
- reg = <0x51>;
|
|
- };
|
|
-
|
|
- ina230@40 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "ti,ina230";
|
|
- reg = <0x40>;
|
|
- shunt-resistor = <2000>;
|
|
- };
|
|
-
|
|
- ina230@44 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "ti,ina230";
|
|
- reg = <0x44>;
|
|
- shunt-resistor = <2000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART >;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status: status {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287.dts
|
|
deleted file mode 100644
|
|
index 43e39bdf96..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287.dts
|
|
+++ /dev/null
|
|
@@ -1,221 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Giammarco Marzano <stich86@gmail.com>.
|
|
-// Copyright (c) 2023, Andreas Böhler <dev@aboehler.at>
|
|
-
|
|
-#include "qcom-ipq4018-mf287_common.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF287";
|
|
- compatible = "zte,mf287";
|
|
-};
|
|
-
|
|
-&gpio_modem_reset {
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
-};
|
|
-
|
|
-&key_reset {
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&key_wps {
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&led_status {
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 { /* flash@1 ? */
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0x140000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@140000 {
|
|
- label = "ART";
|
|
- reg = <0x140000 0x140000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "mac";
|
|
- reg = <0x280000 0x140000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mac_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@3c0000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x3c0000 0x600000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@9c0000 {
|
|
- label = "oops";
|
|
- reg = <0x9c0000 0x140000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "web";
|
|
- reg = <0xb00000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1300000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1300000 0x2200000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x3200000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- zigbee@2 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- compatible = "silabs,em3581";
|
|
- reg = <2>;
|
|
- spi-max-frequency = <12000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59", "gpio1";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "zte,mf287";
|
|
-};
|
|
-
|
|
-&wifi1{
|
|
- qcom,ath10k-calibration-variant = "zte,mf287";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287_common.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287_common.dtsi
|
|
deleted file mode 100644
|
|
index 5227243467..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287_common.dtsi
|
|
+++ /dev/null
|
|
@@ -1,191 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Giammarco Marzano <stich86@gmail.com>.
|
|
-// Copyright (c) 2023, Andreas Böhler <dev@aboehler.at>
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_status;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * bootargs forced by u-boot bootipq command:
|
|
- * 'ubi.mtd=rootfs root=mtd:ubi_rootfs rootfstype=squashfs rootwait'
|
|
- */
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status: led-0 {
|
|
- label = "blue:power";
|
|
- function = LED_FUNCTION_POWER;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- };
|
|
- };
|
|
-
|
|
- gpio_export {
|
|
- compatible = "gpio-export";
|
|
- #size-cells = <0>;
|
|
-
|
|
- gpio_modem_reset: modem {
|
|
- gpio-export,name = "modem-reset";
|
|
- gpio-export,output = <0>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- key_reset: key-reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- key_wps: key-wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_mac_0>;
|
|
- mac-address-increment = <2>;
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_mac_0>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_mac_0>;
|
|
- mac-address-increment = <1>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287plus.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287plus.dts
|
|
deleted file mode 100644
|
|
index f09a77ff59..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287plus.dts
|
|
+++ /dev/null
|
|
@@ -1,221 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Giammarco Marzano <stich86@gmail.com>.
|
|
-// Copyright (c) 2023, Andreas Böhler <dev@aboehler.at>
|
|
-
|
|
-#include "qcom-ipq4018-mf287_common.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF287Plus";
|
|
- compatible = "zte,mf287plus";
|
|
-};
|
|
-
|
|
-&gpio_modem_reset {
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
-};
|
|
-
|
|
-&key_reset {
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&key_wps {
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&led_status {
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 { /* flash@1 ? */
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0x140000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@140000 {
|
|
- label = "ART";
|
|
- reg = <0x140000 0x140000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "mac";
|
|
- reg = <0x280000 0x140000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mac_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@3c0000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x3c0000 0x600000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@9c0000 {
|
|
- label = "oops";
|
|
- reg = <0x9c0000 0x140000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "web";
|
|
- reg = <0xb00000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1300000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1300000 0x2200000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x3200000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- zigbee@2 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- compatible = "silabs,em3581";
|
|
- reg = <2>;
|
|
- spi-max-frequency = <12000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59", "gpio1";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "zte,mf287plus";
|
|
-};
|
|
-
|
|
-&wifi1{
|
|
- qcom,ath10k-calibration-variant = "zte,mf287plus";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287pro.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287pro.dts
|
|
deleted file mode 100644
|
|
index 4fd44989c5..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-mf287pro.dts
|
|
+++ /dev/null
|
|
@@ -1,268 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Giammarco Marzano <stich86@gmail.com>.
|
|
-// Copyright (c) 2023, Andreas Böhler <dev@aboehler.at>
|
|
-
|
|
-#include "qcom-ipq4018-mf287_common.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF287Pro";
|
|
- compatible = "zte,mf287pro";
|
|
-
|
|
- regulator-usb-vbus {
|
|
- compatible = "regulator-fixed";
|
|
- regulator-name = "USB_VBUS";
|
|
- regulator-min-microvolt = <5000000>;
|
|
- regulator-max-microvolt = <5000000>;
|
|
- regulator-always-on;
|
|
- regulator-boot-on;
|
|
- gpio = <&tlmm 25 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-};
|
|
-
|
|
-&gpio_modem_reset {
|
|
- gpios = <&tlmm 8 GPIO_ACTIVE_HIGH>;
|
|
-};
|
|
-
|
|
-&key_reset {
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&key_wps {
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&led_status {
|
|
- gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 { /* flash@1 ? */
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a0000 {
|
|
- label = "ART";
|
|
- reg = <0xa0000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@120000 {
|
|
- label = "mac";
|
|
- reg = <0x120000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mac_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1a0000 {
|
|
- label = "reserved2";
|
|
- reg = <0x1a0000 0xc0000>;
|
|
- };
|
|
-
|
|
- partition@260000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x260000 0x400000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@660000 {
|
|
- label = "log";
|
|
- reg = <0x660000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@a60000 {
|
|
- label = "oops";
|
|
- reg = <0xa60000 0xa0000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "reserved3";
|
|
- reg = <0xb00000 0x500000>;
|
|
- };
|
|
-
|
|
- partition@1000000 {
|
|
- label = "web";
|
|
- reg = <0x1000000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1800000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1800000 0x1d00000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x3200000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio12", "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12", "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-/* The MF287Plus and MF287Pro share the same board data file */
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "zte,mf287plus";
|
|
-};
|
|
-
|
|
-/* The MF287Plus and MF287Pro share the same board data file */
|
|
-&wifi1{
|
|
- qcom,ath10k-calibration-variant = "zte,mf287plus";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-nbg6617.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-nbg6617.dts
|
|
deleted file mode 100644
|
|
index ff7252d696..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-nbg6617.dts
|
|
+++ /dev/null
|
|
@@ -1,361 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/input/linux-event-codes.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "ZyXEL NBG6617";
|
|
- compatible = "zyxel,nbg6617";
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * the vendor u-boot adds root and mtdparts cmdline parameters
|
|
- * which we don't want... but we have to overwrite them or else
|
|
- * the kernel will take them at face value.
|
|
- */
|
|
- bootargs-append = " mtdparts= root=31:13";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb2_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wlan {
|
|
- label = "wlan";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- linux,code = <KEY_RFKILL>;
|
|
- linux,input-type = <EV_SW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
- pinctrl-0 = <&led_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- power: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- usb {
|
|
- label = "green:usb";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- trigger-sources = <&usb2_port1>, <&usb3_port1>, <&usb3_port2>;
|
|
- linux,default-trigger = "usbport";
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "green:wps";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-low;
|
|
- };
|
|
- };
|
|
- led_pins: led_pinmux {
|
|
- mux {
|
|
- pins = "gpio0", "gpio1", "gpio3", "gpio5", "gpio58";
|
|
- drive-strength = <0x8>;
|
|
- bias-disable;
|
|
- output-low;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 { /* BLSP1 QUP1 */
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <50000000>;
|
|
- status = "okay";
|
|
- m25p,fast-read;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "APPSBL"; /* u-boot */
|
|
- reg = <0x000e0000 0x00080000>;
|
|
- /* U-Boot Standalone App "zloader" is located at 0x64000 */
|
|
- read-only;
|
|
- };
|
|
- partition6@160000 {
|
|
- label = "APPSBLENV"; /* u-boot env */
|
|
- reg = <0x00160000 0x00010000>;
|
|
- };
|
|
- partition7@170000 {
|
|
- /* make a backup of this partition! */
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition8@180000 {
|
|
- label = "kernel";
|
|
- reg = <0x00180000 0x00400000>;
|
|
- };
|
|
- partition9@580000 {
|
|
- label = "dualflag";
|
|
- reg = <0x00580000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition10@590000 {
|
|
- label = "header";
|
|
- reg = <0x00590000 0x00010000>;
|
|
- };
|
|
- partition11@5a0000 {
|
|
- label = "romd";
|
|
- reg = <0x005a0000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition12@6a0000 {
|
|
- label = "not_root_data";
|
|
- /*
|
|
- * for some strange reason, someone at ZyXEL
|
|
- * had the "great" idea to put the rootfs_data
|
|
- * in front of rootfs... Don't do that!
|
|
- * As a result this one, full MebiByte remains
|
|
- * unused.
|
|
- */
|
|
- reg = <0x006a0000 0x00100000>;
|
|
- };
|
|
- partition13@7a0000 {
|
|
- label = "rootfs";
|
|
- reg = <0x007a0000 0x01860000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ZyXEL-NBG6617";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ZyXEL-NBG6617";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-pa1200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-pa1200.dts
|
|
deleted file mode 100644
|
|
index af4a7b196b..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-pa1200.dts
|
|
+++ /dev/null
|
|
@@ -1,225 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2017-2020, Sven Eckelmann <sven@narfation.org>
|
|
- * Copyright (c) 2018, Marek Lindner <marek.lindner@kaiwoo.ai>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Plasma Cloud PA1200";
|
|
- compatible = "plasmacloud,pa1200";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_purple;
|
|
- led-failsafe = &led_status_yellow;
|
|
- led-running = &led_status_cyan;
|
|
- led-upgrade = &led_status_yellow;
|
|
- label-mac-device = &swport5;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status_cyan: status_cyan {
|
|
- label = "cyan:status";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_purple: status_purple {
|
|
- label = "purple:status";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_yellow: status_yellow {
|
|
- label = "yellow:status";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- /* partitions are passed via bootloader */
|
|
- partitions {
|
|
- partition-art {
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "0:ART";
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "ethernet2";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "ethernet1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "PlasmaCloud-PA1200";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "PlasmaCloud-PA1200";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rt-ac58u.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rt-ac58u.dts
|
|
deleted file mode 100644
|
|
index 87705e5f60..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rt-ac58u.dts
|
|
+++ /dev/null
|
|
@@ -1,316 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "ASUS RT-AC58U";
|
|
- compatible = "asus,rt-ac58u";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x8000000>;
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: status {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "blue:wan";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2G {
|
|
- label = "blue:wlan2G";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5G {
|
|
- label = "blue:wlan5G";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- usb {
|
|
- label = "blue:usb";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- trigger-sources = <&usb3_port1>, <&usb3_port2>;
|
|
- linux,default-trigger = "usbport";
|
|
- };
|
|
-
|
|
- lan {
|
|
- label = "blue:lan";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 { /* BLSP1 QUP1 */
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- /*
|
|
- * U-boot looks for "n25q128a11" node,
|
|
- * if we don't have it, it will spit out the following warning:
|
|
- * "ipq: fdt fixup unable to find compatible node".
|
|
- */
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- linux,modalias = "m25p80", "mx25l1606e", "n25q128a11";
|
|
- spi-max-frequency = <30000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- /* 0x00180000 - 0x00200000 unused */
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 {
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <30000000>;
|
|
-
|
|
- /*
|
|
- * U-boot looks for "spinand,mt29f" node,
|
|
- * if we don't have it, it will spit out the following warning:
|
|
- * "ipq: fdt fixup unable to find compatible node".
|
|
- */
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x08000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "RT-AC58U";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "RT-AC58U";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx.dtsi
|
|
deleted file mode 100644
|
|
index df9425b12a..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx.dtsi
|
|
+++ /dev/null
|
|
@@ -1,210 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-ap.dk01.1.dtsi"
|
|
-
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- pinctrl@1000000 {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio58", "gpio59";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 4 1>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- cs-gpios = <&tlmm 54 0>, <&tlmm 63 0>;
|
|
- num-cs = <2>;
|
|
-
|
|
- xt25f128b@0 {
|
|
- /*
|
|
- * Factory U-boot looks in 0:BOOTCONFIG partition for active
|
|
- * partitions settings and mangles the partition config so
|
|
- * 0:QSEE/0:QSEE_1, 0:CDT/0:CDT_1 and 0:APPSBL/0:APPSBL_1 pairs
|
|
- * can be swaped. It isn't a problem but we never can be sure where
|
|
- * OFW put factory images. "n25q128a11" is required for proper nor
|
|
- * recognition in u-boot.
|
|
- */
|
|
- compatible = "jedec,spi-nor", "n25q128a11";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:BOOTCONFIG";
|
|
- reg = <0x60000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- label = "0:BOOTCONFIG1";
|
|
- reg = <0x80000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a0000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0xa0000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "0:QSEE_1";
|
|
- reg = <0x100000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@160000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x160000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:CDT_1";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x180000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@190000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x190000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1a0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x1a0000 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@240000 {
|
|
- label = "0:APPSBL_1";
|
|
- reg = <0x240000 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2e0000 {
|
|
- label = "0:ART";
|
|
- reg = <0x2e0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- config: partition@2f0000 {
|
|
- label = "0:CONFIG";
|
|
- reg = <0x2f0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@300000 {
|
|
- label = "0:CONFIG_RW";
|
|
- reg = <0x300000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@310000 {
|
|
- label = "0:EVENTSLOG";
|
|
- reg = <0x310000 0x90000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- xt26g02a@1 {
|
|
- /*
|
|
- * Factory U-boot looks in 0:BOOTCONFIG partition for active
|
|
- * partitions settings and mangles the partition config so
|
|
- * rootfs/rootfs_1 pairs can be swaped.
|
|
- * It isn't a problem but we never can be sure where OFW put
|
|
- * factory images. "spinand,mt29f" value is required for proper
|
|
- * nand recognition in u-boot.
|
|
- */
|
|
- compatible = "spi-nand", "spinand,mt29f";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs_1";
|
|
- reg = <0x00000000 0x08000000>;
|
|
- };
|
|
-
|
|
- partition@8000000 {
|
|
- label = "rootfs";
|
|
- reg = <0x08000000 0x08000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- phy-reset-gpio = <&tlmm 62 0>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx10.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx10.dts
|
|
deleted file mode 100644
|
|
index 8fc976a11b..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx10.dts
|
|
+++ /dev/null
|
|
@@ -1,73 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4018-rutx.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Teltonika RUTX10";
|
|
- compatible = "teltonika,rutx10";
|
|
-
|
|
- soc {
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wifi2g {
|
|
- label = "green:wifi2g";
|
|
- gpios = <&stm32_io 19 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wifi5g {
|
|
- label = "green:wifi5g";
|
|
- gpios = <&stm32_io 18 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- gpio_export {
|
|
- compatible = "gpio-export";
|
|
- #size-cells = <0>;
|
|
-
|
|
- gpio_out {
|
|
- gpio-export,name = "gpio_out";
|
|
- gpio-export,output = <0>;
|
|
- gpio-export,direction_may_change = <0>;
|
|
- gpios = <&stm32_io 23 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- gpio_in {
|
|
- gpio-export,name = "gpio_in";
|
|
- gpio-export,input = <0>;
|
|
- gpio-export,direction_may_change = <0>;
|
|
- gpios = <&stm32_io 24 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- clock-frequency = <400000>;
|
|
-
|
|
- stm32_io: stm32@74 {
|
|
- compatible = "tlt,stm32v1";
|
|
- #gpio-cells = <2>;
|
|
- #interrupt-cells = <2>;
|
|
- gpio-controller;
|
|
- interrupt-controller;
|
|
- interrupt-parent = <&tlmm>;
|
|
- interrupts = <5 2>;
|
|
- reg = <0x74>;
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Teltonika-RUTX10";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Teltonika-RUTX10";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx50.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx50.dts
|
|
deleted file mode 100644
|
|
index ea2102f7d6..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-rutx50.dts
|
|
+++ /dev/null
|
|
@@ -1,181 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4018-rutx.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Teltonika RUTX50";
|
|
- compatible = "teltonika,rutx50";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_rssi0;
|
|
- led-failsafe = &led_rssi0;
|
|
- led-running = &led_rssi0;
|
|
- led-upgrade = &led_rssi0;
|
|
- label-mac-device = &gmac;
|
|
- };
|
|
-
|
|
- soc {
|
|
- gpio-export {
|
|
- compatible = "gpio-export";
|
|
- #size-cells = <0>;
|
|
-
|
|
- gpio_modem_reset {
|
|
- gpio-export,name = "modem_reset";
|
|
- gpio-export,output = <0>;
|
|
- gpios = <&shift_io 8 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- gpio_modem_power {
|
|
- gpio-export,name = "modem_power";
|
|
- gpio-export,output = <0>;
|
|
- gpios = <&shift_io 9 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- gpio_out_1 {
|
|
- gpio-export,name = "sim-select";
|
|
- /* 0 = SIM1 ; 1 = SIM2 */
|
|
- gpio-export,output = <0>;
|
|
- gpios = <&shift_io 10 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- gpio_in_1 {
|
|
- gpio-export,name = "sim-detect";
|
|
- gpio-export,input = <0>;
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led-0 {
|
|
- label = "green:sim1";
|
|
- gpios = <&shift_io 14 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- label = "green:sim2";
|
|
- gpios = <&shift_io 15 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-2 {
|
|
- label = "green:eth";
|
|
- gpios = <&shift_io 6 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-3 {
|
|
- label = "green:wifi";
|
|
- gpios = <&shift_io 7 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-4 {
|
|
- label = "green:3g";
|
|
- gpios = <&shift_io 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-5 {
|
|
- label = "green:4g";
|
|
- gpios = <&shift_io 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-6 {
|
|
- label = "green:5g";
|
|
- gpios = <&shift_io 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_rssi0: led-7 {
|
|
- label = "green:rssi0";
|
|
- gpios = <&shift_io 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-8 {
|
|
- label = "green:rssi1";
|
|
- gpios = <&shift_io 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-9 {
|
|
- label = "green:rssi2";
|
|
- gpios = <&shift_io 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-10 {
|
|
- label = "green:wifi2g";
|
|
- gpios = <&shift_io 12 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-11 {
|
|
- label = "green:wifi5g";
|
|
- gpios = <&shift_io 13 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- spi-gpio {
|
|
- compatible = "spi-gpio";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- gpio-sck = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- gpio-mosi = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- cs-gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- num-chipselects = <1>;
|
|
-
|
|
- shift_io: shift_io@0 {
|
|
- compatible = "fairchild,74hc595";
|
|
- reg = <0>;
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
- /* Attn: This is specific to RUTX50 in Teltonika GPL */
|
|
- registers-number = <2>;
|
|
- spi-max-frequency = <10000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Teltonika-RUTX10";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Teltonika-RUTX10";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-sxtsq-5-ac.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-sxtsq-5-ac.dts
|
|
deleted file mode 100644
|
|
index de3fa96922..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-sxtsq-5-ac.dts
|
|
+++ /dev/null
|
|
@@ -1,239 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MikroTik SXTsq 5 ac (RBSXTsqG-5acD)";
|
|
- compatible = "mikrotik,sxtsq-5-ac";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_user;
|
|
- led-failsafe = &led_user;
|
|
- led-running = &led_user;
|
|
- led-upgrade = &led_user;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII_RGMII4>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_user: user {
|
|
- label = "green:user";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rssilow {
|
|
- label = "green:rssilow";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rssimediumlow {
|
|
- label = "green:rssimediumlow";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rssimedium {
|
|
- label = "green:rssimedium";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rssimediumhigh {
|
|
- label = "green:rssimediumhigh";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rssihigh {
|
|
- label = "green:rssihigh";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <40000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x100000 0xf00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-SXTsq-5-ac";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-
|
|
- /delete-property/ psgmii-ethphy;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- phy-mode = "rgmii";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wac510.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wac510.dts
|
|
deleted file mode 100644
|
|
index 2dbfaa086e..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wac510.dts
|
|
+++ /dev/null
|
|
@@ -1,380 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "Netgear WAC510";
|
|
- compatible = "netgear,wac510";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power_amber;
|
|
- led-failsafe = &led_power_amber;
|
|
- led-running = &led_power_green;
|
|
- led-upgrade = &led_power_amber;
|
|
- ethernet1 = &swport5;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- led_spi {
|
|
- compatible = "spi-gpio";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- sck-gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- mosi-gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- num-chipselects = <0>;
|
|
-
|
|
- ssr: ssr@0 {
|
|
- compatible = "fairchild,74hc595";
|
|
- reg = <0>;
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
- registers-number = <1>;
|
|
- spi-max-frequency = <1000000>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power_amber: led-0 {
|
|
- label = "amber:power";
|
|
- color = <LED_COLOR_ID_AMBER>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- gpios = <&ssr 6 GPIO_ACTIVE_LOW>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_power_green: led-1 {
|
|
- label = "green:power";
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- gpios = <&ssr 5 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led-2 {
|
|
- /* 2.4GHz blue - activity */
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <0>;
|
|
- gpios = <&ssr 4 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- led-3 {
|
|
- /* 2.4GHz green - link */
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <0>;
|
|
- gpios = <&ssr 3 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0radio";
|
|
- };
|
|
-
|
|
- led-4 {
|
|
- /* 5GHz blue - activity */
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <1>;
|
|
- gpios = <&ssr 2 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- led-5 {
|
|
- /* 5GHz green - link */
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <1>;
|
|
- gpios = <&ssr 1 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1radio";
|
|
- };
|
|
-
|
|
- led-6 {
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_ACTIVITY;
|
|
- gpios = <&ssr 0 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <50000000>;
|
|
- reg = <0>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x000f0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1e0000 {
|
|
- label = "0:MANUDATA";
|
|
- reg = <0x001e0000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_manudata_6: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1f0000 {
|
|
- label = "0:ART";
|
|
- reg = <0x001f0000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- nand@1 {
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <48000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs";
|
|
- reg = <0x00000000 0x03800000>;
|
|
- };
|
|
-
|
|
- partition@3800000 {
|
|
- label = "rootfs_1";
|
|
- reg = <0x03800000 0x03800000>;
|
|
- };
|
|
-
|
|
- partition@7000000 {
|
|
- label = "var_config";
|
|
- reg = <0x07000000 0x00f00000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@7f00000 {
|
|
- label = "Oops_log";
|
|
- reg = <0x07f00000 0x000c0000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 62 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_manudata_6>;
|
|
- qcom,ath10k-calibration-variant = "Netgear-WAC510";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_manudata_6>;
|
|
- mac-address-increment = <16>;
|
|
- qcom,ath10k-calibration-variant = "Netgear-WAC510";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac-lte.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac-lte.dts
|
|
deleted file mode 100644
|
|
index 8ff18d92b7..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac-lte.dts
|
|
+++ /dev/null
|
|
@@ -1,45 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2022, Alexander Couzens <lynxis@fe80.eu> */
|
|
-
|
|
-#include "qcom-ipq4018-wap-ac.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "MikroTik wAP ac LTE";
|
|
- compatible = "mikrotik,wap-ac-lte";
|
|
-
|
|
- soc {
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- phys = <&usb3_hs_phy>;
|
|
- phy-names = "usb2-phy";
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <2 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable USB power";
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dts
|
|
deleted file mode 100644
|
|
index 1bfcbf1e33..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dts
|
|
+++ /dev/null
|
|
@@ -1,9 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4018-wap-ac.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "MikroTik wAP ac";
|
|
- compatible = "mikrotik,wap-ac";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dtsi
|
|
deleted file mode 100644
|
|
index 777f46e3af..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-ac.dtsi
|
|
+++ /dev/null
|
|
@@ -1,215 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2020, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x08000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_user;
|
|
- led-failsafe = &led_user;
|
|
- led-running = &led_user;
|
|
- led-upgrade = &led_user;
|
|
- };
|
|
-
|
|
- soc {
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- led_user: user {
|
|
- label = "green:user";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <40000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- size = <0x2000>;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x100000 0xf00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "sw-eth2";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "sw-eth1";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-wAP-ac";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-wAP-ac";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-r-ac.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-r-ac.dts
|
|
deleted file mode 100644
|
|
index e7f28f23cf..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wap-r-ac.dts
|
|
+++ /dev/null
|
|
@@ -1,45 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2022, Alexander Couzens <lynxis@fe80.eu> */
|
|
-
|
|
-#include "qcom-ipq4018-wap-ac.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "MikroTik wAP R ac";
|
|
- compatible = "mikrotik,wap-r-ac";
|
|
-
|
|
- soc {
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- phys = <&usb3_hs_phy>;
|
|
- phy-names = "usb2-phy";
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <2 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable USB power";
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-whw01.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-whw01.dts
|
|
deleted file mode 100644
|
|
index 5859548254..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-whw01.dts
|
|
+++ /dev/null
|
|
@@ -1,336 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/leds/common.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Linksys WHW01";
|
|
- compatible = "linksys,whw01";
|
|
-
|
|
- aliases {
|
|
- serial0 = &blsp1_uart1;
|
|
- led-boot = &led_system_blue;
|
|
- led-running = &led_system_blue;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- bootargs-append = " root=/dev/ubiblock0_0";
|
|
- };
|
|
-
|
|
- soc {
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-1 = <&i2c_0_pins>;
|
|
- pinctrl-names = "i2c_active", "i2c_sleep";
|
|
-
|
|
- leds@62 {
|
|
- compatible = "nxp,pca9633";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- reg = <0x62>;
|
|
-
|
|
- /* RGB? */
|
|
- led@0 {
|
|
- reg = <0>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- reg = <1>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- led_system_blue: led@2 {
|
|
- reg = <2>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- nor@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xd0000 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
-
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "u_env";
|
|
- reg = <0x180000 0x40000>;
|
|
- };
|
|
-
|
|
- partition@1c0000 {
|
|
- label = "s_env";
|
|
- reg = <0x1c0000 0x20000>;
|
|
- };
|
|
-
|
|
- partition@1e0000 {
|
|
- label = "devinfo";
|
|
- reg = <0x1e0000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- nand@1 {
|
|
- reg = <1>;
|
|
- compatible = "spi-nand";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "kernel";
|
|
- reg = <0x0000000 0x5000000>;
|
|
- };
|
|
-
|
|
- partition@600000 {
|
|
- label = "rootfs";
|
|
- reg = <0x0600000 0x4a00000>;
|
|
- };
|
|
-
|
|
- partition@5000000 {
|
|
- label = "alt_kernel";
|
|
- reg = <0x5000000 0x5000000>;
|
|
- };
|
|
-
|
|
- partition@5600000 {
|
|
- label = "alt_rootfs";
|
|
- reg = <0x5600000 0x4a00000>;
|
|
- };
|
|
-
|
|
- partition@a000000 {
|
|
- label = "sysdiag";
|
|
- reg = <0xa000000 0x0200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a200000 {
|
|
- label = "syscfg";
|
|
- reg = <0xa200000 0x5e00000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- phy-reset-gpio = <&tlmm 62 GPIO_ACTIVE_HIGH>;
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_mdio {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_mdc {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio4";
|
|
- };
|
|
-
|
|
- pinconf {
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinconf_cs {
|
|
- pins = "gpio54", "gpio4";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio58", "gpio59";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- reset_pinmux {
|
|
- mux {
|
|
- pins = "gpio63";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "linksys-whw01-v1";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "linksys-whw01-v1";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "eth1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "eth2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wr-1.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wr-1.dts
|
|
deleted file mode 100644
|
|
index 16951da47f..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wr-1.dts
|
|
+++ /dev/null
|
|
@@ -1,292 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Pakedge WR-1";
|
|
- compatible = "pakedge,wr-1";
|
|
-
|
|
- aliases {
|
|
- label-mac-device = &gmac;
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
- pinctrl-0 = <&key_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
- pinctrl-0 = <&led_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- led_power: power {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_LOW>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "blue:wlan5g";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0000000 0x0040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x0040000 0x0020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x0060000 0x0060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x00c0000 0x0010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x00d0000 0x0010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x00e0000 0x0010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x00f0000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x0170000 0x0010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "firmware";
|
|
- reg = <0x0180000 0x1e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- key_pins: key_pinmux {
|
|
- mux {
|
|
- function = "gpio";
|
|
- pins = "gpio59";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- led_pins: led_pinmux {
|
|
- mux {
|
|
- function = "gpio";
|
|
- pins = "gpio0", "gpio1", "gpio2";
|
|
- bias-none;
|
|
- drive-strength = <2>;
|
|
- output-low;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- function = "blsp_uart0";
|
|
- pins = "gpio60", "gpio61";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- bias-disable;
|
|
- drive-strength = <12>;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- bias-disable;
|
|
- drive-strength = <2>;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "Pakedge-WR-1";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "Pakedge-WR-1";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wre6606.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wre6606.dts
|
|
deleted file mode 100644
|
|
index efb267ae36..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wre6606.dts
|
|
+++ /dev/null
|
|
@@ -1,252 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2018, David Bauer <mail@david-bauer.net>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "ZyXEL WRE6606";
|
|
- compatible = "zyxel,wre6606";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " mtdparts=";
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wps {
|
|
- label = "green:wps";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g_green {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- power: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan5g_red {
|
|
- label = "red:wlan5g";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2g_red {
|
|
- label = "red:wlan2g";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2g_green {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- mx25l12805d@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition1@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition2@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition3@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition4@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition5@E0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition6@F0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition7@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition8@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x00180000 0x00ce0000>;
|
|
- };
|
|
-
|
|
- partition9@e60000 {
|
|
- label = "manufacture";
|
|
- reg = <0x00e60000 0x00050000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition10@eb0000 {
|
|
- label = "storage";
|
|
- reg = <0x00eb0000 0x00150000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ZyXEL-WRE6606";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ZyXEL-WRE6606";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wrtq-329acn.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wrtq-329acn.dts
|
|
deleted file mode 100644
|
|
index 4694c56819..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4018-wrtq-329acn.dts
|
|
+++ /dev/null
|
|
@@ -1,302 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Luma Home WRTQ-329ACN";
|
|
- compatible = "luma,wrtq-329acn";
|
|
-
|
|
- i2c-gpio {
|
|
- compatible = "i2c-gpio";
|
|
- sda-gpios = <&tlmm 1 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN)>;
|
|
- scl-gpios = <&tlmm 0 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN)>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- /* No driver exists */
|
|
- led_ring@48 {
|
|
- compatible = "ti,msp430";
|
|
- reg = <0x48>;
|
|
- };
|
|
-
|
|
- eeprom@50 {
|
|
- compatible = "atmel,24c16";
|
|
- reg = <0x50>;
|
|
- pagesize = <16>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
- pinctrl-0 = <&spi0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x000000 0x040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x040000 0x020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x060000 0x060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x0c0000 0x010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x0d0000 0x010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x0e0000 0x010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x0f0000 0x080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_art_0: macaddr@0{
|
|
- reg = <0x0000 0x0006>;
|
|
- };
|
|
-
|
|
- macaddr_art_6: macaddr@6{
|
|
- reg = <0x0006 0x0006>;
|
|
- };
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- flash@1 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x0000000 0x8000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial0_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_art_6>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_art_0>;
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial0_pins: serial0_pinmux {
|
|
- mux {
|
|
- function = "blsp_uart0";
|
|
- pins = "gpio60", "gpio61";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi0_pins: spi0_pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- bias-disable;
|
|
- drive-strength = <12>;
|
|
- };
|
|
-
|
|
- mux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- bias-disable;
|
|
- drive-strength = <2>;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "Luma-WRTQ-329ACN";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "Luma-WRTQ-329ACN";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-a62.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-a62.dts
|
|
deleted file mode 100644
|
|
index d348101110..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-a62.dts
|
|
+++ /dev/null
|
|
@@ -1,269 +0,0 @@
|
|
-// SPDX-License-Identifier: ISC
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017-2018, Sven Eckelmann <sven.eckelmann@openmesh.com>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "OpenMesh A62";
|
|
- compatible = "openmesh,a62";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART >;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_green;
|
|
- led-failsafe = &led_status_green;
|
|
- led-running = &led_status_green;
|
|
- led-upgrade = &led_status_green;
|
|
- label-mac-device = &swport4;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- status_red {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_green: status_green {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- status_blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- watchdog {
|
|
- compatible = "linux,wdt-gpio";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- hw_algo = "toggle";
|
|
- /* hw_margin_ms is actually 300s but driver limits it to 60s */
|
|
- hw_margin_ms = <60000>;
|
|
- always-running;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <58 GPIO_ACTIVE_HIGH>;
|
|
- output-low;
|
|
- line-name = "enable USB2 power";
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- /* partitions are passed via bootloader */
|
|
- partitions {
|
|
- partition-art {
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "0:ART";
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- qcom,ath10k-calibration-variant = "OM-A62";
|
|
- ieee80211-freq-limit = <5170000 5350000>;
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_9000>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "ethernet1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "ethernet2";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "OM-A62";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "OM-A62";
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-cm520-79f.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-cm520-79f.dts
|
|
deleted file mode 100644
|
|
index 1dde17e293..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-cm520-79f.dts
|
|
+++ /dev/null
|
|
@@ -1,387 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MobiPromo CM520-79F";
|
|
- compatible = "mobipromo,cm520-79f";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_sys;
|
|
- led-failsafe = &led_sys;
|
|
- led-running = &led_sys;
|
|
- led-upgrade = &led_sys;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <1000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb2_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- led_spi {
|
|
- compatible = "spi-gpio";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- sck-gpios = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
- mosi-gpios = <&tlmm 36 GPIO_ACTIVE_HIGH>;
|
|
- num-chipselects = <0>;
|
|
-
|
|
- led_gpio: led_gpio@0 {
|
|
- compatible = "fairchild,74hc595";
|
|
- reg = <0>;
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
- registers-number = <1>;
|
|
- spi-max-frequency = <1000000>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- usb {
|
|
- label = "blue:usb";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "usbport";
|
|
- trigger-sources = <&usb3_port1>, <&usb3_port2>, <&usb2_port1>;
|
|
- };
|
|
-
|
|
- led_sys: can {
|
|
- label = "blue:can";
|
|
- gpios = <&tlmm 11 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "blue:wan";
|
|
- gpios = <&led_gpio 0 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan1 {
|
|
- label = "blue:lan1";
|
|
- gpios = <&led_gpio 1 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan2 {
|
|
- label = "blue:lan2";
|
|
- gpios = <&led_gpio 2 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&led_gpio 5 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "blue:wlan5g";
|
|
- gpios = <&led_gpio 6 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x100000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "BOOTCONFIG";
|
|
- reg = <0x200000 0x100000>;
|
|
- };
|
|
-
|
|
- partition@300000 {
|
|
- label = "QSEE";
|
|
- reg = <0x300000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@400000 {
|
|
- label = "QSEE_1";
|
|
- reg = <0x400000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@500000 {
|
|
- label = "CDT";
|
|
- reg = <0x500000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@580000 {
|
|
- label = "CDT_1";
|
|
- reg = <0x580000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@600000 {
|
|
- label = "BOOTCONFIG1";
|
|
- reg = <0x600000 0x80000>;
|
|
- };
|
|
-
|
|
- partition@680000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x680000 0x80000>;
|
|
- };
|
|
-
|
|
- partition@700000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x700000 0x200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@900000 {
|
|
- label = "APPSBL_1";
|
|
- reg = <0x900000 0x200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- art: partition@b00000 {
|
|
- label = "ART";
|
|
- reg = <0xb00000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_art_1006: macaddr@1006 {
|
|
- reg = <0x1006 0x6>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_art_5006: macaddr@5006 {
|
|
- reg = <0x5006 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@b80000 {
|
|
- label = "ubi";
|
|
- reg = <0xb80000 0x7480000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_1006>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_5006>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "CM520-79F";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "CM520-79F";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c1.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c1.dts
|
|
deleted file mode 100644
|
|
index 70e05c7eef..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c1.dts
|
|
+++ /dev/null
|
|
@@ -1,136 +0,0 @@
|
|
-/* SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
- *
|
|
- * Copyright (c) 2018 Peng Zhang <sd20@qxwlan.com>
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019-e2600ac.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Qxwlan E2600AC c1";
|
|
- compatible = "qxwlan,e2600ac-c1";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- partition@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0x1e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "Qxwlan-E2600AC-C1";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "Qxwlan-E2600AC-C1";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "sw-eth1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "sw-eth2";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c2.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c2.dts
|
|
deleted file mode 100644
|
|
index 2ad794e8ec..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac-c2.dts
|
|
+++ /dev/null
|
|
@@ -1,179 +0,0 @@
|
|
-/* SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
- *
|
|
- * Copyright (c) 2018 Peng Zhang <sd20@qxwlan.com>
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019-e2600ac.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Qxwlan E2600AC c2";
|
|
- compatible = "qxwlan,e2600ac-c2";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x04000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- nand_pins: nand-pins {
|
|
-
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "Qxwlan-E2600AC-C2";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "Qxwlan-E2600AC-C2";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "sw-eth1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "sw-eth2";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "sw-eth3";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac.dtsi
|
|
deleted file mode 100644
|
|
index 9689bc566f..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-e2600ac.dtsi
|
|
+++ /dev/null
|
|
@@ -1,244 +0,0 @@
|
|
-/* SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
- *
|
|
- * Copyright (c) 2018 Peng Zhang <sd20@qxwlan.com>
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
-
|
|
- model = "Qxwlan E2600AC";
|
|
- compatible = "qcom,ipq4019";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>; /* 256MB */
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb2_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- serial@78af000 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- serial@78b0000 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- i2c@78b7000 { /* BLSP1 QUP2 */
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3: usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led1 {
|
|
- label = "green:wlan0";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led2 {
|
|
- label = "green:wlan1";
|
|
- gpios = <&tlmm 36 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led3 {
|
|
- label = "green:usb";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- trigger-sources = <&usb2_port1>, <&usb3_port1>, <&usb3_port2>;
|
|
- linux,default-trigger = "usbport";
|
|
- };
|
|
-
|
|
- led4 {
|
|
- label = "green:ctrl1";
|
|
- gpios = <&tlmm 51 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led5 {
|
|
- label = "green:ctrl2";
|
|
- gpios = <&tlmm 30 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led6 {
|
|
- label = "green:ctrl3";
|
|
- gpios = <&tlmm 31 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c-0-pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0-pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ea8300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ea8300.dts
|
|
deleted file mode 100644
|
|
index 5a738da33d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ea8300.dts
|
|
+++ /dev/null
|
|
@@ -1,95 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-xx8300.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Linksys EA8300 (Dallas)";
|
|
- compatible = "linksys,ea8300", "qcom,ipq4019";
|
|
-
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_wps_amber;
|
|
- led-failsafe = &led_wps;
|
|
- led-running = &led_linksys;
|
|
- led-upgrade = &led_world;
|
|
- serial0 = &blsp1_uart1;
|
|
- };
|
|
-
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- // Retain node names from running OEM on EA8300
|
|
-
|
|
- // Front panel LEDs, top to bottom
|
|
-
|
|
- led_plug: diag {
|
|
- label = "amber:plug";
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_world: internet {
|
|
- label = "amber:world";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_wps: wps {
|
|
- label = "white:wps";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_wps_amber: wps_amber {
|
|
- label = "amber:wps";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_linksys: pwr {
|
|
- label = "white:linksys";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- // On back panel, above USB socket
|
|
-
|
|
- led_usb: usb {
|
|
- label = "green:usb";
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- trigger-sources = <&usb3_port1>, <&usb3_port2>,
|
|
- <&usb2_port1>;
|
|
- linux,default-trigger = "usbport";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "linksys-ea8300-fcc";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5170000 5330000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-ea8300-fcc";
|
|
-};
|
|
-
|
|
-&wifi2 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5490000 5835000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-ea8300-fcc";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-eap2200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-eap2200.dts
|
|
deleted file mode 100644
|
|
index dc144a1584..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-eap2200.dts
|
|
+++ /dev/null
|
|
@@ -1,286 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "EnGenius EAP2200";
|
|
- compatible = "engenius,eap2200";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: power {
|
|
- label = "amber:power";
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan1 {
|
|
- label = "blue:lan1";
|
|
- gpios = <&tlmm 44 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- lan2 {
|
|
- label = "blue:lan2";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "yellow:wlan5g";
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- wlan5g2 {
|
|
- label = "yellow:wlan5g2";
|
|
- gpios = <&tlmm 48 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy2tpt";
|
|
- };
|
|
-
|
|
- mode {
|
|
- label = "blue:mode";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition6@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition7@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs1";
|
|
- reg = <0x00000000 0x04000000>;
|
|
- };
|
|
- partition@40000000 {
|
|
- label = "ubi";
|
|
- reg = <0x04000000 0x04000000>;
|
|
- };
|
|
-
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_9000>;
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EAP2200";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EAP2200";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5170000 5350000>;
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "EnGenius-EAP2200";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzbox-7530.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzbox-7530.dts
|
|
deleted file mode 100644
|
|
index 336da52f27..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzbox-7530.dts
|
|
+++ /dev/null
|
|
@@ -1,321 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "AVM FRITZ!Box 7530";
|
|
- compatible = "avm,fritzbox-7530";
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " coherent_pool=4M";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &power_green;
|
|
- led-failsafe = &info_red;
|
|
- led-running = &power_green;
|
|
- led-upgrade = &info_red;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wlan {
|
|
- label = "wlan";
|
|
- gpios = <&tlmm 42 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RFKILL>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 41 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- dect {
|
|
- label = "dect";
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_PHONE>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- info_red: info_red {
|
|
- label = "red:info";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- info {
|
|
- label = "green:info";
|
|
- gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- fon {
|
|
- label = "green:fon";
|
|
- gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- power_green: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "green:wps";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- usb-power {
|
|
- line-name = "enable USB3 power";
|
|
- gpios = <49 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- /delete-property/ nand-ecc-strength;
|
|
- /delete-property/ nand-ecc-step-size;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x000000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x080000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "QSEE";
|
|
- reg = <0x100000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "CDT";
|
|
- reg = <0x180000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1c0000 {
|
|
- label = "QSEE_B";
|
|
- reg = <0x1c0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@240000 {
|
|
- label = "urlader0";
|
|
- reg = <0x240000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "urlader1";
|
|
- reg = <0x280000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2c0000 {
|
|
- label = "nand-tffs";
|
|
- reg = <0x2c0000 0x840000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- /* 'kernel1' in AVM firmware */
|
|
- label = "uboot0";
|
|
- reg = <0xb00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@f00000 {
|
|
- /* 'kernel2' in AVM firmware */
|
|
- label = "uboot1";
|
|
- reg = <0xf00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@1300000 {
|
|
- label = "ubi";
|
|
- reg = <0x1300000 0x6d00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZBox-7530";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZBox-7530";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- dsl@1,0 {
|
|
- compatible = "intel,vrx518";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-1200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-1200.dts
|
|
deleted file mode 100644
|
|
index 723f2161c6..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-1200.dts
|
|
+++ /dev/null
|
|
@@ -1,290 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "AVM FRITZ!Repeater 1200";
|
|
- compatible = "avm,fritzrepeater-1200";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power_green;
|
|
- led-failsafe = &power_red;
|
|
- led-running = &power_green;
|
|
- led-upgrade = &power_red;
|
|
- label-mac-device = &wifi0;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- ethphy: ethernet-phy@0 {
|
|
- reg = <0x0>;
|
|
- };
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII_RGMII5>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- key {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "WPS button";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power_red: power_red {
|
|
- label = "red:power";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- power_green: power_green {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- power_yellow {
|
|
- label = "yellow:power";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- phy-reset {
|
|
- line-name = "PHY-reset";
|
|
- gpios = <19 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-
|
|
- phy-reset-2 {
|
|
- line-name = "PHY-reset-2";
|
|
- gpios = <47 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x80000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "QSEE";
|
|
- reg = <0x100000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "CDT";
|
|
- reg = <0x180000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1c0000 {
|
|
- label = "QSEE_B";
|
|
- reg = <0x1c0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@240000 {
|
|
- label = "urlader0";
|
|
- reg = <0x240000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "urlader1";
|
|
- reg = <0x280000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2c0000 {
|
|
- label = "nand-tffs";
|
|
- reg = <0x2c0000 0x840000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- /* 'kernel1' in AVM firmware */
|
|
- label = "uboot0";
|
|
- reg = <0xb00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@f00000 {
|
|
- /* 'kernel2' in AVM firmware */
|
|
- label = "uboot1";
|
|
- reg = <0xf00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@1300000 {
|
|
- label = "ubi";
|
|
- reg = <0x1300000 0x6d00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZRepeater-1200";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZRepeater-1200";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-
|
|
- /delete-property/ psgmii-ethphy;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- phy-handle = <ðphy>;
|
|
- phy-mode = "rgmii-id";
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&psgmiiphy {
|
|
- status = "disabled";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-3000.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-3000.dts
|
|
deleted file mode 100644
|
|
index 41dec72542..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-fritzrepeater-3000.dts
|
|
+++ /dev/null
|
|
@@ -1,272 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "AVM FRITZ!Repeater 3000";
|
|
- compatible = "avm,fritzrepeater-3000";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power_led;
|
|
- led-failsafe = &power_led;
|
|
- led-running = &power_led;
|
|
- led-upgrade = &power_led;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- key {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- connect {
|
|
- label = "Connect";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- connect_red {
|
|
- label = "red:connect";
|
|
- gpios = <&tlmm 30 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- connect_green {
|
|
- label = "green:connect";
|
|
- gpios = <&tlmm 31 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- connect_blue {
|
|
- label = "blue:connect";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- power_led: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- /delete-property/ nand-ecc-strength;
|
|
- /delete-property/ nand-ecc-step-size;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x000000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x080000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "QSEE";
|
|
- reg = <0x100000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "CDT";
|
|
- reg = <0x180000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1c0000 {
|
|
- label = "QSEE_B";
|
|
- reg = <0x1c0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@240000 {
|
|
- label = "urlader0";
|
|
- reg = <0x240000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "urlader1";
|
|
- reg = <0x280000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2c0000 {
|
|
- label = "nand-tffs";
|
|
- reg = <0x2c0000 0x840000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- /* 'kernel1' in AVM firmware */
|
|
- label = "uboot0";
|
|
- reg = <0xb00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@f00000 {
|
|
- /* 'kernel2' in AVM firmware */
|
|
- label = "uboot1";
|
|
- reg = <0xf00000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@1300000 {
|
|
- label = "ubi";
|
|
- reg = <0x1300000 0x6d00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- /* BDFs are identical for the FRITZ!Box 7530 and the FRITZ!Repeater 3000 */
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZRepeater-3000";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5170000 5350000>;
|
|
- /* BDFs are identical for the FRITZ!Box 7530 and the FRITZ!Repeater 3000 */
|
|
- qcom,ath10k-calibration-variant = "AVM-FRITZRepeater-3000";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 35 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi@1,0 {
|
|
- /* QCA9984 */
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
- /* Uses the reference BDF */
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-gl-b2200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-gl-b2200.dts
|
|
deleted file mode 100644
|
|
index 96ab73962e..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-gl-b2200.dts
|
|
+++ /dev/null
|
|
@@ -1,386 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "GL.iNet GL-B2200";
|
|
- compatible = "glinet,gl-b2200", "qcom,ipq4019";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/mmcblk0p2 rw rootwait clk_ignore_unused";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- ethernet1 = &swport4;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- linux,input-type = <1>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- linux,input-type = <1>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power_blue {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 57 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "on";
|
|
- };
|
|
- internet_blue {
|
|
- label = "blue:internet";
|
|
- gpios = <&tlmm 60 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- power_white {
|
|
- label = "white:power";
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- internet_white {
|
|
- label = "white:internet";
|
|
- gpios = <&tlmm 66 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- cd-gpios = <&tlmm 3 GPIO_ACTIVE_LOW>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi2 {
|
|
- pinctrl-0 = <&spi_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- spidev1: spi@0 {
|
|
- compatible = "silabs,si3210";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9",
|
|
- "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinconf_cs {
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_1_pins: spi_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio44", "gpio46", "gpio47";
|
|
- function = "blsp_spi1";
|
|
- bias-disable;
|
|
- };
|
|
- cs {
|
|
- pins = "gpio45";
|
|
- function = "gpio";
|
|
- bias-pull-up;
|
|
- };
|
|
- reset {
|
|
- pins = "gpio43";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio35";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- host_int {
|
|
- pins = "gpio2";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- wake {
|
|
- pins = "gpio48";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- pinmux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio29", "gpio30", "gpio31", "gpio32";
|
|
- drive-strength = <10>;
|
|
- };
|
|
-
|
|
- pinmux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
-
|
|
- pinmux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio28";
|
|
- drive-strength = <10>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- status = "okay";
|
|
- /* Bootlog shows this is a 168c:0056 - QCA 9888v2 */
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_9000>;
|
|
- qcom,ath10k-calibration-variant = "GL-B2200";
|
|
- ieee80211-freq-limit = <5450000 5900000>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "GL-B2200";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "GL-B2200";
|
|
- ieee80211-freq-limit = <5100000 5400000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-habanero-dvk.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-habanero-dvk.dts
|
|
deleted file mode 100644
|
|
index 23a654dcff..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-habanero-dvk.dts
|
|
+++ /dev/null
|
|
@@ -1,387 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2019, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "8devices Habanero DVK";
|
|
- compatible = "8dev,habanero-dvk";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_upgrade;
|
|
- ethernet1 = &swport5;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3: usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 8 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status: status {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 37 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_upgrade: upgrade {
|
|
- label = "green:upgrade";
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- label = "green:wlan2g";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "green:wlan5g";
|
|
- gpios = <&tlmm 48 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- cd-gpios = <&tlmm 22 GPIO_ACTIVE_LOW>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56", "gpio57",
|
|
- "gpio60", "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67", "gpio68",
|
|
- "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- pinmux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio28", "gpio29", "gpio30", "gpio31";
|
|
- drive-strength = <10>;
|
|
- };
|
|
-
|
|
- pinmux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
-
|
|
- pinmux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio32";
|
|
- drive-strength = <10>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
- reg = <0>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV"; /* uboot env */
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- partition@180000 {
|
|
- label = "cfg";
|
|
- reg = <0x00180000 0x00040000>;
|
|
- };
|
|
- partition@1c0000 {
|
|
- label = "firmware";
|
|
- compatible = "denx,fit";
|
|
- reg = <0x001c0000 0x01e40000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-/* Some DVK boards ship without NAND */
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- /* Free slot for use */
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
- };
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "8devices-Habanero";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "8devices-Habanero";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3-lte6-kit.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3-lte6-kit.dts
|
|
deleted file mode 100644
|
|
index 6459fc3b92..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3-lte6-kit.dts
|
|
+++ /dev/null
|
|
@@ -1,312 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2021, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MikroTik hAP ac3 LTE6 kit";
|
|
- compatible = "mikrotik,hap-ac3-lte6-kit";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_blue;
|
|
- led-failsafe = &led_status_red;
|
|
- led-running = &led_status_blue;
|
|
- led-upgrade = &led_status_red;
|
|
- };
|
|
-
|
|
- soc {
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status_blue: status-blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_red: status-red {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_status_green: status-green {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 23 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- ethernet {
|
|
- label = "green:ethernet";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "green:wan";
|
|
- gpios = <&tlmm 28 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan1 {
|
|
- label = "green:lan1";
|
|
- gpios = <&tlmm 29 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan2 {
|
|
- label = "green:lan2";
|
|
- gpios = <&tlmm 30 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan3 {
|
|
- label = "green:lan3";
|
|
- gpios = <&tlmm 31 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan4 {
|
|
- label = "green:lan4";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <44 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable USB power";
|
|
- };
|
|
-
|
|
- enable-mpcie-power {
|
|
- gpio-hog;
|
|
- gpios = <51 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable mPCI-E power";
|
|
- };
|
|
-
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <10000000>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- size = <0x2000>;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@110000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x110000 0xef0000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3.dts
|
|
deleted file mode 100644
|
|
index 35c4c26a2c..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-hap-ac3.dts
|
|
+++ /dev/null
|
|
@@ -1,351 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2021, Robert Marko <robimarko@gmail.com> */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "MikroTik hAP ac3";
|
|
- compatible = "mikrotik,hap-ac3";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status_blue;
|
|
- led-failsafe = &led_status_red;
|
|
- led-running = &led_status_blue;
|
|
- led-upgrade = &led_status_red;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- mode {
|
|
- label = "mode";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RFKILL>;
|
|
- };
|
|
-
|
|
- led {
|
|
- label = "led";
|
|
- gpios = <&tlmm 42 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status_blue: status-blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_red: status-red {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_status_green: status-green {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 23 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- ethernet {
|
|
- label = "green:ethernet";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wan {
|
|
- label = "green:wan";
|
|
- gpios = <&tlmm 28 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan1 {
|
|
- label = "green:lan1";
|
|
- gpios = <&tlmm 29 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan2 {
|
|
- label = "green:lan2";
|
|
- gpios = <&tlmm 30 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan3 {
|
|
- label = "green:lan3";
|
|
- gpios = <&tlmm 31 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- lan4 {
|
|
- label = "green:lan4";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- poe {
|
|
- label = "red:poe";
|
|
- gpios = <&tlmm 36 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio55", "gpio56", "gpio57", "gpio60",
|
|
- "gpio62", "gpio63", "gpio64", "gpio65",
|
|
- "gpio66", "gpio67", "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- enable-usb-power {
|
|
- gpio-hog;
|
|
- gpios = <44 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- line-name = "enable USB power";
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <40000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- size = <0x2000>;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "kernel";
|
|
- reg = <0x0 0xa00000>;
|
|
- };
|
|
-
|
|
- partition@a00000 {
|
|
- label = "ubi";
|
|
- reg = <0xa00000 0x7600000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-hAP-ac3";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "MikroTik-hAP-ac3";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-lhgg-60ad.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-lhgg-60ad.dts
|
|
deleted file mode 100644
|
|
index 38bacfa2ba..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-lhgg-60ad.dts
|
|
+++ /dev/null
|
|
@@ -1,281 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2019, Robert Marko <robimarko@gmail.com>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Mikrotik Wireless Wire Dish LHGG-60ad";
|
|
- compatible = "mikrotik,lhgg-60ad";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &user;
|
|
- led-failsafe = &user;
|
|
- led-running = &user;
|
|
- led-upgrade = &user;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII_RGMII5>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: power {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 0 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- user: user {
|
|
- label = "yellow:user";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- align-left {
|
|
- label = "green:align-left";
|
|
- gpios = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- align-right {
|
|
- label = "green:align-right";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan-rx {
|
|
- label = "green:align-down";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan-tx {
|
|
- label = "green:align-up";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi-0-pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
- status = "okay";
|
|
-
|
|
- m25p80@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "Qualcomm";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- compatible = "mikrotik,routerboot-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "RouterBoot";
|
|
- reg = <0x80000 0x80000>;
|
|
-
|
|
- hard_config {
|
|
- read-only;
|
|
- size = <0x2000>;
|
|
- };
|
|
-
|
|
- dtb_config {
|
|
- read-only;
|
|
- };
|
|
-
|
|
- soft_config {
|
|
- };
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- compatible = "mikrotik,minor";
|
|
- label = "firmware";
|
|
- reg = <0x100000 0xf00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 42 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- /* wil6210 802.11ad card */
|
|
- wifi: wifi@1,0 {
|
|
- status = "okay";
|
|
- /* wil6210 driver has no compatible */
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&psgmiiphy {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-
|
|
- /delete-property/ psgmii-ethphy;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- phy-handle = <ðphy0>;
|
|
- phy-mode = "rgmii-id";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-map-ac2200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-map-ac2200.dts
|
|
deleted file mode 100644
|
|
index 32f0473fb1..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-map-ac2200.dts
|
|
+++ /dev/null
|
|
@@ -1,363 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "ASUS Lyra MAP-AC2200";
|
|
- compatible = "asus,map-ac2200";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_blue0;
|
|
- led-failsafe = &led_red0;
|
|
- led-running = &led_blue0;
|
|
- led-upgrade = &led_red0;
|
|
- ethernet1 = &swport4;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@80000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x80000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "QSEE";
|
|
- reg = <0x100000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "CDT";
|
|
- reg = <0x200000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x280000 0x140000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3c0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x3c0000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@400000 {
|
|
- label = "ubi";
|
|
- reg = <0x400000 0x7c00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio20", "gpio21";
|
|
- drive-strength = <16>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
- enable_ext_pa_high {
|
|
- gpio-hog;
|
|
- gpios = <44 GPIO_ACTIVE_HIGH>,
|
|
- <46 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- bias-pull-down;
|
|
- line-name = "enable external PA output-high";
|
|
- };
|
|
- enable_ext_pa_low {
|
|
- gpio-hog;
|
|
- gpios = <45 GPIO_ACTIVE_HIGH>,
|
|
- <47 GPIO_ACTIVE_HIGH>;
|
|
- output-low;
|
|
- bias-pull-down;
|
|
- line-name = "enable external PA output-low";
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ASUS-MAP-AC2200";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ASUS-MAP-AC2200";
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- qcom,ath10k-calibration-variant = "ASUS-MAP-AC2200";
|
|
- ieee80211-freq-limit = <5170000 5350000>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- /* Bluetooth module attached via USB */
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- led-controller@32 {
|
|
- /* 9-channel RGB LED controller */
|
|
- compatible = "national,lp5523";
|
|
- reg = <0x32>;
|
|
- clock-mode = /bits/ 8 <1>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- /*
|
|
- * There is only one single extremely bright RGB-LED.
|
|
- * The RGB-color channels are running in parallel to
|
|
- * increase the current delivery capabilities beyond
|
|
- * what a single PWM-output of the controller can do.
|
|
- */
|
|
-
|
|
- led_blue0: led@0 {
|
|
- chan-name = "blue-0";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <0>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function-enumerator = <0>;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- chan-name = "blue-1";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <1>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function-enumerator = <1>;
|
|
- };
|
|
-
|
|
- led@2 {
|
|
- chan-name = "blue-2";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <2>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function-enumerator = <2>;
|
|
- };
|
|
-
|
|
- led_green0: led@3 {
|
|
- chan-name = "green-0";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <3>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function-enumerator = <0>;
|
|
- };
|
|
-
|
|
- led@4 {
|
|
- chan-name = "green-1";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <4>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function-enumerator = <1>;
|
|
- };
|
|
-
|
|
- led@5 {
|
|
- chan-name = "green-2";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <5>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function-enumerator = <2>;
|
|
- };
|
|
-
|
|
- led_red0: led@6 {
|
|
- chan-name = "red-0";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <6>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function-enumerator = <0>;
|
|
- };
|
|
-
|
|
- led@7 {
|
|
- chan-name = "red-1";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <7>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function-enumerator = <1>;
|
|
- };
|
|
-
|
|
- led@8 {
|
|
- chan-name = "red-2";
|
|
- led-cur = /bits/ 8 <0xfa>;
|
|
- max-cur = /bits/ 8 <0xff>;
|
|
- reg = <8>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function-enumerator = <2>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf18a.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf18a.dts
|
|
deleted file mode 100644
|
|
index 80d71ac0cc..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf18a.dts
|
|
+++ /dev/null
|
|
@@ -1,483 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Marcin Gajda <mgajda@o2.pl>.
|
|
-
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF18A";
|
|
- compatible = "zte,mf18a";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * bootargs forced by u-boot bootipq command:
|
|
- * 'ubi.mtd=rootfs root=mtd:ubi_rootfs rootfstype=squashfs rootwait'
|
|
- */
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- gpio-restart {
|
|
- compatible = "gpio-restart";
|
|
- gpios = <&tlmm 8 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_internal: led-0 {
|
|
- label = "blue:internal";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- led_power: led-1 {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 48 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- led-2 {
|
|
- function = LED_FUNCTION_WLAN;
|
|
- label = "blue:wlan";
|
|
- gpios = <&tlmm 23 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- led-3 {
|
|
- label = "red:wlan";
|
|
- gpios = <&tlmm 26 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led-4 {
|
|
- function = LED_FUNCTION_WLAN;
|
|
- label = "blue:smart";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- led-5 {
|
|
- label = "red:smart";
|
|
- gpios = <&tlmm 25 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- resetzwave {
|
|
- label = "resetzwave";
|
|
- gpios = <&tlmm 11 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- /* u-boot is looking for "n25q128a11" property */
|
|
- compatible = "jedec,spi-nor", "n25q128a11";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_config_0>;
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_config_0>;
|
|
- mac-address-increment = <1>;
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a0000 {
|
|
- label = "ART";
|
|
- reg = <0xa0000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@120000 {
|
|
- label = "mac";
|
|
- reg = <0x120000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_config_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1a0000 {
|
|
- label = "reserved2";
|
|
- reg = <0x1a0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@260000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x260000 0x400000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@660000 {
|
|
- label = "log";
|
|
- reg = <0x660000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@a60000 {
|
|
- label = "oops";
|
|
- reg = <0xa60000 0xa0000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "reserved3";
|
|
- reg = <0xb00000 0x500000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1000000 {
|
|
- label = "web";
|
|
- reg = <0x1000000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1800000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1800000 0x1d00000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x2800000>;
|
|
-
|
|
- };
|
|
- partition@7600000 {
|
|
- label = "iot-db";
|
|
- reg = <0x7600000 0xa00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_config_0>;
|
|
- mac-address-increment = <2>;
|
|
- qcom,ath10k-calibration-variant = "ZTE-MF18A";
|
|
-};
|
|
-
|
|
-//* This node is used for 5Ghz on QCA9982 */
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
- clkreq-gpio = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "pci168c,0040";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_9000>, <&macaddr_config_0>;
|
|
- mac-address-increment = <3>;
|
|
- qcom,ath10k-calibration-variant = "ZTE-MF18A";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf286d.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf286d.dts
|
|
deleted file mode 100644
|
|
index ff04279a60..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf286d.dts
|
|
+++ /dev/null
|
|
@@ -1,448 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF286D";
|
|
- compatible = "zte,mf286d";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_internal;
|
|
- led-failsafe = &led_internal;
|
|
- led-running = &led_internal;
|
|
- led-upgrade = &led_internal;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * bootargs forced by u-boot bootipq command:
|
|
- * 'ubi.mtd=rootfs root=mtd:ubi_rootfs rootfstype=squashfs rootwait'
|
|
- */
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- gpio-restart {
|
|
- compatible = "gpio-restart";
|
|
- gpios = <&tlmm 8 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_internal: led-0 {
|
|
- function = LED_FUNCTION_STATUS;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- label = "blue:internal_led";
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- function = LED_FUNCTION_WLAN;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wifi {
|
|
- label = "wifi";
|
|
- linux,code = <KEY_RFKILL>;
|
|
- gpios = <&tlmm 11 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- /* u-boot is looking for "n25q128a11" property */
|
|
- compatible = "jedec,spi-nor", "n25q128a11";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_config_0>;
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a0000 {
|
|
- label = "ART";
|
|
- reg = <0xa0000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@120000 {
|
|
- label = "mac";
|
|
- reg = <0x120000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_config_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1a0000 {
|
|
- label = "reserved2";
|
|
- reg = <0x1a0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@260000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x260000 0x400000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@660000 {
|
|
- label = "log";
|
|
- reg = <0x660000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@a60000 {
|
|
- label = "oops";
|
|
- reg = <0xa60000 0xa0000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "reserved3";
|
|
- reg = <0xb00000 0x500000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1000000 {
|
|
- label = "web";
|
|
- reg = <0x1000000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1800000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1800000 0x1d00000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x3200000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_config_0>;
|
|
- mac-address-increment = <1>;
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_config_0>;
|
|
- mac-address-increment = <2>;
|
|
- qcom,ath10k-calibration-variant = "zte,mf286d";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_config_0>;
|
|
- mac-address-increment = <3>;
|
|
- qcom,ath10k-calibration-variant = "zte,mf286d";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf289f.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf289f.dts
|
|
deleted file mode 100644
|
|
index 0d9f24ad70..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mf289f.dts
|
|
+++ /dev/null
|
|
@@ -1,440 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-// Copyright (c) 2022, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-// Copyright (c) 2022, Giammarco Marzano <stich86@gmail.com>.
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "ZTE MF289F";
|
|
- compatible = "zte,mf289f";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_status;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * bootargs forced by u-boot bootipq command:
|
|
- * 'ubi.mtd=rootfs root=mtd:ubi_rootfs rootfstype=squashfs rootwait'
|
|
- */
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- /*
|
|
- * This node is used to restart modem module to avoid anomalous
|
|
- * behaviours on initial communication.
|
|
- */
|
|
- gpio-restart {
|
|
- compatible = "gpio-restart";
|
|
- gpios = <&tlmm 8 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_status: led-0 {
|
|
- label = "blue:power";
|
|
- function = LED_FUNCTION_POWER;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- function = LED_FUNCTION_WLAN;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- key-reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- key-wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>,
|
|
- <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1b0000 {
|
|
- label = "0:reserved1";
|
|
- reg = <0x1b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- spi-nand@1 { /* flash@1 ? */
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "fota-flag";
|
|
- reg = <0x0 0xa0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@a0000 {
|
|
- label = "ART";
|
|
- reg = <0xa0000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@120000 {
|
|
- label = "mac";
|
|
- reg = <0x120000 0x80000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mac_0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1a0000 {
|
|
- label = "reserved2";
|
|
- reg = <0x1a0000 0xc0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@260000 {
|
|
- label = "cfg-param";
|
|
- reg = <0x260000 0x400000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@660000 {
|
|
- label = "log";
|
|
- reg = <0x660000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@a60000 {
|
|
- label = "oops";
|
|
- reg = <0xa60000 0xa0000>;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "reserved3";
|
|
- reg = <0xb00000 0x500000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1000000 {
|
|
- label = "web";
|
|
- reg = <0x1000000 0x800000>;
|
|
- };
|
|
-
|
|
- partition@1800000 {
|
|
- label = "rootfs";
|
|
- reg = <0x1800000 0x1d00000>;
|
|
- };
|
|
-
|
|
- partition@3500000 {
|
|
- label = "data";
|
|
- reg = <0x3500000 0x1900000>;
|
|
- };
|
|
-
|
|
- partition@4e00000 {
|
|
- label = "fota";
|
|
- reg = <0x4e00000 0x3200000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_mac_0>;
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_mac_0>;
|
|
- mac-address-increment = <1>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12", "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_mac_0>;
|
|
- mac-address-increment = <2>;
|
|
- qcom,ath10k-calibration-variant = "zte,mf289f";
|
|
-};
|
|
-
|
|
-/* This node is used only on AT2 version for 5Ghz on IPQ4019 with board-id=21 */
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_mac_0>;
|
|
- mac-address-increment = <3>;
|
|
- qcom,ath10k-calibration-variant = "zte,mf289f";
|
|
-};
|
|
-
|
|
-/* This node is used only on AT1 version for 5Ghz on QCA9984 */
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
- clkreq-gpio = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_mac_0>;
|
|
- mac-address-increment = <4>;
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- qcom,ath10k-calibration-variant = "zte,mf289f";
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mr8300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mr8300.dts
|
|
deleted file mode 100644
|
|
index 057aa88028..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-mr8300.dts
|
|
+++ /dev/null
|
|
@@ -1,80 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-xx8300.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Linksys MR8300 (Dallas)";
|
|
- compatible = "linksys,mr8300", "qcom,ipq4019";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_blue;
|
|
- led-failsafe = &led_red;
|
|
- led-running = &led_blue;
|
|
- led-upgrade = &led_amber;
|
|
- serial0 = &blsp1_uart1;
|
|
- };
|
|
-
|
|
- // Top panel LEDs, above Linksys logo
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_red: red {
|
|
- label = "red:alarm";
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_amber: amber {
|
|
- label = "amber:programming";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_blue: blue {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- // On back panel, above USB socket
|
|
-
|
|
- led_usb: usb {
|
|
- label = "green:usb";
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- trigger-sources = <&usb3_port1>, <&usb3_port2>,
|
|
- <&usb2_port1>;
|
|
- linux,default-trigger = "usbport";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "linksys-mr8300-v0-fcc";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5170000 5330000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-mr8300-v0-fcc";
|
|
-};
|
|
-
|
|
-&wifi2 {
|
|
- status = "okay";
|
|
- ieee80211-freq-limit = <5490000 5835000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-mr8300-v0-fcc";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ncp-hg100-cellular.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ncp-hg100-cellular.dts
|
|
deleted file mode 100644
|
|
index ea27defea3..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-ncp-hg100-cellular.dts
|
|
+++ /dev/null
|
|
@@ -1,635 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Sony NCP-HG100/Cellular";
|
|
- compatible = "sony,ncp-hg100-cellular";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_cloud_green;
|
|
- led-failsafe = &led_cloud_red;
|
|
- led-running = &led_cloud_green;
|
|
- led-upgrade = &led_cloud_green;
|
|
- label-mac-device = &gmac;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs = "console=ttyMSM0,115200n8 root=/dev/mmcblk0p15 rootfstype=squashfs,ext4";
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x20000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- tcsr@1949000 {
|
|
- status = "okay";
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- status = "okay";
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- status = "okay";
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- status = "okay";
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- dma@7984000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys-repeat {
|
|
- compatible = "gpio-keys";
|
|
- pinctrl-0 = <&keys_pins>;
|
|
- pinctrl-names = "default";
|
|
- autorepeat;
|
|
-
|
|
- key-volup {
|
|
- label = "volume up";
|
|
- linux,code = <KEY_VOLUMEUP>;
|
|
- gpios = <&tlmm 39 GPIO_ACTIVE_HIGH>;
|
|
- linux,input-type = <EV_KEY>;
|
|
- };
|
|
-
|
|
- key-voldown {
|
|
- label = "volume down";
|
|
- linux,code = <KEY_VOLUMEDOWN>;
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
- linux,input-type = <EV_KEY>;
|
|
- };
|
|
-
|
|
- key-alexatrigger {
|
|
- label = "alexa trigger";
|
|
- linux,code = <BTN_0>;
|
|
- gpios = <&tlmm 42 GPIO_ACTIVE_HIGH>;
|
|
- linux,input-type = <EV_KEY>;
|
|
- };
|
|
-
|
|
- key-mute {
|
|
- label = "mic mute";
|
|
- linux,code = <BTN_1>;
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- linux,input-type = <EV_SW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- key-reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- key-wps {
|
|
- label = "setup";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- pinctrl-0 = <&bt_pins>, <&aud_pins>, <&mcu_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- /*
|
|
- * uart0 is shared for debug console and Z-Wave,
|
|
- * use only for debug console in OpenWrt.
|
|
- *
|
|
- * 1: debug console
|
|
- * 0: Z-Wave
|
|
- */
|
|
- uart0_ctrl_pins: uart0_ctrl_pinmux {
|
|
- mux {
|
|
- pins = "gpio15";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- /*
|
|
- * reset pin for Z-Wave
|
|
- * active-low, >= 20ns
|
|
- */
|
|
- zwave_pins: zwave_pinmux {
|
|
- mux {
|
|
- pins = "gpio59";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9",
|
|
- "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- bt_pins: bt_pinmux {
|
|
- mux_reset {
|
|
- pins = "gpio66";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
-
|
|
- mux_pwr {
|
|
- pins = "gpio68";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_1_pins: i2c_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio12", "gpio13";
|
|
- function = "blsp_i2c1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- keys_pins: keys_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio39", "gpio40", "gpio42", "gpio47";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio2";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- mux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio28", "gpio29", "gpio30", "gpio31";
|
|
- drive-strength = <4>;
|
|
- };
|
|
-
|
|
- mux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
-
|
|
- mux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio32";
|
|
- drive-strength = <4>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- aud_pins: aud_pinmux {
|
|
- mux {
|
|
- pins = "gpio48", "gpio49", "gpio50", "gpio51";
|
|
- function = "aud_pin";
|
|
- };
|
|
- };
|
|
-
|
|
- alc1304_pins: alc1304_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio44";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio45";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- cx2902x_reset: cx2902x_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio64";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio65";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- lte_pins: lte_pinmux {
|
|
- mux_en {
|
|
- pins = "gpio20";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
-
|
|
- mux_reset {
|
|
- pins = "gpio35";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- };
|
|
-
|
|
- usb3_pins: usb3_pinmux {
|
|
- mux_en {
|
|
- pins = "gpio36";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
-
|
|
- mux_flt {
|
|
- pins = "gpio4";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- };
|
|
-
|
|
- mcu_pins: mcu_pinmux {
|
|
- mux_boot {
|
|
- pins = "gpio38";
|
|
- function = "gpio";
|
|
- output-low;
|
|
- };
|
|
-
|
|
- mux_reset {
|
|
- pins = "gpio5";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c4 {
|
|
- /*
|
|
- * There is no driver for the following devices:
|
|
- * - CY8C4014LQI@14 : Touch-Sensor for buttons on top
|
|
- * - MINI54FDE@15 : MCU for Fan/RGB LED/Thermal control
|
|
- * - ALC5629@18 : I2S/PCM Audio DAC
|
|
- * - CX20924@41 : Voice Input Processor
|
|
- */
|
|
- pinctrl-0 = <&i2c_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- led-controller@32 {
|
|
- compatible = "ti,lp55231";
|
|
- reg = <0x32>;
|
|
- clock-mode = /bits/ 8 <0>;
|
|
- enable-gpio = <&tlmm 1 GPIO_ACTIVE_HIGH>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- led@0 {
|
|
- chan-name = "green:wan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x0>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WAN;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- chan-name = "blue:wan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x1>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WAN;
|
|
- };
|
|
-
|
|
- led@2 {
|
|
- chan-name = "green:lan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x2>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- };
|
|
-
|
|
- led@3 {
|
|
- chan-name = "blue:lan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x3>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- };
|
|
-
|
|
- led@4 {
|
|
- chan-name = "green:wlan-2";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x4>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <2>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- led@5 {
|
|
- chan-name = "blue:wlan-2";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x5>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <2>;
|
|
- };
|
|
-
|
|
- led@6 {
|
|
- chan-name = "red:wan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x6>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_WAN;
|
|
- };
|
|
-
|
|
- led@7 {
|
|
- chan-name = "red:lan";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x7>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- };
|
|
-
|
|
- led@8 {
|
|
- chan-name = "red:wlan-2";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x8>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <2>;
|
|
- };
|
|
- };
|
|
-
|
|
- led-controller@33 {
|
|
- compatible = "ti,lp55231";
|
|
- reg = <0x33>;
|
|
- clock-mode = /bits/ 8 <0>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- led@0 {
|
|
- chan-name = "green:wlan-5";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x0>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- function-enumerator = <5>;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- chan-name = "blue:wlan-5";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x1>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <5>;
|
|
- };
|
|
-
|
|
- led@2 {
|
|
- chan-name = "green:wan-4";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x2>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_WAN; /* WWAN/LTE/4G */
|
|
- function-enumerator = <4>; /* WWAN/LTE/4G */
|
|
- };
|
|
-
|
|
- led@3 {
|
|
- chan-name = "blue:wan-4";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x3>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WAN; /* WWAN/LTE/4G */
|
|
- function-enumerator = <4>; /* WWAN/LTE/4G */
|
|
- };
|
|
-
|
|
- led_cloud_green: led@4 {
|
|
- chan-name = "green:power";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x4>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- led@5 {
|
|
- chan-name = "blue:power";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x5>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- led@6 {
|
|
- chan-name = "red:wlan-5";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x6>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <5>;
|
|
- };
|
|
-
|
|
- led@7 {
|
|
- chan-name = "red:wan-4";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x7>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_WAN; /* WWAN/LTE/4G */
|
|
- function-enumerator = <4>; /* WWAN/LTE/4G */
|
|
- };
|
|
-
|
|
- led_cloud_red: led@8 {
|
|
- chan-name = "red:power";
|
|
- led-cur = /bits/ 8 <50>;
|
|
- max-cur = /bits/ 8 <100>;
|
|
- reg = <0x8>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>, <&uart0_ctrl_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 41 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- vqmmc-supply = <&vqmmc>;
|
|
- non-removable;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- emmc@0 {
|
|
- compatible = "mmc-card";
|
|
- reg = <0>;
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&usb3_pins>, <<e_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- device@1 {
|
|
- compatible = "usb1bc7,1900";
|
|
- reg = <1>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "wan";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Sony-NCP-HG100-Cellular";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Sony-NCP-HG100-Cellular";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-oap100.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-oap100.dts
|
|
deleted file mode 100644
|
|
index beb168eb49..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-oap100.dts
|
|
+++ /dev/null
|
|
@@ -1,339 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "EdgeCore OAP-100";
|
|
- compatible = "edgecore,oap100";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_system;
|
|
- led-failsafe = &led_system;
|
|
- led-running = &led_system;
|
|
- led-upgrade = &led_system;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb2_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- key {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- button@1 {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,input-type = <1>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_system: led_system {
|
|
- label = "green:system";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_2g {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&tlmm 34 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_5g {
|
|
- label = "blue:wlan5g";
|
|
- gpios = <&tlmm 35 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- gpio_export {
|
|
- compatible = "gpio-export";
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb {
|
|
- gpio-export,name = "usb-power";
|
|
- gpio-export,output = <1>;
|
|
- gpios = <&tlmm 44 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- poe {
|
|
- gpio-export,name = "poe-power";
|
|
- gpio-export,output = <0>;
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- linux,modalias = "m25p80", "gd25q256";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition6@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition7@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "rootfs";
|
|
- reg = <0x00000000 0x4000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "Edgecore OAP100";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "Edgecore OAP100";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-orbi.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-orbi.dtsi
|
|
deleted file mode 100644
|
|
index 44dbfef529..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-orbi.dtsi
|
|
+++ /dev/null
|
|
@@ -1,338 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- aliases {
|
|
- led-boot = &led_status_white;
|
|
- led-failsafe = &led_status_red;
|
|
- led-running = &led_status_green;
|
|
- led-upgrade = &led_status_blue;
|
|
- label-mac-device = &gmac;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led-0 {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "on";
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- label = "red:power";
|
|
- gpios = <&tlmm 64 GPIO_ACTIVE_HIGH>;
|
|
- panic-indicator;
|
|
- };
|
|
-
|
|
- led_status_green: led-2 {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 53 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_red: led-3 {
|
|
- label = "red:status";
|
|
- gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_blue: led-4 {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 57 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_status_white: led-5 {
|
|
- label = "white:status";
|
|
- gpios = <&tlmm 60 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- cd-gpios = <&tlmm 22 GPIO_ACTIVE_LOW>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio58", "gpio59";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- pinmux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio28", "gpio29", "gpio30", "gpio31";
|
|
- drive-strength = <10>;
|
|
- };
|
|
-
|
|
- pinmux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
-
|
|
- pinmux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio32";
|
|
- drive-strength = <10>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- status = "okay";
|
|
-
|
|
- led-controller@27 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- compatible = "ti,tlc59108"; /* really is tlc59208f */
|
|
- reg = <0x27>;
|
|
-
|
|
- led0@0 {
|
|
- label = "rgb:led0";
|
|
- reg = <0x0>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led1@1 {
|
|
- label = "rgb:led1";
|
|
- reg = <0x1>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led2@2 {
|
|
- label = "rgb:led2";
|
|
- reg = <0x2>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led3@3 {
|
|
- label = "rgb:led3";
|
|
- reg = <0x3>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led4@4 {
|
|
- label = "rgb:led4";
|
|
- reg = <0x4>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led5@5 {
|
|
- label = "rgb:led5";
|
|
- reg = <0x5>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led6@6 {
|
|
- label = "rgb:led6";
|
|
- reg = <0x6>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
-
|
|
- led7@7 {
|
|
- label = "rgb:led7";
|
|
- reg = <0x7>;
|
|
- linux,default-trigger = "default-on";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
- qcom,ath10k-calibration-variant = "Netgear-Orbi-Pro-SRK60";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "Netgear-Orbi-Pro-SRK60";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- qcom,ath10k-calibration-variant = "Netgear-Orbi-Pro-SRK60";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-pa2200.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-pa2200.dts
|
|
deleted file mode 100644
|
|
index 259ea7bb47..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-pa2200.dts
|
|
+++ /dev/null
|
|
@@ -1,250 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-/* Copyright (c) 2017-2020, Sven Eckelmann <sven@narfation.org>
|
|
- * Copyright (c) 2018, Marek Lindner <marek.lindner@kaiwoo.ai>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Plasma Cloud PA2200";
|
|
- compatible = "plasmacloud,pa2200";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART >;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power_orange;
|
|
- led-failsafe = &led_status_blue;
|
|
- led-running = &led_power_orange;
|
|
- led-upgrade = &led_status_blue;
|
|
- label-mac-device = &swport4;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power_orange: power_orange {
|
|
- label = "orange:power";
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- 2g_blue {
|
|
- label = "blue:2g";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- 2g_green {
|
|
- label = "green:5g1";
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- 5g2_green {
|
|
- label = "green:5g2";
|
|
- gpios = <&tlmm 48 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy2tpt";
|
|
- };
|
|
-
|
|
- led_status_blue: status_blue {
|
|
- label = "blue:status";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- /* partitions are passed via bootloader */
|
|
- partitions {
|
|
- partition-art {
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- label = "0:ART";
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- qcom,ath10k-calibration-variant = "PlasmaCloud-PA2200";
|
|
- ieee80211-freq-limit = <5170000 5350000>;
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_9000>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "ethernet1";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "ethernet2";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "PlasmaCloud-PA2200";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "PlasmaCloud-PA2200";
|
|
- ieee80211-freq-limit = <5470000 5875000>;
|
|
-
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-128m.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-128m.dts
|
|
deleted file mode 100644
|
|
index 0896374ab2..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-128m.dts
|
|
+++ /dev/null
|
|
@@ -1,18 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-r619ac.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "P&W R619AC 128M";
|
|
- compatible = "p2w,r619ac-128m";
|
|
-};
|
|
-
|
|
-&nand_rootfs {
|
|
- /*
|
|
- * Watch out: stock MIBIB is set up for a 64MiB chip.
|
|
- * If a 128MiB flash chip is used, make sure to have
|
|
- * the right values in MIBIB or the device might not
|
|
- * boot.
|
|
- */
|
|
- reg = <0x0 0x8000000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-64m.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-64m.dts
|
|
deleted file mode 100644
|
|
index 6c8821a90e..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac-64m.dts
|
|
+++ /dev/null
|
|
@@ -1,12 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-r619ac.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "P&W R619AC 64M";
|
|
- compatible = "p2w,r619ac-64m";
|
|
-};
|
|
-
|
|
-&nand_rootfs {
|
|
- reg = <0x0 0x4000000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac.dtsi
|
|
deleted file mode 100644
|
|
index d7a987f98d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-r619ac.dtsi
|
|
+++ /dev/null
|
|
@@ -1,387 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- chosen {
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_sys;
|
|
- led-failsafe = &led_sys;
|
|
- led-running = &led_sys;
|
|
- led-upgrade = &led_sys;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_sys: led-0 {
|
|
- label = "blue:sys";
|
|
- gpios = <&tlmm 39 GPIO_ACTIVE_HIGH>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- label = "blue:wlan2g";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <0>;
|
|
- };
|
|
-
|
|
- led-2 {
|
|
- label = "blue:wlan5g";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <1>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- nand_rootfs: partition@0 {
|
|
- label = "ubi";
|
|
- /* reg defined in 64M/128M variant dts. */
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- pinctrl-names = "default";
|
|
- pinctrl-0 = <&pcie_pins>;
|
|
- perst-gpio = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- /* Free slot for use */
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- pinctrl-0 = <&sd_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- vqmmc-supply = <&vqmmc>;
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- pcie_pins: pcie_pinmux {
|
|
- mux {
|
|
- pins = "gpio2";
|
|
- function = "gpio";
|
|
- output-low;
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_0_pins: sd_0_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26", "gpio28";
|
|
- function = "sdio";
|
|
- drive-strength = <10>;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio27";
|
|
- function = "sdio";
|
|
- drive-strength = <16>;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0-pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- qcom,single-led-1000;
|
|
- qcom,single-led-100;
|
|
- qcom,single-led-10;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan4";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "P&W-R619AC";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "P&W-R619AC";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbr50.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbr50.dts
|
|
deleted file mode 100644
|
|
index a803999804..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbr50.dts
|
|
+++ /dev/null
|
|
@@ -1,30 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-orbi.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "NETGEAR RBR50";
|
|
- compatible = "netgear,rbr50";
|
|
-
|
|
- chosen {
|
|
- bootargs = "root=/dev/mmcblk0p20 blkdevparts=mmcblk0:512K@17K(0:SBL1)ro,512K(0:BOOTCONFIG)ro,512K(0:QSEE)ro,512K(0:QSEE_ALT)ro,256K(0:CDT)ro,256K(0:CDT_ALT)ro,256K(0:DDRPARAMS)ro,256K(0:APPSBLENV)ro,1M(0:APPSBL)ro,1M(0:APPSBL_ALT)ro,256K(0:ART)ro,256K(ARTMTD)ro,2M(language)ro,256K(config)ro,256K(pot)ro,256K(traffic_meter)ro,256K(pot_bak)ro,256K(traffic_meter.bak)ro,3840K(kernel),31488K(rootfs),35328K@9233K(firmware),256K(mtdoops)ro,1457651200(reserved)ro,-(unallocated) rootfstype=squashfs,ext4 rootwait";
|
|
- };
|
|
-
|
|
- soc {
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbs50.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbs50.dts
|
|
deleted file mode 100644
|
|
index 4d0a9132c6..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rbs50.dts
|
|
+++ /dev/null
|
|
@@ -1,30 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-orbi.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "NETGEAR RBS50";
|
|
- compatible = "netgear,rbs50";
|
|
-
|
|
- chosen {
|
|
- bootargs = "root=/dev/mmcblk0p20 blkdevparts=mmcblk0:512K@17K(0:SBL1)ro,512K(0:BOOTCONFIG)ro,512K(0:QSEE)ro,512K(0:QSEE_ALT)ro,256K(0:CDT)ro,256K(0:CDT_ALT)ro,256K(0:DDRPARAMS)ro,256K(0:APPSBLENV)ro,1M(0:APPSBL)ro,1M(0:APPSBL_ALT)ro,256K(0:ART)ro,256K(ARTMTD)ro,2M(language)ro,256K(config)ro,256K(pot)ro,256K(traffic_meter)ro,256K(pot_bak)ro,256K(traffic_meter.bak)ro,3840K(kernel),31488K(rootfs),35328K@9233K(firmware),256K(mtdoops)ro,1457651200(reserved)ro,-(unallocated) rootfstype=squashfs,ext4 rootwait";
|
|
- };
|
|
-
|
|
- soc {
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rt-ac42u.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rt-ac42u.dts
|
|
deleted file mode 100644
|
|
index f746acfbb9..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rt-ac42u.dts
|
|
+++ /dev/null
|
|
@@ -1,325 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "ASUS RT-AC42U";
|
|
- compatible = "asus,rt-ac42u";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>; /* 256MB */
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 11 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: led-0 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_STATUS;
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
- label = "blue:status";
|
|
- };
|
|
-
|
|
- led-1 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WAN;
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "90000.mdio-1:04:link";
|
|
- };
|
|
-
|
|
- led-2 {
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_WAN;
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "none";
|
|
- };
|
|
-
|
|
- led-3 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <0>;
|
|
- gpios = <&tlmm 52 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- led-4 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_WLAN;
|
|
- function-enumerator = <1>;
|
|
- gpios = <&tlmm 54 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- led-5 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- function-enumerator = <1>;
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led-6 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- function-enumerator = <2>;
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led-7 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- function-enumerator = <3>;
|
|
- gpios = <&tlmm 42 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led-8 {
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_LAN;
|
|
- function-enumerator = <4>;
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio55", "gpio56", "gpio57", "gpio60",
|
|
- "gpio62", "gpio63", "gpio64", "gpio65",
|
|
- "gpio66", "gpio67", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x00000000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@80000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x00080000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@100000 {
|
|
- label = "QSEE";
|
|
- reg = <0x00100000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@200000 {
|
|
- label = "CDT";
|
|
- reg = <0x00200000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@280000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x00280000 0x00140000>;
|
|
- read-only;
|
|
- };
|
|
- partition@3C0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x003C0000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition@400000 {
|
|
- label = "ubi";
|
|
- reg = <0x00400000 0x07C00000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "ASUS-RT-AC42U";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- clkreq-gpio = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
-
|
|
- qcom,ath10k-calibration-variant = "ASUS-RT-AC42U";
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rtl30vw.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rtl30vw.dts
|
|
deleted file mode 100644
|
|
index 6fce4ae87b..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-rtl30vw.dts
|
|
+++ /dev/null
|
|
@@ -1,393 +0,0 @@
|
|
-// SPDX-License-Identifier: ISC
|
|
-// Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
-// Copyright (c) 2019, Cezary Jackiewicz <cezary@eko.one.pl>.
|
|
-// Copyright (c) 2020, Pawel Dembicki <paweldembicki@gmail.com>.
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Cell C RTL30VW";
|
|
- compatible = "cellc,rtl30vw";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power_blue;
|
|
- led-failsafe = &led_power_red;
|
|
- led-running = &led_power_blue;
|
|
- led-upgrade = &led_power_red;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = "ubi.mtd=ubifs root=/dev/ubiblock0_0 rootfstype=squashfs ro";
|
|
- };
|
|
-
|
|
- led_spi {
|
|
- compatible = "spi-gpio";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- num-chipselects = <1>;
|
|
-
|
|
- mosi-gpios = <&tlmm 2 GPIO_ACTIVE_LOW>;
|
|
- cs-gpios = <&tlmm 4 GPIO_ACTIVE_LOW>;
|
|
- sck-gpios = <&tlmm 58 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- led_gpio: led_gpio@0 {
|
|
- compatible = "fairchild,74hc595";
|
|
- reg = <0>;
|
|
- gpio-controller;
|
|
- #gpio-cells = <2>;
|
|
- registers-number = <2>;
|
|
- spi-max-frequency = <1000000>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power_blue: power_blue {
|
|
- gpios = <&led_gpio 0 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:power";
|
|
- default-state = "on";
|
|
- };
|
|
-
|
|
- led_power_red: power_red {
|
|
- gpios = <&led_gpio 1 GPIO_ACTIVE_HIGH>;
|
|
- label = "red:power";
|
|
- };
|
|
-
|
|
- tp28 {
|
|
- gpios = <&led_gpio 6 GPIO_ACTIVE_LOW>;
|
|
- label = "ext:tp28";
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- tp27 {
|
|
- gpios = <&led_gpio 7 GPIO_ACTIVE_LOW>;
|
|
- label = "ext:tp27";
|
|
- default-state = "keep";
|
|
- };
|
|
-
|
|
- wlan2g {
|
|
- gpios = <&led_gpio 8 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:wlan2g";
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- gpios = <&led_gpio 9 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:wlan5g";
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- wps {
|
|
- gpios = <&led_gpio 10 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:wps";
|
|
- };
|
|
-
|
|
- voip {
|
|
- gpios = <&led_gpio 11 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:voip";
|
|
- };
|
|
-
|
|
- s1 {
|
|
- gpios = <&led_gpio 12 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:s1";
|
|
- };
|
|
-
|
|
- s2 {
|
|
- gpios = <&led_gpio 13 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:s2";
|
|
- };
|
|
-
|
|
- s3 {
|
|
- gpios = <&led_gpio 14 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:s3";
|
|
- };
|
|
-
|
|
- s4 {
|
|
- gpios = <&led_gpio 15 GPIO_ACTIVE_HIGH>;
|
|
- label = "blue:s4";
|
|
- };
|
|
-
|
|
- signal {
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- label = "red:signal";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- linux,code = <KEY_RESTART>;
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>, <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- /*"n25q128a11" is required for proper nand recognition in u-boot. */
|
|
- compatible = "jedec,spi-nor", "n25q128a11";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "0:BOOTCONFIG";
|
|
- reg = <0x180000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- flash@1 {
|
|
- /*
|
|
- * Factory U-boot looks in 0:BOOTCONFIG partition for active
|
|
- * partitions settings and mangle partition config. So kernel
|
|
- * /kernel_1 and rootfs/rootfs_1 pairs can be swaped.
|
|
- * It isn't a problem but we never can be sure where OFW put
|
|
- * factory images. "spinand,mt29f" value is required for proper
|
|
- * nand recognition in u-boot.
|
|
- */
|
|
- compatible = "spi-nand","spinand,mt29f";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "kernel";
|
|
- reg = <0x0 0x400000>;
|
|
- };
|
|
-
|
|
- partition@400000 {
|
|
- label = "rootfs";
|
|
- reg = <0x400000 0x2000000>;
|
|
- };
|
|
-
|
|
- partition@2400000 {
|
|
- label = "kernel_1";
|
|
- reg = <0x2400000 0x400000>;
|
|
- };
|
|
-
|
|
- partition@2800000 {
|
|
- label = "rootfs_1";
|
|
- reg = <0x2800000 0x2000000>;
|
|
- };
|
|
-
|
|
- partition@4800000 {
|
|
- label = "ubifs";
|
|
- reg = <0x4800000 0x3800000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "cellc,rtl30vw";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "cellc,rtl30vw";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srr60.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srr60.dts
|
|
deleted file mode 100644
|
|
index 80bcb2e204..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srr60.dts
|
|
+++ /dev/null
|
|
@@ -1,12 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-orbi.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "NETGEAR SRR60";
|
|
- compatible = "netgear,srr60";
|
|
-
|
|
- chosen {
|
|
- bootargs = "root=/dev/mmcblk0p20 blkdevparts=mmcblk0:512K@17K(0:SBL1)ro,512K(0:BOOTCONFIG)ro,512K(0:QSEE)ro,512K(0:QSEE_1)ro,256K(0:CDT)ro,256K(0:CDT_1)ro,512K(0:BOOTCONFIG1)ro,256K(0:APPSBLENV)ro,1M(0:APPSBL)ro,1M(0:APPSBL_1)ro,256K(0:ART)ro,256K(ARTMTD)ro,2M(language)ro,256K(config)ro,256K(pot)ro,256K(traffic_meter)ro,256K(pot_bak)ro,256K(traffic_meter.bak)ro,3840K(kernel),31488K(rootfs),35328K@9233K(firmware),256K(mtdoops)ro,64K(cert)ro,3840K(kernel-2)ro,31488K(rootfs-2)ro,35328K@44881K(firmware-2)ro,5M(device_table)ro,17M(cp_file)ro,102737K(reserved)ro,-(unallocated) rootfstype=squashfs,ext4 rootwait";
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srs60.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srs60.dts
|
|
deleted file mode 100644
|
|
index 65bb7ac397..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-srs60.dts
|
|
+++ /dev/null
|
|
@@ -1,12 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-orbi.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "NETGEAR SRS60";
|
|
- compatible = "netgear,srs60";
|
|
-
|
|
- chosen {
|
|
- bootargs = "root=/dev/mmcblk0p20 blkdevparts=mmcblk0:512K@17K(0:SBL1)ro,512K(0:BOOTCONFIG)ro,512K(0:QSEE)ro,512K(0:QSEE_1)ro,256K(0:CDT)ro,256K(0:CDT_1)ro,512K(0:BOOTCONFIG1)ro,256K(0:APPSBLENV)ro,1M(0:APPSBL)ro,1M(0:APPSBL_1)ro,256K(0:ART)ro,256K(ARTMTD)ro,2M(language)ro,256K(config)ro,256K(pot)ro,256K(traffic_meter)ro,256K(pot_bak)ro,256K(traffic_meter.bak)ro,3840K(kernel),31488K(rootfs),35328K@9233K(firmware),256K(mtdoops)ro,64K(cert)ro,3840K(kernel-2)ro,31488K(rootfs-2)ro,35328K@44881K(firmware-2)ro,5M(device_table)ro,17M(cp_file)ro,102737K(reserved)ro,-(unallocated) rootfstype=squashfs,ext4 rootwait";
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019-32m.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019-32m.dts
|
|
deleted file mode 100644
|
|
index 4efcdaf394..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019-32m.dts
|
|
+++ /dev/null
|
|
@@ -1,88 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019-u4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Unielec U4019 (32M)";
|
|
- compatible = "unielec,u4019-32m","unielec,u4019","qcom,ipq4019";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
- broken-flash-reset;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- partition@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0x1e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019.dtsi
|
|
deleted file mode 100644
|
|
index c7439b87ec..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-u4019.dtsi
|
|
+++ /dev/null
|
|
@@ -1,216 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- compatible = "unielec,u4019","qcom,ipq4019";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_status;
|
|
- serial0 = &blsp1_uart1;
|
|
- serial1 = &blsp1_uart2;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
- pinctrl-0 = <&led_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- led_status: led2 {
|
|
- label = "green:led2";
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0-pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- led_pins: led_pinmux {
|
|
- mux {
|
|
- function = "gpio";
|
|
- pins = "gpio68";
|
|
- bias-disabled;
|
|
- output-low;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-whw03v2.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-whw03v2.dts
|
|
deleted file mode 100644
|
|
index 1f0572b879..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-whw03v2.dts
|
|
+++ /dev/null
|
|
@@ -1,519 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "Linksys WHW03 V2 (Velop)";
|
|
- compatible = "linksys,whw03v2", "qcom,ipq4019";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_blue;
|
|
- led-failsafe = &led_red;
|
|
- led-running = &led_green;
|
|
- led-upgrade = &led_red;
|
|
- };
|
|
-
|
|
- // The arguments rootfstype and ro are needed
|
|
- // to override the default bootargs
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/ubiblock0_0 rootfstype=squashfs ro";
|
|
- stdout-path = &blsp1_uart1;
|
|
- };
|
|
-
|
|
- soc {
|
|
- ess-tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio-pinmux {
|
|
- mux-1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux-2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c-0-pinmux {
|
|
- mux {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio20", "gpio21";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0-pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1-pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9", "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi-0-pinmux {
|
|
- mux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux-cs {
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_1_pins: spi-1-pinmux {
|
|
- mux-1 {
|
|
- function = "blsp_spi1";
|
|
- pins = "gpio44", "gpio46","gpio47";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- mux-2 {
|
|
- pins = "gpio31", "gpio45", "gpio49";
|
|
- function = "gpio";
|
|
- bias-pull-up;
|
|
- output-high;
|
|
- };
|
|
-
|
|
- host-interrupt {
|
|
- pins = "gpio42";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- };
|
|
-
|
|
- wifi_0_pins: wifi0-pinmux {
|
|
- btcoexist {
|
|
- bias-pull-up;
|
|
- drive-strength = <6>;
|
|
- function = "gpio";
|
|
- output-high;
|
|
- pins = "gpio52";
|
|
- };
|
|
- };
|
|
-
|
|
- zigbee-0 {
|
|
- gpio-hog;
|
|
- gpios = <29 GPIO_ACTIVE_HIGH>;
|
|
- bias-disable;
|
|
- output-low;
|
|
- };
|
|
-
|
|
- zigbee-1 {
|
|
- gpio-hog;
|
|
- gpios = <50 GPIO_ACTIVE_HIGH>;
|
|
- bias-disable;
|
|
- input;
|
|
- };
|
|
-
|
|
- bluetooth-enable {
|
|
- gpio-hog;
|
|
- gpios = <32 GPIO_ACTIVE_HIGH>;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- phy-reset-gpios = <&tlmm 19 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- reg = <0x1b>;
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- reg = <0x1c>;
|
|
-};
|
|
-
|
|
-&psgmiiphy {
|
|
- reg = <0x1d>;
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- num-channels = <4>;
|
|
- qcom,num-ees = <2>;
|
|
-
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- bluetooth {
|
|
- compatible = "csr,8811";
|
|
-
|
|
- enable-gpios = <&tlmm 32 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi2 {
|
|
- pinctrl-0 = <&spi_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- cs-gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- zigbee@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- compatible = "silabs,em3581";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <12000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- status = "okay";
|
|
-
|
|
- // RGB LEDs
|
|
- pca9633: led-controller {
|
|
- compatible = "nxp,pca9633";
|
|
- nxp,hw-blink;
|
|
- reg = <0x62>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- led_red: red@0 {
|
|
- label = "red";
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_INDICATOR;
|
|
- linux,default-trigger = "none";
|
|
- reg = <0>;
|
|
- };
|
|
-
|
|
- led_green: green@1 {
|
|
- label = "green";
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- function = LED_FUNCTION_INDICATOR;
|
|
- linux,default-trigger = "none";
|
|
- reg = <1>;
|
|
- };
|
|
-
|
|
- led_blue: blue@2 {
|
|
- label = "blue";
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_INDICATOR;
|
|
- linux,default-trigger = "default-on";
|
|
- reg = <2>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x100000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "QSEE";
|
|
- reg = <0x200000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@300000 {
|
|
- label = "CDT";
|
|
- reg = <0x300000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@380000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x380000 0x200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@580000 {
|
|
- label = "ART";
|
|
- reg = <0x580000 0x80000>;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- read-only;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x9000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@600000 {
|
|
- label = "u_env";
|
|
- reg = <0x600000 0x80000>;
|
|
- };
|
|
-
|
|
- partition@680000 {
|
|
- label = "s_env";
|
|
- reg = <0x680000 0x40000>;
|
|
- };
|
|
-
|
|
- partition@6c0000 {
|
|
- label = "devinfo";
|
|
- reg = <0x6c0000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@700000 {
|
|
- label = "kernel";
|
|
- reg = <0x700000 0xa100000>;
|
|
- };
|
|
-
|
|
- partition@d00000 {
|
|
- label = "rootfs";
|
|
- reg = <0xd00000 0x9b00000>;
|
|
- };
|
|
-
|
|
- partition@a800000 {
|
|
- label = "alt_kernel";
|
|
- reg = <0xa800000 0xa100000>;
|
|
- };
|
|
-
|
|
- partition@ae00000 {
|
|
- label = "alt_rootfs";
|
|
- reg = <0xae00000 0x9b00000>;
|
|
- };
|
|
-
|
|
- partition@14900000 {
|
|
- label = "sysdiag";
|
|
- reg = <0x14900000 0x200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@14b00000 {
|
|
- label = "syscfg";
|
|
- reg = <0x14b00000 0xb500000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpios = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpios = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
- clkreq-gpios = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "wan";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- pinctrl-0 = <&wifi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- status = "okay";
|
|
-
|
|
- qcom,coexist-support = <1>;
|
|
- qcom,coexist-gpio-pin = <0x34>;
|
|
-
|
|
- ieee80211-freq-limit = <2401000 2473000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-whw03v2";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_gmac0>;
|
|
- mac-address-increment = <1>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
-
|
|
- ieee80211-freq-limit = <5170000 5250000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-whw03v2";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_gmac0>;
|
|
- mac-address-increment = <2>;
|
|
-};
|
|
-
|
|
-&wifi2 {
|
|
- status = "okay";
|
|
-
|
|
- ieee80211-freq-limit = <5735000 5835000>;
|
|
- qcom,ath10k-calibration-variant = "linksys-whw03v2";
|
|
-
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_9000>, <&macaddr_gmac0>;
|
|
- mac-address-increment = <3>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wifi.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wifi.dts
|
|
deleted file mode 100644
|
|
index f92c289738..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wifi.dts
|
|
+++ /dev/null
|
|
@@ -1,447 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0
|
|
-/*
|
|
- * Copyright (c) 2016, 2018 The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2016 Google, Inc
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- model = "Google WiFi (Gale)";
|
|
- compatible = "google,wifi", "google,gale-v2", "qcom,ipq4019";
|
|
-
|
|
- aliases {
|
|
- label-mac-device = &gmac0;
|
|
- led-boot = &led0_blue;
|
|
- led-failsafe = &led0_red;
|
|
- led-running = &led0_blue;
|
|
- led-upgrade = &led0_red;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * rootwait: in case we're booting from slow/async USB storage.
|
|
- */
|
|
- bootargs-append = " rootwait";
|
|
- stdout-path = &blsp1_uart1;
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x20000000>; /* 512MB */
|
|
- };
|
|
-
|
|
- soc {
|
|
- edma@c080000 {
|
|
- /*
|
|
- * Factory bootloader (depthcharge) will fail to boot
|
|
- * if this exact path (soc/edma@c080000/gmac0) doesn't
|
|
- * exist.
|
|
- */
|
|
- gmac0: gmac0 {
|
|
- };
|
|
-
|
|
- /*
|
|
- * Factory bootloader (depthcharge) will fail to boot
|
|
- * if this exact path (soc/edma@c080000/gmac1) doesn't
|
|
- * exist.
|
|
- */
|
|
- gmac1 {
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
- pinctrl-0 = <&fw_pinmux>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 57 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- fw_pinmux: fw_pinmux {
|
|
- wp {
|
|
- pins = "gpio53";
|
|
- output-low;
|
|
- };
|
|
- recovery {
|
|
- pins = "gpio57";
|
|
- function = "gpio";
|
|
- bias-none;
|
|
- };
|
|
- developer {
|
|
- pins = "gpio41";
|
|
- bias-none;
|
|
- };
|
|
- };
|
|
-
|
|
- reset802_15_4 {
|
|
- pins = "gpio60";
|
|
- };
|
|
-
|
|
- led_reset {
|
|
- pins = "gpio22";
|
|
- output-high;
|
|
- };
|
|
-
|
|
- sys_reset {
|
|
- pins = "gpio19";
|
|
- output-high;
|
|
- };
|
|
-
|
|
- rx_active {
|
|
- pins = "gpio43";
|
|
- bias-pull,down;
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14","gpio15";
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio13", "gpio14","gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinconf_cs {
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_1_pins: spi_1_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi1";
|
|
- pins = "gpio44", "gpio46","gpio47";
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio45";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio44", "gpio46","gpio47";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinconf_cs {
|
|
- pins = "gpio45";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9", "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- drive-open-drain;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_1_pins: i2c_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio34", "gpio35";
|
|
- function = "blsp_i2c1";
|
|
- drive-open-drain;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_0_pins: sd_0_pinmux {
|
|
- sd0 {
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26", "gpio29", "gpio30", "gpio31", "gpio32";
|
|
- function = "sdio";
|
|
- drive-strength = <10>;
|
|
- bias-pull-up;
|
|
- pull-up-res = <0>;
|
|
- };
|
|
- sdclk {
|
|
- pins = "gpio27";
|
|
- function = "sdio";
|
|
- drive-strength = <2>;
|
|
- bias-pull-up;
|
|
- pull-up-res = <0>;
|
|
- };
|
|
- sdcmd {
|
|
- pins = "gpio28";
|
|
- function = "sdio";
|
|
- drive-strength = <10>;
|
|
- bias-pull-up;
|
|
- pull-up-res = <0>;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-disable;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-disable;
|
|
- };
|
|
- mux_3 {
|
|
- pins = "gpio40";
|
|
- function = "gpio";
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- wifi1_1_pins: wifi2_pinmux {
|
|
- mux {
|
|
- pins = "gpio58";
|
|
- output-low;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- tpm@20 {
|
|
- compatible = "infineon,slb9645tt";
|
|
- reg = <0x20>;
|
|
- powered-while-suspended;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c4 {
|
|
- pinctrl-0 = <&i2c_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- led-controller@32 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
- compatible = "national,lp5523";
|
|
- reg = <0x32>;
|
|
- clock-mode = /bits/ 8 <1>;
|
|
-
|
|
-#if 1
|
|
- led0_red: led@0 {
|
|
- reg = <0>;
|
|
- chan-name = "LED0_Red";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- function = LED_FUNCTION_FAULT;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- reg = <1>;
|
|
- chan-name = "LED0_Green";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- };
|
|
-
|
|
- led0_blue: led@2 {
|
|
- reg = <2>;
|
|
- chan-name = "LED0_Blue";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- function = LED_FUNCTION_POWER;
|
|
- };
|
|
-#else
|
|
- /*
|
|
- * openwrt isn't ready to handle multi-intensity leds yet
|
|
- * # echo 255 255 255 > /sys/class/leds/tricolor/multi_intensity
|
|
- * # echo 255 > /sys/class/leds/tricolor/brightness
|
|
- */
|
|
- multi-led@2 {
|
|
- function = LED_FUNCTION_POWER;
|
|
- reg = <2>;
|
|
- color = <LED_COLOR_ID_RGB>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- led@0 {
|
|
- reg = <0>;
|
|
- chan-name = "tricolor";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- };
|
|
-
|
|
- led@1 {
|
|
- reg = <1>;
|
|
- chan-name = "tricolor";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- };
|
|
-
|
|
- led@2 {
|
|
- reg = <2>;
|
|
- chan-name = "tricolor";
|
|
- led-cur = /bits/ 8 <0x64>;
|
|
- max-cur = /bits/ 8 <0x78>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- };
|
|
- };
|
|
-#endif
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi2 {
|
|
- pinctrl-0 = <&spi_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- /*
|
|
- * This "spidev" was included in the manufacturer device tree. I
|
|
- * suspect it's the (unused; and removed from later HW spins) Zigbee
|
|
- * radio -- SiliconLabs EM3581 Zigbee? There's no driver or binding for
|
|
- * this at the moment.
|
|
- */
|
|
- spidev@0 {
|
|
- compatible = "spidev";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&sd_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- clock-frequency = <192000000>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
- non-removable;
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "GO_GALE";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&wifi1_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- qcom,ath10k-calibration-variant = "GO_GALE";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wpj419.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wpj419.dts
|
|
deleted file mode 100644
|
|
index ca37884db2..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wpj419.dts
|
|
+++ /dev/null
|
|
@@ -1,370 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2019, Nguyen Dinh Phi <phi_nguyen@compex.com.sg>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Compex WPJ419";
|
|
- compatible = "compex,wpj419", "qcom,ipq4019";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- reserved-memory {
|
|
- ranges;
|
|
- rsvd1@87000000 {
|
|
- /* Reserved for other subsystem */
|
|
- reg = <0x87000000 0x500000>;
|
|
- no-map;
|
|
- };
|
|
- wifi_dump@87500000 {
|
|
- reg = <0x87500000 0x600000>;
|
|
- no-map;
|
|
- };
|
|
-
|
|
- rsvd2@87B00000 {
|
|
- /* Reserved for other subsystem */
|
|
- reg = <0x87B00000 0x500000>;
|
|
- no-map;
|
|
- };
|
|
- };
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- pinctrl@1000000 {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9", "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- led_0_pins: led0_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio36";
|
|
- function = "led0";
|
|
- bias-pull-down;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio40";
|
|
- function = "led4";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- blsp_dma: dma@7884000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- spi_0: spi@78b5000 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>, <&tlmm 41 GPIO_ACTIVE_HIGH>;
|
|
- num-cs = <2>;
|
|
-
|
|
- flash0@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
- broken-flash-reset;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x000000 0x040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x040000 0x020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x060000 0x060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x0c0000 0x010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x0d0000 0x010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0x0e0000 0x010000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "u-boot";
|
|
- reg = <0x0f0000 0x080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- nand@1 {
|
|
- reg = <1>;
|
|
- status = "okay";
|
|
- compatible = "spi-nand";
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- /* The device has 128MB, but we can only address
|
|
- * 64MB because of the bootloader's default settings.
|
|
- * This is due to the old mt29f driver,
|
|
- * which detected the deivce with only 64MB
|
|
- */
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x0000000 0x4000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <5000>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- i2c_0: i2c@78b7000 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- serial@78af000 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- serial@78b0000 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3_ss_phy: ssphy@9a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3_hs_phy: hsphy@a6000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3: usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb2_hs_phy: hsphy@a8000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- cryptobam: dma@8e04000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- qpic_bam: dma@7984000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- pcie0: pci@40000000 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wtr-m2133hp.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wtr-m2133hp.dts
|
|
deleted file mode 100644
|
|
index 3260de23bd..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-wtr-m2133hp.dts
|
|
+++ /dev/null
|
|
@@ -1,462 +0,0 @@
|
|
-// SPDX-License-Identifier: ISC
|
|
-/*
|
|
- * Copyright (c) 2015 - 2016, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2020 Yanase Yuki <dev@zpc.sakura.ne.jp>
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Buffalo WTR-M2133HP";
|
|
- compatible = "buffalo,wtr-m2133hp", "qcom,ipq4019";
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x20000000>;
|
|
- };
|
|
-
|
|
- chosen {
|
|
- /*
|
|
- * U-Boot adds "ubi.mtd=rootfs root=mtd:ubi_rootfs" to
|
|
- * kernel command line. But we use different partition names,
|
|
- * so we have to set correct parameters.
|
|
- */
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power_blue;
|
|
- led-failsafe = &led_power_orange;
|
|
- led-running = &led_power_white;
|
|
- led-upgrade = &led_power_blue;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power_white: power_white {
|
|
- label = "white:power";
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_power_orange: power_orange {
|
|
- label = "orange:power";
|
|
- gpios = <&tlmm 25 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_power_blue: power_blue {
|
|
- label = "blue:power";
|
|
- gpios = <&tlmm 43 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- router_white {
|
|
- label = "white:router";
|
|
- gpios = <&tlmm 28 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- router_orange {
|
|
- label = "orange:router";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- internet_white {
|
|
- label = "white:internet";
|
|
- gpios = <&tlmm 27 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- internet_orange {
|
|
- label = "orange:internet";
|
|
- gpios = <&tlmm 45 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wireless_white {
|
|
- label = "white:wireless";
|
|
- gpios = <&tlmm 24 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wireless_orange {
|
|
- label = "orange:wireless";
|
|
- gpios = <&tlmm 44 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- auto_mode {
|
|
- label = "auto_mode";
|
|
- gpios = <&tlmm 9 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <BTN_0>;
|
|
- linux,input-type = <EV_SW>;
|
|
- };
|
|
-
|
|
- router_mode {
|
|
- label = "router_mode";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <BTN_1>;
|
|
- linux,input-type = <EV_SW>;
|
|
- };
|
|
-
|
|
- ap_mode {
|
|
- label = "ap_mode";
|
|
- gpios = <&tlmm 11 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <BTN_2>;
|
|
- linux,input-type = <EV_SW>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
-
|
|
- wps {
|
|
- label = "AOSS Button";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- usb_power {
|
|
- line-name = "USB power";
|
|
- gpios = <34 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi@0,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0 0 0 0 0>;
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_9000>, <&macaddr_orgdata_32>;
|
|
- qcom,ath10k-calibration-variant = "Buffalo-WTR-M2133HP";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0000000 0x0100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x0100000 0x0100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "BOOTCONFIG";
|
|
- reg = <0x0200000 0x0100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@300000 {
|
|
- label = "QSEE";
|
|
- reg = <0x0300000 0x0100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@400000 {
|
|
- label = "QSEE_1";
|
|
- reg = <0x0400000 0x0100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@500000 {
|
|
- label = "CDT";
|
|
- reg = <0x0500000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@580000 {
|
|
- label = "CDT_1";
|
|
- reg = <0x0580000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@600000 {
|
|
- label = "BOOTCONFIG1";
|
|
- reg = <0x0600000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@680000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0x0680000 0x0080000>;
|
|
- };
|
|
-
|
|
- partition@700000 {
|
|
- label = "APPSBL";
|
|
- reg = <0x0700000 0x0200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@900000 {
|
|
- label = "APPSBL_1";
|
|
- reg = <0x0900000 0x0200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@b00000 {
|
|
- label = "ART";
|
|
- reg = <0x0b00000 0x0080000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_9000: precal@9000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@b80000 {
|
|
- label = "ART_1";
|
|
- reg = <0x0b80000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- orgdata: partition@c00000 {
|
|
- label = "ORGDATA";
|
|
- reg = <0x0c00000 0x0080000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_orgdata_20: macaddr@20 {
|
|
- reg = <0x20 0x6>;
|
|
- };
|
|
- macaddr_orgdata_26: macaddr@26 {
|
|
- reg = <0x26 0x6>;
|
|
- };
|
|
- macaddr_orgdata_2c: macaddr@2c {
|
|
- reg = <0x2c 0x6>;
|
|
- };
|
|
- macaddr_orgdata_32: macaddr@32 {
|
|
- reg = <0x32 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@c80000 {
|
|
- label = "ORGDATA_1";
|
|
- reg = <0x0c80000 0x0080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d00000 {
|
|
- label = "ubi";
|
|
- reg = <0x0d00000 0x2900000>;
|
|
- };
|
|
-
|
|
- partition@3600000 {
|
|
- label = "rootfs_recover";
|
|
- reg = <0x3600000 0x2900000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@5f00000 {
|
|
- label = "user_property";
|
|
- reg = <0x5f00000 0x1a20000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_orgdata_26>;
|
|
- qcom,ath10k-calibration-variant = "Buffalo-WTR-M2133HP";
|
|
- ieee80211-freq-limit = <2400000 2483000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_orgdata_2c>;
|
|
- qcom,ath10k-calibration-variant = "Buffalo-WTR-M2133HP";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_orgdata_20>;
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dts
|
|
deleted file mode 100644
|
|
index 681300c502..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dts
|
|
+++ /dev/null
|
|
@@ -1,89 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-/dts-v1/;
|
|
-
|
|
-#include "qcom-ipq4019-x1pro.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-
|
|
-/ {
|
|
- model = "Telco X1 Pro";
|
|
- compatible = "tel,x1pro","qcom,ipq4019";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- flash@0 {
|
|
- reg = <0>;
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
- broken-flash-reset;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- partition@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
- partition@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@e0000 {
|
|
- label = "0:APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- partition@f0000 {
|
|
- label = "0:APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
- art: partition@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
- partition@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0x1e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dtsi
|
|
deleted file mode 100644
|
|
index 3de6a10433..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-x1pro.dtsi
|
|
+++ /dev/null
|
|
@@ -1,216 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- compatible = "tel,x1pro","qcom,ipq4019";
|
|
- aliases {
|
|
- led-boot = &led_status;
|
|
- led-failsafe = &led_status;
|
|
- led-running = &led_status;
|
|
- led-upgrade = &led_status;
|
|
- serial0 = &blsp1_uart1;
|
|
- serial1 = &blsp1_uart2;
|
|
- };
|
|
-
|
|
- soc {
|
|
-
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 47 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
- pinctrl-0 = <&led_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- led_status: status {
|
|
- label = "green:status";
|
|
- gpios = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial0-pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- led_pins: led_pinmux {
|
|
- mux {
|
|
- function = "gpio";
|
|
- pins = "gpio68";
|
|
- bias-disabled;
|
|
- output-low;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-xx8300.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-xx8300.dtsi
|
|
deleted file mode 100644
|
|
index 141ea60442..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4019-xx8300.dtsi
|
|
+++ /dev/null
|
|
@@ -1,326 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-/*
|
|
- * Device Tree Source for Linksys xx8300 (Dallas)
|
|
- *
|
|
- * Copyright (C) 2019, 2022 Jeff Kletsky
|
|
- * Updated 2020 Hans Geiblinger
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
- //
|
|
- // OEM U-Boot provides either
|
|
- // init=/sbin/init rootfstype=ubifs ubi.mtd=11,2048 \
|
|
- // root=ubi0:ubifs rootwait rw
|
|
- // or the same with ubi.mtd=13,2048
|
|
- //
|
|
-
|
|
-/ {
|
|
- chosen {
|
|
- bootargs-append = " root=/dev/ubiblock0_0 rootfstype=squashfs ro";
|
|
- };
|
|
-
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@6000000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb2_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
-
|
|
- dwc3@8a00000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- usb3_port1: port@1 {
|
|
- reg = <1>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
-
|
|
- usb3_port2: port@2 {
|
|
- reg = <2>;
|
|
- #trigger-source-cells = <0>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- regulator-usb-vbus {
|
|
- compatible = "regulator-fixed";
|
|
- regulator-name = "USB_VBUS";
|
|
- regulator-min-microvolt = <5000000>;
|
|
- regulator-max-microvolt = <5000000>;
|
|
- regulator-always-on;
|
|
- regulator-boot-on;
|
|
- gpio = <&tlmm 68 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-};
|
|
-
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "sbl1";
|
|
- reg = <0x0 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@100000 {
|
|
- label = "mibib";
|
|
- reg = <0x100000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "qsee";
|
|
- reg = <0x200000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@300000 {
|
|
- label = "cdt";
|
|
- reg = <0x300000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@380000 {
|
|
- label = "appsblenv";
|
|
- reg = <0x380000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@400000 {
|
|
- label = "ART";
|
|
- reg = <0x400000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@480000 {
|
|
- label = "appsbl";
|
|
- reg = <0x480000 0x200000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@680000 {
|
|
- label = "u_env";
|
|
- reg = <0x680000 0x80000>;
|
|
- // writable -- U-Boot environment
|
|
- };
|
|
-
|
|
- partition@700000 {
|
|
- label = "s_env";
|
|
- reg = <0x700000 0x40000>;
|
|
- // writable -- Boot counter records
|
|
- };
|
|
-
|
|
- partition@740000 {
|
|
- label = "devinfo";
|
|
- reg = <0x740000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@780000 {
|
|
- label = "kernel";
|
|
- reg = <0x780000 0x5800000>;
|
|
- };
|
|
-
|
|
- partition@c80000 {
|
|
- label = "rootfs";
|
|
- reg = <0xc80000 0x5300000>;
|
|
- };
|
|
-
|
|
- partition@5f80000 {
|
|
- label = "alt_kernel";
|
|
- reg = <0x5f80000 0x5800000>;
|
|
- };
|
|
-
|
|
- partition@6480000 {
|
|
- label = "alt_rootfs";
|
|
- reg = <0x6480000 0x5300000>;
|
|
- };
|
|
-
|
|
- partition@b780000 {
|
|
- label = "sysdiag";
|
|
- reg = <0xb780000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@b880000 {
|
|
- label = "syscfg";
|
|
- reg = <0xb880000 0x4680000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_0_pins: serial0-pinmux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- // gpio61 controls led_usb
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio55", "gpio56", "gpio57",
|
|
- "gpio60", "gpio62", "gpio63",
|
|
- "gpio64", "gpio65", "gpio66",
|
|
- "gpio67", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport1 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4028-wpj428.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4028-wpj428.dts
|
|
deleted file mode 100644
|
|
index 48b5cd53d8..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4028-wpj428.dts
|
|
+++ /dev/null
|
|
@@ -1,304 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017, Christian Mehlis <christian@m3hlis.de>
|
|
- * Copyright (c) 2017-2018, Sven Eckelmann <sven.eckelmann@openmesh.com>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Compex WPJ428";
|
|
- compatible = "compex,wpj428";
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 59 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2: usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3: usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- aliases {
|
|
- led-boot = &status;
|
|
- led-failsafe = &status;
|
|
- led-upgrade = &status;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- status: rss4 {
|
|
- label = "green:rss4";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- rss3 {
|
|
- label = "green:rss3";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- beeper: beeper {
|
|
- compatible = "gpio-beeper";
|
|
- gpios = <&tlmm 58 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio53";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- mux_2 {
|
|
- pins = "gpio52";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- m25p80@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV"; /* uboot env*/
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@f0000 {
|
|
- label = "0:APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition5@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_art_e010: mac-address@e010 {
|
|
- reg = <0xe010 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_e018: mac-address@e018 {
|
|
- reg = <0xe018 0x6>;
|
|
- };
|
|
- };
|
|
- partition6@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x00180000 0x01e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "lan1";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_e018>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "lan2";
|
|
-
|
|
- nvmem-cells = <&macaddr_art_e010>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303.dts
|
|
deleted file mode 100644
|
|
index 6cbfa8f37d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303.dts
|
|
+++ /dev/null
|
|
@@ -1,196 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4029-aruba-glenmorangie.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-
|
|
-/ {
|
|
- model = "Aruba AP-303";
|
|
- compatible = "aruba,ap-303";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_system_green;
|
|
- led-failsafe = &led_system_red;
|
|
- led-running = &led_system_green;
|
|
- led-upgrade = &led_system_red;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wifi_green {
|
|
- label = "green:wifi";
|
|
- gpios = <&tlmm 39 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wifi_amber {
|
|
- label = "amber:wifi";
|
|
- gpios = <&tlmm 40 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- led_system_red: system_red {
|
|
- label = "red:system";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_system_green: system_green {
|
|
- label = "green:system";
|
|
- gpios = <&tlmm 47 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- /*
|
|
- * In addition to the Pins listed below,
|
|
- * the following GPIOs have "features":
|
|
- * 54 - out - active low to force HW reset
|
|
- * 41 - out - active low to reset TPM
|
|
- * 43 - out - active low to reset BLE radio
|
|
- * 19 - in - active high when DC powered
|
|
- */
|
|
-
|
|
- phy-reset {
|
|
- line-name = "PHY-reset";
|
|
- gpios = <42 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- /*
|
|
- * There is no partition map for the NOR flash
|
|
- * in the stock firmware.
|
|
- *
|
|
- * All partitions here are based on offsets
|
|
- * found in the U-Boot GPL code and information
|
|
- * from smem.
|
|
- */
|
|
-
|
|
- partition@0 {
|
|
- label = "sbl1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "mibib";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "qsee";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "cdt";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "ddrparams";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "ART";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "appsbl";
|
|
- reg = <0xf0000 0xf0000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1e0000 {
|
|
- label = "mfginfo";
|
|
- reg = <0x1e0000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mfginfo_1d: macaddr@1d {
|
|
- reg = <0x1d 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1f0000 {
|
|
- label = "apcd";
|
|
- reg = <0x1f0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "osss";
|
|
- reg = <0x200000 0x180000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@380000 {
|
|
- label = "appsblenv";
|
|
- reg = <0x380000 0x10000>;
|
|
- };
|
|
-
|
|
- partition@390000 {
|
|
- label = "pds";
|
|
- reg = <0x390000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3a0000 {
|
|
- label = "fcache";
|
|
- reg = <0x3a0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3b0000 {
|
|
- /* Called osss1 in smem */
|
|
- label = "u-boot-env-bak";
|
|
- reg = <0x3b0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3f0000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0x3f0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303h.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303h.dts
|
|
deleted file mode 100644
|
|
index 23abb3537c..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-303h.dts
|
|
+++ /dev/null
|
|
@@ -1,472 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Aruba AP-303H";
|
|
- compatible = "aruba,ap-303h";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_system_green;
|
|
- led-failsafe = &led_system_red;
|
|
- led-running = &led_system_green;
|
|
- led-upgrade = &led_system_amber;
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- reset-gpios = <&tlmm 19 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- i2c_0: i2c@78b7000 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- tpm@29 {
|
|
- /* No Driver */
|
|
- compatible = "atmel,at97sc3203";
|
|
- reg = <0x29>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- power-monitor@40 {
|
|
- /* No driver */
|
|
- compatible = "isl,isl28022";
|
|
- reg = <0x40>;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wifi_green {
|
|
- label = "green:wifi";
|
|
- gpios = <&tlmm 27 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wifi_amber {
|
|
- label = "amber:wifi";
|
|
- gpios = <&tlmm 28 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- pse {
|
|
- label = "green:pse";
|
|
- gpios = <&tlmm 42 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_system_red: system_red {
|
|
- label = "red:system";
|
|
- gpios = <&tlmm 25 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_system_green: system_green {
|
|
- label = "green:system";
|
|
- gpios = <&tlmm 24 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- led_system_amber: system_amber {
|
|
- label = "amber:system";
|
|
- gpios = <&tlmm 26 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "Reset button";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- /* Texas Instruments CC2540T BLE radio */
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- /*
|
|
- * In addition to the Pins listed below,
|
|
- * the following GPIOs have "features":
|
|
- * 39 - out - active low to force HW reset
|
|
- * 32 - out - active low to reset TPM
|
|
- * 43 - out - active low to reset BLE radio
|
|
- * 41 - out - pulse to set warm reset status
|
|
- * 34 - out - active low to enable PSE port
|
|
- * 22 - in - active low when 802.3at powered
|
|
- * 29 - in - active high when DC powered
|
|
- * 40 - in - active low when reset due to cold HW reset
|
|
- * 30 - in - active low when USB overcurrent detected
|
|
- * 35 - in - interrupt line for power monitor chip
|
|
- * 31 - in - active low when PSE port active
|
|
- */
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12", "gpio59";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio20", "gpio21";
|
|
- function = "blsp_i2c0";
|
|
- drive-strength = <4>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- usb-power {
|
|
- line-name = "USB-power";
|
|
- gpios = <23 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>, <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- /*
|
|
- * There is no partition map for the NOR flash
|
|
- * in the stock firmware.
|
|
- *
|
|
- * All partitions here are based on offsets
|
|
- * found in the U-Boot GPL code and information
|
|
- * from smem.
|
|
- */
|
|
-
|
|
- partition@0 {
|
|
- label = "sbl1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "mibib";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "qsee";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "cdt";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "ddrparams";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "appsblenv";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "appsbl";
|
|
- reg = <0xf0000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1e0000 {
|
|
- label = "ART";
|
|
- reg = <0x1f0000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@1f0000 {
|
|
- label = "osss";
|
|
- reg = <0x200000 0x170000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "pds";
|
|
- reg = <0x370000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@380000 {
|
|
- label = "apcd";
|
|
- reg = <0x380000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@390000 {
|
|
- label = "mfginfo";
|
|
- reg = <0x390000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mfginfo_1d: macaddr@1d {
|
|
- reg = <0x1d 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_mfginfo_45: macaddr@45 {
|
|
- reg = <0x45 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@3a0000 {
|
|
- label = "fcache";
|
|
- reg = <0x3a0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3b0000 {
|
|
- /* Called osss1 in smem */
|
|
- label = "u-boot-env-bak";
|
|
- reg = <0x3b0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3f0000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0x3c0000 0x40000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- flash@1 {
|
|
- status = "okay";
|
|
-
|
|
- compatible = "spi-nand";
|
|
- reg = <1>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- /* 'aos0' in Aruba firmware */
|
|
- label = "aos0";
|
|
- reg = <0x0 0x2000000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2000000 {
|
|
- /* 'aos1' in Aruba firmware */
|
|
- label = "ubi";
|
|
- reg = <0x2000000 0x2000000>;
|
|
- };
|
|
-
|
|
- partition@4000000 {
|
|
- label = "aruba-ubifs";
|
|
- reg = <0x4000000 0x4000000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport2 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan3";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "wan";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_mfginfo_45>;
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-303";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_mfginfo_45>;
|
|
- mac-address-increment = <1>;
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-303";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-365.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-365.dts
|
|
deleted file mode 100644
|
|
index 1f7b37d56d..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ap-365.dts
|
|
+++ /dev/null
|
|
@@ -1,219 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4029-aruba-glenmorangie.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-
|
|
-/ {
|
|
- model = "Aruba AP-365";
|
|
- compatible = "aruba,ap-365";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_system_green;
|
|
- led-failsafe = &led_system_red;
|
|
- led-running = &led_system_green;
|
|
- led-upgrade = &led_system_red;
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_system_red: system_red {
|
|
- label = "red:system";
|
|
- gpios = <&tlmm 46 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_system_green: system_green {
|
|
- label = "green:system";
|
|
- gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- system_amber {
|
|
- label = "amber:system";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- watchdog {
|
|
- compatible = "linux,wdt-gpio";
|
|
- gpios = <&tlmm 41 GPIO_ACTIVE_LOW>;
|
|
- hw_algo = "toggle";
|
|
- hw_margin_ms = <1000>;
|
|
- always-running;
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- /*
|
|
- * In addition to the Pins listed below,
|
|
- * the following GPIOs have "features":
|
|
- * 39 - out - pulse low to reset watchdog status flipflop
|
|
- * 40 - out - active high to enable watchdog
|
|
- * 41 - out - watchdog poke
|
|
- * 42 - out - active low to reset BLE radio
|
|
- * 43 - out - active low to reset TPM
|
|
- * 47 - out - pulse low to reset warm reset status
|
|
- * 54 - out - active low to force HW reset
|
|
- * 18 - in - PHY interrupt line
|
|
- * 45 - in - power monitor interrupt
|
|
- * 48 - in - active low when cold reset
|
|
- * 52 - in - active high when watchdog reset
|
|
- */
|
|
-
|
|
- phy-reset {
|
|
- line-name = "PHY-reset";
|
|
- gpios = <42 GPIO_ACTIVE_HIGH>;
|
|
- gpio-hog;
|
|
- output-high;
|
|
- };
|
|
-};
|
|
-
|
|
-&i2c_0 {
|
|
- power-monitor@40 {
|
|
- /* No driver */
|
|
- compatible = "isl,isl28022";
|
|
- reg = <0x40>;
|
|
- };
|
|
-
|
|
- temperature-sensor@48 {
|
|
- compatible = "adi,ad7416";
|
|
- reg = <0x48>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- /*
|
|
- * There is no partition map for the NOR flash
|
|
- * in the stock firmware.
|
|
- *
|
|
- * All partitions here are based on offsets
|
|
- * found in the U-Boot GPL code and information
|
|
- * from smem.
|
|
- */
|
|
-
|
|
- partition@0 {
|
|
- label = "sbl1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@40000 {
|
|
- label = "mibib";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@60000 {
|
|
- label = "qsee";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@c0000 {
|
|
- label = "cdt";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@d0000 {
|
|
- label = "ddrparams";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@e0000 {
|
|
- label = "u-boot-env";
|
|
- reg = <0xe0000 0x10000>;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "appsbl";
|
|
- reg = <0xf0000 0x100000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1f0000 {
|
|
- label = "ART";
|
|
- reg = <0x1f0000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "osss";
|
|
- reg = <0x200000 0x170000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@370000 {
|
|
- label = "pds";
|
|
- reg = <0x370000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@380000 {
|
|
- label = "apcd";
|
|
- reg = <0x380000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@390000 {
|
|
- label = "mfginfo";
|
|
- reg = <0x390000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- macaddr_mfginfo_1d: macaddr@1d {
|
|
- reg = <0x1d 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- partition@3a0000 {
|
|
- label = "fcache";
|
|
- reg = <0x3a0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@3b0000 {
|
|
- label = "osss1";
|
|
- reg = <0x3b0000 0x50000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-365";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-365";
|
|
-};
|
|
-
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-aruba-glenmorangie.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-aruba-glenmorangie.dtsi
|
|
deleted file mode 100644
|
|
index 41de6bb218..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-aruba-glenmorangie.dtsi
|
|
+++ /dev/null
|
|
@@ -1,272 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- ethphy: ethernet-phy@5 {
|
|
- reg = <0x5>;
|
|
- };
|
|
- };
|
|
-
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII_RGMII5>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- i2c_0: i2c@78b7000 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- tpm@29 {
|
|
- /* No Driver */
|
|
- compatible = "atmel,at97sc3203";
|
|
- reg = <0x29>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "Reset button";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- /* Texas Instruments CC2540T BLE radio */
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio10", "gpio11";
|
|
- function = "blsp_i2c0";
|
|
- drive-strength = <4>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- /* 'aos0' in Aruba firmware */
|
|
- label = "aos0";
|
|
- reg = <0x0 0x2000000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@2000000 {
|
|
- /* 'aos1' in Aruba firmware */
|
|
- label = "ubi";
|
|
- reg = <0x2000000 0x2000000>;
|
|
- };
|
|
-
|
|
- partition@4000000 {
|
|
- label = "aruba-ubifs";
|
|
- reg = <0x4000000 0x4000000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-
|
|
- /delete-property/ psgmii-ethphy;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- phy-handle = <ðphy>;
|
|
- phy-mode = "rgmii-id";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy1 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&psgmiiphy {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_mfginfo_1d>;
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-303";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_mfginfo_1d>;
|
|
- mac-address-increment = <1>;
|
|
- qcom,ath10k-calibration-variant = "Aruba-AP-303";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-b1300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-b1300.dts
|
|
deleted file mode 100644
|
|
index 7e4519a746..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-b1300.dts
|
|
+++ /dev/null
|
|
@@ -1,322 +0,0 @@
|
|
-/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for any
|
|
- * purpose with or without fee is hereby granted, provided that the above
|
|
- * copyright notice and this permission notice appear in all copies.
|
|
- *
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- *
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "GL.iNet GL-B1300";
|
|
- compatible = "glinet,gl-b1300";
|
|
-
|
|
- aliases {
|
|
- led-boot = &power;
|
|
- led-failsafe = &power;
|
|
- led-running = &power;
|
|
- led-upgrade = &power;
|
|
- label-mac-device = &swport4;
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 5 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 63 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 4 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "on";
|
|
- };
|
|
-
|
|
- mesh {
|
|
- label = "green:mesh";
|
|
- gpios = <&tlmm 3 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 2 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- mx25l25635f@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- SBL1@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- MIBIB@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- QSEE@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- CDT@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- DDRPARAMS@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- APPSBLENV@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- APPSBL@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- ART@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_gmac0: macaddr@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_gmac1: macaddr@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
- };
|
|
-
|
|
- firmware@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0x1e80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio60", "gpio61";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio54";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio55", "gpio56", "gpio57";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinconf_cs {
|
|
- pins = "gpio54";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport3 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan2";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
- mac-address-increment = <2>;
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan1";
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac0>;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- nvmem-cell-names = "mac-address";
|
|
- nvmem-cells = <&macaddr_gmac1>;
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "GL-B1300";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "GL-B1300";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-s1300.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-s1300.dts
|
|
deleted file mode 100644
|
|
index 0e7f4c970f..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-gl-s1300.dts
|
|
+++ /dev/null
|
|
@@ -1,357 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "GL.iNet GL-S1300";
|
|
- compatible = "glinet,gl-s1300";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_power;
|
|
- led-failsafe = &led_power;
|
|
- led-running = &led_power;
|
|
- led-upgrade = &led_power;
|
|
- };
|
|
-
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- usb2@60f8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- usb3@8af8800 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- wps {
|
|
- label = "wps";
|
|
- gpios = <&tlmm 53 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_WPS_BUTTON>;
|
|
- };
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_power: power {
|
|
- label = "green:power";
|
|
- gpios = <&tlmm 57 GPIO_ACTIVE_HIGH>;
|
|
- default-state = "on";
|
|
- };
|
|
-
|
|
- mesh {
|
|
- label = "green:mesh";
|
|
- gpios = <&tlmm 59 GPIO_ACTIVE_HIGH>;
|
|
- };
|
|
-
|
|
- wlan {
|
|
- label = "green:wlan";
|
|
- gpios = <&tlmm 60 GPIO_ACTIVE_HIGH>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- cd-gpios = <&tlmm 22 GPIO_ACTIVE_LOW>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- SBL1@0 {
|
|
- label = "SBL1";
|
|
- reg = <0x0 0x40000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- MIBIB@40000 {
|
|
- label = "MIBIB";
|
|
- reg = <0x40000 0x20000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- QSEE@60000 {
|
|
- label = "QSEE";
|
|
- reg = <0x60000 0x60000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- CDT@c0000 {
|
|
- label = "CDT";
|
|
- reg = <0xc0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- DDRPARAMS@d0000 {
|
|
- label = "DDRPARAMS";
|
|
- reg = <0xd0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- APPSBLENV@e0000 {
|
|
- label = "APPSBLENV";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- APPSBL@f0000 {
|
|
- label = "APPSBL";
|
|
- reg = <0xf0000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- ART@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
- };
|
|
-
|
|
- firmware@180000 {
|
|
- compatible = "denx,fit";
|
|
- label = "firmware";
|
|
- reg = <0x180000 0xe80000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_spi2 {
|
|
- pinctrl-0 = <&spi_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- spidev1: spi@0 {
|
|
- compatible = "silabs,si3210";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- serial_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9",
|
|
- "gpio10", "gpio11";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinconf_cs {
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_1_pins: spi_1_pinmux {
|
|
- mux {
|
|
- pins = "gpio44", "gpio46", "gpio47";
|
|
- function = "blsp_spi1";
|
|
- bias-disable;
|
|
- };
|
|
- host_int {
|
|
- pins = "gpio42";
|
|
- function = "gpio";
|
|
- input;
|
|
- };
|
|
- cs {
|
|
- pins = "gpio45";
|
|
- function = "gpio";
|
|
- bias-pull-up;
|
|
- };
|
|
- wake {
|
|
- pins = "gpio40";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- reset {
|
|
- pins = "gpio49";
|
|
- function = "gpio";
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- pinmux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio28", "gpio29", "gpio30", "gpio31";
|
|
- drive-strength = <10>;
|
|
- };
|
|
-
|
|
- pinmux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
-
|
|
- pinmux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio32";
|
|
- drive-strength = <10>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_1000>;
|
|
- qcom,ath10k-calibration-variant = "GL-S1300";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration";
|
|
- nvmem-cells = <&precal_art_5000>;
|
|
- qcom,ath10k-calibration-variant = "GL-S1300";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-insect-common.dtsi b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-insect-common.dtsi
|
|
deleted file mode 100644
|
|
index ebfab171f5..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-insect-common.dtsi
|
|
+++ /dev/null
|
|
@@ -1,444 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only
|
|
-/*
|
|
- * Device Tree Source for Meraki "Insect" series
|
|
- *
|
|
- * Copyright (C) 2017 Chris Blake <chrisrblake93@gmail.com>
|
|
- * Copyright (C) 2017 Christian Lamparter <chunkeey@googlemail.com>
|
|
- *
|
|
- * Based on Cisco Meraki DTS from GPL release r25-linux-3.14-20170427
|
|
- *
|
|
- * This file is licensed under the terms of the GNU General Public
|
|
- * License version 2. This program is licensed "as is" without
|
|
- * any warranty of any kind, whether express or implied.
|
|
- */
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-#include <dt-bindings/leds/common.h>
|
|
-
|
|
-/ {
|
|
- aliases {
|
|
- led-boot = &status_green;
|
|
- led-failsafe = &status_red;
|
|
- led-running = &status_green;
|
|
- led-upgrade = &power_orange;
|
|
- };
|
|
-
|
|
- /* Do we really need this defined? */
|
|
- memory {
|
|
- device_type = "memory";
|
|
- reg = <0x80000000 0x10000000>;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- /* It is a 56-bit counter that supplies the count to the ARM arch
|
|
- timers and without upstream driver */
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII_RGMII5>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- serial@78b0000 {
|
|
- pinctrl-0 = <&serial_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- bluetooth {
|
|
- compatible = "ti,cc2650";
|
|
- enable-gpios = <&tlmm 12 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- power_orange: power {
|
|
- label = "orange:power";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- panic-indicator;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_i2c3 {
|
|
- pinctrl-0 = <&i2c_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- eeprom@50 {
|
|
- compatible = "atmel,24c64";
|
|
- pagesize = <32>;
|
|
- reg = <0x50>;
|
|
- read-only; /* This holds our MAC & Meraki board-data */
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- mac_address: mac-address@66 {
|
|
- reg = <0x66 0x6>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_i2c4 {
|
|
- pinctrl-0 = <&i2c_1_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- tricolor: led-controller@30 {
|
|
- compatible = "ti,lp5562";
|
|
- reg = <0x30>;
|
|
- clock-mode = /bits/8 <2>;
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
-
|
|
- /* RGB led */
|
|
- status_red: chan@0 {
|
|
- chan-name = "red:status";
|
|
- led-cur = /bits/ 8 <0x20>;
|
|
- max-cur = /bits/ 8 <0x60>;
|
|
- reg = <0>;
|
|
- color = <LED_COLOR_ID_RED>;
|
|
- };
|
|
-
|
|
- status_green: chan@1 {
|
|
- chan-name = "green:status";
|
|
- led-cur = /bits/ 8 <0x20>;
|
|
- max-cur = /bits/ 8 <0x60>;
|
|
- reg = <1>;
|
|
- color = <LED_COLOR_ID_GREEN>;
|
|
- };
|
|
-
|
|
- chan@2 {
|
|
- chan-name = "blue:status";
|
|
- led-cur = /bits/ 8 <0x20>;
|
|
- max-cur = /bits/ 8 <0x60>;
|
|
- reg = <2>;
|
|
- color = <LED_COLOR_ID_BLUE>;
|
|
- };
|
|
-
|
|
- chan@3 {
|
|
- chan-name = "white:status";
|
|
- led-cur = /bits/ 8 <0x20>;
|
|
- max-cur = /bits/ 8 <0x60>;
|
|
- reg = <3>;
|
|
- color = <LED_COLOR_ID_WHITE>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&nand {
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "sbl1";
|
|
- reg = <0x00000000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@100000 {
|
|
- label = "mibib";
|
|
- reg = <0x00100000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@200000 {
|
|
- label = "bootconfig";
|
|
- reg = <0x00200000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@300000 {
|
|
- label = "qsee";
|
|
- reg = <0x00300000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@400000 {
|
|
- label = "qsee_alt";
|
|
- reg = <0x00400000 0x00100000>;
|
|
- read-only;
|
|
- };
|
|
- partition@500000 {
|
|
- label = "cdt";
|
|
- reg = <0x00500000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@580000 {
|
|
- label = "cdt_alt";
|
|
- reg = <0x00580000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@600000 {
|
|
- label = "ddrparams";
|
|
- reg = <0x00600000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@700000 {
|
|
- label = "u-boot";
|
|
- reg = <0x00700000 0x00200000>;
|
|
- read-only;
|
|
- };
|
|
- partition@900000 {
|
|
- label = "u-boot-backup";
|
|
- reg = <0x00900000 0x00200000>;
|
|
- read-only;
|
|
- };
|
|
- partition@b00000 {
|
|
- label = "ART";
|
|
- reg = <0x00b00000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
- partition@c00000 {
|
|
- label = "ubi";
|
|
- reg = <0x00c00000 0x07000000>;
|
|
- /*
|
|
- * Do not try to allocate the remaining
|
|
- * 4 MiB to this ubi partition. It will
|
|
- * confuse the u-boot and it might not
|
|
- * find the kernel partition anymore.
|
|
- */
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
-
|
|
- wifi2: wifi@1,0 {
|
|
- compatible = "qcom,ath10k";
|
|
- status = "okay";
|
|
- reg = <0x00010000 0 0 0 0>;
|
|
- nvmem-cells = <&mac_address>;
|
|
- nvmem-cell-names = "mac-address";
|
|
- mac-address-increment = <1>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- /*
|
|
- * GPIO43 should be 0/1 whenever the unit is
|
|
- * powered through PoE or AC-Adapter.
|
|
- * That said, playing with this seems to
|
|
- * reset the AP.
|
|
- */
|
|
-
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_0_pins: serial_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1_pinmux {
|
|
- mux {
|
|
- /* We use the i2c-0 pins for serial_1 */
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_i2c0";
|
|
- pins = "gpio20", "gpio21";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio20", "gpio21";
|
|
- drive-strength = <16>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_1_pins: i2c_1_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_i2c1";
|
|
- pins = "gpio34", "gpio35";
|
|
- };
|
|
- pinconf {
|
|
- pins = "gpio34", "gpio35";
|
|
- drive-strength = <16>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- /*
|
|
- * There are 18 pins. 15 pins are common between LCD and NAND.
|
|
- * The QPIC controller arbitrates between LCD and NAND. Of the
|
|
- * remaining 4, 2 are for NAND and 2 are for LCD exclusively.
|
|
- *
|
|
- * The meraki source hints that the bluetooth module claims
|
|
- * pin 52 as well. But sadly, there's no data whenever this
|
|
- * is a NAND or LCD exclusive pin or not.
|
|
- */
|
|
-
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58",
|
|
- "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56",
|
|
- "gpio57", "gpio60", "gpio61",
|
|
- "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67",
|
|
- "gpio68", "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Meraki-MR33";
|
|
- nvmem-cells = <&mac_address>;
|
|
- nvmem-cell-names = "mac-address";
|
|
- mac-address-increment = <2>;
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Meraki-MR33";
|
|
- nvmem-cells = <&mac_address>;
|
|
- nvmem-cell-names = "mac-address";
|
|
- mac-address-increment = <3>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
- nvmem-cells = <&mac_address>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-
|
|
- /delete-property/ psgmii-ethphy;
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
- phy-handle = <ðphy1>;
|
|
- phy-mode = "rgmii-rxid";
|
|
-};
|
|
-
|
|
-ðphy0 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy2 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy3 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-ðphy4 {
|
|
- status = "disabled";
|
|
-};
|
|
-
|
|
-&psgmiiphy {
|
|
- status = "disabled";
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr33.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr33.dts
|
|
deleted file mode 100644
|
|
index 8c8b1b3150..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr33.dts
|
|
+++ /dev/null
|
|
@@ -1,13 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only
|
|
-// Device Tree Source for Meraki MR33 (Stinkbug)
|
|
-
|
|
-#include "qcom-ipq4029-insect-common.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Meraki MR33 Access Point";
|
|
- compatible = "meraki,mr33";
|
|
-};
|
|
-
|
|
-&tricolor {
|
|
- enable-gpio = <&tlmm 48 GPIO_ACTIVE_HIGH>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr74.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr74.dts
|
|
deleted file mode 100644
|
|
index 904f724652..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-mr74.dts
|
|
+++ /dev/null
|
|
@@ -1,13 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only
|
|
-// Device Tree Source for Meraki MR74 (Ladybug)
|
|
-
|
|
-#include "qcom-ipq4029-insect-common.dtsi"
|
|
-
|
|
-/ {
|
|
- model = "Meraki MR74 Access Point";
|
|
- compatible = "meraki,mr74";
|
|
-};
|
|
-
|
|
-&tricolor {
|
|
- enable-gpio = <&tlmm 14 GPIO_ACTIVE_LOW>;
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ws-ap3915i.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ws-ap3915i.dts
|
|
deleted file mode 100644
|
|
index 8794d839a8..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq4029-ws-ap3915i.dts
|
|
+++ /dev/null
|
|
@@ -1,262 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-only OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Extreme Networks WS-AP3915i";
|
|
- compatible = "extreme-networks,ws-ap3915i";
|
|
-
|
|
- aliases {
|
|
- led-boot = &led_system_green;
|
|
- led-failsafe = &led_system_amber;
|
|
- led-running = &led_system_green;
|
|
- led-upgrade = &led_system_amber;
|
|
- };
|
|
-
|
|
- soc {
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- mdio@90000 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
-
|
|
- crypto@8e3a000 {
|
|
- status = "okay";
|
|
- };
|
|
-
|
|
- watchdog@b017000 {
|
|
- status = "okay";
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- led_system_green: system_green {
|
|
- label = "green:system";
|
|
- gpios = <&tlmm 49 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_system_amber: system_amber {
|
|
- label = "amber:system";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_wlan24_green: wlan24_green {
|
|
- label = "green:wlan24";
|
|
- gpios = <&tlmm 23 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- led_wlan24_amber: wlan24_amber {
|
|
- label = "amber:wlan24";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- led_wlan5_green: wlan5_green {
|
|
- label = "green:wlan5";
|
|
- gpios = <&tlmm 22 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- led_wlan5_amber: wlan5_amber {
|
|
- label = "amber:wlan5";
|
|
- gpios = <&tlmm 26 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- iot {
|
|
- label = "blue:iot";
|
|
- gpios = <&tlmm 10 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART >;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- pinctrl-0 = <&serial_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
-
|
|
- label = "lan";
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pin {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pin_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- serial_pins: serial_0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Extreme-Networks-WS-AP3915i";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- qcom,ath10k-calibration-variant = "Extreme-Networks-WS-AP3915i";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- reg = <0>;
|
|
- spi-max-frequency = <24000000>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- /* Layout for 0x0 - 0xe0000 unknown */
|
|
-
|
|
- partition@e0000 {
|
|
- label = "CFG1";
|
|
- reg = <0xe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@f0000 {
|
|
- label = "BootBAK";
|
|
- reg = <0xf0000 0x70000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@160000 {
|
|
- label = "WINGCFG1";
|
|
- reg = <0x160000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@170000 {
|
|
- label = "ART";
|
|
- reg = <0x170000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@180000 {
|
|
- label = "BootPRI";
|
|
- reg = <0x180000 0x70000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@1f0000 {
|
|
- label = "WINGCFG2";
|
|
- reg = <0x1f0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@200000 {
|
|
- label = "FS";
|
|
- reg = <0x200000 0x80000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition@280000 {
|
|
- label = "firmware";
|
|
- reg = <0x280000 0x1d60000>;
|
|
- };
|
|
-
|
|
- partition@1fe0000 {
|
|
- label = "CFG2";
|
|
- reg = <0x1fe0000 0x10000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
diff --git a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq40x9-dr40x9.dts b/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq40x9-dr40x9.dts
|
|
deleted file mode 100644
|
|
index b90b6b28c3..0000000000
|
|
--- a/target/linux/ipq40xx/files/arch/arm/boot/dts/qcom-ipq40x9-dr40x9.dts
|
|
+++ /dev/null
|
|
@@ -1,422 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
-
|
|
-#include "qcom-ipq4019.dtsi"
|
|
-#include <dt-bindings/gpio/gpio.h>
|
|
-#include <dt-bindings/input/input.h>
|
|
-#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
-/ {
|
|
- model = "Wallystech DR40X9";
|
|
- compatible = "wallys,dr40x9";
|
|
-
|
|
- chosen {
|
|
- bootargs-append = " ubi.mtd=ubi root=/dev/ubiblock0_1";
|
|
- };
|
|
-
|
|
- soc {
|
|
- counter@4a1000 {
|
|
- compatible = "qcom,qca-gcnt";
|
|
- reg = <0x4a1000 0x4>;
|
|
- };
|
|
-
|
|
- tcsr@1949000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1949000 0x100>;
|
|
- qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
- };
|
|
-
|
|
- tcsr@194b000 {
|
|
- status = "okay";
|
|
-
|
|
- /* select hostmode */
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x194b000 0x100>;
|
|
- qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
- };
|
|
-
|
|
- ess_tcsr@1953000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1953000 0x1000>;
|
|
- qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
- };
|
|
-
|
|
- tcsr@1957000 {
|
|
- compatible = "qcom,tcsr";
|
|
- reg = <0x1957000 0x100>;
|
|
- qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
- };
|
|
- };
|
|
-
|
|
- keys {
|
|
- compatible = "gpio-keys";
|
|
-
|
|
- reset {
|
|
- label = "reset";
|
|
- gpios = <&tlmm 18 GPIO_ACTIVE_LOW>;
|
|
- linux,code = <KEY_RESTART>;
|
|
- };
|
|
- };
|
|
-
|
|
- leds {
|
|
- compatible = "gpio-leds";
|
|
-
|
|
- wlan2g {
|
|
- label = "dr4029:green:wlan2g";
|
|
- gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy0tpt";
|
|
- };
|
|
-
|
|
- wlan5g {
|
|
- label = "dr4029:green:wlan5g";
|
|
- gpios = <&tlmm 50 GPIO_ACTIVE_LOW>;
|
|
- linux,default-trigger = "phy1tpt";
|
|
- };
|
|
-
|
|
- wlan2g-strength {
|
|
- label = "dr4029:green:wlan2g-strength";
|
|
- gpios = <&tlmm 36 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
-
|
|
- wlan5g-strength {
|
|
- label = "dr4029:green:wlan5g-strength";
|
|
- gpios = <&tlmm 39 GPIO_ACTIVE_LOW>;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&tlmm {
|
|
- mdio_pins: mdio_pinmux {
|
|
- mux_1 {
|
|
- pins = "gpio6";
|
|
- function = "mdio";
|
|
- bias-pull-up;
|
|
- };
|
|
- mux_2 {
|
|
- pins = "gpio7";
|
|
- function = "mdc";
|
|
- bias-pull-up;
|
|
- };
|
|
- };
|
|
-
|
|
- serial0_pins: serial0_pinmux {
|
|
- mux {
|
|
- pins = "gpio16", "gpio17";
|
|
- function = "blsp_uart0";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- serial1_pins: serial1_pinmux {
|
|
- mux {
|
|
- pins = "gpio8", "gpio9";
|
|
- function = "blsp_uart1";
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi_0_pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
- drive-strength = <12>;
|
|
- bias-disable;
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
- drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- nand_pins: nand_pins {
|
|
- pullups {
|
|
- pins = "gpio52", "gpio53", "gpio58", "gpio59";
|
|
- function = "qpic";
|
|
- bias-pull-up;
|
|
- };
|
|
-
|
|
- pulldowns {
|
|
- pins = "gpio54", "gpio55", "gpio56", "gpio57",
|
|
- "gpio60", "gpio62", "gpio63", "gpio64",
|
|
- "gpio65", "gpio66", "gpio67", "gpio68",
|
|
- "gpio69";
|
|
- function = "qpic";
|
|
- bias-pull-down;
|
|
- };
|
|
- };
|
|
-
|
|
- sd_pins: sd_pins {
|
|
- pinmux {
|
|
- function = "sdio";
|
|
- pins = "gpio23", "gpio24", "gpio25", "gpio26",
|
|
- "gpio28", "gpio29", "gpio30", "gpio31";
|
|
- drive-strength = <10>;
|
|
- };
|
|
- pinmux_sd_clk {
|
|
- function = "sdio";
|
|
- pins = "gpio27";
|
|
- drive-strength = <16>;
|
|
- };
|
|
- pinmux_sd7 {
|
|
- function = "sdio";
|
|
- pins = "gpio32";
|
|
- drive-strength = <10>;
|
|
- bias-disable;
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp_dma {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&blsp1_spi1 {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&spi_0_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- cs-gpios = <&tlmm 12 GPIO_ACTIVE_HIGH>;
|
|
-
|
|
- flash@0 {
|
|
- compatible = "jedec,spi-nor";
|
|
- spi-max-frequency = <24000000>;
|
|
- reg = <0>;
|
|
-
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition0@0 {
|
|
- label = "0:SBL1";
|
|
- reg = <0x00000000 0x00040000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition1@40000 {
|
|
- label = "0:MIBIB";
|
|
- reg = <0x00040000 0x00020000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition2@60000 {
|
|
- label = "0:QSEE";
|
|
- reg = <0x00060000 0x00060000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition3@c0000 {
|
|
- label = "0:CDT";
|
|
- reg = <0x000c0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition4@d0000 {
|
|
- label = "0:DDRPARAMS";
|
|
- reg = <0x000d0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition5@e0000 {
|
|
- label = "0:APPSBLENV"; /* uboot env */
|
|
- reg = <0x000e0000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition6@f0000 {
|
|
- label = "0:APPSBL"; /* uboot */
|
|
- reg = <0x000f0000 0x00080000>;
|
|
- read-only;
|
|
- };
|
|
-
|
|
- partition7@170000 {
|
|
- label = "0:ART";
|
|
- reg = <0x00170000 0x00010000>;
|
|
- read-only;
|
|
- compatible = "nvmem-cells";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- precal_art_1000: precal@1000 {
|
|
- reg = <0x1000 0x2f20>;
|
|
- };
|
|
-
|
|
- precal_art_5000: precal@5000 {
|
|
- reg = <0x5000 0x2f20>;
|
|
- };
|
|
-
|
|
- macaddr_art_0: mac-address@0 {
|
|
- reg = <0x0 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_6: mac-address@6 {
|
|
- reg = <0x6 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_1006: mac-address@1006 {
|
|
- reg = <0x1006 0x6>;
|
|
- };
|
|
-
|
|
- macaddr_art_5006: mac-address@5006 {
|
|
- reg = <0x5006 0x6>;
|
|
- };
|
|
-
|
|
- };
|
|
-
|
|
- partition8@180000 {
|
|
- label = "0:CONFIG";
|
|
- reg = <0x00180000 0x00010000>;
|
|
- read-only;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&qpic_bam {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&nand {
|
|
- status = "okay";
|
|
-
|
|
- pinctrl-0 = <&nand_pins>;
|
|
- pinctrl-names = "default";
|
|
-
|
|
- nand@0 {
|
|
- partitions {
|
|
- compatible = "fixed-partitions";
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
-
|
|
- partition@0 {
|
|
- label = "ubi";
|
|
- reg = <0x00000000 0x04000000>;
|
|
- };
|
|
- };
|
|
- };
|
|
-};
|
|
-
|
|
-&blsp1_uart1 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial0_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&blsp1_uart2 {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&serial1_pins>;
|
|
- pinctrl-names = "default";
|
|
-};
|
|
-
|
|
-&crypto {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&cryptobam {
|
|
- num-channels = <4>;
|
|
- qcom,num-ees = <2>;
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&mdio {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&mdio_pins>;
|
|
- pinctrl-names = "default";
|
|
- reset-gpios = <&tlmm 41 GPIO_ACTIVE_LOW>;
|
|
- reset-delay-us = <2000>;
|
|
-};
|
|
-
|
|
-&pcie0 {
|
|
- status = "okay";
|
|
-
|
|
- perst-gpio = <&tlmm 38 GPIO_ACTIVE_LOW>;
|
|
- wake-gpio = <&tlmm 40 GPIO_ACTIVE_LOW>;
|
|
-
|
|
- /* Unpolulated slot */
|
|
- bridge@0,0 {
|
|
- reg = <0x00000000 0 0 0 0>;
|
|
- #address-cells = <3>;
|
|
- #size-cells = <2>;
|
|
- ranges;
|
|
- };
|
|
-};
|
|
-
|
|
-&vqmmc {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&sdhci {
|
|
- status = "okay";
|
|
- pinctrl-0 = <&sd_pins>;
|
|
- pinctrl-names = "default";
|
|
- cd-gpios = <&tlmm 22 GPIO_ACTIVE_LOW>;
|
|
- vqmmc-supply = <&vqmmc>;
|
|
-};
|
|
-
|
|
-&gmac {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&switch {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&swport4 {
|
|
- status = "okay";
|
|
- label = "wan";
|
|
- nvmem-cells = <&macaddr_art_0>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&swport5 {
|
|
- status = "okay";
|
|
- label = "lan";
|
|
- nvmem-cells = <&macaddr_art_6>;
|
|
- nvmem-cell-names = "mac-address";
|
|
-};
|
|
-
|
|
-&wifi0 {
|
|
- status = "okay";
|
|
- nvmem-cells = <&precal_art_1000>, <&macaddr_art_1006>;
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- qcom,ath10k-calibration-variant = "Wallys-DR40X9";
|
|
-};
|
|
-
|
|
-&wifi1 {
|
|
- status = "okay";
|
|
- nvmem-cell-names = "pre-calibration", "mac-address";
|
|
- nvmem-cells = <&precal_art_5000>, <&macaddr_art_5006>;
|
|
- qcom,ath10k-calibration-variant = "Wallys-DR40X9";
|
|
-};
|
|
-
|
|
-&usb2 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb2_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3 {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_ss_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&usb3_hs_phy {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&prng {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
-&watchdog {
|
|
- status = "okay";
|
|
-};
|
|
-
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.c b/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.c
|
|
deleted file mode 100644
|
|
index 202d1a582c..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.c
|
|
+++ /dev/null
|
|
@@ -1,1655 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0
|
|
-/*
|
|
- * Copyright (C) 2009 Felix Fietkau <nbd@nbd.name>
|
|
- * Copyright (C) 2011-2012, 2020-2021 Gabor Juhos <juhosg@openwrt.org>
|
|
- * Copyright (c) 2015, 2019, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2016 John Crispin <john@phrozen.org>
|
|
- * Copyright (c) 2021 Robert Marko <robert.marko@sartura.hr>
|
|
- */
|
|
-
|
|
-#include <linux/version.h>
|
|
-#include <linux/etherdevice.h>
|
|
-#include <linux/if_bridge.h>
|
|
-#include <linux/mdio.h>
|
|
-#include <linux/mfd/syscon.h>
|
|
-#include <linux/module.h>
|
|
-#include <linux/netdevice.h>
|
|
-#include <linux/of_mdio.h>
|
|
-#include <linux/of_net.h>
|
|
-#include <linux/of_platform.h>
|
|
-#include <linux/phy.h>
|
|
-#include <linux/phylink.h>
|
|
-#include <linux/reset.h>
|
|
-#include <net/dsa.h>
|
|
-
|
|
-#include "qca8k-ipq4019.h"
|
|
-
|
|
-#define MIB_DESC(_s, _o, _n) \
|
|
- { \
|
|
- .size = (_s), \
|
|
- .offset = (_o), \
|
|
- .name = (_n), \
|
|
- }
|
|
-
|
|
-static const struct qca8k_mib_desc ar8327_mib[] = {
|
|
- MIB_DESC(1, 0x00, "RxBroad"),
|
|
- MIB_DESC(1, 0x04, "RxPause"),
|
|
- MIB_DESC(1, 0x08, "RxMulti"),
|
|
- MIB_DESC(1, 0x0c, "RxFcsErr"),
|
|
- MIB_DESC(1, 0x10, "RxAlignErr"),
|
|
- MIB_DESC(1, 0x14, "RxRunt"),
|
|
- MIB_DESC(1, 0x18, "RxFragment"),
|
|
- MIB_DESC(1, 0x1c, "Rx64Byte"),
|
|
- MIB_DESC(1, 0x20, "Rx128Byte"),
|
|
- MIB_DESC(1, 0x24, "Rx256Byte"),
|
|
- MIB_DESC(1, 0x28, "Rx512Byte"),
|
|
- MIB_DESC(1, 0x2c, "Rx1024Byte"),
|
|
- MIB_DESC(1, 0x30, "Rx1518Byte"),
|
|
- MIB_DESC(1, 0x34, "RxMaxByte"),
|
|
- MIB_DESC(1, 0x38, "RxTooLong"),
|
|
- MIB_DESC(2, 0x3c, "RxGoodByte"),
|
|
- MIB_DESC(2, 0x44, "RxBadByte"),
|
|
- MIB_DESC(1, 0x4c, "RxOverFlow"),
|
|
- MIB_DESC(1, 0x50, "Filtered"),
|
|
- MIB_DESC(1, 0x54, "TxBroad"),
|
|
- MIB_DESC(1, 0x58, "TxPause"),
|
|
- MIB_DESC(1, 0x5c, "TxMulti"),
|
|
- MIB_DESC(1, 0x60, "TxUnderRun"),
|
|
- MIB_DESC(1, 0x64, "Tx64Byte"),
|
|
- MIB_DESC(1, 0x68, "Tx128Byte"),
|
|
- MIB_DESC(1, 0x6c, "Tx256Byte"),
|
|
- MIB_DESC(1, 0x70, "Tx512Byte"),
|
|
- MIB_DESC(1, 0x74, "Tx1024Byte"),
|
|
- MIB_DESC(1, 0x78, "Tx1518Byte"),
|
|
- MIB_DESC(1, 0x7c, "TxMaxByte"),
|
|
- MIB_DESC(1, 0x80, "TxOverSize"),
|
|
- MIB_DESC(2, 0x84, "TxByte"),
|
|
- MIB_DESC(1, 0x8c, "TxCollision"),
|
|
- MIB_DESC(1, 0x90, "TxAbortCol"),
|
|
- MIB_DESC(1, 0x94, "TxMultiCol"),
|
|
- MIB_DESC(1, 0x98, "TxSingleCol"),
|
|
- MIB_DESC(1, 0x9c, "TxExcDefer"),
|
|
- MIB_DESC(1, 0xa0, "TxDefer"),
|
|
- MIB_DESC(1, 0xa4, "TxLateCol"),
|
|
- MIB_DESC(1, 0xa8, "RXUnicast"),
|
|
- MIB_DESC(1, 0xac, "TXunicast"),
|
|
-};
|
|
-
|
|
-static int
|
|
-qca8k_read(struct qca8k_priv *priv, u32 reg, u32 *val)
|
|
-{
|
|
- return regmap_read(priv->regmap, reg, val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_write(struct qca8k_priv *priv, u32 reg, u32 val)
|
|
-{
|
|
- return regmap_write(priv->regmap, reg, val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_rmw(struct qca8k_priv *priv, u32 reg, u32 mask, u32 write_val)
|
|
-{
|
|
- return regmap_update_bits(priv->regmap, reg, mask, write_val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_reg_set(struct qca8k_priv *priv, u32 reg, u32 val)
|
|
-{
|
|
- return regmap_set_bits(priv->regmap, reg, val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_reg_clear(struct qca8k_priv *priv, u32 reg, u32 val)
|
|
-{
|
|
- return regmap_clear_bits(priv->regmap, reg, val);
|
|
-}
|
|
-
|
|
-static const struct regmap_range qca8k_readable_ranges[] = {
|
|
- regmap_reg_range(0x0000, 0x00e4), /* Global control */
|
|
- regmap_reg_range(0x0100, 0x0168), /* EEE control */
|
|
- regmap_reg_range(0x0200, 0x0270), /* Parser control */
|
|
- regmap_reg_range(0x0400, 0x0454), /* ACL */
|
|
- regmap_reg_range(0x0600, 0x0718), /* Lookup */
|
|
- regmap_reg_range(0x0800, 0x0b70), /* QM */
|
|
- regmap_reg_range(0x0c00, 0x0c80), /* PKT */
|
|
- regmap_reg_range(0x0e00, 0x0e98), /* L3 */
|
|
- regmap_reg_range(0x1000, 0x10ac), /* MIB - Port0 */
|
|
- regmap_reg_range(0x1100, 0x11ac), /* MIB - Port1 */
|
|
- regmap_reg_range(0x1200, 0x12ac), /* MIB - Port2 */
|
|
- regmap_reg_range(0x1300, 0x13ac), /* MIB - Port3 */
|
|
- regmap_reg_range(0x1400, 0x14ac), /* MIB - Port4 */
|
|
- regmap_reg_range(0x1500, 0x15ac), /* MIB - Port5 */
|
|
- regmap_reg_range(0x1600, 0x16ac), /* MIB - Port6 */
|
|
-
|
|
-};
|
|
-
|
|
-static const struct regmap_access_table qca8k_readable_table = {
|
|
- .yes_ranges = qca8k_readable_ranges,
|
|
- .n_yes_ranges = ARRAY_SIZE(qca8k_readable_ranges),
|
|
-};
|
|
-
|
|
-static struct regmap_config qca8k_ipq4019_regmap_config = {
|
|
- .reg_bits = 32,
|
|
- .val_bits = 32,
|
|
- .reg_stride = 4,
|
|
- .max_register = 0x16ac, /* end MIB - Port6 range */
|
|
- .rd_table = &qca8k_readable_table,
|
|
-};
|
|
-
|
|
-static struct regmap_config qca8k_ipq4019_psgmii_phy_regmap_config = {
|
|
- .name = "psgmii-phy",
|
|
- .reg_bits = 32,
|
|
- .val_bits = 32,
|
|
- .reg_stride = 4,
|
|
- .max_register = 0x7fc,
|
|
-};
|
|
-
|
|
-static int
|
|
-qca8k_busy_wait(struct qca8k_priv *priv, u32 reg, u32 mask)
|
|
-{
|
|
- u32 val;
|
|
-
|
|
- return regmap_read_poll_timeout(priv->regmap, reg, val,
|
|
- !(val & mask),
|
|
- 0,
|
|
- QCA8K_BUSY_WAIT_TIMEOUT);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_fdb_read(struct qca8k_priv *priv, struct qca8k_fdb *fdb)
|
|
-{
|
|
- u32 reg[4], val;
|
|
- int i, ret;
|
|
-
|
|
- /* load the ARL table into an array */
|
|
- for (i = 0; i < 4; i++) {
|
|
- ret = qca8k_read(priv, QCA8K_REG_ATU_DATA0 + (i * 4), &val);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
-
|
|
- reg[i] = val;
|
|
- }
|
|
-
|
|
- /* vid - 83:72 */
|
|
- fdb->vid = (reg[2] >> QCA8K_ATU_VID_S) & QCA8K_ATU_VID_M;
|
|
- /* aging - 67:64 */
|
|
- fdb->aging = reg[2] & QCA8K_ATU_STATUS_M;
|
|
- /* portmask - 54:48 */
|
|
- fdb->port_mask = (reg[1] >> QCA8K_ATU_PORT_S) & QCA8K_ATU_PORT_M;
|
|
- /* mac - 47:0 */
|
|
- fdb->mac[0] = (reg[1] >> QCA8K_ATU_ADDR0_S) & 0xff;
|
|
- fdb->mac[1] = reg[1] & 0xff;
|
|
- fdb->mac[2] = (reg[0] >> QCA8K_ATU_ADDR2_S) & 0xff;
|
|
- fdb->mac[3] = (reg[0] >> QCA8K_ATU_ADDR3_S) & 0xff;
|
|
- fdb->mac[4] = (reg[0] >> QCA8K_ATU_ADDR4_S) & 0xff;
|
|
- fdb->mac[5] = reg[0] & 0xff;
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_fdb_write(struct qca8k_priv *priv, u16 vid, u8 port_mask, const u8 *mac,
|
|
- u8 aging)
|
|
-{
|
|
- u32 reg[3] = { 0 };
|
|
- int i;
|
|
-
|
|
- /* vid - 83:72 */
|
|
- reg[2] = (vid & QCA8K_ATU_VID_M) << QCA8K_ATU_VID_S;
|
|
- /* aging - 67:64 */
|
|
- reg[2] |= aging & QCA8K_ATU_STATUS_M;
|
|
- /* portmask - 54:48 */
|
|
- reg[1] = (port_mask & QCA8K_ATU_PORT_M) << QCA8K_ATU_PORT_S;
|
|
- /* mac - 47:0 */
|
|
- reg[1] |= mac[0] << QCA8K_ATU_ADDR0_S;
|
|
- reg[1] |= mac[1];
|
|
- reg[0] |= mac[2] << QCA8K_ATU_ADDR2_S;
|
|
- reg[0] |= mac[3] << QCA8K_ATU_ADDR3_S;
|
|
- reg[0] |= mac[4] << QCA8K_ATU_ADDR4_S;
|
|
- reg[0] |= mac[5];
|
|
-
|
|
- /* load the array into the ARL table */
|
|
- for (i = 0; i < 3; i++)
|
|
- qca8k_write(priv, QCA8K_REG_ATU_DATA0 + (i * 4), reg[i]);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_fdb_access(struct qca8k_priv *priv, enum qca8k_fdb_cmd cmd, int port)
|
|
-{
|
|
- u32 reg;
|
|
- int ret;
|
|
-
|
|
- /* Set the command and FDB index */
|
|
- reg = QCA8K_ATU_FUNC_BUSY;
|
|
- reg |= cmd;
|
|
- if (port >= 0) {
|
|
- reg |= QCA8K_ATU_FUNC_PORT_EN;
|
|
- reg |= (port & QCA8K_ATU_FUNC_PORT_M) << QCA8K_ATU_FUNC_PORT_S;
|
|
- }
|
|
-
|
|
- /* Write the function register triggering the table access */
|
|
- ret = qca8k_write(priv, QCA8K_REG_ATU_FUNC, reg);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* wait for completion */
|
|
- ret = qca8k_busy_wait(priv, QCA8K_REG_ATU_FUNC, QCA8K_ATU_FUNC_BUSY);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* Check for table full violation when adding an entry */
|
|
- if (cmd == QCA8K_FDB_LOAD) {
|
|
- ret = qca8k_read(priv, QCA8K_REG_ATU_FUNC, ®);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
- if (reg & QCA8K_ATU_FUNC_FULL)
|
|
- return -1;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_fdb_next(struct qca8k_priv *priv, struct qca8k_fdb *fdb, int port)
|
|
-{
|
|
- int ret;
|
|
-
|
|
- qca8k_fdb_write(priv, fdb->vid, fdb->port_mask, fdb->mac, fdb->aging);
|
|
- ret = qca8k_fdb_access(priv, QCA8K_FDB_NEXT, port);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
-
|
|
- return qca8k_fdb_read(priv, fdb);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_fdb_add(struct qca8k_priv *priv, const u8 *mac, u16 port_mask,
|
|
- u16 vid, u8 aging)
|
|
-{
|
|
- int ret;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- qca8k_fdb_write(priv, vid, port_mask, mac, aging);
|
|
- ret = qca8k_fdb_access(priv, QCA8K_FDB_LOAD, -1);
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_fdb_del(struct qca8k_priv *priv, const u8 *mac, u16 port_mask, u16 vid)
|
|
-{
|
|
- int ret;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- qca8k_fdb_write(priv, vid, port_mask, mac, 0);
|
|
- ret = qca8k_fdb_access(priv, QCA8K_FDB_PURGE, -1);
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_fdb_flush(struct qca8k_priv *priv)
|
|
-{
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- qca8k_fdb_access(priv, QCA8K_FDB_FLUSH, -1);
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_vlan_access(struct qca8k_priv *priv, enum qca8k_vlan_cmd cmd, u16 vid)
|
|
-{
|
|
- u32 reg;
|
|
- int ret;
|
|
-
|
|
- /* Set the command and VLAN index */
|
|
- reg = QCA8K_VTU_FUNC1_BUSY;
|
|
- reg |= cmd;
|
|
- reg |= vid << QCA8K_VTU_FUNC1_VID_S;
|
|
-
|
|
- /* Write the function register triggering the table access */
|
|
- ret = qca8k_write(priv, QCA8K_REG_VTU_FUNC1, reg);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* wait for completion */
|
|
- ret = qca8k_busy_wait(priv, QCA8K_REG_VTU_FUNC1, QCA8K_VTU_FUNC1_BUSY);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* Check for table full violation when adding an entry */
|
|
- if (cmd == QCA8K_VLAN_LOAD) {
|
|
- ret = qca8k_read(priv, QCA8K_REG_VTU_FUNC1, ®);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
- if (reg & QCA8K_VTU_FUNC1_FULL)
|
|
- return -ENOMEM;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_vlan_add(struct qca8k_priv *priv, u8 port, u16 vid, bool untagged)
|
|
-{
|
|
- u32 reg;
|
|
- int ret;
|
|
-
|
|
- /*
|
|
- We do the right thing with VLAN 0 and treat it as untagged while
|
|
- preserving the tag on egress.
|
|
- */
|
|
- if (vid == 0)
|
|
- return 0;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- ret = qca8k_vlan_access(priv, QCA8K_VLAN_READ, vid);
|
|
- if (ret < 0)
|
|
- goto out;
|
|
-
|
|
- ret = qca8k_read(priv, QCA8K_REG_VTU_FUNC0, ®);
|
|
- if (ret < 0)
|
|
- goto out;
|
|
- reg |= QCA8K_VTU_FUNC0_VALID | QCA8K_VTU_FUNC0_IVL_EN;
|
|
- reg &= ~(QCA8K_VTU_FUNC0_EG_MODE_MASK << QCA8K_VTU_FUNC0_EG_MODE_S(port));
|
|
- if (untagged)
|
|
- reg |= QCA8K_VTU_FUNC0_EG_MODE_UNTAG <<
|
|
- QCA8K_VTU_FUNC0_EG_MODE_S(port);
|
|
- else
|
|
- reg |= QCA8K_VTU_FUNC0_EG_MODE_TAG <<
|
|
- QCA8K_VTU_FUNC0_EG_MODE_S(port);
|
|
-
|
|
- ret = qca8k_write(priv, QCA8K_REG_VTU_FUNC0, reg);
|
|
- if (ret)
|
|
- goto out;
|
|
- ret = qca8k_vlan_access(priv, QCA8K_VLAN_LOAD, vid);
|
|
-
|
|
-out:
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_vlan_del(struct qca8k_priv *priv, u8 port, u16 vid)
|
|
-{
|
|
- u32 reg, mask;
|
|
- int ret, i;
|
|
- bool del;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- ret = qca8k_vlan_access(priv, QCA8K_VLAN_READ, vid);
|
|
- if (ret < 0)
|
|
- goto out;
|
|
-
|
|
- ret = qca8k_read(priv, QCA8K_REG_VTU_FUNC0, ®);
|
|
- if (ret < 0)
|
|
- goto out;
|
|
- reg &= ~(3 << QCA8K_VTU_FUNC0_EG_MODE_S(port));
|
|
- reg |= QCA8K_VTU_FUNC0_EG_MODE_NOT <<
|
|
- QCA8K_VTU_FUNC0_EG_MODE_S(port);
|
|
-
|
|
- /* Check if we're the last member to be removed */
|
|
- del = true;
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++) {
|
|
- mask = QCA8K_VTU_FUNC0_EG_MODE_NOT;
|
|
- mask <<= QCA8K_VTU_FUNC0_EG_MODE_S(i);
|
|
-
|
|
- if ((reg & mask) != mask) {
|
|
- del = false;
|
|
- break;
|
|
- }
|
|
- }
|
|
-
|
|
- if (del) {
|
|
- ret = qca8k_vlan_access(priv, QCA8K_VLAN_PURGE, vid);
|
|
- } else {
|
|
- ret = qca8k_write(priv, QCA8K_REG_VTU_FUNC0, reg);
|
|
- if (ret)
|
|
- goto out;
|
|
- ret = qca8k_vlan_access(priv, QCA8K_VLAN_LOAD, vid);
|
|
- }
|
|
-
|
|
-out:
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_mib_init(struct qca8k_priv *priv)
|
|
-{
|
|
- int ret;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- ret = qca8k_reg_set(priv, QCA8K_REG_MIB, QCA8K_MIB_FLUSH | QCA8K_MIB_BUSY);
|
|
- if (ret)
|
|
- goto exit;
|
|
-
|
|
- ret = qca8k_busy_wait(priv, QCA8K_REG_MIB, QCA8K_MIB_BUSY);
|
|
- if (ret)
|
|
- goto exit;
|
|
-
|
|
- ret = qca8k_reg_set(priv, QCA8K_REG_MIB, QCA8K_MIB_CPU_KEEP);
|
|
- if (ret)
|
|
- goto exit;
|
|
-
|
|
- ret = qca8k_write(priv, QCA8K_REG_MODULE_EN, QCA8K_MODULE_EN_MIB);
|
|
-
|
|
-exit:
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_port_set_status(struct qca8k_priv *priv, int port, int enable)
|
|
-{
|
|
- u32 mask = QCA8K_PORT_STATUS_TXMAC | QCA8K_PORT_STATUS_RXMAC;
|
|
-
|
|
- /* Port 0 is internally connected to the CPU
|
|
- * TODO: Probably check for RGMII as well if it doesnt work
|
|
- * in RGMII mode.
|
|
- */
|
|
- if (port > QCA8K_CPU_PORT)
|
|
- mask |= QCA8K_PORT_STATUS_LINK_AUTO;
|
|
-
|
|
- if (enable)
|
|
- qca8k_reg_set(priv, QCA8K_REG_PORT_STATUS(port), mask);
|
|
- else
|
|
- qca8k_reg_clear(priv, QCA8K_REG_PORT_STATUS(port), mask);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_setup_port(struct dsa_switch *ds, int port)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- int ret;
|
|
-
|
|
- /* CPU port gets connected to all user ports of the switch */
|
|
- if (dsa_is_cpu_port(ds, port)) {
|
|
- ret = qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(QCA8K_CPU_PORT),
|
|
- QCA8K_PORT_LOOKUP_MEMBER, dsa_user_ports(ds));
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* Disable CPU ARP Auto-learning by default */
|
|
- ret = qca8k_reg_clear(priv, QCA8K_PORT_LOOKUP_CTRL(QCA8K_CPU_PORT),
|
|
- QCA8K_PORT_LOOKUP_LEARN);
|
|
- if (ret)
|
|
- return ret;
|
|
- }
|
|
-
|
|
- /* Individual user ports get connected to CPU port only */
|
|
- if (dsa_is_user_port(ds, port)) {
|
|
- int shift = 16 * (port % 2);
|
|
-
|
|
- ret = qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_MEMBER,
|
|
- BIT(QCA8K_CPU_PORT));
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* Enable ARP Auto-learning by default */
|
|
- ret = qca8k_reg_set(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_LEARN);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* For port based vlans to work we need to set the
|
|
- * default egress vid
|
|
- */
|
|
- ret = qca8k_rmw(priv, QCA8K_EGRESS_VLAN(port),
|
|
- 0xfff << shift,
|
|
- QCA8K_PORT_VID_DEF << shift);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- ret = qca8k_write(priv, QCA8K_REG_PORT_VLAN_CTRL0(port),
|
|
- QCA8K_PORT_VLAN_CVID(QCA8K_PORT_VID_DEF) |
|
|
- QCA8K_PORT_VLAN_SVID(QCA8K_PORT_VID_DEF));
|
|
- if (ret)
|
|
- return ret;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_setup(struct dsa_switch *ds)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- int ret, i;
|
|
-
|
|
- /* Make sure that port 0 is the cpu port */
|
|
- if (!dsa_is_cpu_port(ds, 0)) {
|
|
- dev_err(priv->dev, "port 0 is not the CPU port");
|
|
- return -EINVAL;
|
|
- }
|
|
-
|
|
- /* Enable CPU Port */
|
|
- ret = qca8k_reg_set(priv, QCA8K_REG_GLOBAL_FW_CTRL0,
|
|
- QCA8K_GLOBAL_FW_CTRL0_CPU_PORT_EN);
|
|
- if (ret) {
|
|
- dev_err(priv->dev, "failed enabling CPU port");
|
|
- return ret;
|
|
- }
|
|
-
|
|
- /* Enable MIB counters */
|
|
- ret = qca8k_mib_init(priv);
|
|
- if (ret)
|
|
- dev_warn(priv->dev, "MIB init failed");
|
|
-
|
|
- /* Enable QCA header mode on the cpu port */
|
|
- ret = qca8k_write(priv, QCA8K_REG_PORT_HDR_CTRL(QCA8K_CPU_PORT),
|
|
- QCA8K_PORT_HDR_CTRL_ALL << QCA8K_PORT_HDR_CTRL_TX_S |
|
|
- QCA8K_PORT_HDR_CTRL_ALL << QCA8K_PORT_HDR_CTRL_RX_S);
|
|
- if (ret) {
|
|
- dev_err(priv->dev, "failed enabling QCA header mode");
|
|
- return ret;
|
|
- }
|
|
-
|
|
- /* Disable forwarding by default on all ports */
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++) {
|
|
- ret = qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(i),
|
|
- QCA8K_PORT_LOOKUP_MEMBER, 0);
|
|
- if (ret)
|
|
- return ret;
|
|
- }
|
|
-
|
|
- /* Disable MAC by default on all ports */
|
|
- for (i = 1; i < QCA8K_NUM_PORTS; i++)
|
|
- qca8k_port_set_status(priv, i, 0);
|
|
-
|
|
- /* Forward all unknown frames to CPU port for Linux processing */
|
|
- ret = qca8k_write(priv, QCA8K_REG_GLOBAL_FW_CTRL1,
|
|
- BIT(QCA8K_CPU_PORT) << QCA8K_GLOBAL_FW_CTRL1_IGMP_DP_S |
|
|
- BIT(QCA8K_CPU_PORT) << QCA8K_GLOBAL_FW_CTRL1_BC_DP_S |
|
|
- BIT(QCA8K_CPU_PORT) << QCA8K_GLOBAL_FW_CTRL1_MC_DP_S |
|
|
- BIT(QCA8K_CPU_PORT) << QCA8K_GLOBAL_FW_CTRL1_UC_DP_S);
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
- /* Setup connection between CPU port & user ports */
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++) {
|
|
- ret = qca8k_setup_port(ds, i);
|
|
- if (ret)
|
|
- return ret;
|
|
- }
|
|
-
|
|
- /* Setup our port MTUs to match power on defaults */
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++)
|
|
- /* Set per port MTU to 1500 as the MTU change function
|
|
- * will add the overhead and if its set to 1518 then it
|
|
- * will apply the overhead again and we will end up with
|
|
- * MTU of 1536 instead of 1518
|
|
- */
|
|
- priv->port_mtu[i] = ETH_DATA_LEN;
|
|
- ret = qca8k_write(priv, QCA8K_MAX_FRAME_SIZE, ETH_FRAME_LEN + ETH_FCS_LEN);
|
|
- if (ret)
|
|
- dev_warn(priv->dev, "failed setting MTU settings");
|
|
-
|
|
- /* Flush the FDB table */
|
|
- qca8k_fdb_flush(priv);
|
|
-
|
|
- /* We don't have interrupts for link changes, so we need to poll */
|
|
- ds->pcs_poll = true;
|
|
-
|
|
- /* CPU port HW learning doesnt work correctly, so let DSA handle it */
|
|
- ds->assisted_learning_on_cpu_port = true;
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int psgmii_vco_calibrate(struct qca8k_priv *priv)
|
|
-{
|
|
- int val, ret;
|
|
-
|
|
- if (!priv->psgmii_ethphy) {
|
|
- dev_err(priv->dev, "PSGMII eth PHY missing, calibration failed!\n");
|
|
- return -ENODEV;
|
|
- }
|
|
-
|
|
- /* Fix PSGMII RX 20bit */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_BMCR, 0x5b);
|
|
- /* Reset PHY PSGMII */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_BMCR, 0x1b);
|
|
- /* Release PHY PSGMII reset */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_BMCR, 0x5b);
|
|
-
|
|
- /* Poll for VCO PLL calibration finish - Malibu(QCA8075) */
|
|
- ret = phy_read_mmd_poll_timeout(priv->psgmii_ethphy,
|
|
- MDIO_MMD_PMAPMD,
|
|
- 0x28, val,
|
|
- (val & BIT(0)),
|
|
- 10000, 1000000,
|
|
- false);
|
|
- if (ret) {
|
|
- dev_err(priv->dev, "QCA807x PSGMII VCO calibration PLL not ready\n");
|
|
- return ret;
|
|
- }
|
|
- mdelay(50);
|
|
-
|
|
- /* Freeze PSGMII RX CDR */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_RESV2, 0x2230);
|
|
-
|
|
- /* Start PSGMIIPHY VCO PLL calibration */
|
|
- ret = regmap_set_bits(priv->psgmii,
|
|
- PSGMIIPHY_VCO_CALIBRATION_CONTROL_REGISTER_1,
|
|
- PSGMIIPHY_REG_PLL_VCO_CALIB_RESTART);
|
|
-
|
|
- /* Poll for PSGMIIPHY PLL calibration finish - Dakota(IPQ40xx) */
|
|
- ret = regmap_read_poll_timeout(priv->psgmii,
|
|
- PSGMIIPHY_VCO_CALIBRATION_CONTROL_REGISTER_2,
|
|
- val, val & PSGMIIPHY_REG_PLL_VCO_CALIB_READY,
|
|
- 10000, 1000000);
|
|
- if (ret) {
|
|
- dev_err(priv->dev, "IPQ PSGMIIPHY VCO calibration PLL not ready\n");
|
|
- return ret;
|
|
- }
|
|
- mdelay(50);
|
|
-
|
|
- /* Release PSGMII RX CDR */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_RESV2, 0x3230);
|
|
- /* Release PSGMII RX 20bit */
|
|
- ret = phy_write(priv->psgmii_ethphy, MII_BMCR, 0x5f);
|
|
- mdelay(200);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_switch_port_loopback_on_off(struct qca8k_priv *priv, int port, int on)
|
|
-{
|
|
- u32 val = QCA8K_PORT_LOOKUP_LOOPBACK;
|
|
-
|
|
- if (on == 0)
|
|
- val = 0;
|
|
-
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_LOOPBACK, val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_wait_for_phy_link_state(struct phy_device *phy, int need_status)
|
|
-{
|
|
- int a;
|
|
- u16 status;
|
|
-
|
|
- for (a = 0; a < 100; a++) {
|
|
- status = phy_read(phy, MII_QCA8075_SSTATUS);
|
|
- status &= QCA8075_PHY_SPEC_STATUS_LINK;
|
|
- status = !!status;
|
|
- if (status == need_status)
|
|
- return 0;
|
|
- mdelay(8);
|
|
- }
|
|
-
|
|
- return -1;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phy_loopback_on_off(struct qca8k_priv *priv, struct phy_device *phy,
|
|
- int sw_port, int on)
|
|
-{
|
|
- if (on) {
|
|
- phy_write(phy, MII_BMCR, BMCR_ANENABLE | BMCR_RESET);
|
|
- phy_modify(phy, MII_BMCR, BMCR_PDOWN, BMCR_PDOWN);
|
|
- qca8k_wait_for_phy_link_state(phy, 0);
|
|
- qca8k_write(priv, QCA8K_REG_PORT_STATUS(sw_port), 0);
|
|
- phy_write(phy, MII_BMCR,
|
|
- BMCR_SPEED1000 |
|
|
- BMCR_FULLDPLX |
|
|
- BMCR_LOOPBACK);
|
|
- qca8k_wait_for_phy_link_state(phy, 1);
|
|
- qca8k_write(priv, QCA8K_REG_PORT_STATUS(sw_port),
|
|
- QCA8K_PORT_STATUS_SPEED_1000 |
|
|
- QCA8K_PORT_STATUS_TXMAC |
|
|
- QCA8K_PORT_STATUS_RXMAC |
|
|
- QCA8K_PORT_STATUS_DUPLEX);
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(sw_port),
|
|
- QCA8K_PORT_LOOKUP_STATE_FORWARD,
|
|
- QCA8K_PORT_LOOKUP_STATE_FORWARD);
|
|
- } else { /* off */
|
|
- qca8k_write(priv, QCA8K_REG_PORT_STATUS(sw_port), 0);
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(sw_port),
|
|
- QCA8K_PORT_LOOKUP_STATE_DISABLED,
|
|
- QCA8K_PORT_LOOKUP_STATE_DISABLED);
|
|
- phy_write(phy, MII_BMCR, BMCR_SPEED1000 | BMCR_ANENABLE | BMCR_RESET);
|
|
- /* turn off the power of the phys - so that unused
|
|
- ports do not raise links */
|
|
- phy_modify(phy, MII_BMCR, BMCR_PDOWN, BMCR_PDOWN);
|
|
- }
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phy_pkt_gen_prep(struct qca8k_priv *priv, struct phy_device *phy,
|
|
- int pkts_num, int on)
|
|
-{
|
|
- if (on) {
|
|
- /* enable CRC checker and packets counters */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_CRC_AND_PKTS_COUNT, 0);
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_CRC_AND_PKTS_COUNT,
|
|
- QCA8075_MMD7_CNT_FRAME_CHK_EN | QCA8075_MMD7_CNT_SELFCLR);
|
|
- qca8k_wait_for_phy_link_state(phy, 1);
|
|
- /* packet number */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_PKT_NUMB, pkts_num);
|
|
- /* pkt size - 1504 bytes + 20 bytes */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_PKT_SIZE, 1504);
|
|
- } else { /* off */
|
|
- /* packet number */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_PKT_NUMB, 0);
|
|
- /* disable CRC checker and packet counter */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_CRC_AND_PKTS_COUNT, 0);
|
|
- /* disable traffic gen */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_CTRL, 0);
|
|
- }
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_wait_for_phy_pkt_gen_fin(struct qca8k_priv *priv, struct phy_device *phy)
|
|
-{
|
|
- int val;
|
|
- /* wait for all traffic end: 4096(pkt num)*1524(size)*8ns(125MHz)=49938us */
|
|
- phy_read_mmd_poll_timeout(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_CTRL,
|
|
- val, !(val & QCA8075_MMD7_PKT_GEN_INPROGR),
|
|
- 50000, 1000000, true);
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_start_phy_pkt_gen(struct phy_device *phy)
|
|
-{
|
|
- /* start traffic gen */
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_PKT_GEN_CTRL,
|
|
- QCA8075_MMD7_PKT_GEN_START | QCA8075_MMD7_PKT_GEN_INPROGR);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_start_all_phys_pkt_gens(struct qca8k_priv *priv)
|
|
-{
|
|
- struct phy_device *phy;
|
|
- phy = phy_device_create(priv->bus, QCA8075_MDIO_BRDCST_PHY_ADDR,
|
|
- 0, 0, NULL);
|
|
- if (!phy) {
|
|
- dev_err(priv->dev, "unable to create mdio broadcast PHY(0x%x)\n",
|
|
- QCA8075_MDIO_BRDCST_PHY_ADDR);
|
|
- return -ENODEV;
|
|
- }
|
|
-
|
|
- qca8k_start_phy_pkt_gen(phy);
|
|
-
|
|
- phy_device_free(phy);
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_get_phy_pkt_gen_test_result(struct phy_device *phy, int pkts_num)
|
|
-{
|
|
- u32 tx_ok, tx_error;
|
|
- u32 rx_ok, rx_error;
|
|
- u32 tx_ok_high16;
|
|
- u32 rx_ok_high16;
|
|
- u32 tx_all_ok, rx_all_ok;
|
|
-
|
|
- /* check counters */
|
|
- tx_ok = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_EG_FRAME_RECV_CNT_LO);
|
|
- tx_ok_high16 = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_EG_FRAME_RECV_CNT_HI);
|
|
- tx_error = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_EG_FRAME_ERR_CNT);
|
|
- rx_ok = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_IG_FRAME_RECV_CNT_LO);
|
|
- rx_ok_high16 = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_IG_FRAME_RECV_CNT_HI);
|
|
- rx_error = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_IG_FRAME_ERR_CNT);
|
|
- tx_all_ok = tx_ok + (tx_ok_high16 << 16);
|
|
- rx_all_ok = rx_ok + (rx_ok_high16 << 16);
|
|
-
|
|
- if (tx_all_ok < pkts_num)
|
|
- return -1;
|
|
- if(rx_all_ok < pkts_num)
|
|
- return -2;
|
|
- if(tx_error)
|
|
- return -3;
|
|
- if(rx_error)
|
|
- return -4;
|
|
- return 0; /* test is ok */
|
|
-}
|
|
-
|
|
-static
|
|
-void qca8k_phy_broadcast_write_on_off(struct qca8k_priv *priv,
|
|
- struct phy_device *phy, int on)
|
|
-{
|
|
- u32 val;
|
|
-
|
|
- val = phy_read_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_MDIO_BRDCST_WRITE);
|
|
-
|
|
- if (on == 0)
|
|
- val &= ~QCA8075_MMD7_MDIO_BRDCST_WRITE_EN;
|
|
- else
|
|
- val |= QCA8075_MMD7_MDIO_BRDCST_WRITE_EN;
|
|
-
|
|
- phy_write_mmd(phy, MDIO_MMD_AN, QCA8075_MMD7_MDIO_BRDCST_WRITE, val);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_test_dsa_port_for_errors(struct qca8k_priv *priv, struct phy_device *phy,
|
|
- int port, int test_phase)
|
|
-{
|
|
- int res = 0;
|
|
- const int test_pkts_num = QCA8075_PKT_GEN_PKTS_COUNT;
|
|
-
|
|
- if (test_phase == 1) { /* start test preps */
|
|
- qca8k_phy_loopback_on_off(priv, phy, port, 1);
|
|
- qca8k_switch_port_loopback_on_off(priv, port, 1);
|
|
- qca8k_phy_broadcast_write_on_off(priv, phy, 1);
|
|
- qca8k_phy_pkt_gen_prep(priv, phy, test_pkts_num, 1);
|
|
- } else if (test_phase == 2) {
|
|
- /* wait for test results, collect it and cleanup */
|
|
- qca8k_wait_for_phy_pkt_gen_fin(priv, phy);
|
|
- res = qca8k_get_phy_pkt_gen_test_result(phy, test_pkts_num);
|
|
- qca8k_phy_pkt_gen_prep(priv, phy, test_pkts_num, 0);
|
|
- qca8k_phy_broadcast_write_on_off(priv, phy, 0);
|
|
- qca8k_switch_port_loopback_on_off(priv, port, 0);
|
|
- qca8k_phy_loopback_on_off(priv, phy, port, 0);
|
|
- }
|
|
-
|
|
- return res;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_do_dsa_sw_ports_self_test(struct qca8k_priv *priv, int parallel_test)
|
|
-{
|
|
- struct device_node *dn = priv->dev->of_node;
|
|
- struct device_node *ports, *port;
|
|
- struct device_node *phy_dn;
|
|
- struct phy_device *phy;
|
|
- int reg, err = 0, test_phase;
|
|
- u32 tests_result = 0;
|
|
-
|
|
- ports = of_get_child_by_name(dn, "ports");
|
|
- if (!ports) {
|
|
- dev_err(priv->dev, "no ports child node found\n");
|
|
- return -EINVAL;
|
|
- }
|
|
-
|
|
- for (test_phase = 1; test_phase <= 2; test_phase++) {
|
|
- if (parallel_test && test_phase == 2) {
|
|
- err = qca8k_start_all_phys_pkt_gens(priv);
|
|
- if (err)
|
|
- goto error;
|
|
- }
|
|
- for_each_available_child_of_node(ports, port) {
|
|
- err = of_property_read_u32(port, "reg", ®);
|
|
- if (err)
|
|
- goto error;
|
|
- if (reg >= QCA8K_NUM_PORTS) {
|
|
- err = -EINVAL;
|
|
- goto error;
|
|
- }
|
|
- phy_dn = of_parse_phandle(port, "phy-handle", 0);
|
|
- if (phy_dn) {
|
|
- phy = of_phy_find_device(phy_dn);
|
|
- of_node_put(phy_dn);
|
|
- if (phy) {
|
|
- int result;
|
|
- result = qca8k_test_dsa_port_for_errors(priv,
|
|
- phy, reg, test_phase);
|
|
- if (!parallel_test && test_phase == 1)
|
|
- qca8k_start_phy_pkt_gen(phy);
|
|
- put_device(&phy->mdio.dev);
|
|
- if (test_phase == 2) {
|
|
- tests_result <<= 1;
|
|
- if (result)
|
|
- tests_result |= 1;
|
|
- }
|
|
- }
|
|
- }
|
|
- }
|
|
- }
|
|
-
|
|
-end:
|
|
- of_node_put(ports);
|
|
- qca8k_fdb_flush(priv);
|
|
- return tests_result;
|
|
-error:
|
|
- tests_result |= 0xf000;
|
|
- goto end;
|
|
-}
|
|
-
|
|
-static int
|
|
-psgmii_vco_calibrate_and_test(struct dsa_switch *ds)
|
|
-{
|
|
- int ret, a, test_result;
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
-
|
|
- for (a = 0; a <= QCA8K_PSGMII_CALB_NUM; a++) {
|
|
- ret = psgmii_vco_calibrate(priv);
|
|
- if (ret)
|
|
- return ret;
|
|
- /* first we run serial test */
|
|
- test_result = qca8k_do_dsa_sw_ports_self_test(priv, 0);
|
|
- /* and if it is ok then we run the test in parallel */
|
|
- if (!test_result)
|
|
- test_result = qca8k_do_dsa_sw_ports_self_test(priv, 1);
|
|
- if (!test_result) {
|
|
- if (a > 0) {
|
|
- dev_warn(priv->dev, "PSGMII work was stabilized after %d "
|
|
- "calibration retries !\n", a);
|
|
- }
|
|
- return 0;
|
|
- } else {
|
|
- schedule();
|
|
- if (a > 0 && a % 10 == 0) {
|
|
- dev_err(priv->dev, "PSGMII work is unstable !!! "
|
|
- "Let's try to wait a bit ... %d\n", a);
|
|
- set_current_state(TASK_INTERRUPTIBLE);
|
|
- schedule_timeout(msecs_to_jiffies(a * 100));
|
|
- }
|
|
- }
|
|
- }
|
|
-
|
|
- panic("PSGMII work is unstable !!! "
|
|
- "Repeated recalibration attempts did not help(0x%x) !\n",
|
|
- test_result);
|
|
-
|
|
- return -EFAULT;
|
|
-}
|
|
-
|
|
-static int
|
|
-ipq4019_psgmii_configure(struct dsa_switch *ds)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- int ret;
|
|
-
|
|
- if (!priv->psgmii_calibrated) {
|
|
- ret = psgmii_vco_calibrate_and_test(ds);
|
|
-
|
|
- ret = regmap_clear_bits(priv->psgmii, PSGMIIPHY_MODE_CONTROL,
|
|
- PSGMIIPHY_MODE_ATHR_CSCO_MODE_25M);
|
|
- ret = regmap_write(priv->psgmii, PSGMIIPHY_TX_CONTROL,
|
|
- PSGMIIPHY_TX_CONTROL_MAGIC_VALUE);
|
|
-
|
|
- priv->psgmii_calibrated = true;
|
|
-
|
|
- return ret;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phylink_mac_config(struct dsa_switch *ds, int port, unsigned int mode,
|
|
- const struct phylink_link_state *state)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
-
|
|
- switch (port) {
|
|
- case 0:
|
|
- /* CPU port, no configuration needed */
|
|
- return;
|
|
- case 1:
|
|
- case 2:
|
|
- case 3:
|
|
- if (state->interface == PHY_INTERFACE_MODE_PSGMII)
|
|
- if (ipq4019_psgmii_configure(ds))
|
|
- dev_err(ds->dev, "PSGMII configuration failed!\n");
|
|
- return;
|
|
- case 4:
|
|
- case 5:
|
|
- if (state->interface == PHY_INTERFACE_MODE_RGMII ||
|
|
- state->interface == PHY_INTERFACE_MODE_RGMII_ID ||
|
|
- state->interface == PHY_INTERFACE_MODE_RGMII_RXID ||
|
|
- state->interface == PHY_INTERFACE_MODE_RGMII_TXID) {
|
|
- qca8k_reg_set(priv, QCA8K_REG_RGMII_CTRL, QCA8K_RGMII_CTRL_CLK);
|
|
- }
|
|
-
|
|
- if (state->interface == PHY_INTERFACE_MODE_PSGMII)
|
|
- if (ipq4019_psgmii_configure(ds))
|
|
- dev_err(ds->dev, "PSGMII configuration failed!\n");
|
|
- return;
|
|
- default:
|
|
- dev_err(ds->dev, "%s: unsupported port: %i\n", __func__, port);
|
|
- return;
|
|
- }
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phylink_validate(struct dsa_switch *ds, int port,
|
|
- unsigned long *supported,
|
|
- struct phylink_link_state *state)
|
|
-{
|
|
- __ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, };
|
|
-
|
|
- switch (port) {
|
|
- case 0: /* CPU port */
|
|
- if (state->interface != PHY_INTERFACE_MODE_INTERNAL)
|
|
- goto unsupported;
|
|
- break;
|
|
- case 1:
|
|
- case 2:
|
|
- case 3:
|
|
- /* Only PSGMII mode is supported */
|
|
- if (state->interface != PHY_INTERFACE_MODE_PSGMII)
|
|
- goto unsupported;
|
|
- break;
|
|
- case 4:
|
|
- case 5:
|
|
- /* PSGMII and RGMII modes are supported */
|
|
- if (state->interface != PHY_INTERFACE_MODE_PSGMII &&
|
|
- state->interface != PHY_INTERFACE_MODE_RGMII &&
|
|
- state->interface != PHY_INTERFACE_MODE_RGMII_ID &&
|
|
- state->interface != PHY_INTERFACE_MODE_RGMII_RXID &&
|
|
- state->interface != PHY_INTERFACE_MODE_RGMII_TXID)
|
|
- goto unsupported;
|
|
- break;
|
|
- default:
|
|
-unsupported:
|
|
- dev_warn(ds->dev, "interface '%s' (%d) on port %d is not supported\n",
|
|
- phy_modes(state->interface), state->interface, port);
|
|
- linkmode_zero(supported);
|
|
- return;
|
|
- }
|
|
-
|
|
- if (port == 0) {
|
|
- phylink_set_port_modes(mask);
|
|
-
|
|
- phylink_set(mask, 1000baseT_Full);
|
|
-
|
|
- phylink_set(mask, Pause);
|
|
- phylink_set(mask, Asym_Pause);
|
|
-
|
|
- linkmode_and(supported, supported, mask);
|
|
- linkmode_and(state->advertising, state->advertising, mask);
|
|
- } else {
|
|
- /* Simply copy what PHYs tell us */
|
|
- linkmode_copy(state->advertising, supported);
|
|
- }
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_phylink_mac_link_state(struct dsa_switch *ds, int port,
|
|
- struct phylink_link_state *state)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- u32 reg;
|
|
- int ret;
|
|
-
|
|
- ret = qca8k_read(priv, QCA8K_REG_PORT_STATUS(port), ®);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
-
|
|
- state->link = !!(reg & QCA8K_PORT_STATUS_LINK_UP);
|
|
- state->an_complete = state->link;
|
|
- state->an_enabled = !!(reg & QCA8K_PORT_STATUS_LINK_AUTO);
|
|
- state->duplex = (reg & QCA8K_PORT_STATUS_DUPLEX) ? DUPLEX_FULL :
|
|
- DUPLEX_HALF;
|
|
-
|
|
- switch (reg & QCA8K_PORT_STATUS_SPEED) {
|
|
- case QCA8K_PORT_STATUS_SPEED_10:
|
|
- state->speed = SPEED_10;
|
|
- break;
|
|
- case QCA8K_PORT_STATUS_SPEED_100:
|
|
- state->speed = SPEED_100;
|
|
- break;
|
|
- case QCA8K_PORT_STATUS_SPEED_1000:
|
|
- state->speed = SPEED_1000;
|
|
- break;
|
|
- default:
|
|
- state->speed = SPEED_UNKNOWN;
|
|
- break;
|
|
- }
|
|
-
|
|
- state->pause = MLO_PAUSE_NONE;
|
|
- if (reg & QCA8K_PORT_STATUS_RXFLOW)
|
|
- state->pause |= MLO_PAUSE_RX;
|
|
- if (reg & QCA8K_PORT_STATUS_TXFLOW)
|
|
- state->pause |= MLO_PAUSE_TX;
|
|
-
|
|
- return 1;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phylink_mac_link_down(struct dsa_switch *ds, int port, unsigned int mode,
|
|
- phy_interface_t interface)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
-
|
|
- qca8k_port_set_status(priv, port, 0);
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_phylink_mac_link_up(struct dsa_switch *ds, int port, unsigned int mode,
|
|
- phy_interface_t interface, struct phy_device *phydev,
|
|
- int speed, int duplex, bool tx_pause, bool rx_pause)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- u32 reg;
|
|
-
|
|
- if (phylink_autoneg_inband(mode)) {
|
|
- reg = QCA8K_PORT_STATUS_LINK_AUTO;
|
|
- } else {
|
|
- switch (speed) {
|
|
- case SPEED_10:
|
|
- reg = QCA8K_PORT_STATUS_SPEED_10;
|
|
- break;
|
|
- case SPEED_100:
|
|
- reg = QCA8K_PORT_STATUS_SPEED_100;
|
|
- break;
|
|
- case SPEED_1000:
|
|
- reg = QCA8K_PORT_STATUS_SPEED_1000;
|
|
- break;
|
|
- default:
|
|
- reg = QCA8K_PORT_STATUS_LINK_AUTO;
|
|
- break;
|
|
- }
|
|
-
|
|
- if (duplex == DUPLEX_FULL)
|
|
- reg |= QCA8K_PORT_STATUS_DUPLEX;
|
|
-
|
|
- if (rx_pause || dsa_is_cpu_port(ds, port))
|
|
- reg |= QCA8K_PORT_STATUS_RXFLOW;
|
|
-
|
|
- if (tx_pause || dsa_is_cpu_port(ds, port))
|
|
- reg |= QCA8K_PORT_STATUS_TXFLOW;
|
|
- }
|
|
-
|
|
- reg |= QCA8K_PORT_STATUS_TXMAC | QCA8K_PORT_STATUS_RXMAC;
|
|
-
|
|
- qca8k_write(priv, QCA8K_REG_PORT_STATUS(port), reg);
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_get_strings(struct dsa_switch *ds, int port, u32 stringset, uint8_t *data)
|
|
-{
|
|
- int i;
|
|
-
|
|
- if (stringset != ETH_SS_STATS)
|
|
- return;
|
|
-
|
|
- for (i = 0; i < ARRAY_SIZE(ar8327_mib); i++)
|
|
- strncpy(data + i * ETH_GSTRING_LEN, ar8327_mib[i].name,
|
|
- ETH_GSTRING_LEN);
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_get_ethtool_stats(struct dsa_switch *ds, int port,
|
|
- uint64_t *data)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- const struct qca8k_mib_desc *mib;
|
|
- u32 reg, i, val;
|
|
- u32 hi = 0;
|
|
- int ret;
|
|
-
|
|
- for (i = 0; i < ARRAY_SIZE(ar8327_mib); i++) {
|
|
- mib = &ar8327_mib[i];
|
|
- reg = QCA8K_PORT_MIB_COUNTER(port) + mib->offset;
|
|
-
|
|
- ret = qca8k_read(priv, reg, &val);
|
|
- if (ret < 0)
|
|
- continue;
|
|
-
|
|
- if (mib->size == 2) {
|
|
- ret = qca8k_read(priv, reg + 4, &hi);
|
|
- if (ret < 0)
|
|
- continue;
|
|
- }
|
|
-
|
|
- data[i] = val;
|
|
- if (mib->size == 2)
|
|
- data[i] |= (u64)hi << 32;
|
|
- }
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_get_sset_count(struct dsa_switch *ds, int port, int sset)
|
|
-{
|
|
- if (sset != ETH_SS_STATS)
|
|
- return 0;
|
|
-
|
|
- return ARRAY_SIZE(ar8327_mib);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_set_mac_eee(struct dsa_switch *ds, int port, struct ethtool_eee *eee)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- u32 lpi_en = QCA8K_REG_EEE_CTRL_LPI_EN(port);
|
|
- u32 reg;
|
|
- int ret;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- ret = qca8k_read(priv, QCA8K_REG_EEE_CTRL, ®);
|
|
- if (ret < 0)
|
|
- goto exit;
|
|
-
|
|
- if (eee->eee_enabled)
|
|
- reg |= lpi_en;
|
|
- else
|
|
- reg &= ~lpi_en;
|
|
- ret = qca8k_write(priv, QCA8K_REG_EEE_CTRL, reg);
|
|
-
|
|
-exit:
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_get_mac_eee(struct dsa_switch *ds, int port, struct ethtool_eee *e)
|
|
-{
|
|
- /* Nothing to do on the port's MAC */
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_port_stp_state_set(struct dsa_switch *ds, int port, u8 state)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- u32 stp_state;
|
|
-
|
|
- switch (state) {
|
|
- case BR_STATE_DISABLED:
|
|
- stp_state = QCA8K_PORT_LOOKUP_STATE_DISABLED;
|
|
- break;
|
|
- case BR_STATE_BLOCKING:
|
|
- stp_state = QCA8K_PORT_LOOKUP_STATE_BLOCKING;
|
|
- break;
|
|
- case BR_STATE_LISTENING:
|
|
- stp_state = QCA8K_PORT_LOOKUP_STATE_LISTENING;
|
|
- break;
|
|
- case BR_STATE_LEARNING:
|
|
- stp_state = QCA8K_PORT_LOOKUP_STATE_LEARNING;
|
|
- break;
|
|
- case BR_STATE_FORWARDING:
|
|
- default:
|
|
- stp_state = QCA8K_PORT_LOOKUP_STATE_FORWARD;
|
|
- break;
|
|
- }
|
|
-
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_STATE_MASK, stp_state);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_bridge_join(struct dsa_switch *ds, int port, struct net_device *br)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- int port_mask, cpu_port;
|
|
- int i, ret;
|
|
-
|
|
- cpu_port = dsa_to_port(ds, port)->cpu_dp->index;
|
|
- port_mask = BIT(cpu_port);
|
|
-
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++) {
|
|
- if (dsa_is_cpu_port(ds, i))
|
|
- continue;
|
|
- if (dsa_to_port(ds, i)->bridge_dev != br)
|
|
- continue;
|
|
- /* Add this port to the portvlan mask of the other ports
|
|
- * in the bridge
|
|
- */
|
|
- ret = qca8k_reg_set(priv,
|
|
- QCA8K_PORT_LOOKUP_CTRL(i),
|
|
- BIT(port));
|
|
- if (ret)
|
|
- return ret;
|
|
- if (i != port)
|
|
- port_mask |= BIT(i);
|
|
- }
|
|
-
|
|
- /* Add all other ports to this ports portvlan mask */
|
|
- ret = qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_MEMBER, port_mask);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_port_bridge_leave(struct dsa_switch *ds, int port, struct net_device *br)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- int cpu_port, i;
|
|
-
|
|
- cpu_port = dsa_to_port(ds, port)->cpu_dp->index;
|
|
-
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++) {
|
|
- if (dsa_is_cpu_port(ds, i))
|
|
- continue;
|
|
- if (dsa_to_port(ds, i)->bridge_dev != br)
|
|
- continue;
|
|
- /* Remove this port to the portvlan mask of the other ports
|
|
- * in the bridge
|
|
- */
|
|
- qca8k_reg_clear(priv,
|
|
- QCA8K_PORT_LOOKUP_CTRL(i),
|
|
- BIT(port));
|
|
- }
|
|
-
|
|
- /* Set the cpu port to be the only one in the portvlan mask of
|
|
- * this port
|
|
- */
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_MEMBER, BIT(cpu_port));
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_enable(struct dsa_switch *ds, int port,
|
|
- struct phy_device *phy)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
-
|
|
- qca8k_port_set_status(priv, port, 1);
|
|
- priv->port_sts[port].enabled = 1;
|
|
-
|
|
- if (dsa_is_user_port(ds, port))
|
|
- phy_support_asym_pause(phy);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void
|
|
-qca8k_port_disable(struct dsa_switch *ds, int port)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
-
|
|
- qca8k_port_set_status(priv, port, 0);
|
|
- priv->port_sts[port].enabled = 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_change_mtu(struct dsa_switch *ds, int port, int new_mtu)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- int i, mtu = 0;
|
|
-
|
|
- priv->port_mtu[port] = new_mtu;
|
|
-
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++)
|
|
- if (priv->port_mtu[i] > mtu)
|
|
- mtu = priv->port_mtu[i];
|
|
-
|
|
- /* Include L2 header / FCS length */
|
|
- return qca8k_write(priv, QCA8K_MAX_FRAME_SIZE, mtu + ETH_HLEN + ETH_FCS_LEN);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_max_mtu(struct dsa_switch *ds, int port)
|
|
-{
|
|
- return QCA8K_MAX_MTU;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_fdb_insert(struct qca8k_priv *priv, const u8 *addr,
|
|
- u16 port_mask, u16 vid)
|
|
-{
|
|
- /* Set the vid to the port vlan id if no vid is set */
|
|
- if (!vid)
|
|
- vid = QCA8K_PORT_VID_DEF;
|
|
-
|
|
- return qca8k_fdb_add(priv, addr, port_mask, vid,
|
|
- QCA8K_ATU_STATUS_STATIC);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_fdb_add(struct dsa_switch *ds, int port,
|
|
- const unsigned char *addr, u16 vid)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- u16 port_mask = BIT(port);
|
|
-
|
|
- return qca8k_port_fdb_insert(priv, addr, port_mask, vid);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_fdb_del(struct dsa_switch *ds, int port,
|
|
- const unsigned char *addr, u16 vid)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- u16 port_mask = BIT(port);
|
|
-
|
|
- if (!vid)
|
|
- vid = QCA8K_PORT_VID_DEF;
|
|
-
|
|
- return qca8k_fdb_del(priv, addr, port_mask, vid);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_fdb_dump(struct dsa_switch *ds, int port,
|
|
- dsa_fdb_dump_cb_t *cb, void *data)
|
|
-{
|
|
- struct qca8k_priv *priv = (struct qca8k_priv *)ds->priv;
|
|
- struct qca8k_fdb _fdb = { 0 };
|
|
- int cnt = QCA8K_NUM_FDB_RECORDS;
|
|
- bool is_static;
|
|
- int ret = 0;
|
|
-
|
|
- mutex_lock(&priv->reg_mutex);
|
|
- while (cnt-- && !qca8k_fdb_next(priv, &_fdb, port)) {
|
|
- if (!_fdb.aging)
|
|
- break;
|
|
- is_static = (_fdb.aging == QCA8K_ATU_STATUS_STATIC);
|
|
- ret = cb(_fdb.mac, _fdb.vid, is_static, data);
|
|
- if (ret)
|
|
- break;
|
|
- }
|
|
- mutex_unlock(&priv->reg_mutex);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_vlan_filtering(struct dsa_switch *ds, int port, bool vlan_filtering,
|
|
- struct netlink_ext_ack *extack)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
-
|
|
- if (vlan_filtering) {
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_VLAN_MODE,
|
|
- QCA8K_PORT_LOOKUP_VLAN_MODE_SECURE);
|
|
- } else {
|
|
- qca8k_rmw(priv, QCA8K_PORT_LOOKUP_CTRL(port),
|
|
- QCA8K_PORT_LOOKUP_VLAN_MODE,
|
|
- QCA8K_PORT_LOOKUP_VLAN_MODE_NONE);
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_vlan_add(struct dsa_switch *ds, int port,
|
|
- const struct switchdev_obj_port_vlan *vlan,
|
|
- struct netlink_ext_ack *extack)
|
|
-{
|
|
- bool untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
|
|
- bool pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- int ret = 0;
|
|
-
|
|
- ret = qca8k_vlan_add(priv, port, vlan->vid, untagged);
|
|
- if (ret) {
|
|
- dev_err(priv->dev, "Failed to add VLAN to port %d (%d)", port, ret);
|
|
- return ret;
|
|
- }
|
|
-
|
|
- if (pvid) {
|
|
- int shift = 16 * (port % 2);
|
|
-
|
|
- qca8k_rmw(priv, QCA8K_EGRESS_VLAN(port),
|
|
- 0xfff << shift, vlan->vid << shift);
|
|
- qca8k_write(priv, QCA8K_REG_PORT_VLAN_CTRL0(port),
|
|
- QCA8K_PORT_VLAN_CVID(vlan->vid) |
|
|
- QCA8K_PORT_VLAN_SVID(vlan->vid));
|
|
- }
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_port_vlan_del(struct dsa_switch *ds, int port,
|
|
- const struct switchdev_obj_port_vlan *vlan)
|
|
-{
|
|
- struct qca8k_priv *priv = ds->priv;
|
|
- int ret = 0;
|
|
-
|
|
- ret = qca8k_vlan_del(priv, port, vlan->vid);
|
|
- if (ret)
|
|
- dev_err(priv->dev, "Failed to delete VLAN from port %d (%d)", port, ret);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static enum dsa_tag_protocol
|
|
-qca8k_get_tag_protocol(struct dsa_switch *ds, int port,
|
|
- enum dsa_tag_protocol mp)
|
|
-{
|
|
- return DSA_TAG_PROTO_IPQ4019;
|
|
-}
|
|
-
|
|
-static const struct dsa_switch_ops qca8k_switch_ops = {
|
|
- .get_tag_protocol = qca8k_get_tag_protocol,
|
|
- .setup = qca8k_setup,
|
|
- .get_strings = qca8k_get_strings,
|
|
- .get_ethtool_stats = qca8k_get_ethtool_stats,
|
|
- .get_sset_count = qca8k_get_sset_count,
|
|
- .get_mac_eee = qca8k_get_mac_eee,
|
|
- .set_mac_eee = qca8k_set_mac_eee,
|
|
- .port_enable = qca8k_port_enable,
|
|
- .port_disable = qca8k_port_disable,
|
|
- .port_change_mtu = qca8k_port_change_mtu,
|
|
- .port_max_mtu = qca8k_port_max_mtu,
|
|
- .port_stp_state_set = qca8k_port_stp_state_set,
|
|
- .port_bridge_join = qca8k_port_bridge_join,
|
|
- .port_bridge_leave = qca8k_port_bridge_leave,
|
|
- .port_fdb_add = qca8k_port_fdb_add,
|
|
- .port_fdb_del = qca8k_port_fdb_del,
|
|
- .port_fdb_dump = qca8k_port_fdb_dump,
|
|
- .port_vlan_filtering = qca8k_port_vlan_filtering,
|
|
- .port_vlan_add = qca8k_port_vlan_add,
|
|
- .port_vlan_del = qca8k_port_vlan_del,
|
|
- .phylink_validate = qca8k_phylink_validate,
|
|
- .phylink_mac_link_state = qca8k_phylink_mac_link_state,
|
|
- .phylink_mac_config = qca8k_phylink_mac_config,
|
|
- .phylink_mac_link_down = qca8k_phylink_mac_link_down,
|
|
- .phylink_mac_link_up = qca8k_phylink_mac_link_up,
|
|
-};
|
|
-
|
|
-static int
|
|
-qca8k_ipq4019_probe(struct platform_device *pdev)
|
|
-{
|
|
- struct qca8k_priv *priv;
|
|
- void __iomem *base, *psgmii;
|
|
- struct device_node *np = pdev->dev.of_node, *mdio_np, *psgmii_ethphy_np;
|
|
- int ret;
|
|
-
|
|
- priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL);
|
|
- if (!priv)
|
|
- return -ENOMEM;
|
|
-
|
|
- priv->dev = &pdev->dev;
|
|
-
|
|
- base = devm_platform_ioremap_resource_byname(pdev, "base");
|
|
- if (IS_ERR(base))
|
|
- return PTR_ERR(base);
|
|
-
|
|
- priv->regmap = devm_regmap_init_mmio(priv->dev, base,
|
|
- &qca8k_ipq4019_regmap_config);
|
|
- if (IS_ERR(priv->regmap)) {
|
|
- ret = PTR_ERR(priv->regmap);
|
|
- dev_err(priv->dev, "base regmap initialization failed, %d\n", ret);
|
|
- return ret;
|
|
- }
|
|
-
|
|
- psgmii = devm_platform_ioremap_resource_byname(pdev, "psgmii_phy");
|
|
- if (IS_ERR(psgmii))
|
|
- return PTR_ERR(psgmii);
|
|
-
|
|
- priv->psgmii = devm_regmap_init_mmio(priv->dev, psgmii,
|
|
- &qca8k_ipq4019_psgmii_phy_regmap_config);
|
|
- if (IS_ERR(priv->psgmii)) {
|
|
- ret = PTR_ERR(priv->psgmii);
|
|
- dev_err(priv->dev, "PSGMII regmap initialization failed, %d\n", ret);
|
|
- return ret;
|
|
- }
|
|
-
|
|
- mdio_np = of_parse_phandle(np, "mdio", 0);
|
|
- if (!mdio_np) {
|
|
- dev_err(&pdev->dev, "unable to get MDIO bus phandle\n");
|
|
- of_node_put(mdio_np);
|
|
- return -EINVAL;
|
|
- }
|
|
-
|
|
- priv->bus = of_mdio_find_bus(mdio_np);
|
|
- of_node_put(mdio_np);
|
|
- if (!priv->bus) {
|
|
- dev_err(&pdev->dev, "unable to find MDIO bus\n");
|
|
- return -EPROBE_DEFER;
|
|
- }
|
|
-
|
|
- psgmii_ethphy_np = of_parse_phandle(np, "psgmii-ethphy", 0);
|
|
- if (!psgmii_ethphy_np) {
|
|
- dev_dbg(&pdev->dev, "unable to get PSGMII eth PHY phandle\n");
|
|
- of_node_put(psgmii_ethphy_np);
|
|
- }
|
|
-
|
|
- if (psgmii_ethphy_np) {
|
|
- priv->psgmii_ethphy = of_phy_find_device(psgmii_ethphy_np);
|
|
- of_node_put(psgmii_ethphy_np);
|
|
- if (!priv->psgmii_ethphy) {
|
|
- dev_err(&pdev->dev, "unable to get PSGMII eth PHY\n");
|
|
- return -ENODEV;
|
|
- }
|
|
- }
|
|
-
|
|
- priv->ds = devm_kzalloc(priv->dev, sizeof(*priv->ds), GFP_KERNEL);
|
|
- if (!priv->ds)
|
|
- return -ENOMEM;
|
|
-
|
|
- priv->ds->dev = priv->dev;
|
|
- priv->ds->num_ports = QCA8K_NUM_PORTS;
|
|
- priv->ds->priv = priv;
|
|
- priv->ops = qca8k_switch_ops;
|
|
- priv->ds->ops = &priv->ops;
|
|
-
|
|
- mutex_init(&priv->reg_mutex);
|
|
- platform_set_drvdata(pdev, priv);
|
|
-
|
|
- return dsa_register_switch(priv->ds);
|
|
-}
|
|
-
|
|
-static int
|
|
-qca8k_ipq4019_remove(struct platform_device *pdev)
|
|
-{
|
|
- struct qca8k_priv *priv = dev_get_drvdata(&pdev->dev);
|
|
- int i;
|
|
-
|
|
- if (!priv)
|
|
- return 0;
|
|
-
|
|
- for (i = 0; i < QCA8K_NUM_PORTS; i++)
|
|
- qca8k_port_set_status(priv, i, 0);
|
|
-
|
|
- dsa_unregister_switch(priv->ds);
|
|
-
|
|
- dev_set_drvdata(&pdev->dev, NULL);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static const struct of_device_id qca8k_ipq4019_of_match[] = {
|
|
- { .compatible = "qca,ipq4019-qca8337n" },
|
|
- { /* sentinel */ },
|
|
-};
|
|
-
|
|
-static struct platform_driver qca8k_ipq4019_driver = {
|
|
- .probe = qca8k_ipq4019_probe,
|
|
- .remove = qca8k_ipq4019_remove,
|
|
- .driver = {
|
|
- .name = "qca8k-ipq4019",
|
|
- .of_match_table = qca8k_ipq4019_of_match,
|
|
- },
|
|
-};
|
|
-
|
|
-module_platform_driver(qca8k_ipq4019_driver);
|
|
-
|
|
-MODULE_AUTHOR("Mathieu Olivari, John Crispin <john@phrozen.org>");
|
|
-MODULE_AUTHOR("Gabor Juhos <j4g8y7@gmail.com>, Robert Marko <robert.marko@sartura.hr>");
|
|
-MODULE_DESCRIPTION("Qualcomm IPQ4019 built-in switch driver");
|
|
-MODULE_LICENSE("GPL v2");
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.h b/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.h
|
|
deleted file mode 100644
|
|
index 1133501335..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/dsa/qca/qca8k-ipq4019.h
|
|
+++ /dev/null
|
|
@@ -1,289 +0,0 @@
|
|
-/* SPDX-License-Identifier: GPL-2.0-only */
|
|
-/*
|
|
- * Copyright (C) 2009 Felix Fietkau <nbd@nbd.name>
|
|
- * Copyright (C) 2011-2012 Gabor Juhos <juhosg@openwrt.org>
|
|
- * Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
- */
|
|
-
|
|
-#ifndef __QCA8K_H
|
|
-#define __QCA8K_H
|
|
-
|
|
-#include <linux/regmap.h>
|
|
-
|
|
-#define QCA8K_NUM_PORTS 6
|
|
-#define QCA8K_CPU_PORT 0
|
|
-#define QCA8K_MAX_MTU 9000
|
|
-
|
|
-#define QCA8K_BUSY_WAIT_TIMEOUT 2000
|
|
-
|
|
-#define QCA8K_NUM_FDB_RECORDS 2048
|
|
-
|
|
-#define QCA8K_PORT_VID_DEF 1
|
|
-
|
|
-/* Global control registers */
|
|
-#define QCA8K_REG_MASK_CTRL 0x000
|
|
-#define QCA8K_MASK_CTRL_REV_ID_MASK GENMASK(7, 0)
|
|
-#define QCA8K_MASK_CTRL_REV_ID(x) ((x) >> 0)
|
|
-#define QCA8K_MASK_CTRL_DEVICE_ID_MASK GENMASK(15, 8)
|
|
-#define QCA8K_MASK_CTRL_DEVICE_ID(x) ((x) >> 8)
|
|
-#define QCA8K_REG_RGMII_CTRL 0x004
|
|
-#define QCA8K_RGMII_CTRL_RGMII_RXC GENMASK(1, 0)
|
|
-#define QCA8K_RGMII_CTRL_RGMII_TXC GENMASK(9, 8)
|
|
-/* Some kind of CLK selection
|
|
- * 0: gcc_ess_dly2ns
|
|
- * 1: gcc_ess_clk
|
|
- */
|
|
-#define QCA8K_RGMII_CTRL_CLK BIT(10)
|
|
-#define QCA8K_RGMII_CTRL_DELAY_RMII0 GENMASK(17, 16)
|
|
-#define QCA8K_RGMII_CTRL_INVERT_RMII0_REF_CLK BIT(18)
|
|
-#define QCA8K_RGMII_CTRL_DELAY_RMII1 GENMASK(20, 19)
|
|
-#define QCA8K_RGMII_CTRL_INVERT_RMII1_REF_CLK BIT(21)
|
|
-#define QCA8K_RGMII_CTRL_INVERT_RMII0_MASTER_EN BIT(24)
|
|
-#define QCA8K_RGMII_CTRL_INVERT_RMII1_MASTER_EN BIT(25)
|
|
-#define QCA8K_REG_MODULE_EN 0x030
|
|
-#define QCA8K_MODULE_EN_MIB BIT(0)
|
|
-#define QCA8K_REG_MIB 0x034
|
|
-#define QCA8K_MIB_FLUSH BIT(24)
|
|
-#define QCA8K_MIB_CPU_KEEP BIT(20)
|
|
-#define QCA8K_MIB_BUSY BIT(17)
|
|
-#define QCA8K_GOL_MAC_ADDR0 0x60
|
|
-#define QCA8K_GOL_MAC_ADDR1 0x64
|
|
-#define QCA8K_MAX_FRAME_SIZE 0x78
|
|
-#define QCA8K_REG_PORT_STATUS(_i) (0x07c + (_i) * 4)
|
|
-#define QCA8K_PORT_STATUS_SPEED GENMASK(1, 0)
|
|
-#define QCA8K_PORT_STATUS_SPEED_10 0
|
|
-#define QCA8K_PORT_STATUS_SPEED_100 0x1
|
|
-#define QCA8K_PORT_STATUS_SPEED_1000 0x2
|
|
-#define QCA8K_PORT_STATUS_TXMAC BIT(2)
|
|
-#define QCA8K_PORT_STATUS_RXMAC BIT(3)
|
|
-#define QCA8K_PORT_STATUS_TXFLOW BIT(4)
|
|
-#define QCA8K_PORT_STATUS_RXFLOW BIT(5)
|
|
-#define QCA8K_PORT_STATUS_DUPLEX BIT(6)
|
|
-#define QCA8K_PORT_STATUS_LINK_UP BIT(8)
|
|
-#define QCA8K_PORT_STATUS_LINK_AUTO BIT(9)
|
|
-#define QCA8K_PORT_STATUS_LINK_PAUSE BIT(10)
|
|
-#define QCA8K_PORT_STATUS_FLOW_AUTO BIT(12)
|
|
-#define QCA8K_REG_PORT_HDR_CTRL(_i) (0x9c + (_i * 4))
|
|
-#define QCA8K_PORT_HDR_CTRL_RX_MASK GENMASK(3, 2)
|
|
-#define QCA8K_PORT_HDR_CTRL_RX_S 2
|
|
-#define QCA8K_PORT_HDR_CTRL_TX_MASK GENMASK(1, 0)
|
|
-#define QCA8K_PORT_HDR_CTRL_TX_S 0
|
|
-#define QCA8K_PORT_HDR_CTRL_ALL 2
|
|
-#define QCA8K_PORT_HDR_CTRL_MGMT 1
|
|
-#define QCA8K_PORT_HDR_CTRL_NONE 0
|
|
-#define QCA8K_REG_SGMII_CTRL 0x0e0
|
|
-#define QCA8K_SGMII_EN_PLL BIT(1)
|
|
-#define QCA8K_SGMII_EN_RX BIT(2)
|
|
-#define QCA8K_SGMII_EN_TX BIT(3)
|
|
-#define QCA8K_SGMII_EN_SD BIT(4)
|
|
-#define QCA8K_SGMII_CLK125M_DELAY BIT(7)
|
|
-#define QCA8K_SGMII_MODE_CTRL_MASK (BIT(22) | BIT(23))
|
|
-#define QCA8K_SGMII_MODE_CTRL_BASEX (0 << 22)
|
|
-#define QCA8K_SGMII_MODE_CTRL_PHY (1 << 22)
|
|
-#define QCA8K_SGMII_MODE_CTRL_MAC (2 << 22)
|
|
-
|
|
-/* EEE control registers */
|
|
-#define QCA8K_REG_EEE_CTRL 0x100
|
|
-#define QCA8K_REG_EEE_CTRL_LPI_EN(_i) ((_i + 1) * 2)
|
|
-
|
|
-/* ACL registers */
|
|
-#define QCA8K_REG_PORT_VLAN_CTRL0(_i) (0x420 + (_i * 8))
|
|
-#define QCA8K_PORT_VLAN_CVID(x) (x << 16)
|
|
-#define QCA8K_PORT_VLAN_SVID(x) x
|
|
-#define QCA8K_REG_PORT_VLAN_CTRL1(_i) (0x424 + (_i * 8))
|
|
-#define QCA8K_REG_IPV4_PRI_BASE_ADDR 0x470
|
|
-#define QCA8K_REG_IPV4_PRI_ADDR_MASK 0x474
|
|
-
|
|
-/* Lookup registers */
|
|
-#define QCA8K_REG_ATU_DATA0 0x600
|
|
-#define QCA8K_ATU_ADDR2_S 24
|
|
-#define QCA8K_ATU_ADDR3_S 16
|
|
-#define QCA8K_ATU_ADDR4_S 8
|
|
-#define QCA8K_REG_ATU_DATA1 0x604
|
|
-#define QCA8K_ATU_PORT_M 0x7f
|
|
-#define QCA8K_ATU_PORT_S 16
|
|
-#define QCA8K_ATU_ADDR0_S 8
|
|
-#define QCA8K_REG_ATU_DATA2 0x608
|
|
-#define QCA8K_ATU_VID_M 0xfff
|
|
-#define QCA8K_ATU_VID_S 8
|
|
-#define QCA8K_ATU_STATUS_M 0xf
|
|
-#define QCA8K_ATU_STATUS_STATIC 0xf
|
|
-#define QCA8K_REG_ATU_FUNC 0x60c
|
|
-#define QCA8K_ATU_FUNC_BUSY BIT(31)
|
|
-#define QCA8K_ATU_FUNC_PORT_EN BIT(14)
|
|
-#define QCA8K_ATU_FUNC_MULTI_EN BIT(13)
|
|
-#define QCA8K_ATU_FUNC_FULL BIT(12)
|
|
-#define QCA8K_ATU_FUNC_PORT_M 0xf
|
|
-#define QCA8K_ATU_FUNC_PORT_S 8
|
|
-#define QCA8K_REG_VTU_FUNC0 0x610
|
|
-#define QCA8K_VTU_FUNC0_VALID BIT(20)
|
|
-#define QCA8K_VTU_FUNC0_IVL_EN BIT(19)
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_S(_i) (4 + (_i) * 2)
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_MASK 3
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_UNMOD 0
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_UNTAG 1
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_TAG 2
|
|
-#define QCA8K_VTU_FUNC0_EG_MODE_NOT 3
|
|
-#define QCA8K_REG_VTU_FUNC1 0x614
|
|
-#define QCA8K_VTU_FUNC1_BUSY BIT(31)
|
|
-#define QCA8K_VTU_FUNC1_VID_S 16
|
|
-#define QCA8K_VTU_FUNC1_FULL BIT(4)
|
|
-#define QCA8K_REG_GLOBAL_FW_CTRL0 0x620
|
|
-#define QCA8K_GLOBAL_FW_CTRL0_CPU_PORT_EN BIT(10)
|
|
-#define QCA8K_REG_GLOBAL_FW_CTRL1 0x624
|
|
-#define QCA8K_GLOBAL_FW_CTRL1_IGMP_DP_S 24
|
|
-#define QCA8K_GLOBAL_FW_CTRL1_BC_DP_S 16
|
|
-#define QCA8K_GLOBAL_FW_CTRL1_MC_DP_S 8
|
|
-#define QCA8K_GLOBAL_FW_CTRL1_UC_DP_S 0
|
|
-#define QCA8K_PORT_LOOKUP_CTRL(_i) (0x660 + (_i) * 0xc)
|
|
-#define QCA8K_PORT_LOOKUP_MEMBER GENMASK(6, 0)
|
|
-#define QCA8K_PORT_LOOKUP_VLAN_MODE GENMASK(9, 8)
|
|
-#define QCA8K_PORT_LOOKUP_VLAN_MODE_NONE (0 << 8)
|
|
-#define QCA8K_PORT_LOOKUP_VLAN_MODE_FALLBACK (1 << 8)
|
|
-#define QCA8K_PORT_LOOKUP_VLAN_MODE_CHECK (2 << 8)
|
|
-#define QCA8K_PORT_LOOKUP_VLAN_MODE_SECURE (3 << 8)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_MASK GENMASK(18, 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_DISABLED (0 << 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_BLOCKING (1 << 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_LISTENING (2 << 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_LEARNING (3 << 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE_FORWARD (4 << 16)
|
|
-#define QCA8K_PORT_LOOKUP_STATE GENMASK(18, 16)
|
|
-#define QCA8K_PORT_LOOKUP_LEARN BIT(20)
|
|
-#define QCA8K_PORT_LOOKUP_LOOPBACK BIT(21)
|
|
-
|
|
-#define QCA8K_REG_GLOBAL_FC_THRESH 0x800
|
|
-#define QCA8K_GLOBAL_FC_GOL_XON_THRES(x) ((x) << 16)
|
|
-#define QCA8K_GLOBAL_FC_GOL_XON_THRES_S GENMASK(24, 16)
|
|
-#define QCA8K_GLOBAL_FC_GOL_XOFF_THRES(x) ((x) << 0)
|
|
-#define QCA8K_GLOBAL_FC_GOL_XOFF_THRES_S GENMASK(8, 0)
|
|
-
|
|
-#define QCA8K_REG_PORT_HOL_CTRL0(_i) (0x970 + (_i) * 0x8)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI0_BUF GENMASK(3, 0)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI0(x) ((x) << 0)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI1_BUF GENMASK(7, 4)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI1(x) ((x) << 4)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI2_BUF GENMASK(11, 8)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI2(x) ((x) << 8)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI3_BUF GENMASK(15, 12)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI3(x) ((x) << 12)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI4_BUF GENMASK(19, 16)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI4(x) ((x) << 16)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI5_BUF GENMASK(23, 20)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PRI5(x) ((x) << 20)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PORT_BUF GENMASK(29, 24)
|
|
-#define QCA8K_PORT_HOL_CTRL0_EG_PORT(x) ((x) << 24)
|
|
-
|
|
-#define QCA8K_REG_PORT_HOL_CTRL1(_i) (0x974 + (_i) * 0x8)
|
|
-#define QCA8K_PORT_HOL_CTRL1_ING_BUF GENMASK(3, 0)
|
|
-#define QCA8K_PORT_HOL_CTRL1_ING(x) ((x) << 0)
|
|
-#define QCA8K_PORT_HOL_CTRL1_EG_PRI_BUF_EN BIT(6)
|
|
-#define QCA8K_PORT_HOL_CTRL1_EG_PORT_BUF_EN BIT(7)
|
|
-#define QCA8K_PORT_HOL_CTRL1_WRED_EN BIT(8)
|
|
-#define QCA8K_PORT_HOL_CTRL1_EG_MIRROR_EN BIT(16)
|
|
-
|
|
-/* Pkt edit registers */
|
|
-#define QCA8K_EGRESS_VLAN(x) (0x0c70 + (4 * (x / 2)))
|
|
-
|
|
-/* L3 registers */
|
|
-#define QCA8K_HROUTER_CONTROL 0xe00
|
|
-#define QCA8K_HROUTER_CONTROL_GLB_LOCKTIME_M GENMASK(17, 16)
|
|
-#define QCA8K_HROUTER_CONTROL_GLB_LOCKTIME_S 16
|
|
-#define QCA8K_HROUTER_CONTROL_ARP_AGE_MODE 1
|
|
-#define QCA8K_HROUTER_PBASED_CONTROL1 0xe08
|
|
-#define QCA8K_HROUTER_PBASED_CONTROL2 0xe0c
|
|
-#define QCA8K_HNAT_CONTROL 0xe38
|
|
-
|
|
-/* MIB registers */
|
|
-#define QCA8K_PORT_MIB_COUNTER(_i) (0x1000 + (_i) * 0x100)
|
|
-
|
|
-/* IPQ4019 PSGMII PHY registers */
|
|
-#define PSGMIIPHY_MODE_CONTROL 0x1b4
|
|
-#define PSGMIIPHY_MODE_ATHR_CSCO_MODE_25M BIT(0)
|
|
-#define PSGMIIPHY_TX_CONTROL 0x288
|
|
-#define PSGMIIPHY_TX_CONTROL_MAGIC_VALUE 0x8380
|
|
-#define PSGMIIPHY_VCO_CALIBRATION_CONTROL_REGISTER_1 0x9c
|
|
-#define PSGMIIPHY_REG_PLL_VCO_CALIB_RESTART BIT(14)
|
|
-#define PSGMIIPHY_VCO_CALIBRATION_CONTROL_REGISTER_2 0xa0
|
|
-#define PSGMIIPHY_REG_PLL_VCO_CALIB_READY BIT(0)
|
|
-
|
|
-#define QCA8K_PSGMII_CALB_NUM 100
|
|
-#define MII_QCA8075_SSTATUS 0x11
|
|
-#define QCA8075_PHY_SPEC_STATUS_LINK BIT(10)
|
|
-#define QCA8075_MMD7_CRC_AND_PKTS_COUNT 0x8029
|
|
-#define QCA8075_MMD7_PKT_GEN_PKT_NUMB 0x8021
|
|
-#define QCA8075_MMD7_PKT_GEN_PKT_SIZE 0x8062
|
|
-#define QCA8075_MMD7_PKT_GEN_CTRL 0x8020
|
|
-#define QCA8075_MMD7_CNT_SELFCLR BIT(1)
|
|
-#define QCA8075_MMD7_CNT_FRAME_CHK_EN BIT(0)
|
|
-#define QCA8075_MMD7_PKT_GEN_START BIT(13)
|
|
-#define QCA8075_MMD7_PKT_GEN_INPROGR BIT(15)
|
|
-#define QCA8075_MMD7_IG_FRAME_RECV_CNT_HI 0x802a
|
|
-#define QCA8075_MMD7_IG_FRAME_RECV_CNT_LO 0x802b
|
|
-#define QCA8075_MMD7_IG_FRAME_ERR_CNT 0x802c
|
|
-#define QCA8075_MMD7_EG_FRAME_RECV_CNT_HI 0x802d
|
|
-#define QCA8075_MMD7_EG_FRAME_RECV_CNT_LO 0x802e
|
|
-#define QCA8075_MMD7_EG_FRAME_ERR_CNT 0x802f
|
|
-#define QCA8075_MMD7_MDIO_BRDCST_WRITE 0x8028
|
|
-#define QCA8075_MMD7_MDIO_BRDCST_WRITE_EN BIT(15)
|
|
-#define QCA8075_MDIO_BRDCST_PHY_ADDR 0x1f
|
|
-#define QCA8075_PKT_GEN_PKTS_COUNT 4096
|
|
-
|
|
-enum {
|
|
- QCA8K_PORT_SPEED_10M = 0,
|
|
- QCA8K_PORT_SPEED_100M = 1,
|
|
- QCA8K_PORT_SPEED_1000M = 2,
|
|
- QCA8K_PORT_SPEED_ERR = 3,
|
|
-};
|
|
-
|
|
-enum qca8k_fdb_cmd {
|
|
- QCA8K_FDB_FLUSH = 1,
|
|
- QCA8K_FDB_LOAD = 2,
|
|
- QCA8K_FDB_PURGE = 3,
|
|
- QCA8K_FDB_NEXT = 6,
|
|
- QCA8K_FDB_SEARCH = 7,
|
|
-};
|
|
-
|
|
-enum qca8k_vlan_cmd {
|
|
- QCA8K_VLAN_FLUSH = 1,
|
|
- QCA8K_VLAN_LOAD = 2,
|
|
- QCA8K_VLAN_PURGE = 3,
|
|
- QCA8K_VLAN_REMOVE_PORT = 4,
|
|
- QCA8K_VLAN_NEXT = 5,
|
|
- QCA8K_VLAN_READ = 6,
|
|
-};
|
|
-
|
|
-struct ar8xxx_port_status {
|
|
- int enabled;
|
|
-};
|
|
-
|
|
-struct qca8k_priv {
|
|
- struct regmap *regmap;
|
|
- struct mii_bus *bus;
|
|
- struct ar8xxx_port_status port_sts[QCA8K_NUM_PORTS];
|
|
- struct dsa_switch *ds;
|
|
- struct mutex reg_mutex;
|
|
- struct device *dev;
|
|
- struct dsa_switch_ops ops;
|
|
- unsigned int port_mtu[QCA8K_NUM_PORTS];
|
|
-
|
|
- /* IPQ4019 specific */
|
|
- struct regmap *psgmii;
|
|
- bool psgmii_calibrated;
|
|
- struct phy_device *psgmii_ethphy;
|
|
-};
|
|
-
|
|
-struct qca8k_mib_desc {
|
|
- unsigned int size;
|
|
- unsigned int offset;
|
|
- const char *name;
|
|
-};
|
|
-
|
|
-struct qca8k_fdb {
|
|
- u16 vid;
|
|
- u8 port_mask;
|
|
- u8 aging;
|
|
- u8 mac[6];
|
|
-};
|
|
-
|
|
-#endif /* __QCA8K_H */
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/Makefile b/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/Makefile
|
|
deleted file mode 100644
|
|
index 4f2db7283e..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/Makefile
|
|
+++ /dev/null
|
|
@@ -1,8 +0,0 @@
|
|
-# SPDX-License-Identifier: GPL-2.0-only
|
|
-#
|
|
-# Makefile for the IPQ ESS driver
|
|
-#
|
|
-
|
|
-obj-$(CONFIG_QCOM_IPQ4019_ESS_EDMA) += ipq_ess.o
|
|
-
|
|
-ipq_ess-objs := ipqess.o ipqess_ethtool.o
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.c b/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.c
|
|
deleted file mode 100644
|
|
index ee33bb0166..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.c
|
|
+++ /dev/null
|
|
@@ -1,1336 +0,0 @@
|
|
-// SPDX-License-Identifier: (GPL-2.0 OR ISC)
|
|
-/* Copyright (c) 2014 - 2017, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017 - 2018, John Crispin <john@phrozen.org>
|
|
- * Copyright (c) 2018 - 2019, Christian Lamparter <chunkeey@gmail.com>
|
|
- * Copyright (c) 2020 - 2021, Gabor Juhos <j4g8y7@gmail.com>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for
|
|
- * any purpose with or without fee is hereby granted, provided that the
|
|
- * above copyright notice and this permission notice appear in all copies.
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
|
|
- * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- */
|
|
-
|
|
-#include <linux/bitfield.h>
|
|
-#include <linux/clk.h>
|
|
-#include <linux/dsa/ipq4019.h>
|
|
-#include <linux/if_vlan.h>
|
|
-#include <linux/interrupt.h>
|
|
-#include <linux/module.h>
|
|
-#include <linux/of.h>
|
|
-#include <linux/of_device.h>
|
|
-#include <linux/of_mdio.h>
|
|
-#include <linux/of_net.h>
|
|
-#include <linux/phylink.h>
|
|
-#include <linux/platform_device.h>
|
|
-#include <linux/reset.h>
|
|
-#include <linux/skbuff.h>
|
|
-#include <linux/vmalloc.h>
|
|
-#include <net/checksum.h>
|
|
-#include <net/dsa.h>
|
|
-#include <net/ip6_checksum.h>
|
|
-
|
|
-#include "ipqess.h"
|
|
-
|
|
-#define IPQESS_RRD_SIZE 16
|
|
-#define IPQESS_NEXT_IDX(X, Y) (((X) + 1) & ((Y) - 1))
|
|
-#define IPQESS_TX_DMA_BUF_LEN 0x3fff
|
|
-
|
|
-static void ipqess_w32(struct ipqess *ess, u32 reg, u32 val)
|
|
-{
|
|
- writel(val, ess->hw_addr + reg);
|
|
-}
|
|
-
|
|
-static u32 ipqess_r32(struct ipqess *ess, u16 reg)
|
|
-{
|
|
- return readl(ess->hw_addr + reg);
|
|
-}
|
|
-
|
|
-static void ipqess_m32(struct ipqess *ess, u32 mask, u32 val, u16 reg)
|
|
-{
|
|
- u32 _val = ipqess_r32(ess, reg);
|
|
- _val &= ~mask;
|
|
- _val |= val;
|
|
- ipqess_w32(ess, reg, _val);
|
|
-}
|
|
-
|
|
-void ipqess_update_hw_stats(struct ipqess *ess)
|
|
-{
|
|
- uint32_t *p;
|
|
- u32 stat;
|
|
- int i;
|
|
-
|
|
- lockdep_assert_held(&ess->stats_lock);
|
|
-
|
|
- p = (uint32_t *)&(ess->ipqessstats);
|
|
- for (i = 0; i < IPQESS_MAX_TX_QUEUE; i++) {
|
|
- stat = ipqess_r32(ess, IPQESS_REG_TX_STAT_PKT_Q(i));
|
|
- *p += stat;
|
|
- p++;
|
|
- }
|
|
-
|
|
- for (i = 0; i < IPQESS_MAX_TX_QUEUE; i++) {
|
|
- stat = ipqess_r32(ess, IPQESS_REG_TX_STAT_BYTE_Q(i));
|
|
- *p += stat;
|
|
- p++;
|
|
- }
|
|
-
|
|
- for (i = 0; i < IPQESS_MAX_RX_QUEUE; i++) {
|
|
- stat = ipqess_r32(ess, IPQESS_REG_RX_STAT_PKT_Q(i));
|
|
- *p += stat;
|
|
- p++;
|
|
- }
|
|
-
|
|
- for (i = 0; i < IPQESS_MAX_RX_QUEUE; i++) {
|
|
- stat = ipqess_r32(ess, IPQESS_REG_RX_STAT_BYTE_Q(i));
|
|
- *p += stat;
|
|
- p++;
|
|
- }
|
|
-}
|
|
-
|
|
-static int ipqess_tx_ring_alloc(struct ipqess *ess)
|
|
-{
|
|
- struct device *dev = &ess->pdev->dev;
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- struct ipqess_tx_ring *tx_ring = &ess->tx_ring[i];
|
|
- size_t size;
|
|
- u32 idx;
|
|
-
|
|
- tx_ring->ess = ess;
|
|
- tx_ring->ring_id = i;
|
|
- tx_ring->idx = i * 4;
|
|
- tx_ring->count = IPQESS_TX_RING_SIZE;
|
|
- tx_ring->nq = netdev_get_tx_queue(ess->netdev, i);
|
|
-
|
|
- size = sizeof(struct ipqess_buf) * IPQESS_TX_RING_SIZE;
|
|
- tx_ring->buf = devm_kzalloc(dev, size, GFP_KERNEL);
|
|
- if (!tx_ring->buf) {
|
|
- netdev_err(ess->netdev, "buffer alloc of tx ring failed");
|
|
- return -ENOMEM;
|
|
- }
|
|
-
|
|
- size = sizeof(struct ipqess_tx_desc) * IPQESS_TX_RING_SIZE;
|
|
- tx_ring->hw_desc = dmam_alloc_coherent(dev, size, &tx_ring->dma,
|
|
- GFP_KERNEL | __GFP_ZERO);
|
|
- if (!tx_ring->hw_desc) {
|
|
- netdev_err(ess->netdev, "descriptor allocation for tx ring failed");
|
|
- return -ENOMEM;
|
|
- }
|
|
-
|
|
- ipqess_w32(ess, IPQESS_REG_TPD_BASE_ADDR_Q(tx_ring->idx),
|
|
- (u32)tx_ring->dma);
|
|
-
|
|
- idx = ipqess_r32(ess, IPQESS_REG_TPD_IDX_Q(tx_ring->idx));
|
|
- idx >>= IPQESS_TPD_CONS_IDX_SHIFT; /* need u32 here */
|
|
- idx &= 0xffff;
|
|
- tx_ring->head = tx_ring->tail = idx;
|
|
-
|
|
- ipqess_m32(ess, IPQESS_TPD_PROD_IDX_MASK << IPQESS_TPD_PROD_IDX_SHIFT,
|
|
- idx, IPQESS_REG_TPD_IDX_Q(tx_ring->idx));
|
|
- ipqess_w32(ess, IPQESS_REG_TX_SW_CONS_IDX_Q(tx_ring->idx), idx);
|
|
- ipqess_w32(ess, IPQESS_REG_TPD_RING_SIZE, IPQESS_TX_RING_SIZE);
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int ipqess_tx_unmap_and_free(struct device *dev, struct ipqess_buf *buf)
|
|
-{
|
|
- int len = 0;
|
|
-
|
|
- if (buf->flags & IPQESS_DESC_SINGLE)
|
|
- dma_unmap_single(dev, buf->dma, buf->length, DMA_TO_DEVICE);
|
|
- else if (buf->flags & IPQESS_DESC_PAGE)
|
|
- dma_unmap_page(dev, buf->dma, buf->length, DMA_TO_DEVICE);
|
|
-
|
|
- if (buf->flags & IPQESS_DESC_LAST) {
|
|
- len = buf->skb->len;
|
|
- dev_kfree_skb_any(buf->skb);
|
|
- }
|
|
-
|
|
- buf->flags = 0;
|
|
-
|
|
- return len;
|
|
-}
|
|
-
|
|
-static void ipqess_tx_ring_free(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- int j;
|
|
-
|
|
- if (ess->tx_ring[i].hw_desc)
|
|
- continue;
|
|
-
|
|
- for (j = 0; j < IPQESS_TX_RING_SIZE; j++) {
|
|
- struct ipqess_buf *buf = &ess->tx_ring[i].buf[j];
|
|
-
|
|
- ipqess_tx_unmap_and_free(&ess->pdev->dev, buf);
|
|
- }
|
|
-
|
|
- ess->tx_ring[i].buf = NULL;
|
|
- }
|
|
-}
|
|
-
|
|
-static int ipqess_rx_buf_prepare(struct ipqess_buf *buf,
|
|
- struct ipqess_rx_ring *rx_ring)
|
|
-{
|
|
- /* Clean the HW DESC header, otherwise we might end up
|
|
- * with a spurious desc because of random garbage */
|
|
- memset(buf->skb->data, 0, sizeof(struct ipqess_rx_desc));
|
|
-
|
|
- buf->dma = dma_map_single(rx_ring->ppdev, buf->skb->data,
|
|
- IPQESS_RX_HEAD_BUFF_SIZE, DMA_FROM_DEVICE);
|
|
- if (dma_mapping_error(rx_ring->ppdev, buf->dma)) {
|
|
- dev_err_once(rx_ring->ppdev,
|
|
- "IPQESS DMA mapping failed for linear address %x",
|
|
- buf->dma);
|
|
- dev_kfree_skb_any(buf->skb);
|
|
- buf->skb = NULL;
|
|
- return -EFAULT;
|
|
- }
|
|
-
|
|
- buf->length = IPQESS_RX_HEAD_BUFF_SIZE;
|
|
- rx_ring->hw_desc[rx_ring->head] = (struct ipqess_rx_desc *)buf->dma;
|
|
- rx_ring->head = (rx_ring->head + 1) % IPQESS_RX_RING_SIZE;
|
|
-
|
|
- ipqess_m32(rx_ring->ess, IPQESS_RFD_PROD_IDX_BITS,
|
|
- (rx_ring->head + IPQESS_RX_RING_SIZE - 1) % IPQESS_RX_RING_SIZE,
|
|
- IPQESS_REG_RFD_IDX_Q(rx_ring->idx));
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-/* locking is handled by the caller */
|
|
-static int ipqess_rx_buf_alloc_napi(struct ipqess_rx_ring *rx_ring)
|
|
-{
|
|
- struct ipqess_buf *buf = &rx_ring->buf[rx_ring->head];
|
|
-
|
|
- buf->skb = napi_alloc_skb(&rx_ring->napi_rx,
|
|
- IPQESS_RX_HEAD_BUFF_SIZE);
|
|
- if (!buf->skb)
|
|
- return -ENOMEM;
|
|
-
|
|
- return ipqess_rx_buf_prepare(buf, rx_ring);
|
|
-}
|
|
-
|
|
-static int ipqess_rx_buf_alloc(struct ipqess_rx_ring *rx_ring)
|
|
-{
|
|
- struct ipqess_buf *buf = &rx_ring->buf[rx_ring->head];
|
|
-
|
|
- buf->skb = netdev_alloc_skb_ip_align(rx_ring->ess->netdev,
|
|
- IPQESS_RX_HEAD_BUFF_SIZE);
|
|
- if (!buf->skb)
|
|
- return -ENOMEM;
|
|
-
|
|
- return ipqess_rx_buf_prepare(buf, rx_ring);
|
|
-}
|
|
-
|
|
-static void ipqess_refill_work(struct work_struct *work)
|
|
-{
|
|
- struct ipqess_rx_ring_refill *rx_refill = container_of(work,
|
|
- struct ipqess_rx_ring_refill, refill_work);
|
|
- struct ipqess_rx_ring *rx_ring = rx_refill->rx_ring;
|
|
- int refill = 0;
|
|
-
|
|
- /* don't let this loop by accident. */
|
|
- while (atomic_dec_and_test(&rx_ring->refill_count)) {
|
|
- napi_disable(&rx_ring->napi_rx);
|
|
- if (ipqess_rx_buf_alloc(rx_ring)) {
|
|
- refill++;
|
|
- dev_dbg(rx_ring->ppdev,
|
|
- "Not all buffers were reallocated");
|
|
- }
|
|
- napi_enable(&rx_ring->napi_rx);
|
|
- }
|
|
-
|
|
- if (atomic_add_return(refill, &rx_ring->refill_count))
|
|
- schedule_work(&rx_refill->refill_work);
|
|
-}
|
|
-
|
|
-
|
|
-static int ipqess_rx_ring_alloc(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- int j;
|
|
-
|
|
- ess->rx_ring[i].ess = ess;
|
|
- ess->rx_ring[i].ppdev = &ess->pdev->dev;
|
|
- ess->rx_ring[i].ring_id = i;
|
|
- ess->rx_ring[i].idx = i * 2;
|
|
-
|
|
- ess->rx_ring[i].buf = devm_kzalloc(&ess->pdev->dev,
|
|
- sizeof(struct ipqess_buf) * IPQESS_RX_RING_SIZE,
|
|
- GFP_KERNEL);
|
|
- if (!ess->rx_ring[i].buf)
|
|
- return -ENOMEM;
|
|
-
|
|
- ess->rx_ring[i].hw_desc = dmam_alloc_coherent(&ess->pdev->dev,
|
|
- sizeof(struct ipqess_rx_desc) * IPQESS_RX_RING_SIZE,
|
|
- &ess->rx_ring[i].dma, GFP_KERNEL);
|
|
- if (!ess->rx_ring[i].hw_desc)
|
|
- return -ENOMEM;
|
|
-
|
|
- for (j = 0; j < IPQESS_RX_RING_SIZE; j++)
|
|
- if (ipqess_rx_buf_alloc(&ess->rx_ring[i]) < 0)
|
|
- return -ENOMEM;
|
|
-
|
|
- ess->rx_refill[i].rx_ring = &ess->rx_ring[i];
|
|
- INIT_WORK(&ess->rx_refill[i].refill_work, ipqess_refill_work);
|
|
-
|
|
- ipqess_w32(ess, IPQESS_REG_RFD_BASE_ADDR_Q(ess->rx_ring[i].idx),
|
|
- (u32)(ess->rx_ring[i].dma));
|
|
- }
|
|
-
|
|
- ipqess_w32(ess, IPQESS_REG_RX_DESC0,
|
|
- (IPQESS_RX_HEAD_BUFF_SIZE << IPQESS_RX_BUF_SIZE_SHIFT) |
|
|
- (IPQESS_RX_RING_SIZE << IPQESS_RFD_RING_SIZE_SHIFT));
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void ipqess_rx_ring_free(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- int j;
|
|
-
|
|
- atomic_set(&ess->rx_ring[i].refill_count, 0);
|
|
- cancel_work_sync(&ess->rx_refill[i].refill_work);
|
|
-
|
|
- for (j = 0; j < IPQESS_RX_RING_SIZE; j++) {
|
|
- dma_unmap_single(&ess->pdev->dev,
|
|
- ess->rx_ring[i].buf[j].dma,
|
|
- ess->rx_ring[i].buf[j].length,
|
|
- DMA_FROM_DEVICE);
|
|
- dev_kfree_skb_any(ess->rx_ring[i].buf[j].skb);
|
|
- }
|
|
- }
|
|
-}
|
|
-
|
|
-static struct net_device_stats *ipqess_get_stats(struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- spin_lock(&ess->stats_lock);
|
|
- ipqess_update_hw_stats(ess);
|
|
- spin_unlock(&ess->stats_lock);
|
|
-
|
|
- return &ess->stats;
|
|
-}
|
|
-
|
|
-static int ipqess_rx_poll(struct ipqess_rx_ring *rx_ring, int budget)
|
|
-{
|
|
- u32 length = 0, num_desc, tail, rx_ring_tail;
|
|
- int done = 0;
|
|
-
|
|
- rx_ring_tail = rx_ring->tail;
|
|
-
|
|
- tail = ipqess_r32(rx_ring->ess, IPQESS_REG_RFD_IDX_Q(rx_ring->idx));
|
|
- tail >>= IPQESS_RFD_CONS_IDX_SHIFT;
|
|
- tail &= IPQESS_RFD_CONS_IDX_MASK;
|
|
-
|
|
- while (done < budget) {
|
|
- struct sk_buff *skb;
|
|
- struct ipqess_rx_desc *rd;
|
|
-
|
|
- if (rx_ring_tail == tail)
|
|
- break;
|
|
-
|
|
- dma_unmap_single(rx_ring->ppdev,
|
|
- rx_ring->buf[rx_ring_tail].dma,
|
|
- rx_ring->buf[rx_ring_tail].length,
|
|
- DMA_FROM_DEVICE);
|
|
-
|
|
- skb = xchg(&rx_ring->buf[rx_ring_tail].skb, NULL);
|
|
- rd = (struct ipqess_rx_desc *)skb->data;
|
|
- rx_ring_tail = IPQESS_NEXT_IDX(rx_ring_tail, IPQESS_RX_RING_SIZE);
|
|
-
|
|
- /* Check if RRD is valid */
|
|
- if (!(rd->rrd7 & IPQESS_RRD_DESC_VALID)) {
|
|
- num_desc = 1;
|
|
- dev_kfree_skb_any(skb);
|
|
- goto skip;
|
|
- }
|
|
-
|
|
- num_desc = rd->rrd1 & IPQESS_RRD_NUM_RFD_MASK;
|
|
- length = rd->rrd6 & IPQESS_RRD_PKT_SIZE_MASK;
|
|
-
|
|
- skb_reserve(skb, IPQESS_RRD_SIZE);
|
|
- if (num_desc > 1) {
|
|
- /* can we use build_skb here ? */
|
|
- struct sk_buff *skb_prev = NULL;
|
|
- int size_remaining;
|
|
- int i;
|
|
-
|
|
- skb->data_len = 0;
|
|
- skb->tail += (IPQESS_RX_HEAD_BUFF_SIZE - IPQESS_RRD_SIZE);
|
|
- skb->len = skb->truesize = length;
|
|
- size_remaining = length - (IPQESS_RX_HEAD_BUFF_SIZE - IPQESS_RRD_SIZE);
|
|
-
|
|
- for (i = 1; i < num_desc; i++) {
|
|
- /* TODO: use build_skb ? */
|
|
- struct sk_buff *skb_temp = rx_ring->buf[rx_ring_tail].skb;
|
|
-
|
|
- dma_unmap_single(rx_ring->ppdev,
|
|
- rx_ring->buf[rx_ring_tail].dma,
|
|
- rx_ring->buf[rx_ring_tail].length,
|
|
- DMA_FROM_DEVICE);
|
|
-
|
|
- skb_put(skb_temp, min(size_remaining, IPQESS_RX_HEAD_BUFF_SIZE));
|
|
- if (skb_prev)
|
|
- skb_prev->next = rx_ring->buf[rx_ring_tail].skb;
|
|
- else
|
|
- skb_shinfo(skb)->frag_list = rx_ring->buf[rx_ring_tail].skb;
|
|
- skb_prev = rx_ring->buf[rx_ring_tail].skb;
|
|
- rx_ring->buf[rx_ring_tail].skb->next = NULL;
|
|
-
|
|
- skb->data_len += rx_ring->buf[rx_ring_tail].skb->len;
|
|
- size_remaining -= rx_ring->buf[rx_ring_tail].skb->len;
|
|
-
|
|
- rx_ring_tail = IPQESS_NEXT_IDX(rx_ring_tail, IPQESS_RX_RING_SIZE);
|
|
- }
|
|
-
|
|
- } else {
|
|
- skb_put(skb, length);
|
|
- }
|
|
-
|
|
- skb->dev = rx_ring->ess->netdev;
|
|
- skb->protocol = eth_type_trans(skb, rx_ring->ess->netdev);
|
|
- skb_record_rx_queue(skb, rx_ring->ring_id);
|
|
-
|
|
- if (rd->rrd6 & IPQESS_RRD_CSUM_FAIL_MASK)
|
|
- skb_checksum_none_assert(skb);
|
|
- else
|
|
- skb->ip_summed = CHECKSUM_UNNECESSARY;
|
|
-
|
|
- if (rd->rrd7 & IPQESS_RRD_CVLAN) {
|
|
- __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rd->rrd4);
|
|
- } else if (rd->rrd1 & IPQESS_RRD_SVLAN) {
|
|
- __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021AD), rd->rrd4);
|
|
- }
|
|
- napi_gro_receive(&rx_ring->napi_rx, skb);
|
|
-
|
|
- /* TODO: do we need to have these here ? */
|
|
- rx_ring->ess->stats.rx_packets++;
|
|
- rx_ring->ess->stats.rx_bytes += length;
|
|
-
|
|
- done++;
|
|
-skip:
|
|
-
|
|
- num_desc += atomic_xchg(&rx_ring->refill_count, 0);
|
|
- while (num_desc) {
|
|
- if (ipqess_rx_buf_alloc_napi(rx_ring)) {
|
|
- num_desc = atomic_add_return(num_desc,
|
|
- &rx_ring->refill_count);
|
|
- if (num_desc >= ((4 * IPQESS_RX_RING_SIZE + 6) / 7))
|
|
- schedule_work(&rx_ring->ess->rx_refill[rx_ring->ring_id].refill_work);
|
|
- break;
|
|
- }
|
|
- num_desc--;
|
|
- }
|
|
- }
|
|
-
|
|
- ipqess_w32(rx_ring->ess, IPQESS_REG_RX_SW_CONS_IDX_Q(rx_ring->idx),
|
|
- rx_ring_tail);
|
|
- rx_ring->tail = rx_ring_tail;
|
|
-
|
|
- return done;
|
|
-}
|
|
-
|
|
-static int ipqess_tx_complete(struct ipqess_tx_ring *tx_ring, int budget)
|
|
-{
|
|
- u32 tail;
|
|
- int done = 0;
|
|
- int total = 0, ret;
|
|
-
|
|
- tail = ipqess_r32(tx_ring->ess, IPQESS_REG_TPD_IDX_Q(tx_ring->idx));
|
|
- tail >>= IPQESS_TPD_CONS_IDX_SHIFT;
|
|
- tail &= IPQESS_TPD_CONS_IDX_MASK;
|
|
-
|
|
- while ((tx_ring->tail != tail) && (done < budget)) {
|
|
- //pr_info("freeing txq:%d tail:%d tailbuf:%p\n", tx_ring->idx, tx_ring->tail, &tx_ring->buf[tx_ring->tail]);
|
|
- ret = ipqess_tx_unmap_and_free(&tx_ring->ess->pdev->dev,
|
|
- &tx_ring->buf[tx_ring->tail]);
|
|
- tx_ring->tail = IPQESS_NEXT_IDX(tx_ring->tail, tx_ring->count);
|
|
- if (ret) {
|
|
- total += ret;
|
|
- done++;
|
|
- }
|
|
- }
|
|
-
|
|
- ipqess_w32(tx_ring->ess,
|
|
- IPQESS_REG_TX_SW_CONS_IDX_Q(tx_ring->idx),
|
|
- tx_ring->tail);
|
|
-
|
|
- if (netif_tx_queue_stopped(tx_ring->nq)) {
|
|
- netdev_dbg(tx_ring->ess->netdev, "waking up tx queue %d\n",
|
|
- tx_ring->idx);
|
|
- netif_tx_wake_queue(tx_ring->nq);
|
|
- }
|
|
-
|
|
- netdev_tx_completed_queue(tx_ring->nq, done, total);
|
|
-
|
|
- return done;
|
|
-}
|
|
-
|
|
-static int ipqess_tx_napi(struct napi_struct *napi, int budget)
|
|
-{
|
|
- struct ipqess_tx_ring *tx_ring = container_of(napi, struct ipqess_tx_ring,
|
|
- napi_tx);
|
|
- u32 tx_status;
|
|
- int work_done = 0;
|
|
-
|
|
- tx_status = ipqess_r32(tx_ring->ess, IPQESS_REG_TX_ISR);
|
|
- tx_status &= BIT(tx_ring->idx);
|
|
-
|
|
- work_done = ipqess_tx_complete(tx_ring, budget);
|
|
-
|
|
- ipqess_w32(tx_ring->ess, IPQESS_REG_TX_ISR, tx_status);
|
|
-
|
|
- if (likely(work_done < budget)) {
|
|
- if (napi_complete_done(napi, work_done))
|
|
- ipqess_w32(tx_ring->ess,
|
|
- IPQESS_REG_TX_INT_MASK_Q(tx_ring->idx), 0x1);
|
|
- }
|
|
-
|
|
- return work_done;
|
|
-}
|
|
-
|
|
-static int ipqess_rx_napi(struct napi_struct *napi, int budget)
|
|
-{
|
|
- struct ipqess_rx_ring *rx_ring = container_of(napi, struct ipqess_rx_ring,
|
|
- napi_rx);
|
|
- struct ipqess *ess = rx_ring->ess;
|
|
- int remain_budget = budget;
|
|
- int rx_done;
|
|
- u32 rx_mask = BIT(rx_ring->idx);
|
|
- u32 status;
|
|
-
|
|
-poll_again:
|
|
- ipqess_w32(ess, IPQESS_REG_RX_ISR, rx_mask);
|
|
- rx_done = ipqess_rx_poll(rx_ring, remain_budget);
|
|
-
|
|
- if (rx_done == remain_budget)
|
|
- return budget;
|
|
-
|
|
- status = ipqess_r32(ess, IPQESS_REG_RX_ISR);
|
|
- if (status & rx_mask) {
|
|
- remain_budget -= rx_done;
|
|
- goto poll_again;
|
|
- }
|
|
-
|
|
- if (napi_complete_done(napi, rx_done + budget - remain_budget))
|
|
- ipqess_w32(ess, IPQESS_REG_RX_INT_MASK_Q(rx_ring->idx), 0x1);
|
|
-
|
|
- return rx_done + budget - remain_budget;
|
|
-}
|
|
-
|
|
-static irqreturn_t ipqess_interrupt_tx(int irq, void *priv)
|
|
-{
|
|
- struct ipqess_tx_ring *tx_ring = (struct ipqess_tx_ring *) priv;
|
|
-
|
|
- if (likely(napi_schedule_prep(&tx_ring->napi_tx))) {
|
|
- ipqess_w32(tx_ring->ess,
|
|
- IPQESS_REG_TX_INT_MASK_Q(tx_ring->idx),
|
|
- 0x0);
|
|
- __napi_schedule(&tx_ring->napi_tx);
|
|
- }
|
|
-
|
|
- return IRQ_HANDLED;
|
|
-}
|
|
-
|
|
-static irqreturn_t ipqess_interrupt_rx(int irq, void *priv)
|
|
-{
|
|
- struct ipqess_rx_ring *rx_ring = (struct ipqess_rx_ring *) priv;
|
|
-
|
|
- if (likely(napi_schedule_prep(&rx_ring->napi_rx))) {
|
|
- ipqess_w32(rx_ring->ess,
|
|
- IPQESS_REG_RX_INT_MASK_Q(rx_ring->idx),
|
|
- 0x0);
|
|
- __napi_schedule(&rx_ring->napi_rx);
|
|
- }
|
|
-
|
|
- return IRQ_HANDLED;
|
|
-}
|
|
-
|
|
-static void ipqess_irq_enable(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- ipqess_w32(ess, IPQESS_REG_RX_ISR, 0xff);
|
|
- ipqess_w32(ess, IPQESS_REG_TX_ISR, 0xffff);
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- ipqess_w32(ess, IPQESS_REG_RX_INT_MASK_Q(ess->rx_ring[i].idx), 1);
|
|
- ipqess_w32(ess, IPQESS_REG_TX_INT_MASK_Q(ess->tx_ring[i].idx), 1);
|
|
- }
|
|
-}
|
|
-
|
|
-static void ipqess_irq_disable(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- ipqess_w32(ess, IPQESS_REG_RX_INT_MASK_Q(ess->rx_ring[i].idx), 0);
|
|
- ipqess_w32(ess, IPQESS_REG_TX_INT_MASK_Q(ess->tx_ring[i].idx), 0);
|
|
- }
|
|
-}
|
|
-
|
|
-static int __init ipqess_init(struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- struct device_node *of_node = ess->pdev->dev.of_node;
|
|
- return phylink_of_phy_connect(ess->phylink, of_node, 0);
|
|
-}
|
|
-
|
|
-static void ipqess_uninit(struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- phylink_disconnect_phy(ess->phylink);
|
|
-}
|
|
-
|
|
-static int ipqess_open(struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- int i;
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- napi_enable(&ess->tx_ring[i].napi_tx);
|
|
- napi_enable(&ess->rx_ring[i].napi_rx);
|
|
- }
|
|
- ipqess_irq_enable(ess);
|
|
- phylink_start(ess->phylink);
|
|
- netif_tx_start_all_queues(netdev);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int ipqess_stop(struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- int i;
|
|
-
|
|
- netif_tx_stop_all_queues(netdev);
|
|
- phylink_stop(ess->phylink);
|
|
- ipqess_irq_disable(ess);
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- napi_disable(&ess->tx_ring[i].napi_tx);
|
|
- napi_disable(&ess->rx_ring[i].napi_rx);
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int ipqess_do_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- switch (cmd) {
|
|
- case SIOCGMIIPHY:
|
|
- case SIOCGMIIREG:
|
|
- case SIOCSMIIREG:
|
|
- return phylink_mii_ioctl(ess->phylink, ifr, cmd);
|
|
- default:
|
|
- break;
|
|
- }
|
|
-
|
|
- return -EOPNOTSUPP;
|
|
-}
|
|
-
|
|
-
|
|
-static inline u16 ipqess_tx_desc_available(struct ipqess_tx_ring *tx_ring)
|
|
-{
|
|
- u16 count = 0;
|
|
-
|
|
- if (tx_ring->tail <= tx_ring->head)
|
|
- count = IPQESS_TX_RING_SIZE;
|
|
-
|
|
- count += tx_ring->tail - tx_ring->head - 1;
|
|
-
|
|
- return count;
|
|
-}
|
|
-
|
|
-static inline int ipqess_cal_txd_req(struct sk_buff *skb)
|
|
-{
|
|
- int tpds;
|
|
-
|
|
- /* one TPD for the header, and one for each fragments */
|
|
- tpds = 1 + skb_shinfo(skb)->nr_frags;
|
|
- if (skb_is_gso(skb) && skb_is_gso_v6(skb)) {
|
|
- /* for LSOv2 one extra TPD is needed */
|
|
- tpds++;
|
|
- }
|
|
-
|
|
- return tpds;
|
|
-}
|
|
-
|
|
-static struct ipqess_buf *ipqess_get_tx_buffer(struct ipqess_tx_ring *tx_ring,
|
|
- struct ipqess_tx_desc *desc)
|
|
-{
|
|
- return &tx_ring->buf[desc - tx_ring->hw_desc];
|
|
-}
|
|
-
|
|
-static struct ipqess_tx_desc *ipqess_tx_desc_next(struct ipqess_tx_ring *tx_ring)
|
|
-{
|
|
- struct ipqess_tx_desc *desc;
|
|
-
|
|
- desc = &tx_ring->hw_desc[tx_ring->head];
|
|
- tx_ring->head = IPQESS_NEXT_IDX(tx_ring->head, tx_ring->count);
|
|
-
|
|
- return desc;
|
|
-}
|
|
-
|
|
-static void ipqess_rollback_tx(struct ipqess *eth,
|
|
- struct ipqess_tx_desc *first_desc, int ring_id)
|
|
-{
|
|
- struct ipqess_tx_ring *tx_ring = ð->tx_ring[ring_id];
|
|
- struct ipqess_buf *buf;
|
|
- struct ipqess_tx_desc *desc = NULL;
|
|
- u16 start_index, index;
|
|
-
|
|
- start_index = first_desc - tx_ring->hw_desc;
|
|
-
|
|
- index = start_index;
|
|
- while (index != tx_ring->head) {
|
|
- desc = &tx_ring->hw_desc[index];
|
|
- buf = &tx_ring->buf[index];
|
|
- ipqess_tx_unmap_and_free(ð->pdev->dev, buf);
|
|
- memset(desc, 0, sizeof(struct ipqess_tx_desc));
|
|
- if (++index == tx_ring->count)
|
|
- index = 0;
|
|
- }
|
|
- tx_ring->head = start_index;
|
|
-}
|
|
-
|
|
-static bool ipqess_process_dsa_tag_sh(struct sk_buff *skb, u32 *word3)
|
|
-{
|
|
- struct skb_shared_info *shinfo = skb_shinfo(skb);
|
|
- struct ipq40xx_dsa_tag_data *tag_data;
|
|
-
|
|
- if (shinfo->dsa_tag_proto != DSA_TAG_PROTO_IPQ4019)
|
|
- return false;
|
|
-
|
|
- tag_data = (struct ipq40xx_dsa_tag_data *)shinfo->dsa_tag_data;
|
|
-
|
|
- pr_debug("SH tag @ %08x, dp:%02x from_cpu:%u\n",
|
|
- (u32)tag_data, tag_data->dp, tag_data->from_cpu);
|
|
-
|
|
- *word3 |= tag_data->dp << IPQESS_TPD_PORT_BITMAP_SHIFT;
|
|
- if (tag_data->from_cpu)
|
|
- *word3 |= BIT(IPQESS_TPD_FROM_CPU_SHIFT);
|
|
-
|
|
- return true;
|
|
-}
|
|
-
|
|
-static void ipqess_get_dp_info(struct ipqess *ess, struct sk_buff *skb,
|
|
- u32 *word3)
|
|
-{
|
|
- if (netdev_uses_dsa(ess->netdev)) {
|
|
-
|
|
- if (ipqess_process_dsa_tag_sh(skb, word3))
|
|
- return;
|
|
- }
|
|
-
|
|
- *word3 |= 0x3e << IPQESS_TPD_PORT_BITMAP_SHIFT;
|
|
-}
|
|
-
|
|
-static int ipqess_tx_map_and_fill(struct ipqess_tx_ring *tx_ring, struct sk_buff *skb)
|
|
-{
|
|
- struct ipqess_buf *buf = NULL;
|
|
- struct platform_device *pdev = tx_ring->ess->pdev;
|
|
- struct ipqess_tx_desc *desc = NULL, *first_desc = NULL;
|
|
- u32 word1 = 0, word3 = 0, lso_word1 = 0, svlan_tag = 0;
|
|
- u16 len;
|
|
- int i;
|
|
-
|
|
- ipqess_get_dp_info(tx_ring->ess, skb, &word3);
|
|
-
|
|
- if (skb_is_gso(skb)) {
|
|
- if (skb_shinfo(skb)->gso_type & SKB_GSO_TCPV4) {
|
|
- lso_word1 |= IPQESS_TPD_IPV4_EN;
|
|
- ip_hdr(skb)->check = 0;
|
|
- tcp_hdr(skb)->check = ~csum_tcpudp_magic(ip_hdr(skb)->saddr,
|
|
- ip_hdr(skb)->daddr, 0, IPPROTO_TCP, 0);
|
|
- } else if (skb_shinfo(skb)->gso_type & SKB_GSO_TCPV6) {
|
|
- lso_word1 |= IPQESS_TPD_LSO_V2_EN;
|
|
- ipv6_hdr(skb)->payload_len = 0;
|
|
- tcp_hdr(skb)->check = ~csum_ipv6_magic(&ipv6_hdr(skb)->saddr,
|
|
- &ipv6_hdr(skb)->daddr, 0, IPPROTO_TCP, 0);
|
|
- }
|
|
-
|
|
- lso_word1 |= IPQESS_TPD_LSO_EN |
|
|
- ((skb_shinfo(skb)->gso_size & IPQESS_TPD_MSS_MASK) << IPQESS_TPD_MSS_SHIFT) |
|
|
- (skb_transport_offset(skb) << IPQESS_TPD_HDR_SHIFT);
|
|
- } else if (likely(skb->ip_summed == CHECKSUM_PARTIAL)) {
|
|
- u8 css, cso;
|
|
- cso = skb_checksum_start_offset(skb);
|
|
- css = cso + skb->csum_offset;
|
|
-
|
|
- word1 |= (IPQESS_TPD_CUSTOM_CSUM_EN);
|
|
- word1 |= (cso >> 1) << IPQESS_TPD_HDR_SHIFT;
|
|
- word1 |= ((css >> 1) << IPQESS_TPD_CUSTOM_CSUM_SHIFT);
|
|
- }
|
|
-
|
|
- if (skb_vlan_tag_present(skb)) {
|
|
- switch (skb->vlan_proto) {
|
|
- case htons(ETH_P_8021Q):
|
|
- word3 |= BIT(IPQESS_TX_INS_CVLAN);
|
|
- word3 |= skb_vlan_tag_get(skb) << IPQESS_TX_CVLAN_TAG_SHIFT;
|
|
- break;
|
|
- case htons(ETH_P_8021AD):
|
|
- word1 |= BIT(IPQESS_TX_INS_SVLAN);
|
|
- svlan_tag = skb_vlan_tag_get(skb);
|
|
- break;
|
|
- default:
|
|
- dev_err(&pdev->dev, "no ctag or stag present\n");
|
|
- goto vlan_tag_error;
|
|
- }
|
|
- }
|
|
-
|
|
- if (eth_type_vlan(skb->protocol))
|
|
- word1 |= IPQESS_TPD_VLAN_TAGGED;
|
|
-
|
|
- if (skb->protocol == htons(ETH_P_PPP_SES))
|
|
- word1 |= IPQESS_TPD_PPPOE_EN;
|
|
-
|
|
- len = skb_headlen(skb);
|
|
-
|
|
- first_desc = desc = ipqess_tx_desc_next(tx_ring);
|
|
- if (lso_word1 & IPQESS_TPD_LSO_V2_EN) {
|
|
- desc->addr = cpu_to_le16(skb->len);
|
|
- desc->word1 = word1 | lso_word1;
|
|
- desc->svlan_tag = svlan_tag;
|
|
- desc->word3 = word3;
|
|
- desc = ipqess_tx_desc_next(tx_ring);
|
|
- }
|
|
-
|
|
- buf = ipqess_get_tx_buffer(tx_ring, desc);
|
|
- buf->length = len;
|
|
- buf->dma = dma_map_single(&pdev->dev,
|
|
- skb->data, len, DMA_TO_DEVICE);
|
|
- if (dma_mapping_error(&pdev->dev, buf->dma))
|
|
- goto dma_error;
|
|
-
|
|
- desc->addr = cpu_to_le32(buf->dma);
|
|
- desc->len = cpu_to_le16(len);
|
|
-
|
|
- buf->flags |= IPQESS_DESC_SINGLE;
|
|
- desc->word1 = word1 | lso_word1;
|
|
- desc->svlan_tag = svlan_tag;
|
|
- desc->word3 = word3;
|
|
-
|
|
- for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) {
|
|
- skb_frag_t *frag = &skb_shinfo(skb)->frags[i];
|
|
- len = skb_frag_size(frag);
|
|
- desc = ipqess_tx_desc_next(tx_ring);
|
|
- buf = ipqess_get_tx_buffer(tx_ring, desc);
|
|
- buf->length = len;
|
|
- buf->flags |= IPQESS_DESC_PAGE;
|
|
- buf->dma = skb_frag_dma_map(&pdev->dev, frag, 0, len, DMA_TO_DEVICE);
|
|
- if (dma_mapping_error(&pdev->dev, buf->dma))
|
|
- goto dma_error;
|
|
-
|
|
- desc->addr = cpu_to_le32(buf->dma);
|
|
- desc->len = cpu_to_le16(len);
|
|
- desc->svlan_tag = svlan_tag;
|
|
- desc->word1 = word1 | lso_word1;
|
|
- desc->word3 = word3;
|
|
- }
|
|
- desc->word1 |= 1 << IPQESS_TPD_EOP_SHIFT;
|
|
- buf->skb = skb;
|
|
- buf->flags |= IPQESS_DESC_LAST;
|
|
-
|
|
- return 0;
|
|
-
|
|
-dma_error:
|
|
- ipqess_rollback_tx(tx_ring->ess, first_desc, tx_ring->ring_id);
|
|
- dev_err(&pdev->dev, "TX DMA map failed\n");
|
|
-
|
|
-vlan_tag_error:
|
|
- return -ENOMEM;
|
|
-}
|
|
-
|
|
-static inline void ipqess_kick_tx(struct ipqess_tx_ring *tx_ring)
|
|
-{
|
|
- /* Ensure that all TPDs has been written completely */
|
|
- dma_wmb();
|
|
-
|
|
- /* update software producer index */
|
|
- ipqess_w32(tx_ring->ess, IPQESS_REG_TPD_IDX_Q(tx_ring->idx),
|
|
- tx_ring->head);
|
|
-}
|
|
-
|
|
-static netdev_tx_t ipqess_xmit(struct sk_buff *skb,
|
|
- struct net_device *netdev)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- struct ipqess_tx_ring *tx_ring;
|
|
- int avail;
|
|
- int tx_num;
|
|
- int ret;
|
|
-
|
|
- tx_ring = &ess->tx_ring[skb_get_queue_mapping(skb)];
|
|
- tx_num = ipqess_cal_txd_req(skb);
|
|
- avail = ipqess_tx_desc_available(tx_ring);
|
|
- if (avail < tx_num) {
|
|
- netdev_dbg(netdev,
|
|
- "stopping tx queue %d, avail=%d req=%d im=%x\n",
|
|
- tx_ring->idx, avail, tx_num,
|
|
- ipqess_r32(tx_ring->ess,
|
|
- IPQESS_REG_TX_INT_MASK_Q(tx_ring->idx)));
|
|
- netif_tx_stop_queue(tx_ring->nq);
|
|
- ipqess_w32(tx_ring->ess, IPQESS_REG_TX_INT_MASK_Q(tx_ring->idx), 0x1);
|
|
- ipqess_kick_tx(tx_ring);
|
|
- return NETDEV_TX_BUSY;
|
|
- }
|
|
-
|
|
- ret = ipqess_tx_map_and_fill(tx_ring, skb);
|
|
- if (ret) {
|
|
- dev_kfree_skb_any(skb);
|
|
- ess->stats.tx_errors++;
|
|
- goto err_out;
|
|
- }
|
|
-
|
|
- ess->stats.tx_packets++;
|
|
- ess->stats.tx_bytes += skb->len;
|
|
- netdev_tx_sent_queue(tx_ring->nq, skb->len);
|
|
-
|
|
- if (!netdev_xmit_more() || netif_xmit_stopped(tx_ring->nq))
|
|
- ipqess_kick_tx(tx_ring);
|
|
-
|
|
-err_out:
|
|
- return NETDEV_TX_OK;
|
|
-}
|
|
-
|
|
-static int ipqess_set_mac_address(struct net_device *netdev, void *p)
|
|
-{
|
|
- int ret = eth_mac_addr(netdev, p);
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- const char *macaddr = netdev->dev_addr;
|
|
-
|
|
- if (ret)
|
|
- return ret;
|
|
-
|
|
-// spin_lock_bh(&mac->hw->page_lock);
|
|
- ipqess_w32(ess, IPQESS_REG_MAC_CTRL1,
|
|
- (macaddr[0] << 8) | macaddr[1]);
|
|
- ipqess_w32(ess, IPQESS_REG_MAC_CTRL0,
|
|
- (macaddr[2] << 24) | (macaddr[3] << 16) |
|
|
- (macaddr[4] << 8) | macaddr[5]);
|
|
-// spin_unlock_bh(&mac->hw->page_lock);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void ipqess_tx_timeout(struct net_device *netdev, unsigned int txq_id)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- struct ipqess_tx_ring *tr = &ess->tx_ring[txq_id];
|
|
-
|
|
- netdev_warn(netdev, "hardware queue %d is in stuck?\n",
|
|
- tr->idx);
|
|
-
|
|
- /* TODO: dump hardware queue */
|
|
-}
|
|
-
|
|
-static const struct net_device_ops ipqess_axi_netdev_ops = {
|
|
- .ndo_init = ipqess_init,
|
|
- .ndo_uninit = ipqess_uninit,
|
|
- .ndo_open = ipqess_open,
|
|
- .ndo_stop = ipqess_stop,
|
|
- .ndo_do_ioctl = ipqess_do_ioctl,
|
|
- .ndo_start_xmit = ipqess_xmit,
|
|
- .ndo_get_stats = ipqess_get_stats,
|
|
- .ndo_set_mac_address = ipqess_set_mac_address,
|
|
- .ndo_tx_timeout = ipqess_tx_timeout,
|
|
-};
|
|
-
|
|
-static void ipqess_hw_stop(struct ipqess *ess)
|
|
-{
|
|
- int i;
|
|
-
|
|
- /* disable all RX queue IRQs */
|
|
- for (i = 0; i < IPQESS_MAX_RX_QUEUE; i++)
|
|
- ipqess_w32(ess, IPQESS_REG_RX_INT_MASK_Q(i), 0);
|
|
-
|
|
- /* disable all TX queue IRQs */
|
|
- for (i = 0; i < IPQESS_MAX_TX_QUEUE; i++)
|
|
- ipqess_w32(ess, IPQESS_REG_TX_INT_MASK_Q(i), 0);
|
|
-
|
|
- /* disable all other IRQs */
|
|
- ipqess_w32(ess, IPQESS_REG_MISC_IMR, 0);
|
|
- ipqess_w32(ess, IPQESS_REG_WOL_IMR, 0);
|
|
-
|
|
- /* clear the IRQ status registers */
|
|
- ipqess_w32(ess, IPQESS_REG_RX_ISR, 0xff);
|
|
- ipqess_w32(ess, IPQESS_REG_TX_ISR, 0xffff);
|
|
- ipqess_w32(ess, IPQESS_REG_MISC_ISR, 0x1fff);
|
|
- ipqess_w32(ess, IPQESS_REG_WOL_ISR, 0x1);
|
|
- ipqess_w32(ess, IPQESS_REG_WOL_CTRL, 0);
|
|
-
|
|
- /* disable RX and TX queues */
|
|
- ipqess_m32(ess, IPQESS_RXQ_CTRL_EN_MASK, 0, IPQESS_REG_RXQ_CTRL);
|
|
- ipqess_m32(ess, IPQESS_TXQ_CTRL_TXQ_EN, 0, IPQESS_REG_TXQ_CTRL);
|
|
-}
|
|
-
|
|
-static int ipqess_hw_init(struct ipqess *ess)
|
|
-{
|
|
- u32 tmp;
|
|
- int i, err;
|
|
-
|
|
- ipqess_hw_stop(ess);
|
|
-
|
|
- ipqess_m32(ess, BIT(IPQESS_INTR_SW_IDX_W_TYP_SHIFT),
|
|
- IPQESS_INTR_SW_IDX_W_TYPE << IPQESS_INTR_SW_IDX_W_TYP_SHIFT,
|
|
- IPQESS_REG_INTR_CTRL);
|
|
-
|
|
- /* enable IRQ delay slot */
|
|
- ipqess_w32(ess, IPQESS_REG_IRQ_MODRT_TIMER_INIT,
|
|
- (IPQESS_TX_IMT << IPQESS_IRQ_MODRT_TX_TIMER_SHIFT) |
|
|
- (IPQESS_RX_IMT << IPQESS_IRQ_MODRT_RX_TIMER_SHIFT));
|
|
-
|
|
- /* Set Customer and Service VLAN TPIDs */
|
|
- ipqess_w32(ess, IPQESS_REG_VLAN_CFG,
|
|
- (ETH_P_8021Q << IPQESS_VLAN_CFG_CVLAN_TPID_SHIFT) |
|
|
- (ETH_P_8021AD << IPQESS_VLAN_CFG_SVLAN_TPID_SHIFT));
|
|
-
|
|
- /* Configure the TX Queue bursting */
|
|
- ipqess_w32(ess, IPQESS_REG_TXQ_CTRL,
|
|
- (IPQESS_TPD_BURST << IPQESS_TXQ_NUM_TPD_BURST_SHIFT) |
|
|
- (IPQESS_TXF_BURST << IPQESS_TXQ_TXF_BURST_NUM_SHIFT) |
|
|
- IPQESS_TXQ_CTRL_TPD_BURST_EN);
|
|
-
|
|
- /* Set RSS type */
|
|
- ipqess_w32(ess, IPQESS_REG_RSS_TYPE,
|
|
- IPQESS_RSS_TYPE_IPV4TCP | IPQESS_RSS_TYPE_IPV6_TCP |
|
|
- IPQESS_RSS_TYPE_IPV4_UDP | IPQESS_RSS_TYPE_IPV6UDP |
|
|
- IPQESS_RSS_TYPE_IPV4 | IPQESS_RSS_TYPE_IPV6);
|
|
-
|
|
- /* Set RFD ring burst and threshold */
|
|
- ipqess_w32(ess, IPQESS_REG_RX_DESC1,
|
|
- (IPQESS_RFD_BURST << IPQESS_RXQ_RFD_BURST_NUM_SHIFT) |
|
|
- (IPQESS_RFD_THR << IPQESS_RXQ_RFD_PF_THRESH_SHIFT) |
|
|
- (IPQESS_RFD_LTHR << IPQESS_RXQ_RFD_LOW_THRESH_SHIFT));
|
|
-
|
|
- /* Set Rx FIFO
|
|
- * - threshold to start to DMA data to host
|
|
- */
|
|
- ipqess_w32(ess, IPQESS_REG_RXQ_CTRL,
|
|
- IPQESS_FIFO_THRESH_128_BYTE | IPQESS_RXQ_CTRL_RMV_VLAN);
|
|
-
|
|
- err = ipqess_rx_ring_alloc(ess);
|
|
- if (err)
|
|
- return err;
|
|
-
|
|
- err = ipqess_tx_ring_alloc(ess);
|
|
- if (err)
|
|
- return err;
|
|
-
|
|
- /* Load all of ring base addresses above into the dma engine */
|
|
- ipqess_m32(ess, 0, BIT(IPQESS_LOAD_PTR_SHIFT),
|
|
- IPQESS_REG_TX_SRAM_PART);
|
|
-
|
|
- /* Disable TX FIFO low watermark and high watermark */
|
|
- ipqess_w32(ess, IPQESS_REG_TXF_WATER_MARK, 0);
|
|
-
|
|
- /* Configure RSS indirection table.
|
|
- * 128 hash will be configured in the following
|
|
- * pattern: hash{0,1,2,3} = {Q0,Q2,Q4,Q6} respectively
|
|
- * and so on
|
|
- */
|
|
- for (i = 0; i < IPQESS_NUM_IDT; i++)
|
|
- ipqess_w32(ess, IPQESS_REG_RSS_IDT(i), IPQESS_RSS_IDT_VALUE);
|
|
-
|
|
- /* Configure load balance mapping table.
|
|
- * 4 table entry will be configured according to the
|
|
- * following pattern: load_balance{0,1,2,3} = {Q0,Q1,Q3,Q4}
|
|
- * respectively.
|
|
- */
|
|
- ipqess_w32(ess, IPQESS_REG_LB_RING, IPQESS_LB_REG_VALUE);
|
|
-
|
|
- /* Configure Virtual queue for Tx rings */
|
|
- ipqess_w32(ess, IPQESS_REG_VQ_CTRL0, IPQESS_VQ_REG_VALUE);
|
|
- ipqess_w32(ess, IPQESS_REG_VQ_CTRL1, IPQESS_VQ_REG_VALUE);
|
|
-
|
|
- /* Configure Max AXI Burst write size to 128 bytes*/
|
|
- ipqess_w32(ess, IPQESS_REG_AXIW_CTRL_MAXWRSIZE,
|
|
- IPQESS_AXIW_MAXWRSIZE_VALUE);
|
|
-
|
|
- /* Enable TX queues */
|
|
- ipqess_m32(ess, 0, IPQESS_TXQ_CTRL_TXQ_EN, IPQESS_REG_TXQ_CTRL);
|
|
-
|
|
- /* Enable RX queues */
|
|
- tmp = 0;
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++)
|
|
- tmp |= IPQESS_RXQ_CTRL_EN(ess->rx_ring[i].idx);
|
|
-
|
|
- ipqess_m32(ess, IPQESS_RXQ_CTRL_EN_MASK, tmp, IPQESS_REG_RXQ_CTRL);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static void ipqess_validate(struct phylink_config *config,
|
|
- unsigned long *supported,
|
|
- struct phylink_link_state *state)
|
|
-{
|
|
- struct ipqess *ess = container_of(config, struct ipqess, phylink_config);
|
|
- __ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, };
|
|
-
|
|
- if (state->interface != PHY_INTERFACE_MODE_INTERNAL) {
|
|
- dev_err(&ess->pdev->dev, "unsupported interface mode: %d\n",
|
|
- state->interface);
|
|
- linkmode_zero(supported);
|
|
- return;
|
|
- }
|
|
-
|
|
- phylink_set_port_modes(mask);
|
|
- phylink_set(mask, 1000baseT_Full);
|
|
- phylink_set(mask, Pause);
|
|
- phylink_set(mask, Asym_Pause);
|
|
-
|
|
- linkmode_and(supported, supported, mask);
|
|
- linkmode_and(state->advertising, state->advertising, mask);
|
|
-}
|
|
-
|
|
-static void ipqess_mac_config(struct phylink_config *config, unsigned int mode,
|
|
- const struct phylink_link_state *state)
|
|
-{
|
|
- /* TODO */
|
|
-}
|
|
-
|
|
-static void ipqess_mac_link_down(struct phylink_config *config,
|
|
- unsigned int mode,
|
|
- phy_interface_t interface)
|
|
-{
|
|
- /* TODO */
|
|
-}
|
|
-
|
|
-static void ipqess_mac_link_up(struct phylink_config *config,
|
|
- struct phy_device *phy, unsigned int mode,
|
|
- phy_interface_t interface,
|
|
- int speed, int duplex,
|
|
- bool tx_pause, bool rx_pause)
|
|
-{
|
|
- /* TODO */
|
|
-}
|
|
-
|
|
-static struct phylink_mac_ops ipqess_phylink_mac_ops = {
|
|
- .validate = ipqess_validate,
|
|
- .mac_config = ipqess_mac_config,
|
|
- .mac_link_up = ipqess_mac_link_up,
|
|
- .mac_link_down = ipqess_mac_link_down,
|
|
-};
|
|
-
|
|
-static void ipqess_cleanup(struct ipqess *ess)
|
|
-{
|
|
- ipqess_hw_stop(ess);
|
|
- unregister_netdev(ess->netdev);
|
|
-
|
|
- ipqess_tx_ring_free(ess);
|
|
- ipqess_rx_ring_free(ess);
|
|
-
|
|
- if (!IS_ERR_OR_NULL(ess->phylink))
|
|
- phylink_destroy(ess->phylink);
|
|
-}
|
|
-
|
|
-static void ess_reset(struct ipqess *ess)
|
|
-{
|
|
- reset_control_assert(ess->ess_rst);
|
|
-
|
|
- mdelay(10);
|
|
-
|
|
- reset_control_deassert(ess->ess_rst);
|
|
-
|
|
- /* Waiting for all inner tables to be flushed and reinitialized.
|
|
- * This takes between 5 and 10ms.
|
|
- */
|
|
- mdelay(10);
|
|
-}
|
|
-
|
|
-static int ipqess_axi_probe(struct platform_device *pdev)
|
|
-{
|
|
- struct device_node *np = pdev->dev.of_node;
|
|
- struct ipqess *ess;
|
|
- struct net_device *netdev;
|
|
- struct resource *res;
|
|
- int i, err = 0;
|
|
-
|
|
- netdev = devm_alloc_etherdev_mqs(&pdev->dev, sizeof(struct ipqess),
|
|
- IPQESS_NETDEV_QUEUES,
|
|
- IPQESS_NETDEV_QUEUES);
|
|
- if (!netdev)
|
|
- return -ENOMEM;
|
|
-
|
|
- ess = netdev_priv(netdev);
|
|
- ess->netdev = netdev;
|
|
- ess->pdev = pdev;
|
|
- spin_lock_init(&ess->stats_lock);
|
|
- SET_NETDEV_DEV(netdev, &pdev->dev);
|
|
- platform_set_drvdata(pdev, netdev);
|
|
-
|
|
- err = of_get_mac_address(np, netdev->dev_addr);
|
|
- if (err == -EPROBE_DEFER)
|
|
- return -EPROBE_DEFER;
|
|
-
|
|
- if (err) {
|
|
-
|
|
- random_ether_addr(netdev->dev_addr);
|
|
- dev_info(&ess->pdev->dev, "generated random MAC address %pM\n",
|
|
- netdev->dev_addr);
|
|
- netdev->addr_assign_type = NET_ADDR_RANDOM;
|
|
- }
|
|
-
|
|
- res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
|
- ess->hw_addr = devm_ioremap_resource(&pdev->dev, res);
|
|
- if (IS_ERR(ess->hw_addr)) {
|
|
- err = PTR_ERR(ess->hw_addr);
|
|
- goto err_out;
|
|
- }
|
|
-
|
|
- ess->ess_clk = of_clk_get_by_name(np, "ess_clk");
|
|
- if (IS_ERR(ess->ess_clk)) {
|
|
- dev_err(&pdev->dev, "Failed to get ess_clk\n");
|
|
- return PTR_ERR(ess->ess_clk);
|
|
- }
|
|
-
|
|
- ess->ess_rst = devm_reset_control_get(&pdev->dev, "ess_rst");
|
|
- if (IS_ERR(ess->ess_rst)) {
|
|
- dev_err(&pdev->dev, "Failed to get ess_rst control!\n");
|
|
- return PTR_ERR(ess->ess_rst);
|
|
- }
|
|
-
|
|
- clk_prepare_enable(ess->ess_clk);
|
|
-
|
|
- ess_reset(ess);
|
|
-
|
|
- ess->phylink_config.dev = &netdev->dev;
|
|
- ess->phylink_config.type = PHYLINK_NETDEV;
|
|
- ess->phylink_config.pcs_poll = true;
|
|
-
|
|
- ess->phylink = phylink_create(&ess->phylink_config,
|
|
- of_fwnode_handle(np),
|
|
- PHY_INTERFACE_MODE_INTERNAL,
|
|
- &ipqess_phylink_mac_ops);
|
|
- if (IS_ERR(ess->phylink)) {
|
|
- err = PTR_ERR(ess->phylink);
|
|
- goto err_out;
|
|
- }
|
|
-
|
|
- for (i = 0; i < IPQESS_MAX_TX_QUEUE; i++) {
|
|
- ess->tx_irq[i] = platform_get_irq(pdev, i);
|
|
- scnprintf(ess->tx_irq_names[i], sizeof(ess->tx_irq_names[i]),
|
|
- "%s:txq%d", pdev->name, i);
|
|
- }
|
|
-
|
|
- for (i = 0; i < IPQESS_MAX_RX_QUEUE; i++) {
|
|
- ess->rx_irq[i] = platform_get_irq(pdev, i + IPQESS_MAX_TX_QUEUE);
|
|
- scnprintf(ess->rx_irq_names[i], sizeof(ess->rx_irq_names[i]),
|
|
- "%s:rxq%d", pdev->name, i);
|
|
- }
|
|
-
|
|
-#undef NETIF_F_TSO6
|
|
-#define NETIF_F_TSO6 0
|
|
-
|
|
- netdev->netdev_ops = &ipqess_axi_netdev_ops;
|
|
- netdev->features = NETIF_F_HW_CSUM | NETIF_F_RXCSUM |
|
|
- NETIF_F_HW_VLAN_CTAG_RX |
|
|
- NETIF_F_HW_VLAN_CTAG_TX |
|
|
- NETIF_F_TSO | NETIF_F_TSO6 |
|
|
- NETIF_F_GRO | NETIF_F_SG;
|
|
- /* feature change is not supported yet */
|
|
- netdev->hw_features = 0;
|
|
- netdev->vlan_features = NETIF_F_HW_CSUM | NETIF_F_SG | NETIF_F_RXCSUM |
|
|
- NETIF_F_TSO | NETIF_F_TSO6 |
|
|
- NETIF_F_GRO;
|
|
- netdev->watchdog_timeo = 5 * HZ;
|
|
- netdev->base_addr = (u32) ess->hw_addr;
|
|
- netdev->max_mtu = 9000;
|
|
- netdev->gso_max_segs = IPQESS_TX_RING_SIZE / 2;
|
|
-
|
|
- ipqess_set_ethtool_ops(netdev);
|
|
-
|
|
- err = register_netdev(netdev);
|
|
- if (err)
|
|
- goto err_out;
|
|
-
|
|
- err = ipqess_hw_init(ess);
|
|
- if (err)
|
|
- goto err_out;
|
|
-
|
|
- dev_set_threaded(netdev, true);
|
|
-
|
|
- for (i = 0; i < IPQESS_NETDEV_QUEUES; i++) {
|
|
- int qid;
|
|
-
|
|
- netif_tx_napi_add(netdev, &ess->tx_ring[i].napi_tx,
|
|
- ipqess_tx_napi, 64);
|
|
- netif_napi_add(netdev,
|
|
- &ess->rx_ring[i].napi_rx,
|
|
- ipqess_rx_napi, 64);
|
|
-
|
|
- qid = ess->tx_ring[i].idx;
|
|
- err = devm_request_irq(&ess->netdev->dev, ess->tx_irq[qid],
|
|
- ipqess_interrupt_tx, 0, ess->tx_irq_names[qid],
|
|
- &ess->tx_ring[i]);
|
|
- if (err)
|
|
- goto err_out;
|
|
-
|
|
- qid = ess->rx_ring[i].idx;
|
|
- err = devm_request_irq(&ess->netdev->dev, ess->rx_irq[qid],
|
|
- ipqess_interrupt_rx, 0, ess->rx_irq_names[qid],
|
|
- &ess->rx_ring[i]);
|
|
- if (err)
|
|
- goto err_out;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-
|
|
-err_out:
|
|
- ipqess_cleanup(ess);
|
|
- return err;
|
|
-}
|
|
-
|
|
-static int ipqess_axi_remove(struct platform_device *pdev)
|
|
-{
|
|
- const struct net_device *netdev = platform_get_drvdata(pdev);
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- ipqess_cleanup(ess);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static const struct of_device_id ipqess_of_mtable[] = {
|
|
- {.compatible = "qcom,ipq4019-ess-edma" },
|
|
- {}
|
|
-};
|
|
-MODULE_DEVICE_TABLE(of, ipqess_of_mtable);
|
|
-
|
|
-static struct platform_driver ipqess_axi_driver = {
|
|
- .driver = {
|
|
- .name = "ipqess-edma",
|
|
- .of_match_table = ipqess_of_mtable,
|
|
- },
|
|
- .probe = ipqess_axi_probe,
|
|
- .remove = ipqess_axi_remove,
|
|
-};
|
|
-
|
|
-module_platform_driver(ipqess_axi_driver);
|
|
-
|
|
-MODULE_AUTHOR("Qualcomm Atheros Inc");
|
|
-MODULE_AUTHOR("John Crispin <john@phrozen.org>");
|
|
-MODULE_AUTHOR("Christian Lamparter <chunkeey@gmail.com>");
|
|
-MODULE_AUTHOR("Gabor Juhos <j4g8y7@gmail.com>");
|
|
-MODULE_LICENSE("GPL");
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.h b/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.h
|
|
deleted file mode 100644
|
|
index ca4cb7b2d4..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess.h
|
|
+++ /dev/null
|
|
@@ -1,530 +0,0 @@
|
|
-// SPDX-License-Identifier: (GPL-2.0 OR ISC)
|
|
-/* Copyright (c) 2014 - 2016, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017 - 2018, John Crispin <john@phrozen.org>
|
|
- * Copyright (c) 2018 - 2019, Christian Lamparter <chunkeey@gmail.com>
|
|
- * Copyright (c) 2020 - 2021, Gabor Juhos <j4g8y7@gmail.com>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for
|
|
- * any purpose with or without fee is hereby granted, provided that the
|
|
- * above copyright notice and this permission notice appear in all copies.
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
|
|
- * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- */
|
|
-
|
|
-#ifndef _IPQESS_H_
|
|
-#define _IPQESS_H_
|
|
-
|
|
-#define IPQESS_NETDEV_QUEUES 4
|
|
-
|
|
-#define IPQESS_TPD_EOP_SHIFT 31
|
|
-
|
|
-#define IPQESS_PORT_ID_SHIFT 12
|
|
-#define IPQESS_PORT_ID_MASK 0x7
|
|
-
|
|
-/* tpd word 3 bit 18-28 */
|
|
-#define IPQESS_TPD_PORT_BITMAP_SHIFT 18
|
|
-
|
|
-#define IPQESS_TPD_FROM_CPU_SHIFT 25
|
|
-
|
|
-#define IPQESS_RX_RING_SIZE 128
|
|
-#define IPQESS_RX_HEAD_BUFF_SIZE 1540
|
|
-#define IPQESS_TX_RING_SIZE 128
|
|
-#define IPQESS_MAX_RX_QUEUE 8
|
|
-#define IPQESS_MAX_TX_QUEUE 16
|
|
-
|
|
-
|
|
-/* Configurations */
|
|
-#define IPQESS_INTR_CLEAR_TYPE 0
|
|
-#define IPQESS_INTR_SW_IDX_W_TYPE 0
|
|
-#define IPQESS_FIFO_THRESH_TYPE 0
|
|
-#define IPQESS_RSS_TYPE 0
|
|
-#define IPQESS_RX_IMT 0x0020
|
|
-#define IPQESS_TX_IMT 0x0050
|
|
-#define IPQESS_TPD_BURST 5
|
|
-#define IPQESS_TXF_BURST 0x100
|
|
-#define IPQESS_RFD_BURST 8
|
|
-#define IPQESS_RFD_THR 16
|
|
-#define IPQESS_RFD_LTHR 0
|
|
-
|
|
-/* Flags used in transmit direction */
|
|
-#define IPQESS_DESC_LAST 0x1
|
|
-#define IPQESS_DESC_SINGLE 0x2
|
|
-#define IPQESS_DESC_PAGE 0x4
|
|
-
|
|
-struct ipqesstool_statistics {
|
|
- u32 tx_q0_pkt;
|
|
- u32 tx_q1_pkt;
|
|
- u32 tx_q2_pkt;
|
|
- u32 tx_q3_pkt;
|
|
- u32 tx_q4_pkt;
|
|
- u32 tx_q5_pkt;
|
|
- u32 tx_q6_pkt;
|
|
- u32 tx_q7_pkt;
|
|
- u32 tx_q8_pkt;
|
|
- u32 tx_q9_pkt;
|
|
- u32 tx_q10_pkt;
|
|
- u32 tx_q11_pkt;
|
|
- u32 tx_q12_pkt;
|
|
- u32 tx_q13_pkt;
|
|
- u32 tx_q14_pkt;
|
|
- u32 tx_q15_pkt;
|
|
- u32 tx_q0_byte;
|
|
- u32 tx_q1_byte;
|
|
- u32 tx_q2_byte;
|
|
- u32 tx_q3_byte;
|
|
- u32 tx_q4_byte;
|
|
- u32 tx_q5_byte;
|
|
- u32 tx_q6_byte;
|
|
- u32 tx_q7_byte;
|
|
- u32 tx_q8_byte;
|
|
- u32 tx_q9_byte;
|
|
- u32 tx_q10_byte;
|
|
- u32 tx_q11_byte;
|
|
- u32 tx_q12_byte;
|
|
- u32 tx_q13_byte;
|
|
- u32 tx_q14_byte;
|
|
- u32 tx_q15_byte;
|
|
- u32 rx_q0_pkt;
|
|
- u32 rx_q1_pkt;
|
|
- u32 rx_q2_pkt;
|
|
- u32 rx_q3_pkt;
|
|
- u32 rx_q4_pkt;
|
|
- u32 rx_q5_pkt;
|
|
- u32 rx_q6_pkt;
|
|
- u32 rx_q7_pkt;
|
|
- u32 rx_q0_byte;
|
|
- u32 rx_q1_byte;
|
|
- u32 rx_q2_byte;
|
|
- u32 rx_q3_byte;
|
|
- u32 rx_q4_byte;
|
|
- u32 rx_q5_byte;
|
|
- u32 rx_q6_byte;
|
|
- u32 rx_q7_byte;
|
|
- u32 tx_desc_error;
|
|
-};
|
|
-
|
|
-struct ipqess_tx_desc {
|
|
- __le16 len;
|
|
- __le16 svlan_tag;
|
|
- __le32 word1;
|
|
- __le32 addr;
|
|
- __le32 word3;
|
|
-} __aligned(16) __packed;
|
|
-
|
|
-struct ipqess_rx_desc {
|
|
- u16 rrd0;
|
|
- u16 rrd1;
|
|
- u16 rrd2;
|
|
- u16 rrd3;
|
|
- u16 rrd4;
|
|
- u16 rrd5;
|
|
- u16 rrd6;
|
|
- u16 rrd7;
|
|
-} __aligned(16) __packed;
|
|
-
|
|
-struct ipqess_buf {
|
|
- struct sk_buff *skb;
|
|
- dma_addr_t dma;
|
|
- u32 flags;
|
|
- u16 length;
|
|
-};
|
|
-
|
|
-struct ipqess_tx_ring {
|
|
- struct napi_struct napi_tx;
|
|
- u32 idx;
|
|
- int ring_id;
|
|
- struct ipqess *ess;
|
|
- struct netdev_queue *nq;
|
|
- struct ipqess_tx_desc *hw_desc;
|
|
- struct ipqess_buf *buf;
|
|
- dma_addr_t dma;
|
|
- u16 count;
|
|
- u16 head;
|
|
- u16 tail;
|
|
-};
|
|
-
|
|
-struct ipqess_rx_ring {
|
|
- struct napi_struct napi_rx;
|
|
- u32 idx;
|
|
- int ring_id;
|
|
- struct ipqess *ess;
|
|
- struct device *ppdev;
|
|
- struct ipqess_rx_desc **hw_desc;
|
|
- struct ipqess_buf *buf;
|
|
- dma_addr_t dma;
|
|
- u16 head;
|
|
- u16 tail;
|
|
- atomic_t refill_count;
|
|
-};
|
|
-
|
|
-struct ipqess_rx_ring_refill {
|
|
- struct ipqess_rx_ring *rx_ring;
|
|
- struct work_struct refill_work;
|
|
-};
|
|
-
|
|
-#define IPQESS_IRQ_NAME_LEN 32
|
|
-
|
|
-struct ipqess {
|
|
- struct net_device *netdev;
|
|
- void __iomem *hw_addr;
|
|
- struct clk *ess_clk;
|
|
- struct reset_control *ess_rst;
|
|
-
|
|
- struct ipqess_rx_ring rx_ring[IPQESS_NETDEV_QUEUES];
|
|
-
|
|
- struct platform_device *pdev;
|
|
- struct phylink *phylink;
|
|
- struct phylink_config phylink_config;
|
|
- struct ipqess_tx_ring tx_ring[IPQESS_NETDEV_QUEUES];
|
|
-
|
|
- struct ipqesstool_statistics ipqessstats;
|
|
- spinlock_t stats_lock;
|
|
- struct net_device_stats stats;
|
|
-
|
|
- struct ipqess_rx_ring_refill rx_refill[IPQESS_NETDEV_QUEUES];
|
|
- u32 tx_irq[IPQESS_MAX_TX_QUEUE];
|
|
- char tx_irq_names[IPQESS_MAX_TX_QUEUE][IPQESS_IRQ_NAME_LEN];
|
|
- u32 rx_irq[IPQESS_MAX_RX_QUEUE];
|
|
- char rx_irq_names[IPQESS_MAX_TX_QUEUE][IPQESS_IRQ_NAME_LEN];
|
|
-};
|
|
-
|
|
-static inline void build_test(void)
|
|
-{
|
|
- struct ipqess *ess;
|
|
- BUILD_BUG_ON(ARRAY_SIZE(ess->rx_ring) != ARRAY_SIZE(ess->rx_refill));
|
|
-}
|
|
-
|
|
-void ipqess_set_ethtool_ops(struct net_device *netdev);
|
|
-void ipqess_update_hw_stats(struct ipqess *ess);
|
|
-
|
|
-/* register definition */
|
|
-#define IPQESS_REG_MAS_CTRL 0x0
|
|
-#define IPQESS_REG_TIMEOUT_CTRL 0x004
|
|
-#define IPQESS_REG_DBG0 0x008
|
|
-#define IPQESS_REG_DBG1 0x00C
|
|
-#define IPQESS_REG_SW_CTRL0 0x100
|
|
-#define IPQESS_REG_SW_CTRL1 0x104
|
|
-
|
|
-/* Interrupt Status Register */
|
|
-#define IPQESS_REG_RX_ISR 0x200
|
|
-#define IPQESS_REG_TX_ISR 0x208
|
|
-#define IPQESS_REG_MISC_ISR 0x210
|
|
-#define IPQESS_REG_WOL_ISR 0x218
|
|
-
|
|
-#define IPQESS_MISC_ISR_RX_URG_Q(x) (1 << x)
|
|
-
|
|
-#define IPQESS_MISC_ISR_AXIR_TIMEOUT 0x00000100
|
|
-#define IPQESS_MISC_ISR_AXIR_ERR 0x00000200
|
|
-#define IPQESS_MISC_ISR_TXF_DEAD 0x00000400
|
|
-#define IPQESS_MISC_ISR_AXIW_ERR 0x00000800
|
|
-#define IPQESS_MISC_ISR_AXIW_TIMEOUT 0x00001000
|
|
-
|
|
-#define IPQESS_WOL_ISR 0x00000001
|
|
-
|
|
-/* Interrupt Mask Register */
|
|
-#define IPQESS_REG_MISC_IMR 0x214
|
|
-#define IPQESS_REG_WOL_IMR 0x218
|
|
-
|
|
-#define IPQESS_RX_IMR_NORMAL_MASK 0x1
|
|
-#define IPQESS_TX_IMR_NORMAL_MASK 0x1
|
|
-#define IPQESS_MISC_IMR_NORMAL_MASK 0x80001FFF
|
|
-#define IPQESS_WOL_IMR_NORMAL_MASK 0x1
|
|
-
|
|
-/* Edma receive consumer index */
|
|
-#define IPQESS_REG_RX_SW_CONS_IDX_Q(x) (0x220 + ((x) << 2)) /* x is the queue id */
|
|
-
|
|
-/* Edma transmit consumer index */
|
|
-#define IPQESS_REG_TX_SW_CONS_IDX_Q(x) (0x240 + ((x) << 2)) /* x is the queue id */
|
|
-
|
|
-/* IRQ Moderator Initial Timer Register */
|
|
-#define IPQESS_REG_IRQ_MODRT_TIMER_INIT 0x280
|
|
-#define IPQESS_IRQ_MODRT_TIMER_MASK 0xFFFF
|
|
-#define IPQESS_IRQ_MODRT_RX_TIMER_SHIFT 0
|
|
-#define IPQESS_IRQ_MODRT_TX_TIMER_SHIFT 16
|
|
-
|
|
-/* Interrupt Control Register */
|
|
-#define IPQESS_REG_INTR_CTRL 0x284
|
|
-#define IPQESS_INTR_CLR_TYP_SHIFT 0
|
|
-#define IPQESS_INTR_SW_IDX_W_TYP_SHIFT 1
|
|
-#define IPQESS_INTR_CLEAR_TYPE_W1 0
|
|
-#define IPQESS_INTR_CLEAR_TYPE_R 1
|
|
-
|
|
-/* RX Interrupt Mask Register */
|
|
-#define IPQESS_REG_RX_INT_MASK_Q(x) (0x300 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-/* TX Interrupt mask register */
|
|
-#define IPQESS_REG_TX_INT_MASK_Q(x) (0x340 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-/* Load Ptr Register
|
|
- * Software sets this bit after the initialization of the head and tail
|
|
- */
|
|
-#define IPQESS_REG_TX_SRAM_PART 0x400
|
|
-#define IPQESS_LOAD_PTR_SHIFT 16
|
|
-
|
|
-/* TXQ Control Register */
|
|
-#define IPQESS_REG_TXQ_CTRL 0x404
|
|
-#define IPQESS_TXQ_CTRL_IP_OPTION_EN 0x10
|
|
-#define IPQESS_TXQ_CTRL_TXQ_EN 0x20
|
|
-#define IPQESS_TXQ_CTRL_ENH_MODE 0x40
|
|
-#define IPQESS_TXQ_CTRL_LS_8023_EN 0x80
|
|
-#define IPQESS_TXQ_CTRL_TPD_BURST_EN 0x100
|
|
-#define IPQESS_TXQ_CTRL_LSO_BREAK_EN 0x200
|
|
-#define IPQESS_TXQ_NUM_TPD_BURST_MASK 0xF
|
|
-#define IPQESS_TXQ_TXF_BURST_NUM_MASK 0xFFFF
|
|
-#define IPQESS_TXQ_NUM_TPD_BURST_SHIFT 0
|
|
-#define IPQESS_TXQ_TXF_BURST_NUM_SHIFT 16
|
|
-
|
|
-#define IPQESS_REG_TXF_WATER_MARK 0x408 /* In 8-bytes */
|
|
-#define IPQESS_TXF_WATER_MARK_MASK 0x0FFF
|
|
-#define IPQESS_TXF_LOW_WATER_MARK_SHIFT 0
|
|
-#define IPQESS_TXF_HIGH_WATER_MARK_SHIFT 16
|
|
-#define IPQESS_TXQ_CTRL_BURST_MODE_EN 0x80000000
|
|
-
|
|
-/* WRR Control Register */
|
|
-#define IPQESS_REG_WRR_CTRL_Q0_Q3 0x40c
|
|
-#define IPQESS_REG_WRR_CTRL_Q4_Q7 0x410
|
|
-#define IPQESS_REG_WRR_CTRL_Q8_Q11 0x414
|
|
-#define IPQESS_REG_WRR_CTRL_Q12_Q15 0x418
|
|
-
|
|
-/* Weight round robin(WRR), it takes queue as input, and computes
|
|
- * starting bits where we need to write the weight for a particular
|
|
- * queue
|
|
- */
|
|
-#define IPQESS_WRR_SHIFT(x) (((x) * 5) % 20)
|
|
-
|
|
-/* Tx Descriptor Control Register */
|
|
-#define IPQESS_REG_TPD_RING_SIZE 0x41C
|
|
-#define IPQESS_TPD_RING_SIZE_SHIFT 0
|
|
-#define IPQESS_TPD_RING_SIZE_MASK 0xFFFF
|
|
-
|
|
-/* Transmit descriptor base address */
|
|
-#define IPQESS_REG_TPD_BASE_ADDR_Q(x) (0x420 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-/* TPD Index Register */
|
|
-#define IPQESS_REG_TPD_IDX_Q(x) (0x460 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-#define IPQESS_TPD_PROD_IDX_BITS 0x0000FFFF
|
|
-#define IPQESS_TPD_CONS_IDX_BITS 0xFFFF0000
|
|
-#define IPQESS_TPD_PROD_IDX_MASK 0xFFFF
|
|
-#define IPQESS_TPD_CONS_IDX_MASK 0xFFFF
|
|
-#define IPQESS_TPD_PROD_IDX_SHIFT 0
|
|
-#define IPQESS_TPD_CONS_IDX_SHIFT 16
|
|
-
|
|
-/* TX Virtual Queue Mapping Control Register */
|
|
-#define IPQESS_REG_VQ_CTRL0 0x4A0
|
|
-#define IPQESS_REG_VQ_CTRL1 0x4A4
|
|
-
|
|
-/* Virtual QID shift, it takes queue as input, and computes
|
|
- * Virtual QID position in virtual qid control register
|
|
- */
|
|
-#define IPQESS_VQ_ID_SHIFT(i) (((i) * 3) % 24)
|
|
-
|
|
-/* Virtual Queue Default Value */
|
|
-#define IPQESS_VQ_REG_VALUE 0x240240
|
|
-
|
|
-/* Tx side Port Interface Control Register */
|
|
-#define IPQESS_REG_PORT_CTRL 0x4A8
|
|
-#define IPQESS_PAD_EN_SHIFT 15
|
|
-
|
|
-/* Tx side VLAN Configuration Register */
|
|
-#define IPQESS_REG_VLAN_CFG 0x4AC
|
|
-
|
|
-#define IPQESS_VLAN_CFG_SVLAN_TPID_SHIFT 0
|
|
-#define IPQESS_VLAN_CFG_SVLAN_TPID_MASK 0xffff
|
|
-#define IPQESS_VLAN_CFG_CVLAN_TPID_SHIFT 16
|
|
-#define IPQESS_VLAN_CFG_CVLAN_TPID_MASK 0xffff
|
|
-
|
|
-#define IPQESS_TX_CVLAN 16
|
|
-#define IPQESS_TX_INS_CVLAN 17
|
|
-#define IPQESS_TX_CVLAN_TAG_SHIFT 0
|
|
-
|
|
-#define IPQESS_TX_SVLAN 14
|
|
-#define IPQESS_TX_INS_SVLAN 15
|
|
-#define IPQESS_TX_SVLAN_TAG_SHIFT 16
|
|
-
|
|
-/* Tx Queue Packet Statistic Register */
|
|
-#define IPQESS_REG_TX_STAT_PKT_Q(x) (0x700 + ((x) << 3)) /* x = queue id */
|
|
-
|
|
-#define IPQESS_TX_STAT_PKT_MASK 0xFFFFFF
|
|
-
|
|
-/* Tx Queue Byte Statistic Register */
|
|
-#define IPQESS_REG_TX_STAT_BYTE_Q(x) (0x704 + ((x) << 3)) /* x = queue id */
|
|
-
|
|
-/* Load Balance Based Ring Offset Register */
|
|
-#define IPQESS_REG_LB_RING 0x800
|
|
-#define IPQESS_LB_RING_ENTRY_MASK 0xff
|
|
-#define IPQESS_LB_RING_ID_MASK 0x7
|
|
-#define IPQESS_LB_RING_PROFILE_ID_MASK 0x3
|
|
-#define IPQESS_LB_RING_ENTRY_BIT_OFFSET 8
|
|
-#define IPQESS_LB_RING_ID_OFFSET 0
|
|
-#define IPQESS_LB_RING_PROFILE_ID_OFFSET 3
|
|
-#define IPQESS_LB_REG_VALUE 0x6040200
|
|
-
|
|
-/* Load Balance Priority Mapping Register */
|
|
-#define IPQESS_REG_LB_PRI_START 0x804
|
|
-#define IPQESS_REG_LB_PRI_END 0x810
|
|
-#define IPQESS_LB_PRI_REG_INC 4
|
|
-#define IPQESS_LB_PRI_ENTRY_BIT_OFFSET 4
|
|
-#define IPQESS_LB_PRI_ENTRY_MASK 0xf
|
|
-
|
|
-/* RSS Priority Mapping Register */
|
|
-#define IPQESS_REG_RSS_PRI 0x820
|
|
-#define IPQESS_RSS_PRI_ENTRY_MASK 0xf
|
|
-#define IPQESS_RSS_RING_ID_MASK 0x7
|
|
-#define IPQESS_RSS_PRI_ENTRY_BIT_OFFSET 4
|
|
-
|
|
-/* RSS Indirection Register */
|
|
-#define IPQESS_REG_RSS_IDT(x) (0x840 + ((x) << 2)) /* x = No. of indirection table */
|
|
-#define IPQESS_NUM_IDT 16
|
|
-#define IPQESS_RSS_IDT_VALUE 0x64206420
|
|
-
|
|
-/* Default RSS Ring Register */
|
|
-#define IPQESS_REG_DEF_RSS 0x890
|
|
-#define IPQESS_DEF_RSS_MASK 0x7
|
|
-
|
|
-/* RSS Hash Function Type Register */
|
|
-#define IPQESS_REG_RSS_TYPE 0x894
|
|
-#define IPQESS_RSS_TYPE_NONE 0x01
|
|
-#define IPQESS_RSS_TYPE_IPV4TCP 0x02
|
|
-#define IPQESS_RSS_TYPE_IPV6_TCP 0x04
|
|
-#define IPQESS_RSS_TYPE_IPV4_UDP 0x08
|
|
-#define IPQESS_RSS_TYPE_IPV6UDP 0x10
|
|
-#define IPQESS_RSS_TYPE_IPV4 0x20
|
|
-#define IPQESS_RSS_TYPE_IPV6 0x40
|
|
-#define IPQESS_RSS_HASH_MODE_MASK 0x7f
|
|
-
|
|
-#define IPQESS_REG_RSS_HASH_VALUE 0x8C0
|
|
-
|
|
-#define IPQESS_REG_RSS_TYPE_RESULT 0x8C4
|
|
-
|
|
-#define IPQESS_HASH_TYPE_START 0
|
|
-#define IPQESS_HASH_TYPE_END 5
|
|
-#define IPQESS_HASH_TYPE_SHIFT 12
|
|
-
|
|
-#define IPQESS_RFS_FLOW_ENTRIES 1024
|
|
-#define IPQESS_RFS_FLOW_ENTRIES_MASK (IPQESS_RFS_FLOW_ENTRIES - 1)
|
|
-#define IPQESS_RFS_EXPIRE_COUNT_PER_CALL 128
|
|
-
|
|
-/* RFD Base Address Register */
|
|
-#define IPQESS_REG_RFD_BASE_ADDR_Q(x) (0x950 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-/* RFD Index Register */
|
|
-#define IPQESS_REG_RFD_IDX_Q(x) (0x9B0 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-#define IPQESS_RFD_PROD_IDX_BITS 0x00000FFF
|
|
-#define IPQESS_RFD_CONS_IDX_BITS 0x0FFF0000
|
|
-#define IPQESS_RFD_PROD_IDX_MASK 0xFFF
|
|
-#define IPQESS_RFD_CONS_IDX_MASK 0xFFF
|
|
-#define IPQESS_RFD_PROD_IDX_SHIFT 0
|
|
-#define IPQESS_RFD_CONS_IDX_SHIFT 16
|
|
-
|
|
-/* Rx Descriptor Control Register */
|
|
-#define IPQESS_REG_RX_DESC0 0xA10
|
|
-#define IPQESS_RFD_RING_SIZE_MASK 0xFFF
|
|
-#define IPQESS_RX_BUF_SIZE_MASK 0xFFFF
|
|
-#define IPQESS_RFD_RING_SIZE_SHIFT 0
|
|
-#define IPQESS_RX_BUF_SIZE_SHIFT 16
|
|
-
|
|
-#define IPQESS_REG_RX_DESC1 0xA14
|
|
-#define IPQESS_RXQ_RFD_BURST_NUM_MASK 0x3F
|
|
-#define IPQESS_RXQ_RFD_PF_THRESH_MASK 0x1F
|
|
-#define IPQESS_RXQ_RFD_LOW_THRESH_MASK 0xFFF
|
|
-#define IPQESS_RXQ_RFD_BURST_NUM_SHIFT 0
|
|
-#define IPQESS_RXQ_RFD_PF_THRESH_SHIFT 8
|
|
-#define IPQESS_RXQ_RFD_LOW_THRESH_SHIFT 16
|
|
-
|
|
-/* RXQ Control Register */
|
|
-#define IPQESS_REG_RXQ_CTRL 0xA18
|
|
-#define IPQESS_FIFO_THRESH_TYPE_SHIF 0
|
|
-#define IPQESS_FIFO_THRESH_128_BYTE 0x0
|
|
-#define IPQESS_FIFO_THRESH_64_BYTE 0x1
|
|
-#define IPQESS_RXQ_CTRL_RMV_VLAN 0x00000002
|
|
-#define IPQESS_RXQ_CTRL_EN_MASK GENMASK(15, 8)
|
|
-#define IPQESS_RXQ_CTRL_EN(__qid) BIT(8 + (__qid))
|
|
-
|
|
-/* AXI Burst Size Config */
|
|
-#define IPQESS_REG_AXIW_CTRL_MAXWRSIZE 0xA1C
|
|
-#define IPQESS_AXIW_MAXWRSIZE_VALUE 0x0
|
|
-
|
|
-/* Rx Statistics Register */
|
|
-#define IPQESS_REG_RX_STAT_BYTE_Q(x) (0xA30 + ((x) << 2)) /* x = queue id */
|
|
-#define IPQESS_REG_RX_STAT_PKT_Q(x) (0xA50 + ((x) << 2)) /* x = queue id */
|
|
-
|
|
-/* WoL Pattern Length Register */
|
|
-#define IPQESS_REG_WOL_PATTERN_LEN0 0xC00
|
|
-#define IPQESS_WOL_PT_LEN_MASK 0xFF
|
|
-#define IPQESS_WOL_PT0_LEN_SHIFT 0
|
|
-#define IPQESS_WOL_PT1_LEN_SHIFT 8
|
|
-#define IPQESS_WOL_PT2_LEN_SHIFT 16
|
|
-#define IPQESS_WOL_PT3_LEN_SHIFT 24
|
|
-
|
|
-#define IPQESS_REG_WOL_PATTERN_LEN1 0xC04
|
|
-#define IPQESS_WOL_PT4_LEN_SHIFT 0
|
|
-#define IPQESS_WOL_PT5_LEN_SHIFT 8
|
|
-#define IPQESS_WOL_PT6_LEN_SHIFT 16
|
|
-
|
|
-/* WoL Control Register */
|
|
-#define IPQESS_REG_WOL_CTRL 0xC08
|
|
-#define IPQESS_WOL_WK_EN 0x00000001
|
|
-#define IPQESS_WOL_MG_EN 0x00000002
|
|
-#define IPQESS_WOL_PT0_EN 0x00000004
|
|
-#define IPQESS_WOL_PT1_EN 0x00000008
|
|
-#define IPQESS_WOL_PT2_EN 0x00000010
|
|
-#define IPQESS_WOL_PT3_EN 0x00000020
|
|
-#define IPQESS_WOL_PT4_EN 0x00000040
|
|
-#define IPQESS_WOL_PT5_EN 0x00000080
|
|
-#define IPQESS_WOL_PT6_EN 0x00000100
|
|
-
|
|
-/* MAC Control Register */
|
|
-#define IPQESS_REG_MAC_CTRL0 0xC20
|
|
-#define IPQESS_REG_MAC_CTRL1 0xC24
|
|
-
|
|
-/* WoL Pattern Register */
|
|
-#define IPQESS_REG_WOL_PATTERN_START 0x5000
|
|
-#define IPQESS_PATTERN_PART_REG_OFFSET 0x40
|
|
-
|
|
-
|
|
-/* TX descriptor fields */
|
|
-#define IPQESS_TPD_HDR_SHIFT 0
|
|
-#define IPQESS_TPD_PPPOE_EN 0x00000100
|
|
-#define IPQESS_TPD_IP_CSUM_EN 0x00000200
|
|
-#define IPQESS_TPD_TCP_CSUM_EN 0x0000400
|
|
-#define IPQESS_TPD_UDP_CSUM_EN 0x00000800
|
|
-#define IPQESS_TPD_CUSTOM_CSUM_EN 0x00000C00
|
|
-#define IPQESS_TPD_LSO_EN 0x00001000
|
|
-#define IPQESS_TPD_LSO_V2_EN 0x00002000
|
|
-/* The VLAN_TAGGED bit is not used in the publicly available
|
|
- * drivers. The definition has been stolen from the Atheros
|
|
- * 'alx' driver (drivers/net/ethernet/atheros/alx/hw.h). It
|
|
- * seems that it has the same meaning in regard to the EDMA
|
|
- * hardware.
|
|
- */
|
|
-#define IPQESS_TPD_VLAN_TAGGED 0x00004000
|
|
-#define IPQESS_TPD_IPV4_EN 0x00010000
|
|
-#define IPQESS_TPD_MSS_MASK 0x1FFF
|
|
-#define IPQESS_TPD_MSS_SHIFT 18
|
|
-#define IPQESS_TPD_CUSTOM_CSUM_SHIFT 18
|
|
-
|
|
-/* RRD descriptor fields */
|
|
-#define IPQESS_RRD_NUM_RFD_MASK 0x000F
|
|
-#define IPQESS_RRD_PKT_SIZE_MASK 0x3FFF
|
|
-#define IPQESS_RRD_SRC_PORT_NUM_MASK 0x4000
|
|
-#define IPQESS_RRD_SVLAN 0x8000
|
|
-#define IPQESS_RRD_FLOW_COOKIE_MASK 0x07FF;
|
|
-
|
|
-#define IPQESS_RRD_PKT_SIZE_MASK 0x3FFF
|
|
-#define IPQESS_RRD_CSUM_FAIL_MASK 0xC000
|
|
-#define IPQESS_RRD_CVLAN 0x0001
|
|
-#define IPQESS_RRD_DESC_VALID 0x8000
|
|
-
|
|
-#define IPQESS_RRD_PRIORITY_SHIFT 4
|
|
-#define IPQESS_RRD_PRIORITY_MASK 0x7
|
|
-#define IPQESS_RRD_PORT_TYPE_SHIFT 7
|
|
-#define IPQESS_RRD_PORT_TYPE_MASK 0x1F
|
|
-
|
|
-#endif
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess_ethtool.c b/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess_ethtool.c
|
|
deleted file mode 100644
|
|
index da5fb4deed..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/ethernet/qualcomm/ipqess/ipqess_ethtool.c
|
|
+++ /dev/null
|
|
@@ -1,175 +0,0 @@
|
|
-// SPDX-License-Identifier: (GPL-2.0 OR ISC)
|
|
-/* Copyright (c) 2015 - 2016, The Linux Foundation. All rights reserved.
|
|
- * Copyright (c) 2017 - 2018, John Crispin <john@phrozen.org>
|
|
- *
|
|
- * Permission to use, copy, modify, and/or distribute this software for
|
|
- * any purpose with or without fee is hereby granted, provided that the
|
|
- * above copyright notice and this permission notice appear in all copies.
|
|
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
|
|
- * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
- */
|
|
-
|
|
-#include <linux/ethtool.h>
|
|
-#include <linux/netdevice.h>
|
|
-#include <linux/string.h>
|
|
-#include <linux/phylink.h>
|
|
-
|
|
-#include "ipqess.h"
|
|
-
|
|
-struct ipqesstool_stats {
|
|
- uint8_t string[ETH_GSTRING_LEN];
|
|
- uint32_t offset;
|
|
-};
|
|
-
|
|
-#define IPQESS_STAT(m) offsetof(struct ipqesstool_statistics, m)
|
|
-#define DRVINFO_LEN 32
|
|
-
|
|
-static const struct ipqesstool_stats ipqess_stats[] = {
|
|
- {"tx_q0_pkt", IPQESS_STAT(tx_q0_pkt)},
|
|
- {"tx_q1_pkt", IPQESS_STAT(tx_q1_pkt)},
|
|
- {"tx_q2_pkt", IPQESS_STAT(tx_q2_pkt)},
|
|
- {"tx_q3_pkt", IPQESS_STAT(tx_q3_pkt)},
|
|
- {"tx_q4_pkt", IPQESS_STAT(tx_q4_pkt)},
|
|
- {"tx_q5_pkt", IPQESS_STAT(tx_q5_pkt)},
|
|
- {"tx_q6_pkt", IPQESS_STAT(tx_q6_pkt)},
|
|
- {"tx_q7_pkt", IPQESS_STAT(tx_q7_pkt)},
|
|
- {"tx_q8_pkt", IPQESS_STAT(tx_q8_pkt)},
|
|
- {"tx_q9_pkt", IPQESS_STAT(tx_q9_pkt)},
|
|
- {"tx_q10_pkt", IPQESS_STAT(tx_q10_pkt)},
|
|
- {"tx_q11_pkt", IPQESS_STAT(tx_q11_pkt)},
|
|
- {"tx_q12_pkt", IPQESS_STAT(tx_q12_pkt)},
|
|
- {"tx_q13_pkt", IPQESS_STAT(tx_q13_pkt)},
|
|
- {"tx_q14_pkt", IPQESS_STAT(tx_q14_pkt)},
|
|
- {"tx_q15_pkt", IPQESS_STAT(tx_q15_pkt)},
|
|
- {"tx_q0_byte", IPQESS_STAT(tx_q0_byte)},
|
|
- {"tx_q1_byte", IPQESS_STAT(tx_q1_byte)},
|
|
- {"tx_q2_byte", IPQESS_STAT(tx_q2_byte)},
|
|
- {"tx_q3_byte", IPQESS_STAT(tx_q3_byte)},
|
|
- {"tx_q4_byte", IPQESS_STAT(tx_q4_byte)},
|
|
- {"tx_q5_byte", IPQESS_STAT(tx_q5_byte)},
|
|
- {"tx_q6_byte", IPQESS_STAT(tx_q6_byte)},
|
|
- {"tx_q7_byte", IPQESS_STAT(tx_q7_byte)},
|
|
- {"tx_q8_byte", IPQESS_STAT(tx_q8_byte)},
|
|
- {"tx_q9_byte", IPQESS_STAT(tx_q9_byte)},
|
|
- {"tx_q10_byte", IPQESS_STAT(tx_q10_byte)},
|
|
- {"tx_q11_byte", IPQESS_STAT(tx_q11_byte)},
|
|
- {"tx_q12_byte", IPQESS_STAT(tx_q12_byte)},
|
|
- {"tx_q13_byte", IPQESS_STAT(tx_q13_byte)},
|
|
- {"tx_q14_byte", IPQESS_STAT(tx_q14_byte)},
|
|
- {"tx_q15_byte", IPQESS_STAT(tx_q15_byte)},
|
|
- {"rx_q0_pkt", IPQESS_STAT(rx_q0_pkt)},
|
|
- {"rx_q1_pkt", IPQESS_STAT(rx_q1_pkt)},
|
|
- {"rx_q2_pkt", IPQESS_STAT(rx_q2_pkt)},
|
|
- {"rx_q3_pkt", IPQESS_STAT(rx_q3_pkt)},
|
|
- {"rx_q4_pkt", IPQESS_STAT(rx_q4_pkt)},
|
|
- {"rx_q5_pkt", IPQESS_STAT(rx_q5_pkt)},
|
|
- {"rx_q6_pkt", IPQESS_STAT(rx_q6_pkt)},
|
|
- {"rx_q7_pkt", IPQESS_STAT(rx_q7_pkt)},
|
|
- {"rx_q0_byte", IPQESS_STAT(rx_q0_byte)},
|
|
- {"rx_q1_byte", IPQESS_STAT(rx_q1_byte)},
|
|
- {"rx_q2_byte", IPQESS_STAT(rx_q2_byte)},
|
|
- {"rx_q3_byte", IPQESS_STAT(rx_q3_byte)},
|
|
- {"rx_q4_byte", IPQESS_STAT(rx_q4_byte)},
|
|
- {"rx_q5_byte", IPQESS_STAT(rx_q5_byte)},
|
|
- {"rx_q6_byte", IPQESS_STAT(rx_q6_byte)},
|
|
- {"rx_q7_byte", IPQESS_STAT(rx_q7_byte)},
|
|
- {"tx_desc_error", IPQESS_STAT(tx_desc_error)},
|
|
-};
|
|
-
|
|
-static int ipqess_get_strset_count(struct net_device *netdev, int sset)
|
|
-{
|
|
- switch (sset) {
|
|
- case ETH_SS_STATS:
|
|
- return ARRAY_SIZE(ipqess_stats);
|
|
- default:
|
|
- netdev_dbg(netdev, "%s: Invalid string set", __func__);
|
|
- return -EOPNOTSUPP;
|
|
- }
|
|
-}
|
|
-
|
|
-static void ipqess_get_strings(struct net_device *netdev, uint32_t stringset,
|
|
- uint8_t *data)
|
|
-{
|
|
- uint8_t *p = data;
|
|
- uint32_t i;
|
|
-
|
|
- switch (stringset) {
|
|
- case ETH_SS_STATS:
|
|
- for (i = 0; i < ARRAY_SIZE(ipqess_stats); i++) {
|
|
- memcpy(p, ipqess_stats[i].string,
|
|
- min((size_t)ETH_GSTRING_LEN,
|
|
- strlen(ipqess_stats[i].string) + 1));
|
|
- p += ETH_GSTRING_LEN;
|
|
- }
|
|
- break;
|
|
- }
|
|
-}
|
|
-
|
|
-static void ipqess_get_ethtool_stats(struct net_device *netdev,
|
|
- struct ethtool_stats *stats,
|
|
- uint64_t *data)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
- u32 *essstats = (u32 *)&ess->ipqessstats;
|
|
- int i;
|
|
-
|
|
- spin_lock(&ess->stats_lock);
|
|
-
|
|
- ipqess_update_hw_stats(ess);
|
|
-
|
|
- for (i = 0; i < ARRAY_SIZE(ipqess_stats); i++)
|
|
- data[i] = *(u32 *)(essstats + (ipqess_stats[i].offset / sizeof(u32)));
|
|
-
|
|
- spin_unlock(&ess->stats_lock);
|
|
-}
|
|
-
|
|
-static void ipqess_get_drvinfo(struct net_device *dev,
|
|
- struct ethtool_drvinfo *info)
|
|
-{
|
|
- strlcpy(info->driver, "qca_ipqess", DRVINFO_LEN);
|
|
- strlcpy(info->bus_info, "axi", ETHTOOL_BUSINFO_LEN);
|
|
-}
|
|
-
|
|
-static int ipqess_get_settings(struct net_device *netdev,
|
|
- struct ethtool_link_ksettings *cmd)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- return phylink_ethtool_ksettings_get(ess->phylink, cmd);
|
|
-}
|
|
-
|
|
-static int ipqess_set_settings(struct net_device *netdev,
|
|
- const struct ethtool_link_ksettings *cmd)
|
|
-{
|
|
- struct ipqess *ess = netdev_priv(netdev);
|
|
-
|
|
- return phylink_ethtool_ksettings_set(ess->phylink, cmd);
|
|
-}
|
|
-
|
|
-static void ipqess_get_ringparam(struct net_device *netdev,
|
|
- struct ethtool_ringparam *ring)
|
|
-{
|
|
- ring->tx_max_pending = IPQESS_TX_RING_SIZE;
|
|
- ring->rx_max_pending = IPQESS_RX_RING_SIZE;
|
|
-}
|
|
-
|
|
-static const struct ethtool_ops ipqesstool_ops = {
|
|
- .get_drvinfo = &ipqess_get_drvinfo,
|
|
- .get_link = ðtool_op_get_link,
|
|
- .get_link_ksettings = &ipqess_get_settings,
|
|
- .set_link_ksettings = &ipqess_set_settings,
|
|
- .get_strings = &ipqess_get_strings,
|
|
- .get_sset_count = &ipqess_get_strset_count,
|
|
- .get_ethtool_stats = &ipqess_get_ethtool_stats,
|
|
- .get_ringparam = ipqess_get_ringparam,
|
|
-};
|
|
-
|
|
-void ipqess_set_ethtool_ops(struct net_device *netdev)
|
|
-{
|
|
- netdev->ethtool_ops = &ipqesstool_ops;
|
|
-}
|
|
diff --git a/target/linux/ipq40xx/files/drivers/net/phy/qca807x.c b/target/linux/ipq40xx/files/drivers/net/phy/qca807x.c
|
|
deleted file mode 100644
|
|
index 23b0ca74f7..0000000000
|
|
--- a/target/linux/ipq40xx/files/drivers/net/phy/qca807x.c
|
|
+++ /dev/null
|
|
@@ -1,839 +0,0 @@
|
|
-// SPDX-License-Identifier: GPL-2.0-or-later
|
|
-/*
|
|
- * Copyright (c) 2020 Sartura Ltd.
|
|
- *
|
|
- * Author: Robert Marko <robert.marko@sartura.hr>
|
|
- *
|
|
- * Qualcomm QCA8072 and QCA8075 PHY driver
|
|
- */
|
|
-
|
|
-#include <linux/version.h>
|
|
-#include <linux/module.h>
|
|
-#include <linux/of.h>
|
|
-#include <linux/phy.h>
|
|
-#include <linux/bitfield.h>
|
|
-#include <linux/ethtool_netlink.h>
|
|
-#include <linux/gpio.h>
|
|
-#include <linux/sfp.h>
|
|
-
|
|
-#include <dt-bindings/net/qcom-qca807x.h>
|
|
-
|
|
-#define PHY_ID_QCA8072 0x004dd0b2
|
|
-#define PHY_ID_QCA8075 0x004dd0b1
|
|
-#define PHY_ID_QCA807X_PSGMII 0x06820805
|
|
-
|
|
-/* Downshift */
|
|
-#define QCA807X_SMARTSPEED_EN BIT(5)
|
|
-#define QCA807X_SMARTSPEED_RETRY_LIMIT_MASK GENMASK(4, 2)
|
|
-#define QCA807X_SMARTSPEED_RETRY_LIMIT_DEFAULT 5
|
|
-#define QCA807X_SMARTSPEED_RETRY_LIMIT_MIN 2
|
|
-#define QCA807X_SMARTSPEED_RETRY_LIMIT_MAX 9
|
|
-
|
|
-/* Cable diagnostic test (CDT) */
|
|
-#define QCA807X_CDT 0x16
|
|
-#define QCA807X_CDT_ENABLE BIT(15)
|
|
-#define QCA807X_CDT_ENABLE_INTER_PAIR_SHORT BIT(13)
|
|
-#define QCA807X_CDT_STATUS BIT(11)
|
|
-#define QCA807X_CDT_MMD3_STATUS 0x8064
|
|
-#define QCA807X_CDT_MDI0_STATUS_MASK GENMASK(15, 12)
|
|
-#define QCA807X_CDT_MDI1_STATUS_MASK GENMASK(11, 8)
|
|
-#define QCA807X_CDT_MDI2_STATUS_MASK GENMASK(7, 4)
|
|
-#define QCA807X_CDT_MDI3_STATUS_MASK GENMASK(3, 0)
|
|
-#define QCA807X_CDT_RESULTS_INVALID 0x0
|
|
-#define QCA807X_CDT_RESULTS_OK 0x1
|
|
-#define QCA807X_CDT_RESULTS_OPEN 0x2
|
|
-#define QCA807X_CDT_RESULTS_SAME_SHORT 0x3
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OK 0x4
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OK 0x8
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OK 0xc
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OPEN 0x6
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OPEN 0xa
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OPEN 0xe
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_SHORT 0x7
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_SHORT 0xb
|
|
-#define QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_SHORT 0xf
|
|
-#define QCA807X_CDT_RESULTS_BUSY 0x9
|
|
-#define QCA807X_CDT_MMD3_MDI0_LENGTH 0x8065
|
|
-#define QCA807X_CDT_MMD3_MDI1_LENGTH 0x8066
|
|
-#define QCA807X_CDT_MMD3_MDI2_LENGTH 0x8067
|
|
-#define QCA807X_CDT_MMD3_MDI3_LENGTH 0x8068
|
|
-#define QCA807X_CDT_SAME_SHORT_LENGTH_MASK GENMASK(15, 8)
|
|
-#define QCA807X_CDT_CROSS_SHORT_LENGTH_MASK GENMASK(7, 0)
|
|
-
|
|
-#define QCA807X_CHIP_CONFIGURATION 0x1f
|
|
-#define QCA807X_BT_BX_REG_SEL BIT(15)
|
|
-#define QCA807X_BT_BX_REG_SEL_FIBER 0
|
|
-#define QCA807X_BT_BX_REG_SEL_COPPER 1
|
|
-#define QCA807X_CHIP_CONFIGURATION_MODE_CFG_MASK GENMASK(3, 0)
|
|
-#define QCA807X_CHIP_CONFIGURATION_MODE_QSGMII_SGMII 4
|
|
-#define QCA807X_CHIP_CONFIGURATION_MODE_PSGMII_FIBER 3
|
|
-#define QCA807X_CHIP_CONFIGURATION_MODE_PSGMII_ALL_COPPER 0
|
|
-
|
|
-#define QCA807X_MEDIA_SELECT_STATUS 0x1a
|
|
-#define QCA807X_MEDIA_DETECTED_COPPER BIT(5)
|
|
-#define QCA807X_MEDIA_DETECTED_1000_BASE_X BIT(4)
|
|
-#define QCA807X_MEDIA_DETECTED_100_BASE_FX BIT(3)
|
|
-
|
|
-#define QCA807X_MMD7_FIBER_MODE_AUTO_DETECTION 0x807e
|
|
-#define QCA807X_MMD7_FIBER_MODE_AUTO_DETECTION_EN BIT(0)
|
|
-
|
|
-#define QCA807X_MMD7_1000BASE_T_POWER_SAVE_PER_CABLE_LENGTH 0x801a
|
|
-#define QCA807X_CONTROL_DAC_MASK GENMASK(2, 0)
|
|
-
|
|
-#define QCA807X_MMD7_LED_100N_1 0x8074
|
|
-#define QCA807X_MMD7_LED_100N_2 0x8075
|
|
-#define QCA807X_MMD7_LED_1000N_1 0x8076
|
|
-#define QCA807X_MMD7_LED_1000N_2 0x8077
|
|
-#define QCA807X_LED_TXACT_BLK_EN_2 BIT(10)
|
|
-#define QCA807X_LED_RXACT_BLK_EN_2 BIT(9)
|
|
-#define QCA807X_LED_GT_ON_EN_2 BIT(6)
|
|
-#define QCA807X_LED_HT_ON_EN_2 BIT(5)
|
|
-#define QCA807X_LED_BT_ON_EN_2 BIT(4)
|
|
-#define QCA807X_GPIO_FORCE_EN BIT(15)
|
|
-#define QCA807X_GPIO_FORCE_MODE_MASK GENMASK(14, 13)
|
|
-
|
|
-#define QCA807X_INTR_ENABLE 0x12
|
|
-#define QCA807X_INTR_STATUS 0x13
|
|
-#define QCA807X_INTR_ENABLE_AUTONEG_ERR BIT(15)
|
|
-#define QCA807X_INTR_ENABLE_SPEED_CHANGED BIT(14)
|
|
-#define QCA807X_INTR_ENABLE_DUPLEX_CHANGED BIT(13)
|
|
-#define QCA807X_INTR_ENABLE_LINK_FAIL BIT(11)
|
|
-#define QCA807X_INTR_ENABLE_LINK_SUCCESS BIT(10)
|
|
-
|
|
-#define QCA807X_FUNCTION_CONTROL 0x10
|
|
-#define QCA807X_FC_MDI_CROSSOVER_MODE_MASK GENMASK(6, 5)
|
|
-#define QCA807X_FC_MDI_CROSSOVER_AUTO 3
|
|
-#define QCA807X_FC_MDI_CROSSOVER_MANUAL_MDIX 1
|
|
-#define QCA807X_FC_MDI_CROSSOVER_MANUAL_MDI 0
|
|
-
|
|
-#define QCA807X_PHY_SPECIFIC_STATUS 0x11
|
|
-#define QCA807X_SS_SPEED_AND_DUPLEX_RESOLVED BIT(11)
|
|
-#define QCA807X_SS_SPEED_MASK GENMASK(15, 14)
|
|
-#define QCA807X_SS_SPEED_1000 2
|
|
-#define QCA807X_SS_SPEED_100 1
|
|
-#define QCA807X_SS_SPEED_10 0
|
|
-#define QCA807X_SS_DUPLEX BIT(13)
|
|
-#define QCA807X_SS_MDIX BIT(6)
|
|
-
|
|
-/* PSGMII PHY specific */
|
|
-#define PSGMII_QSGMII_DRIVE_CONTROL_1 0xb
|
|
-#define PSGMII_QSGMII_TX_DRIVER_MASK GENMASK(7, 4)
|
|
-#define PSGMII_MODE_CTRL 0x6d
|
|
-#define PSGMII_MODE_CTRL_AZ_WORKAROUND_MASK BIT(0)
|
|
-#define PSGMII_MMD3_SERDES_CONTROL 0x805a
|
|
-
|
|
-struct qca807x_gpio_priv {
|
|
- struct phy_device *phy;
|
|
-};
|
|
-
|
|
-static int qca807x_get_downshift(struct phy_device *phydev, u8 *data)
|
|
-{
|
|
- int val, cnt, enable;
|
|
-
|
|
- val = phy_read(phydev, MII_NWAYTEST);
|
|
- if (val < 0)
|
|
- return val;
|
|
-
|
|
- enable = FIELD_GET(QCA807X_SMARTSPEED_EN, val);
|
|
- cnt = FIELD_GET(QCA807X_SMARTSPEED_RETRY_LIMIT_MASK, val) + 2;
|
|
-
|
|
- *data = enable ? cnt : DOWNSHIFT_DEV_DISABLE;
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_set_downshift(struct phy_device *phydev, u8 cnt)
|
|
-{
|
|
- int ret, val;
|
|
-
|
|
- if (cnt > QCA807X_SMARTSPEED_RETRY_LIMIT_MAX ||
|
|
- (cnt < QCA807X_SMARTSPEED_RETRY_LIMIT_MIN && cnt != DOWNSHIFT_DEV_DISABLE))
|
|
- return -EINVAL;
|
|
-
|
|
- if (!cnt) {
|
|
- ret = phy_clear_bits(phydev, MII_NWAYTEST, QCA807X_SMARTSPEED_EN);
|
|
- } else {
|
|
- val = QCA807X_SMARTSPEED_EN;
|
|
- val |= FIELD_PREP(QCA807X_SMARTSPEED_RETRY_LIMIT_MASK, cnt - 2);
|
|
-
|
|
- phy_modify(phydev, MII_NWAYTEST,
|
|
- QCA807X_SMARTSPEED_EN |
|
|
- QCA807X_SMARTSPEED_RETRY_LIMIT_MASK,
|
|
- val);
|
|
- }
|
|
-
|
|
- ret = genphy_soft_reset(phydev);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int qca807x_get_tunable(struct phy_device *phydev,
|
|
- struct ethtool_tunable *tuna, void *data)
|
|
-{
|
|
- switch (tuna->id) {
|
|
- case ETHTOOL_PHY_DOWNSHIFT:
|
|
- return qca807x_get_downshift(phydev, data);
|
|
- default:
|
|
- return -EOPNOTSUPP;
|
|
- }
|
|
-}
|
|
-
|
|
-static int qca807x_set_tunable(struct phy_device *phydev,
|
|
- struct ethtool_tunable *tuna, const void *data)
|
|
-{
|
|
- switch (tuna->id) {
|
|
- case ETHTOOL_PHY_DOWNSHIFT:
|
|
- return qca807x_set_downshift(phydev, *(const u8 *)data);
|
|
- default:
|
|
- return -EOPNOTSUPP;
|
|
- }
|
|
-}
|
|
-
|
|
-static bool qca807x_distance_valid(int result)
|
|
-{
|
|
- switch (result) {
|
|
- case QCA807X_CDT_RESULTS_OPEN:
|
|
- case QCA807X_CDT_RESULTS_SAME_SHORT:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_SHORT:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_SHORT:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_SHORT:
|
|
- return true;
|
|
- }
|
|
- return false;
|
|
-}
|
|
-
|
|
-static int qca807x_report_length(struct phy_device *phydev,
|
|
- int pair, int result)
|
|
-{
|
|
- int length;
|
|
- int ret;
|
|
-
|
|
- ret = phy_read_mmd(phydev, MDIO_MMD_PCS, QCA807X_CDT_MMD3_MDI0_LENGTH + pair);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
-
|
|
- switch (result) {
|
|
- case ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT:
|
|
- length = (FIELD_GET(QCA807X_CDT_SAME_SHORT_LENGTH_MASK, ret) * 800) / 10;
|
|
- break;
|
|
- case ETHTOOL_A_CABLE_RESULT_CODE_OPEN:
|
|
- case ETHTOOL_A_CABLE_RESULT_CODE_CROSS_SHORT:
|
|
- length = (FIELD_GET(QCA807X_CDT_CROSS_SHORT_LENGTH_MASK, ret) * 800) / 10;
|
|
- break;
|
|
- }
|
|
-
|
|
- ethnl_cable_test_fault_length(phydev, pair, length);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_cable_test_report_trans(int result)
|
|
-{
|
|
- switch (result) {
|
|
- case QCA807X_CDT_RESULTS_OK:
|
|
- return ETHTOOL_A_CABLE_RESULT_CODE_OK;
|
|
- case QCA807X_CDT_RESULTS_OPEN:
|
|
- return ETHTOOL_A_CABLE_RESULT_CODE_OPEN;
|
|
- case QCA807X_CDT_RESULTS_SAME_SHORT:
|
|
- return ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT;
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OK:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_OPEN:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI1_SAME_SHORT:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI2_SAME_SHORT:
|
|
- case QCA807X_CDT_RESULTS_CROSS_SHORT_WITH_MDI3_SAME_SHORT:
|
|
- return ETHTOOL_A_CABLE_RESULT_CODE_CROSS_SHORT;
|
|
- default:
|
|
- return ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC;
|
|
- }
|
|
-}
|
|
-
|
|
-static int qca807x_cable_test_report(struct phy_device *phydev)
|
|
-{
|
|
- int pair0, pair1, pair2, pair3;
|
|
- int ret;
|
|
-
|
|
- ret = phy_read_mmd(phydev, MDIO_MMD_PCS, QCA807X_CDT_MMD3_STATUS);
|
|
- if (ret < 0)
|
|
- return ret;
|
|
-
|
|
- pair0 = FIELD_GET(QCA807X_CDT_MDI0_STATUS_MASK, ret);
|
|
- pair1 = FIELD_GET(QCA807X_CDT_MDI1_STATUS_MASK, ret);
|
|
- pair2 = FIELD_GET(QCA807X_CDT_MDI2_STATUS_MASK, ret);
|
|
- pair3 = FIELD_GET(QCA807X_CDT_MDI3_STATUS_MASK, ret);
|
|
-
|
|
- ethnl_cable_test_result(phydev, ETHTOOL_A_CABLE_PAIR_A,
|
|
- qca807x_cable_test_report_trans(pair0));
|
|
- ethnl_cable_test_result(phydev, ETHTOOL_A_CABLE_PAIR_B,
|
|
- qca807x_cable_test_report_trans(pair1));
|
|
- ethnl_cable_test_result(phydev, ETHTOOL_A_CABLE_PAIR_C,
|
|
- qca807x_cable_test_report_trans(pair2));
|
|
- ethnl_cable_test_result(phydev, ETHTOOL_A_CABLE_PAIR_D,
|
|
- qca807x_cable_test_report_trans(pair3));
|
|
-
|
|
- if (qca807x_distance_valid(pair0))
|
|
- qca807x_report_length(phydev, 0, qca807x_cable_test_report_trans(pair0));
|
|
- if (qca807x_distance_valid(pair1))
|
|
- qca807x_report_length(phydev, 1, qca807x_cable_test_report_trans(pair1));
|
|
- if (qca807x_distance_valid(pair2))
|
|
- qca807x_report_length(phydev, 2, qca807x_cable_test_report_trans(pair2));
|
|
- if (qca807x_distance_valid(pair3))
|
|
- qca807x_report_length(phydev, 3, qca807x_cable_test_report_trans(pair3));
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_cable_test_get_status(struct phy_device *phydev,
|
|
- bool *finished)
|
|
-{
|
|
- int val;
|
|
-
|
|
- *finished = false;
|
|
-
|
|
- val = phy_read(phydev, QCA807X_CDT);
|
|
- if (!((val & QCA807X_CDT_ENABLE) && (val & QCA807X_CDT_STATUS))) {
|
|
- *finished = true;
|
|
-
|
|
- return qca807x_cable_test_report(phydev);
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_cable_test_start(struct phy_device *phydev)
|
|
-{
|
|
- int val, ret;
|
|
-
|
|
- val = phy_read(phydev, QCA807X_CDT);
|
|
- /* Enable inter-pair short check as well */
|
|
- val &= ~QCA807X_CDT_ENABLE_INTER_PAIR_SHORT;
|
|
- val |= QCA807X_CDT_ENABLE;
|
|
- ret = phy_write(phydev, QCA807X_CDT, val);
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-#ifdef CONFIG_GPIOLIB
|
|
-static int qca807x_gpio_get_direction(struct gpio_chip *gc, unsigned int offset)
|
|
-{
|
|
- return GPIO_LINE_DIRECTION_OUT;
|
|
-}
|
|
-
|
|
-static int qca807x_gpio_get_reg(unsigned int offset)
|
|
-{
|
|
- return QCA807X_MMD7_LED_100N_2 + (offset % 2) * 2;
|
|
-}
|
|
-
|
|
-static int qca807x_gpio_get(struct gpio_chip *gc, unsigned int offset)
|
|
-{
|
|
- struct qca807x_gpio_priv *priv = gpiochip_get_data(gc);
|
|
- int val;
|
|
-
|
|
- val = phy_read_mmd(priv->phy, MDIO_MMD_AN, qca807x_gpio_get_reg(offset));
|
|
-
|
|
- return FIELD_GET(QCA807X_GPIO_FORCE_MODE_MASK, val);
|
|
-}
|
|
-
|
|
-static void qca807x_gpio_set(struct gpio_chip *gc, unsigned int offset, int value)
|
|
-{
|
|
- struct qca807x_gpio_priv *priv = gpiochip_get_data(gc);
|
|
- int val;
|
|
-
|
|
- val = phy_read_mmd(priv->phy, MDIO_MMD_AN, qca807x_gpio_get_reg(offset));
|
|
- val &= ~QCA807X_GPIO_FORCE_MODE_MASK;
|
|
- val |= QCA807X_GPIO_FORCE_EN;
|
|
- val |= FIELD_PREP(QCA807X_GPIO_FORCE_MODE_MASK, value);
|
|
-
|
|
- phy_write_mmd(priv->phy, MDIO_MMD_AN, qca807x_gpio_get_reg(offset), val);
|
|
-}
|
|
-
|
|
-static int qca807x_gpio_dir_out(struct gpio_chip *gc, unsigned int offset, int value)
|
|
-{
|
|
- qca807x_gpio_set(gc, offset, value);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_gpio(struct phy_device *phydev)
|
|
-{
|
|
- struct device *dev = &phydev->mdio.dev;
|
|
- struct qca807x_gpio_priv *priv;
|
|
- struct gpio_chip *gc;
|
|
-
|
|
- priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
|
|
- if (!priv)
|
|
- return -ENOMEM;
|
|
-
|
|
- priv->phy = phydev;
|
|
-
|
|
- gc = devm_kzalloc(dev, sizeof(*gc), GFP_KERNEL);
|
|
- if (!gc)
|
|
- return -ENOMEM;
|
|
-
|
|
- gc->label = dev_name(dev);
|
|
- gc->base = -1;
|
|
- gc->ngpio = 2;
|
|
- gc->parent = dev;
|
|
- gc->owner = THIS_MODULE;
|
|
- gc->can_sleep = true;
|
|
- gc->get_direction = qca807x_gpio_get_direction;
|
|
- gc->direction_output = qca807x_gpio_dir_out;
|
|
- gc->get = qca807x_gpio_get;
|
|
- gc->set = qca807x_gpio_set;
|
|
-
|
|
- return devm_gpiochip_add_data(dev, gc, priv);
|
|
-}
|
|
-#endif
|
|
-
|
|
-static int qca807x_read_copper_status(struct phy_device *phydev)
|
|
-{
|
|
- int ss, err, old_link = phydev->link;
|
|
-
|
|
- /* Update the link, but return if there was an error */
|
|
- err = genphy_update_link(phydev);
|
|
- if (err)
|
|
- return err;
|
|
-
|
|
- /* why bother the PHY if nothing can have changed */
|
|
- if (phydev->autoneg == AUTONEG_ENABLE && old_link && phydev->link)
|
|
- return 0;
|
|
-
|
|
- phydev->speed = SPEED_UNKNOWN;
|
|
- phydev->duplex = DUPLEX_UNKNOWN;
|
|
- phydev->pause = 0;
|
|
- phydev->asym_pause = 0;
|
|
-
|
|
- err = genphy_read_lpa(phydev);
|
|
- if (err < 0)
|
|
- return err;
|
|
-
|
|
- /* Read the QCA807x PHY-Specific Status register copper page,
|
|
- * which indicates the speed and duplex that the PHY is actually
|
|
- * using, irrespective of whether we are in autoneg mode or not.
|
|
- */
|
|
- ss = phy_read(phydev, QCA807X_PHY_SPECIFIC_STATUS);
|
|
- if (ss < 0)
|
|
- return ss;
|
|
-
|
|
- if (ss & QCA807X_SS_SPEED_AND_DUPLEX_RESOLVED) {
|
|
- int sfc;
|
|
-
|
|
- sfc = phy_read(phydev, QCA807X_FUNCTION_CONTROL);
|
|
- if (sfc < 0)
|
|
- return sfc;
|
|
-
|
|
- switch (FIELD_GET(QCA807X_SS_SPEED_MASK, ss)) {
|
|
- case QCA807X_SS_SPEED_10:
|
|
- phydev->speed = SPEED_10;
|
|
- break;
|
|
- case QCA807X_SS_SPEED_100:
|
|
- phydev->speed = SPEED_100;
|
|
- break;
|
|
- case QCA807X_SS_SPEED_1000:
|
|
- phydev->speed = SPEED_1000;
|
|
- break;
|
|
- }
|
|
- if (ss & QCA807X_SS_DUPLEX)
|
|
- phydev->duplex = DUPLEX_FULL;
|
|
- else
|
|
- phydev->duplex = DUPLEX_HALF;
|
|
-
|
|
- if (ss & QCA807X_SS_MDIX)
|
|
- phydev->mdix = ETH_TP_MDI_X;
|
|
- else
|
|
- phydev->mdix = ETH_TP_MDI;
|
|
-
|
|
- switch (FIELD_GET(QCA807X_FC_MDI_CROSSOVER_MODE_MASK, sfc)) {
|
|
- case QCA807X_FC_MDI_CROSSOVER_MANUAL_MDI:
|
|
- phydev->mdix_ctrl = ETH_TP_MDI;
|
|
- break;
|
|
- case QCA807X_FC_MDI_CROSSOVER_MANUAL_MDIX:
|
|
- phydev->mdix_ctrl = ETH_TP_MDI_X;
|
|
- break;
|
|
- case QCA807X_FC_MDI_CROSSOVER_AUTO:
|
|
- phydev->mdix_ctrl = ETH_TP_MDI_AUTO;
|
|
- break;
|
|
- }
|
|
- }
|
|
-
|
|
- if (phydev->autoneg == AUTONEG_ENABLE && phydev->autoneg_complete)
|
|
- phy_resolve_aneg_pause(phydev);
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_read_fiber_status(struct phy_device *phydev)
|
|
-{
|
|
- int ss, err, lpa, old_link = phydev->link;
|
|
-
|
|
- /* Update the link, but return if there was an error */
|
|
- err = genphy_update_link(phydev);
|
|
- if (err)
|
|
- return err;
|
|
-
|
|
- /* why bother the PHY if nothing can have changed */
|
|
- if (phydev->autoneg == AUTONEG_ENABLE && old_link && phydev->link)
|
|
- return 0;
|
|
-
|
|
- phydev->speed = SPEED_UNKNOWN;
|
|
- phydev->duplex = DUPLEX_UNKNOWN;
|
|
- phydev->pause = 0;
|
|
- phydev->asym_pause = 0;
|
|
-
|
|
- if (phydev->autoneg == AUTONEG_ENABLE && phydev->autoneg_complete) {
|
|
- lpa = phy_read(phydev, MII_LPA);
|
|
- if (lpa < 0)
|
|
- return lpa;
|
|
-
|
|
- linkmode_mod_bit(ETHTOOL_LINK_MODE_Autoneg_BIT,
|
|
- phydev->lp_advertising, lpa & LPA_LPACK);
|
|
- linkmode_mod_bit(ETHTOOL_LINK_MODE_1000baseX_Full_BIT,
|
|
- phydev->lp_advertising, lpa & LPA_1000XFULL);
|
|
- linkmode_mod_bit(ETHTOOL_LINK_MODE_Pause_BIT,
|
|
- phydev->lp_advertising, lpa & LPA_1000XPAUSE);
|
|
- linkmode_mod_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT,
|
|
- phydev->lp_advertising,
|
|
- lpa & LPA_1000XPAUSE_ASYM);
|
|
-
|
|
- phy_resolve_aneg_linkmode(phydev);
|
|
- }
|
|
-
|
|
- /* Read the QCA807x PHY-Specific Status register fiber page,
|
|
- * which indicates the speed and duplex that the PHY is actually
|
|
- * using, irrespective of whether we are in autoneg mode or not.
|
|
- */
|
|
- ss = phy_read(phydev, QCA807X_PHY_SPECIFIC_STATUS);
|
|
- if (ss < 0)
|
|
- return ss;
|
|
-
|
|
- if (ss & QCA807X_SS_SPEED_AND_DUPLEX_RESOLVED) {
|
|
- switch (FIELD_GET(QCA807X_SS_SPEED_MASK, ss)) {
|
|
- case QCA807X_SS_SPEED_100:
|
|
- phydev->speed = SPEED_100;
|
|
- break;
|
|
- case QCA807X_SS_SPEED_1000:
|
|
- phydev->speed = SPEED_1000;
|
|
- break;
|
|
- }
|
|
-
|
|
- if (ss & QCA807X_SS_DUPLEX)
|
|
- phydev->duplex = DUPLEX_FULL;
|
|
- else
|
|
- phydev->duplex = DUPLEX_HALF;
|
|
- }
|
|
-
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_read_status(struct phy_device *phydev)
|
|
-{
|
|
- if (linkmode_test_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, phydev->supported)) {
|
|
- switch (phydev->port) {
|
|
- case PORT_FIBRE:
|
|
- return qca807x_read_fiber_status(phydev);
|
|
- case PORT_TP:
|
|
- return qca807x_read_copper_status(phydev);
|
|
- default:
|
|
- return -EINVAL;
|
|
- }
|
|
- } else
|
|
- return qca807x_read_copper_status(phydev);
|
|
-}
|
|
-
|
|
-static int qca807x_config_intr(struct phy_device *phydev)
|
|
-{
|
|
- int ret, val;
|
|
-
|
|
- val = phy_read(phydev, QCA807X_INTR_ENABLE);
|
|
-
|
|
- if (phydev->interrupts == PHY_INTERRUPT_ENABLED) {
|
|
- /* Check for combo port as it has fewer interrupts */
|
|
- if (phy_read(phydev, QCA807X_CHIP_CONFIGURATION)) {
|
|
- val |= QCA807X_INTR_ENABLE_SPEED_CHANGED;
|
|
- val |= QCA807X_INTR_ENABLE_LINK_FAIL;
|
|
- val |= QCA807X_INTR_ENABLE_LINK_SUCCESS;
|
|
- } else {
|
|
- val |= QCA807X_INTR_ENABLE_AUTONEG_ERR;
|
|
- val |= QCA807X_INTR_ENABLE_SPEED_CHANGED;
|
|
- val |= QCA807X_INTR_ENABLE_DUPLEX_CHANGED;
|
|
- val |= QCA807X_INTR_ENABLE_LINK_FAIL;
|
|
- val |= QCA807X_INTR_ENABLE_LINK_SUCCESS;
|
|
- }
|
|
- ret = phy_write(phydev, QCA807X_INTR_ENABLE, val);
|
|
- } else {
|
|
- ret = phy_write(phydev, QCA807X_INTR_ENABLE, 0);
|
|
- }
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static irqreturn_t qca807x_handle_interrupt(struct phy_device *phydev)
|
|
-{
|
|
- int irq_status, int_enabled;
|
|
-
|
|
- irq_status = phy_read(phydev, QCA807X_INTR_STATUS);
|
|
- if (irq_status < 0) {
|
|
- phy_error(phydev);
|
|
- return IRQ_NONE;
|
|
- }
|
|
-
|
|
- /* Read the current enabled interrupts */
|
|
- int_enabled = phy_read(phydev, QCA807X_INTR_ENABLE);
|
|
- if (int_enabled < 0) {
|
|
- phy_error(phydev);
|
|
- return IRQ_NONE;
|
|
- }
|
|
-
|
|
- /* See if this was one of our enabled interrupts */
|
|
- if (!(irq_status & int_enabled))
|
|
- return IRQ_NONE;
|
|
-
|
|
- phy_trigger_machine(phydev);
|
|
-
|
|
- return IRQ_HANDLED;
|
|
-}
|
|
-
|
|
-static int qca807x_led_config(struct phy_device *phydev)
|
|
-{
|
|
- struct device_node *node = phydev->mdio.dev.of_node;
|
|
- bool led_config = false;
|
|
- int val;
|
|
-
|
|
- val = phy_read_mmd(phydev, MDIO_MMD_AN, QCA807X_MMD7_LED_1000N_1);
|
|
- if (val < 0)
|
|
- return val;
|
|
-
|
|
- if (of_property_read_bool(node, "qcom,single-led-1000")) {
|
|
- val |= QCA807X_LED_TXACT_BLK_EN_2;
|
|
- val |= QCA807X_LED_RXACT_BLK_EN_2;
|
|
- val |= QCA807X_LED_GT_ON_EN_2;
|
|
-
|
|
- led_config = true;
|
|
- }
|
|
-
|
|
- if (of_property_read_bool(node, "qcom,single-led-100")) {
|
|
- val |= QCA807X_LED_HT_ON_EN_2;
|
|
-
|
|
- led_config = true;
|
|
- }
|
|
-
|
|
- if (of_property_read_bool(node, "qcom,single-led-10")) {
|
|
- val |= QCA807X_LED_BT_ON_EN_2;
|
|
-
|
|
- led_config = true;
|
|
- }
|
|
-
|
|
- if (led_config)
|
|
- return phy_write_mmd(phydev, MDIO_MMD_AN, QCA807X_MMD7_LED_1000N_1, val);
|
|
- else
|
|
- return 0;
|
|
-}
|
|
-
|
|
-static int qca807x_sfp_insert(void *upstream, const struct sfp_eeprom_id *id)
|
|
-{
|
|
- struct phy_device *phydev = upstream;
|
|
- __ETHTOOL_DECLARE_LINK_MODE_MASK(support) = { 0, };
|
|
- phy_interface_t iface;
|
|
- int ret;
|
|
-
|
|
- sfp_parse_support(phydev->sfp_bus, id, support);
|
|
- iface = sfp_select_interface(phydev->sfp_bus, support);
|
|
-
|
|
- dev_info(&phydev->mdio.dev, "%s SFP module inserted\n", phy_modes(iface));
|
|
-
|
|
- switch (iface) {
|
|
- case PHY_INTERFACE_MODE_1000BASEX:
|
|
- case PHY_INTERFACE_MODE_100BASEX:
|
|
- /* Set PHY mode to PSGMII combo (1/4 copper + combo ports) mode */
|
|
- ret = phy_modify(phydev,
|
|
- QCA807X_CHIP_CONFIGURATION,
|
|
- QCA807X_CHIP_CONFIGURATION_MODE_CFG_MASK,
|
|
- QCA807X_CHIP_CONFIGURATION_MODE_PSGMII_FIBER);
|
|
- /* Enable fiber mode autodection (1000Base-X or 100Base-FX) */
|
|
- ret = phy_set_bits_mmd(phydev,
|
|
- MDIO_MMD_AN,
|
|
- QCA807X_MMD7_FIBER_MODE_AUTO_DETECTION,
|
|
- QCA807X_MMD7_FIBER_MODE_AUTO_DETECTION_EN);
|
|
- /* Select fiber page */
|
|
- ret = phy_clear_bits(phydev,
|
|
- QCA807X_CHIP_CONFIGURATION,
|
|
- QCA807X_BT_BX_REG_SEL);
|
|
-
|
|
- phydev->port = PORT_FIBRE;
|
|
- break;
|
|
- default:
|
|
- dev_err(&phydev->mdio.dev, "Incompatible SFP module inserted\n");
|
|
- return -EINVAL;
|
|
- }
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static void qca807x_sfp_remove(void *upstream)
|
|
-{
|
|
- struct phy_device *phydev = upstream;
|
|
-
|
|
- /* Select copper page */
|
|
- phy_set_bits(phydev,
|
|
- QCA807X_CHIP_CONFIGURATION,
|
|
- QCA807X_BT_BX_REG_SEL);
|
|
-
|
|
- phydev->port = PORT_TP;
|
|
-}
|
|
-
|
|
-static const struct sfp_upstream_ops qca807x_sfp_ops = {
|
|
- .attach = phy_sfp_attach,
|
|
- .detach = phy_sfp_detach,
|
|
- .module_insert = qca807x_sfp_insert,
|
|
- .module_remove = qca807x_sfp_remove,
|
|
-};
|
|
-
|
|
-static int qca807x_config(struct phy_device *phydev)
|
|
-{
|
|
- struct device_node *node = phydev->mdio.dev.of_node;
|
|
- int control_dac, ret = 0;
|
|
- u32 of_control_dac;
|
|
-
|
|
- /* Check for Combo port */
|
|
- if (phy_read(phydev, QCA807X_CHIP_CONFIGURATION)) {
|
|
- int psgmii_serdes;
|
|
-
|
|
- /* Prevent PSGMII going into hibernation via PSGMII self test */
|
|
- psgmii_serdes = phy_read_mmd(phydev, MDIO_MMD_PCS, PSGMII_MMD3_SERDES_CONTROL);
|
|
- psgmii_serdes &= ~BIT(1);
|
|
- ret = phy_write_mmd(phydev, MDIO_MMD_PCS,
|
|
- PSGMII_MMD3_SERDES_CONTROL,
|
|
- psgmii_serdes);
|
|
- }
|
|
-
|
|
- if (!of_property_read_u32(node, "qcom,control-dac", &of_control_dac)) {
|
|
- control_dac = phy_read_mmd(phydev, MDIO_MMD_AN,
|
|
- QCA807X_MMD7_1000BASE_T_POWER_SAVE_PER_CABLE_LENGTH);
|
|
- control_dac &= ~QCA807X_CONTROL_DAC_MASK;
|
|
- control_dac |= FIELD_PREP(QCA807X_CONTROL_DAC_MASK, of_control_dac);
|
|
- ret = phy_write_mmd(phydev, MDIO_MMD_AN,
|
|
- QCA807X_MMD7_1000BASE_T_POWER_SAVE_PER_CABLE_LENGTH,
|
|
- control_dac);
|
|
- }
|
|
-
|
|
- /* Optionally configure LED-s */
|
|
- if (IS_ENABLED(CONFIG_GPIOLIB)) {
|
|
- /* Check whether PHY-s pins are used as GPIO-s */
|
|
- if (!of_property_read_bool(node, "gpio-controller"))
|
|
- ret = qca807x_led_config(phydev);
|
|
- } else {
|
|
- ret = qca807x_led_config(phydev);
|
|
- }
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int qca807x_probe(struct phy_device *phydev)
|
|
-{
|
|
- struct device_node *node = phydev->mdio.dev.of_node;
|
|
- int ret = 0;
|
|
-
|
|
- if (IS_ENABLED(CONFIG_GPIOLIB)) {
|
|
- /* Do not register a GPIO controller unless flagged for it */
|
|
- if (of_property_read_bool(node, "gpio-controller"))
|
|
- ret = qca807x_gpio(phydev);
|
|
- }
|
|
-
|
|
- /* Attach SFP bus on combo port*/
|
|
- if (phy_read(phydev, QCA807X_CHIP_CONFIGURATION)) {
|
|
- ret = phy_sfp_probe(phydev, &qca807x_sfp_ops);
|
|
- linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, phydev->supported);
|
|
- linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, phydev->advertising);
|
|
- }
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static int qca807x_psgmii_config(struct phy_device *phydev)
|
|
-{
|
|
- struct device_node *node = phydev->mdio.dev.of_node;
|
|
- int tx_amp, ret = 0;
|
|
- u32 tx_driver_strength;
|
|
-
|
|
- /* Workaround to enable AZ transmitting ability */
|
|
- ret = phy_clear_bits_mmd(phydev,
|
|
- MDIO_MMD_PMAPMD,
|
|
- PSGMII_MODE_CTRL,
|
|
- PSGMII_MODE_CTRL_AZ_WORKAROUND_MASK);
|
|
-
|
|
- /* PSGMII/QSGMII TX amp set to DT defined value instead of default 600mV */
|
|
- if (!of_property_read_u32(node, "qcom,tx-driver-strength", &tx_driver_strength)) {
|
|
- tx_amp = phy_read(phydev, PSGMII_QSGMII_DRIVE_CONTROL_1);
|
|
- tx_amp &= ~PSGMII_QSGMII_TX_DRIVER_MASK;
|
|
- tx_amp |= FIELD_PREP(PSGMII_QSGMII_TX_DRIVER_MASK, tx_driver_strength);
|
|
- ret = phy_write(phydev, PSGMII_QSGMII_DRIVE_CONTROL_1, tx_amp);
|
|
- }
|
|
-
|
|
- return ret;
|
|
-}
|
|
-
|
|
-static struct phy_driver qca807x_drivers[] = {
|
|
- {
|
|
- PHY_ID_MATCH_EXACT(PHY_ID_QCA8072),
|
|
- .name = "Qualcomm QCA8072",
|
|
- .flags = PHY_POLL_CABLE_TEST,
|
|
- /* PHY_GBIT_FEATURES */
|
|
- .probe = qca807x_probe,
|
|
- .config_init = qca807x_config,
|
|
- .read_status = qca807x_read_status,
|
|
- .config_intr = qca807x_config_intr,
|
|
- .handle_interrupt = qca807x_handle_interrupt,
|
|
- .soft_reset = genphy_soft_reset,
|
|
- .get_tunable = qca807x_get_tunable,
|
|
- .set_tunable = qca807x_set_tunable,
|
|
- .resume = genphy_resume,
|
|
- .suspend = genphy_suspend,
|
|
- .cable_test_start = qca807x_cable_test_start,
|
|
- .cable_test_get_status = qca807x_cable_test_get_status,
|
|
- },
|
|
- {
|
|
- PHY_ID_MATCH_EXACT(PHY_ID_QCA8075),
|
|
- .name = "Qualcomm QCA8075",
|
|
- .flags = PHY_POLL_CABLE_TEST,
|
|
- /* PHY_GBIT_FEATURES */
|
|
- .probe = qca807x_probe,
|
|
- .config_init = qca807x_config,
|
|
- .read_status = qca807x_read_status,
|
|
- .config_intr = qca807x_config_intr,
|
|
- .handle_interrupt = qca807x_handle_interrupt,
|
|
- .soft_reset = genphy_soft_reset,
|
|
- .get_tunable = qca807x_get_tunable,
|
|
- .set_tunable = qca807x_set_tunable,
|
|
- .resume = genphy_resume,
|
|
- .suspend = genphy_suspend,
|
|
- .cable_test_start = qca807x_cable_test_start,
|
|
- .cable_test_get_status = qca807x_cable_test_get_status,
|
|
- },
|
|
- {
|
|
- PHY_ID_MATCH_EXACT(PHY_ID_QCA807X_PSGMII),
|
|
- .name = "Qualcomm QCA807x PSGMII",
|
|
- .probe = qca807x_psgmii_config,
|
|
- },
|
|
-};
|
|
-module_phy_driver(qca807x_drivers);
|
|
-
|
|
-static struct mdio_device_id __maybe_unused qca807x_tbl[] = {
|
|
- { PHY_ID_MATCH_EXACT(PHY_ID_QCA8072) },
|
|
- { PHY_ID_MATCH_EXACT(PHY_ID_QCA8075) },
|
|
- { PHY_ID_MATCH_MODEL(PHY_ID_QCA807X_PSGMII) },
|
|
- { }
|
|
-};
|
|
-
|
|
-MODULE_AUTHOR("Robert Marko");
|
|
-MODULE_DESCRIPTION("Qualcomm QCA807x PHY driver");
|
|
-MODULE_DEVICE_TABLE(mdio, qca807x_tbl);
|
|
-MODULE_LICENSE("GPL");
|
|
diff --git a/target/linux/ipq40xx/generic/target.mk b/target/linux/ipq40xx/generic/target.mk
|
|
deleted file mode 100644
|
|
index 90c1b762af..0000000000
|
|
--- a/target/linux/ipq40xx/generic/target.mk
|
|
+++ /dev/null
|
|
@@ -1,3 +0,0 @@
|
|
-BOARDNAME:=Generic
|
|
-FEATURES+=emmc
|
|
-DEFAULT_PACKAGES += ath10k-board-qca4019
|
|
diff --git a/target/linux/ipq40xx/image/Makefile b/target/linux/ipq40xx/image/Makefile
|
|
deleted file mode 100644
|
|
index 2ba4c779a0..0000000000
|
|
--- a/target/linux/ipq40xx/image/Makefile
|
|
+++ /dev/null
|
|
@@ -1,19 +0,0 @@
|
|
-include $(TOPDIR)/rules.mk
|
|
-include $(INCLUDE_DIR)/image.mk
|
|
-
|
|
-define Device/Default
|
|
- PROFILES := Default
|
|
- KERNEL_DEPENDS = $$(wildcard $(DTS_DIR)/$$(DEVICE_DTS).dts)
|
|
- KERNEL_LOADADDR := 0x80208000
|
|
- DEVICE_DTS = $$(SOC)-$(lastword $(subst _, ,$(1)))
|
|
- DEVICE_DTS_CONFIG := config@1
|
|
- IMAGES := sysupgrade.bin
|
|
- IMAGE/sysupgrade.bin = sysupgrade-tar | append-metadata
|
|
- IMAGE/sysupgrade.bin/squashfs :=
|
|
- DEVICE_COMPAT_VERSION := 1.1
|
|
- DEVICE_COMPAT_MESSAGE := Config cannot be migrated from swconfig to DSA
|
|
-endef
|
|
-
|
|
-include $(SUBTARGET).mk
|
|
-
|
|
-$(eval $(call BuildImage))
|
|
diff --git a/target/linux/ipq40xx/image/chromium.mk b/target/linux/ipq40xx/image/chromium.mk
|
|
deleted file mode 100644
|
|
index f6ac69ecf1..0000000000
|
|
--- a/target/linux/ipq40xx/image/chromium.mk
|
|
+++ /dev/null
|
|
@@ -1,40 +0,0 @@
|
|
-define Build/cros-gpt
|
|
- cp $@ $@.tmp 2>/dev/null || true
|
|
- ptgen -o $@.tmp -g \
|
|
- -T cros_kernel -N kernel -p $(CONFIG_TARGET_KERNEL_PARTSIZE)m \
|
|
- -N rootfs -p $(CONFIG_TARGET_ROOTFS_PARTSIZE)m
|
|
- cat $@.tmp >> $@
|
|
- rm $@.tmp
|
|
-endef
|
|
-
|
|
-define Build/append-kernel-part
|
|
- dd if=$(IMAGE_KERNEL) bs=$(CONFIG_TARGET_KERNEL_PARTSIZE)M conv=sync >> $@
|
|
-endef
|
|
-
|
|
-# NB: Chrome OS bootloaders replace the '%U' in command lines with the UUID of
|
|
-# the kernel partition it chooses to boot from. This gives a flexible way to
|
|
-# consistently build and sign kernels that always use the subsequent
|
|
-# (PARTNROFF=1) partition as their rootfs.
|
|
-define Build/cros-vboot
|
|
- $(STAGING_DIR_HOST)/bin/cros-vbutil \
|
|
- -k $@ -c "root=PARTUUID=%U/PARTNROFF=1" -o $@.new
|
|
- @mv $@.new $@
|
|
-endef
|
|
-
|
|
-define Device/google_wifi
|
|
- DEVICE_VENDOR := Google
|
|
- DEVICE_MODEL := WiFi (Gale)
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SUFFIX := -fit-zImage.itb.vboot
|
|
- KERNEL = kernel-bin | fit none $$(KDIR)/image-$$(DEVICE_DTS).dtb | cros-vboot
|
|
- KERNEL_NAME := zImage
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := cros-gpt | append-kernel-part | append-rootfs
|
|
- # Note: Chromium/Depthcharge-based bootloaders insert a reserved-memory
|
|
- # ramoops node into the Device Tree automatically, so we can use
|
|
- # kmod-ramoops.
|
|
- DEVICE_PACKAGES := partx-utils mkf2fs e2fsprogs \
|
|
- kmod-fs-ext4 kmod-fs-f2fs kmod-google-firmware \
|
|
- kmod-ramoops
|
|
-endef
|
|
-TARGET_DEVICES += google_wifi
|
|
diff --git a/target/linux/ipq40xx/image/generic.mk b/target/linux/ipq40xx/image/generic.mk
|
|
deleted file mode 100644
|
|
index 99a9b78b78..0000000000
|
|
--- a/target/linux/ipq40xx/image/generic.mk
|
|
+++ /dev/null
|
|
@@ -1,1241 +0,0 @@
|
|
-
|
|
-DEVICE_VARS += NETGEAR_BOARD_ID NETGEAR_HW_ID
|
|
-DEVICE_VARS += RAS_BOARD RAS_ROOTFS_SIZE RAS_VERSION
|
|
-DEVICE_VARS += WRGG_DEVNAME WRGG_SIGNATURE
|
|
-
|
|
-define Device/FitImage
|
|
- KERNEL_SUFFIX := -uImage.itb
|
|
- KERNEL = kernel-bin | gzip | fit gzip $$(KDIR)/image-$$(DEVICE_DTS).dtb
|
|
- KERNEL_NAME := Image
|
|
-endef
|
|
-
|
|
-define Device/FitImageLzma
|
|
- KERNEL_SUFFIX := -uImage.itb
|
|
- KERNEL = kernel-bin | lzma | fit lzma $$(KDIR)/image-$$(DEVICE_DTS).dtb
|
|
- KERNEL_NAME := Image
|
|
-endef
|
|
-
|
|
-define Device/FitzImage
|
|
- KERNEL_SUFFIX := -zImage.itb
|
|
- KERNEL = kernel-bin | fit none $$(KDIR)/image-$$(DEVICE_DTS).dtb
|
|
- KERNEL_NAME := zImage
|
|
-endef
|
|
-
|
|
-define Device/UbiFit
|
|
- KERNEL_IN_UBI := 1
|
|
- IMAGES := factory.ubi sysupgrade.bin
|
|
- IMAGE/factory.ubi := append-ubi
|
|
- IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
|
-endef
|
|
-
|
|
-define Device/DniImage
|
|
- $(call Device/FitzImage)
|
|
- NETGEAR_BOARD_ID :=
|
|
- NETGEAR_HW_ID :=
|
|
- IMAGES += factory.img
|
|
- IMAGE/factory.img := append-kernel | pad-offset 64k 64 | append-uImage-fakehdr filesystem | append-rootfs | pad-rootfs | netgear-dni
|
|
- IMAGE/sysupgrade.bin := append-kernel | pad-offset 64k 64 | append-uImage-fakehdr filesystem | \
|
|
- append-rootfs | pad-rootfs | check-size | append-metadata
|
|
-endef
|
|
-
|
|
-define Build/append-rootfshdr
|
|
- mkimage -A $(LINUX_KARCH) \
|
|
- -O linux -T filesystem \
|
|
- -C lzma -a $(KERNEL_LOADADDR) -e $(if $(KERNEL_ENTRY),$(KERNEL_ENTRY),$(KERNEL_LOADADDR)) \
|
|
- -n root.squashfs -d $(IMAGE_ROOTFS) $@.new
|
|
- cat $(IMAGE_KERNEL) > $@.$1
|
|
- dd if=$@.new bs=64 count=1 >> $@.$1
|
|
-endef
|
|
-
|
|
-define Build/append-rutx-metadata
|
|
- echo \
|
|
- '{ \
|
|
- "device_code": [".*"], \
|
|
- "hwver": [".*"], \
|
|
- "batch": [".*"], \
|
|
- "serial": [".*"], \
|
|
- "supported_devices":["teltonika,rutx"] \
|
|
- }' | fwtool -I - $@
|
|
-endef
|
|
-
|
|
-define Build/copy-file
|
|
- cat "$(1)" > "$@"
|
|
-endef
|
|
-
|
|
-define Build/mkmylofw_32m
|
|
- $(eval device_id=$(word 1,$(1)))
|
|
- $(eval revision=$(word 2,$(1)))
|
|
-
|
|
- let \
|
|
- size="$$(stat -c%s $@)" \
|
|
- pad="$(subst k,* 1024,$(BLOCKSIZE))" \
|
|
- pad="(pad - (size % pad)) % pad" \
|
|
- newsize='size + pad'; \
|
|
- $(STAGING_DIR_HOST)/bin/mkmylofw \
|
|
- -B WPE72 -i 0x11f6:$(device_id):0x11f6:$(device_id) -r $(revision) \
|
|
- -s 0x2000000 -p0x180000:$$newsize:al:0x80208000:"OpenWrt":$@ \
|
|
- $@.new
|
|
- @mv $@.new $@
|
|
-endef
|
|
-
|
|
-define Build/wac5xx-netgear-tar
|
|
- mkdir $@.tmp
|
|
- mv $@ $@.tmp/wac5xx-ubifs-root.img
|
|
- md5sum $@.tmp/wac5xx-ubifs-root.img > $@.tmp/wac5xx-ubifs-root.md5sum
|
|
- echo "WAC505 WAC510" > $@.tmp/metadata.txt
|
|
- echo "WAC505_V9.9.9.9" > $@.tmp/version
|
|
- tar -C $@.tmp/ -cf $@ .
|
|
- rm -rf $@.tmp
|
|
-endef
|
|
-
|
|
-define Build/qsdk-ipq-factory-nand-askey
|
|
- $(TOPDIR)/scripts/mkits-qsdk-ipq-image.sh $@.its\
|
|
- askey_kernel $@.$1 \
|
|
- askey_fs $(IMAGE_ROOTFS) \
|
|
- ubifs $@
|
|
- PATH=$(LINUX_DIR)/scripts/dtc:$(PATH) mkimage -f $@.its $@.new
|
|
- @mv $@.new $@
|
|
-endef
|
|
-
|
|
-define Build/qsdk-ipq-app-gpt
|
|
- cp $@ $@.tmp 2>/dev/null || true
|
|
- ptgen -g -o $@.tmp -a 1 -l 1024 \
|
|
- -t 0x2e -N 0:HLOS -r -p 32M \
|
|
- -t 0x83 -N rootfs -r -p 128M \
|
|
- -N rootfs_data -p 512M
|
|
- cat $@.tmp >> $@
|
|
- rm $@.tmp
|
|
-endef
|
|
-
|
|
-define Build/SenaoFW
|
|
- -$(STAGING_DIR_HOST)/bin/mksenaofw \
|
|
- -n $(BOARD_NAME) -r $(VENDOR_ID) -p $(1) \
|
|
- -c $(DATECODE) -w $(2) -x $(CW_VER) -t 0 \
|
|
- -e $@ \
|
|
- -o $@.new
|
|
- @cp $@.new $@
|
|
-endef
|
|
-
|
|
-define Build/wrgg-image
|
|
- mkwrggimg -i $@ \
|
|
- -o $@.new \
|
|
- -d "$(WRGG_DEVNAME)" \
|
|
- -s "$(WRGG_SIGNATURE)" \
|
|
- -v "" -m "" -B ""
|
|
- mv $@.new $@
|
|
-endef
|
|
-
|
|
-define Device/8dev_habanero-dvk
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := 8devices
|
|
- DEVICE_MODEL := Habanero DVK
|
|
- IMAGE_SIZE := 30976k
|
|
- SOC := qcom-ipq4019
|
|
- IMAGE/sysupgrade.bin := append-kernel | pad-to 64k | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += 8dev_habanero-dvk
|
|
-
|
|
-define Device/8dev_jalapeno-common
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- SOC := qcom-ipq4018
|
|
-endef
|
|
-
|
|
-define Device/8dev_jalapeno
|
|
- $(call Device/8dev_jalapeno-common)
|
|
- DEVICE_VENDOR := 8devices
|
|
- DEVICE_MODEL := Jalapeno
|
|
-endef
|
|
-TARGET_DEVICES += 8dev_jalapeno
|
|
-
|
|
-define Device/alfa-network_ap120c-ac
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := ALFA Network
|
|
- DEVICE_MODEL := AP120C-AC
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := kmod-usb-acm kmod-tpm-i2c-atmel
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGE_SIZE := 65536k
|
|
- IMAGES := factory.bin sysupgrade.bin
|
|
- IMAGE/factory.bin := append-ubi | qsdk-ipq-factory-nand
|
|
-endef
|
|
-TARGET_DEVICES += alfa-network_ap120c-ac
|
|
-
|
|
-define Device/aruba_glenmorangie
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := Aruba
|
|
- SOC := qcom-ipq4029
|
|
-endef
|
|
-
|
|
-define Device/aruba_ap-303
|
|
- $(call Device/aruba_glenmorangie)
|
|
- DEVICE_MODEL := AP-303
|
|
-endef
|
|
-TARGET_DEVICES += aruba_ap-303
|
|
-
|
|
-define Device/aruba_ap-303h
|
|
- $(call Device/aruba_glenmorangie)
|
|
- DEVICE_MODEL := AP-303H
|
|
-endef
|
|
-TARGET_DEVICES += aruba_ap-303h
|
|
-
|
|
-define Device/aruba_ap-365
|
|
- $(call Device/aruba_glenmorangie)
|
|
- DEVICE_MODEL := AP-365
|
|
- DEVICE_PACKAGES := kmod-hwmon-ad7418
|
|
-endef
|
|
-TARGET_DEVICES += aruba_ap-365
|
|
-
|
|
-define Device/asus_map-ac2200
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := ASUS
|
|
- DEVICE_MODEL := Lyra (MAP-AC2200)
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct kmod-ath3k
|
|
-endef
|
|
-TARGET_DEVICES += asus_map-ac2200
|
|
-
|
|
-# WARNING: this is an initramfs image that gets you half of the way there
|
|
-# you need to delete the jffs2 ubi volume and sysupgrade to the final image
|
|
-# to get a "trx" you can flash via web UI for ac42u/ac58u:
|
|
-# - change call Device/FitImageLzma to Device/FitImage
|
|
-# - add the following below UIMAGE_NAME
|
|
-# UIMAGE_MAGIC := 0x27051956
|
|
-# IMAGES += factory.trx
|
|
-# IMAGE/factory.trx := copy-file $(KDIR)/tmp/$$(KERNEL_INITRAMFS_IMAGE) | uImage none
|
|
-define Device/asus_rt-ac42u
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := ASUS
|
|
- DEVICE_MODEL := RT-AC42U
|
|
- DEVICE_ALT0_VENDOR := ASUS
|
|
- DEVICE_ALT0_MODEL := RT-ACRH17
|
|
- DEVICE_ALT1_VENDOR := ASUS
|
|
- DEVICE_ALT1_MODEL := RT-AC2200
|
|
- SOC := qcom-ipq4019
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGE_SIZE := 20439364
|
|
- FILESYSTEMS := squashfs
|
|
-# RT-AC82U is nowhere to be found online
|
|
-# Rather, this device is a/k/a RT-AC42U
|
|
-# But we'll go with what the vendor firmware has...
|
|
- UIMAGE_NAME:=$(shell echo -e '\03\01\01\01RT-AC82U')
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9984-ct kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += asus_rt-ac42u
|
|
-
|
|
-define Device/asus_rt-ac58u
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := ASUS
|
|
- DEVICE_MODEL := RT-AC58U
|
|
- DEVICE_ALT0_VENDOR := ASUS
|
|
- DEVICE_ALT0_MODEL := RT-ACRH13
|
|
- SOC := qcom-ipq4018
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGE_SIZE := 20439364
|
|
- FILESYSTEMS := squashfs
|
|
-# Someone - in their infinite wisdom - decided to put the firmware
|
|
-# version in front of the image name \03\00\00\04 => Version 3.0.0.4
|
|
-# Since u-boot works with strings we either need another fixup step
|
|
-# to add a version... or we are very careful not to add '\0' into that
|
|
-# string and call it a day.... Yeah, we do the latter!
|
|
- UIMAGE_NAME:=$(shell echo -e '\03\01\01\01RT-AC58U')
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers \
|
|
- kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += asus_rt-ac58u
|
|
-
|
|
-define Device/avm_fritzbox-4040
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := AVM
|
|
- DEVICE_MODEL := FRITZ!Box 4040
|
|
- SOC := qcom-ipq4018
|
|
- BOARD_NAME := fritz4040
|
|
- IMAGE_SIZE := 29056k
|
|
- UBOOT_PATH := $(STAGING_DIR_IMAGE)/uboot-fritz4040.bin
|
|
- UBOOT_PARTITION_SIZE := 524288
|
|
- IMAGES += eva.bin
|
|
- IMAGE/eva.bin := append-uboot | pad-to $$$$(UBOOT_PARTITION_SIZE) | append-kernel | append-rootfs | pad-rootfs
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
- DEVICE_PACKAGES := fritz-tffs fritz-caldata
|
|
-endef
|
|
-TARGET_DEVICES += avm_fritzbox-4040
|
|
-
|
|
-define Device/avm_fritzbox-7530
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := AVM
|
|
- DEVICE_MODEL := FRITZ!Box 7530
|
|
- DEVICE_ALT0_VENDOR := AVM
|
|
- DEVICE_ALT0_MODEL := FRITZ!Box 7520
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := fritz-caldata fritz-tffs-nand ltq-vdsl-vr11-app
|
|
-endef
|
|
-TARGET_DEVICES += avm_fritzbox-7530
|
|
-
|
|
-define Device/avm_fritzrepeater-1200
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := AVM
|
|
- DEVICE_MODEL := FRITZ!Repeater 1200
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := fritz-caldata fritz-tffs-nand
|
|
-endef
|
|
-TARGET_DEVICES += avm_fritzrepeater-1200
|
|
-
|
|
-define Device/avm_fritzrepeater-3000
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := AVM
|
|
- DEVICE_MODEL := FRITZ!Repeater 3000
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9984-ct fritz-caldata fritz-tffs-nand
|
|
-endef
|
|
-TARGET_DEVICES += avm_fritzrepeater-3000
|
|
-
|
|
-define Device/buffalo_wtr-m2133hp
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Buffalo
|
|
- DEVICE_MODEL := WTR-M2133HP
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9984-ct
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
-endef
|
|
-TARGET_DEVICES += buffalo_wtr-m2133hp
|
|
-
|
|
-define Device/cellc_rtl30vw
|
|
- KERNEL_SUFFIX := -zImage.itb
|
|
- KERNEL_INITRAMFS = kernel-bin | gzip | fit gzip $$(KDIR)/image-$$(DEVICE_DTS).dtb
|
|
- KERNEL = kernel-bin | fit none $$(KDIR)/image-$$(DEVICE_DTS).dtb | uImage lzma | pad-to 2048
|
|
- KERNEL_NAME := zImage
|
|
- KERNEL_IN_UBI :=
|
|
- IMAGES := factory.bin sysupgrade.bin
|
|
- IMAGE/factory.bin := append-rootfshdr kernel | append-ubi | qsdk-ipq-factory-nand-askey kernel
|
|
- IMAGE/sysupgrade.bin := append-rootfshdr kernel | sysupgrade-tar kernel=$$$$@.kernel | append-metadata
|
|
- DEVICE_VENDOR := Cell C
|
|
- DEVICE_MODEL := RTL30VW
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@5
|
|
- KERNEL_INSTALL := 1
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 57344k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi
|
|
-endef
|
|
-TARGET_DEVICES += cellc_rtl30vw
|
|
-
|
|
-define Device/cilab_meshpoint-one
|
|
- $(call Device/8dev_jalapeno-common)
|
|
- DEVICE_VENDOR := Crisis Innovation Lab
|
|
- DEVICE_MODEL := MeshPoint.One
|
|
- DEVICE_PACKAGES += kmod-i2c-gpio kmod-iio-bmp280-i2c kmod-hwmon-ina2xx kmod-rtc-pcf2127
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += cilab_meshpoint-one
|
|
-
|
|
-define Device/compex_wpj419
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Compex
|
|
- DEVICE_MODEL := WPJ419
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@12
|
|
- KERNEL_INSTALL := 1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- FILESYSTEMS := squashfs
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += compex_wpj419
|
|
-
|
|
-define Device/compex_wpj428
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Compex
|
|
- DEVICE_MODEL := WPJ428
|
|
- SOC := qcom-ipq4028
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- BLOCKSIZE := 64k
|
|
- IMAGE_SIZE := 31232k
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGES += cpximg-6a04.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- IMAGE/cpximg-6a04.bin := append-kernel | append-rootfs | pad-rootfs | mkmylofw_32m 0x8A2 3
|
|
- DEVICE_PACKAGES := kmod-gpio-beeper
|
|
- DEFAULT := n
|
|
-endef
|
|
-TARGET_DEVICES += compex_wpj428
|
|
-
|
|
-define Device/devolo_magic-2-wifi-next
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := devolo
|
|
- DEVICE_MODEL := Magic 2 WiFi next
|
|
- SOC := qcom-ipq4018
|
|
- KERNEL_SIZE := 4096k
|
|
-
|
|
- # If the bootloader sees 0xDEADC0DE and this trailer at the 64k boundary of a TFTP image
|
|
- # it will bootm it, just like we want for the initramfs.
|
|
- KERNEL_INITRAMFS := kernel-bin | gzip | fit gzip $$(KDIR)/image-$$(DEVICE_DTS).dtb | pad-to 64k |\
|
|
- append-string -e '\xDE\xAD\xC0\xDE{"fl_initramfs":""}\x00'
|
|
-
|
|
- IMAGE_SIZE := 26624k
|
|
- IMAGES := sysupgrade.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- DEFAULT := n
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += devolo_magic-2-wifi-next
|
|
-
|
|
-define Device/dlink_dap-2610
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := D-Link
|
|
- DEVICE_MODEL := DAP-2610
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c1
|
|
- BLOCKSIZE := 64k
|
|
- WRGG_DEVNAME := /dev/mtdblock/8
|
|
- WRGG_SIGNATURE := wapac30_dkbs_dap2610
|
|
- IMAGE_SIZE := 14080k
|
|
- IMAGES += factory.bin
|
|
- # Bootloader expects a special 160 byte header which is added by
|
|
- # wrgg-image.
|
|
- # Factory image size must be larger than 6MB, and size in wrgg header must
|
|
- # match actual factory image size to be flashable from D-Link http server.
|
|
- # Bootloader verifies checksum of wrgg image before booting, thus jffs2
|
|
- # cannot be part of the wrgg image. This is solved in the factory image by
|
|
- # having the rootfs at the end of the image (without pad-rootfs). And in
|
|
- # the sysupgrade image only the kernel is included in the wrgg checksum,
|
|
- # but this is not flashable from the D-link http server.
|
|
- # append-rootfs must start on an erase block boundary.
|
|
- IMAGE/factory.bin := append-kernel | pad-offset 6144k 160 | append-rootfs | wrgg-image | check-size
|
|
- IMAGE/sysupgrade.bin := append-kernel | wrgg-image | pad-to $$$$(BLOCKSIZE) | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += dlink_dap-2610
|
|
-
|
|
-define Device/edgecore_ecw5211
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Edgecore
|
|
- DEVICE_MODEL := ECW5211
|
|
- SOC := qcom-ipq4018
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c2
|
|
- DEVICE_PACKAGES := kmod-tpm-i2c-atmel kmod-usb-acm
|
|
-endef
|
|
-TARGET_DEVICES += edgecore_ecw5211
|
|
-
|
|
-define Device/edgecore_oap100
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Edgecore
|
|
- DEVICE_MODEL := OAP100
|
|
- SOC := qcom-ipq4019
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGES := sysupgrade.bin
|
|
- DEVICE_DTS_CONFIG := config@ap.dk07.1-c1
|
|
- DEVICE_PACKAGES := kmod-usb-acm kmod-usb-net kmod-usb-net-cdc-qmi uqmi
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += edgecore_oap100
|
|
-
|
|
-define Device/engenius_eap1300
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := EnGenius
|
|
- DEVICE_MODEL := EAP1300
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- BOARD_NAME := eap1300
|
|
- SOC := qcom-ipq4018
|
|
- KERNEL_SIZE := 5120k
|
|
- IMAGE_SIZE := 25344k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += engenius_eap1300
|
|
-
|
|
-define Device/engenius_eap2200
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := EnGenius
|
|
- DEVICE_MODEL := EAP2200
|
|
- SOC := qcom-ipq4019
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += engenius_eap2200
|
|
-
|
|
-define Device/engenius_emd1
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := EnGenius
|
|
- DEVICE_MODEL := EMD1
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- SOC := qcom-ipq4018
|
|
- IMAGE_SIZE := 30720k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- IMAGE/factory.bin := qsdk-ipq-factory-nor | check-size
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += engenius_emd1
|
|
-
|
|
-define Device/engenius_emr3500
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := EnGenius
|
|
- DEVICE_MODEL := EMR3500
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- SOC := qcom-ipq4018
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 30720k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- IMAGE/factory.bin := qsdk-ipq-factory-nor | check-size
|
|
- DEFAULT := n
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += engenius_emr3500
|
|
-
|
|
-define Device/engenius_ens620ext
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := EnGenius
|
|
- DEVICE_MODEL := ENS620EXT
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- BLOCKSIZE := 64k
|
|
- PAGESIZE := 256
|
|
- BOARD_NAME := ENS620EXT
|
|
- VENDOR_ID := 0x0101
|
|
- PRODUCT_ID := 0x79
|
|
- PRODUCT_ID_NEW := 0xA4
|
|
- DATECODE := 190507
|
|
- FW_VER := 3.1.2
|
|
- FW_VER_NEW := 3.5.6
|
|
- CW_VER := 1.8.99
|
|
- IMAGE_SIZE := 21312k
|
|
- KERNEL_SIZE := 5120k
|
|
- FILESYSTEMS := squashfs
|
|
- IMAGES += factory_30.bin factory_35.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
- IMAGE/factory_30.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-rootfs | pad-rootfs | check-size | SenaoFW $$$$(PRODUCT_ID) $$$$(FW_VER)
|
|
- IMAGE/factory_35.bin := qsdk-ipq-factory-nor | check-size | SenaoFW $$$$(PRODUCT_ID_NEW) $$$$(FW_VER_NEW)
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += engenius_ens620ext
|
|
-
|
|
-define Device/extreme-networks_ws-ap3915i
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Extreme Networks
|
|
- DEVICE_MODEL := WS-AP3915i
|
|
- IMAGE_SIZE := 30080k
|
|
- SOC := qcom-ipq4029
|
|
- BLOCKSIZE := 128k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += extreme-networks_ws-ap3915i
|
|
-
|
|
-define Device/ezviz_cs-w3-wd1200g-eup
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := EZVIZ
|
|
- DEVICE_MODEL := CS-W3-WD1200G
|
|
- DEVICE_VARIANT := EUP
|
|
- IMAGE_SIZE := 14848k
|
|
- KERNEL_SIZE = 6m
|
|
- SOC := qcom-ipq4018
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | \
|
|
- append-metadata
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
- DEVICE_COMPAT_VERSION := 2.0
|
|
- DEVICE_COMPAT_MESSAGE := uboot's bootcmd has to be updated (see wiki). \
|
|
- Upgrade via sysupgrade mechanism is not possible.
|
|
-endef
|
|
-TARGET_DEVICES += ezviz_cs-w3-wd1200g-eup
|
|
-
|
|
-define Device/glinet_gl-a1300
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := GL.iNet
|
|
- DEVICE_MODEL := GL-A1300
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c2
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGE_SIZE := 131072k
|
|
-endef
|
|
-TARGET_DEVICES += glinet_gl-a1300
|
|
-
|
|
-define Device/glinet_gl-ap1300
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := GL.iNet
|
|
- DEVICE_MODEL := GL-AP1300
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c2
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGE_SIZE := 131072k
|
|
- KERNEL_INSTALL := 1
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi
|
|
-endef
|
|
-TARGET_DEVICES += glinet_gl-ap1300
|
|
-
|
|
-define Device/glinet_gl-b1300
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := GL.iNet
|
|
- DEVICE_MODEL := GL-B1300
|
|
- BOARD_NAME := gl-b1300
|
|
- SOC := qcom-ipq4029
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 26624k
|
|
- IMAGE/sysupgrade.bin := append-kernel |append-rootfs | pad-rootfs | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += glinet_gl-b1300
|
|
-
|
|
-define Device/glinet_gl-b2200
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := GL.iNet
|
|
- DEVICE_MODEL := GL-B2200
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@ap.dk04.1-c3
|
|
- KERNEL_INITRAMFS_SUFFIX := -recovery.itb
|
|
- IMAGES := emmc.img.gz sysupgrade.bin
|
|
- IMAGE/emmc.img.gz := qsdk-ipq-app-gpt |\
|
|
- pad-to 1024k | append-kernel |\
|
|
- pad-to 33792k | append-rootfs |\
|
|
- append-metadata | gzip
|
|
- IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct \
|
|
- kmod-fs-ext4 kmod-mmc kmod-spi-dev mkf2fs e2fsprogs kmod-fs-f2fs
|
|
-endef
|
|
-TARGET_DEVICES += glinet_gl-b2200
|
|
-
|
|
-define Device/glinet_gl-s1300
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := GL.iNet
|
|
- DEVICE_MODEL := GL-S1300
|
|
- SOC := qcom-ipq4029
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 26624k
|
|
- IMAGES := sysupgrade.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- DEVICE_PACKAGES := kmod-fs-ext4 kmod-mmc kmod-spi-dev
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += glinet_gl-s1300
|
|
-
|
|
-define Device/kernel-size-6350-8300
|
|
- DEVICE_COMPAT_VERSION := 2.0
|
|
- DEVICE_COMPAT_MESSAGE := Kernel partition size must be increased for \
|
|
- this OpenWrt version. Before continuing, you MUST issue either the \
|
|
- command "fw_setenv kernsize 500000" from the OpenWrt command line, \
|
|
- or "setenv kernsize 500000 ; saveenv" from the U-Boot serial console. \
|
|
- Instead of the sysupgrade image, you must then install the OpenWrt \
|
|
- factory image, setting the force flag and wiping the configuration. \
|
|
- (e.g. "sysupgrade -n -F openwrt-squashfs-factory.bin" on command line)
|
|
-endef
|
|
-
|
|
-define Device/linksys_ea6350v3
|
|
- # The Linksys EA6350v3 has a uboot bootloader that does not
|
|
- # support either booting lzma kernel images nor booting UBI
|
|
- # partitions. This uboot, however, supports raw kernel images and
|
|
- # gzipped images.
|
|
- #
|
|
- # As configured by the OEM factory, the device will boot the kernel
|
|
- # from a fixed address with a fixed length of 3 MiB. Also, the
|
|
- # device has a hard-coded kernel command line that requires the
|
|
- # rootfs and alt_rootfs to be in mtd11 and mtd13 respectively.
|
|
- # Oh... and the kernel partition overlaps with the rootfs
|
|
- # partition (the same for alt_kernel and alt_rootfs).
|
|
- #
|
|
- # If you are planing re-partitioning the device, you may want to
|
|
- # keep these details in mind:
|
|
- # 1. The kernel addresses you should honor are 0x00000000 and
|
|
- # 0x02800000 respectively.
|
|
- # 2. The kernel size (plus the dtb) cannot exceed 3 MiB in size
|
|
- # unless the uboot environment variable "kernsize" is increased.
|
|
- # 3. You can use 'zImage', but not a raw 'Image' packed with lzma.
|
|
- # 4. The kernel command line from uboot is harcoded to boot with
|
|
- # rootfs either in mtd11 or mtd13.
|
|
- $(call Device/FitzImage)
|
|
- $(call Device/kernel-size-6350-8300)
|
|
- DEVICE_VENDOR := Linksys
|
|
- DEVICE_MODEL := EA6350
|
|
- DEVICE_VARIANT := v3
|
|
- SOC := qcom-ipq4018
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- KERNEL_SIZE := 5120k
|
|
- IMAGE_SIZE := 35840k
|
|
- UBINIZE_OPTS := -E 5
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-kernel | append-uImage-fakehdr filesystem | pad-to $$$$(KERNEL_SIZE) | append-ubi | linksys-image type=EA6350v3
|
|
-endef
|
|
-TARGET_DEVICES += linksys_ea6350v3
|
|
-
|
|
-define Device/linksys_ea8300
|
|
- $(call Device/FitzImage)
|
|
- $(call Device/kernel-size-6350-8300)
|
|
- DEVICE_VENDOR := Linksys
|
|
- DEVICE_MODEL := EA8300
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 5120k
|
|
- IMAGE_SIZE := 84992k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- UBINIZE_OPTS := -E 5 # EOD marks to "hide" factory sig at EOF
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | linksys-image type=EA8300
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += linksys_ea8300
|
|
-
|
|
-define Device/linksys_mr8300
|
|
- $(call Device/FitzImage)
|
|
- $(call Device/kernel-size-6350-8300)
|
|
- DEVICE_VENDOR := Linksys
|
|
- DEVICE_MODEL := MR8300
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 5120k
|
|
- IMAGE_SIZE := 84992k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- UBINIZE_OPTS := -E 5 # EOD marks to "hide" factory sig at EOF
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | linksys-image type=MR8300
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += linksys_mr8300
|
|
-
|
|
-define Device/linksys_whw03v2
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := Linksys
|
|
- DEVICE_MODEL := WHW03
|
|
- DEVICE_VARIANT := V2
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 6144k
|
|
- IMAGE_SIZE := 158720k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- UBINIZE_OPTS := -E 5 # EOD marks to "hide" factory sig at EOF
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | linksys-image type=WHW03v2
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct kmod-leds-pca963x kmod-spi-dev kmod-bluetooth
|
|
-endef
|
|
-TARGET_DEVICES += linksys_whw03v2
|
|
-
|
|
-define Device/linksys_whw01
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := Linksys
|
|
- DEVICE_MODEL := WHW01
|
|
- KERNEL_SIZE := 6144k
|
|
- IMAGE_SIZE := 75776K
|
|
- SOC := qcom-ipq4018
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- UBINIZE_OPTS := -E 5 # EOD marks to "hide" factory sig at EOF
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | linksys-image type=WHW01
|
|
- DEVICE_PACKAGES := uboot-envtools kmod-leds-pca963x
|
|
-endef
|
|
-TARGET_DEVICES += linksys_whw01
|
|
-
|
|
-define Device/luma_wrtq-329acn
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Luma Home
|
|
- DEVICE_MODEL := WRTQ-329ACN
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := kmod-ath3k kmod-eeprom-at24 kmod-i2c-gpio
|
|
- IMAGE_SIZE := 76632k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
-endef
|
|
-TARGET_DEVICES += luma_wrtq-329acn
|
|
-
|
|
-define Device/meraki_common
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Cisco Meraki
|
|
- SOC := qcom-ipq4029
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_DTS_LOADADDR := 0x89000000
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9887-ct
|
|
-endef
|
|
-
|
|
-define Device/meraki_mr33
|
|
- $(call Device/meraki_common)
|
|
- DEVICE_MODEL := MR33
|
|
-endef
|
|
-TARGET_DEVICES += meraki_mr33
|
|
-
|
|
-define Device/meraki_mr74
|
|
- $(call Device/meraki_common)
|
|
- DEVICE_MODEL := MR74
|
|
- DEVICE_DTS_CONFIG := config@3
|
|
-endef
|
|
-TARGET_DEVICES += meraki_mr74
|
|
-
|
|
-define Device/mobipromo_cm520-79f
|
|
- $(call Device/FitzImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := MobiPromo
|
|
- DEVICE_MODEL := CM520-79F
|
|
- SOC := qcom-ipq4019
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_PACKAGES := kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += mobipromo_cm520-79f
|
|
-
|
|
-define Device/netgear_ex61x0v2
|
|
- $(call Device/DniImage)
|
|
- DEVICE_VENDOR := NETGEAR
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- NETGEAR_BOARD_ID := EX6150v2series
|
|
- NETGEAR_HW_ID := 29765285+16+0+128+2x2
|
|
- IMAGE_SIZE := 14400k
|
|
- SOC := qcom-ipq4018
|
|
-endef
|
|
-
|
|
-define Device/netgear_ex6100v2
|
|
- $(call Device/netgear_ex61x0v2)
|
|
- DEVICE_MODEL := EX6100
|
|
- DEVICE_VARIANT := v2
|
|
-endef
|
|
-TARGET_DEVICES += netgear_ex6100v2
|
|
-
|
|
-define Device/netgear_ex6150v2
|
|
- $(call Device/netgear_ex61x0v2)
|
|
- DEVICE_MODEL := EX6150
|
|
- DEVICE_VARIANT := v2
|
|
-endef
|
|
-TARGET_DEVICES += netgear_ex6150v2
|
|
-
|
|
-define Device/netgear_orbi
|
|
- $(call Device/DniImage)
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_VENDOR := NETGEAR
|
|
- IMAGE/factory.img := append-kernel | pad-offset 128k 64 | \
|
|
- append-uImage-fakehdr filesystem | pad-to $$$$(KERNEL_SIZE) | \
|
|
- append-rootfs | pad-rootfs | netgear-dni
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-to 64k | \
|
|
- sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9984-ct e2fsprogs kmod-fs-ext4 losetup
|
|
-endef
|
|
-
|
|
-define Device/netgear_rbx50
|
|
- $(call Device/netgear_orbi)
|
|
- NETGEAR_HW_ID := 29765352+0+4000+512+2x2+2x2+4x4
|
|
- KERNEL_SIZE := 3932160
|
|
- ROOTFS_SIZE := 32243712
|
|
- IMAGE_SIZE := 36175872
|
|
-endef
|
|
-
|
|
-define Device/netgear_rbr50
|
|
- $(call Device/netgear_rbx50)
|
|
- DEVICE_MODEL := RBR50
|
|
- DEVICE_VARIANT := v1
|
|
- NETGEAR_BOARD_ID := RBR50
|
|
-endef
|
|
-TARGET_DEVICES += netgear_rbr50
|
|
-
|
|
-define Device/netgear_rbs50
|
|
- $(call Device/netgear_rbx50)
|
|
- DEVICE_MODEL := RBS50
|
|
- DEVICE_VARIANT := v1
|
|
- NETGEAR_BOARD_ID := RBS50
|
|
-endef
|
|
-TARGET_DEVICES += netgear_rbs50
|
|
-
|
|
-define Device/netgear_srx60
|
|
- $(call Device/netgear_orbi)
|
|
- NETGEAR_HW_ID := 29765352+0+4096+512+2x2+2x2+4x4
|
|
- KERNEL_SIZE := 3932160
|
|
- ROOTFS_SIZE := 32243712
|
|
- IMAGE_SIZE := 36175872
|
|
-endef
|
|
-
|
|
-define Device/netgear_srr60
|
|
- $(call Device/netgear_srx60)
|
|
- DEVICE_MODEL := SRR60
|
|
- NETGEAR_BOARD_ID := SRR60
|
|
-endef
|
|
-TARGET_DEVICES += netgear_srr60
|
|
-
|
|
-define Device/netgear_srs60
|
|
- $(call Device/netgear_srx60)
|
|
- DEVICE_MODEL := SRS60
|
|
- NETGEAR_BOARD_ID := SRS60
|
|
-endef
|
|
-TARGET_DEVICES += netgear_srs60
|
|
-
|
|
-define Device/netgear_wac510
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Netgear
|
|
- DEVICE_MODEL := WAC510
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@5
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- IMAGES += factory.tar
|
|
- IMAGE/factory.tar := append-ubi | wac5xx-netgear-tar
|
|
- DEVICE_PACKAGES := uboot-envtools
|
|
-endef
|
|
-TARGET_DEVICES += netgear_wac510
|
|
-
|
|
-define Device/openmesh_a42
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := OpenMesh
|
|
- DEVICE_MODEL := A42
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@om.a42
|
|
- BLOCKSIZE := 64k
|
|
- KERNEL = kernel-bin | lzma | fit lzma $$(KDIR)/image-$$(DEVICE_DTS).dtb | pad-to $$(BLOCKSIZE)
|
|
- IMAGE_SIZE := 15616k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-rootfs | pad-rootfs | openmesh-image ce_type=A42
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-rootfs | sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += openmesh_a42
|
|
-
|
|
-define Device/openmesh_a62
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := OpenMesh
|
|
- DEVICE_MODEL := A62
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@om.a62
|
|
- BLOCKSIZE := 64k
|
|
- KERNEL = kernel-bin | lzma | fit lzma $$(KDIR)/image-$$(DEVICE_DTS).dtb | pad-to $$(BLOCKSIZE)
|
|
- IMAGE_SIZE := 15552k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-rootfs | pad-rootfs | openmesh-image ce_type=A62
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-rootfs | sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct
|
|
-endef
|
|
-TARGET_DEVICES += openmesh_a62
|
|
-
|
|
-define Device/p2w_r619ac
|
|
- $(call Device/FitzImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := P&W
|
|
- DEVICE_MODEL := R619AC
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@10
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
-endef
|
|
-
|
|
-define Device/p2w_r619ac-64m
|
|
- $(call Device/p2w_r619ac)
|
|
- DEVICE_VARIANT := 64M NAND
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-ubi | qsdk-ipq-factory-nand
|
|
-endef
|
|
-TARGET_DEVICES += p2w_r619ac-64m
|
|
-
|
|
-define Device/p2w_r619ac-128m
|
|
- $(call Device/p2w_r619ac)
|
|
- DEVICE_VARIANT := 128M NAND
|
|
-endef
|
|
-TARGET_DEVICES += p2w_r619ac-128m
|
|
-
|
|
-define Device/pakedge_wr-1
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := Pakedge
|
|
- DEVICE_MODEL := WR-1
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c1
|
|
- SOC := qcom-ipq4018
|
|
- BLOCKSIZE := 64k
|
|
- IMAGE_SIZE := 31232k
|
|
- IMAGE/sysupgrade.bin := append-kernel | pad-to $$$$(BLOCKSIZE) | append-rootfs | pad-rootfs | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += pakedge_wr-1
|
|
-
|
|
-define Device/plasmacloud_pa1200
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := Plasma Cloud
|
|
- DEVICE_MODEL := PA1200
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@pc.pa1200
|
|
- BLOCKSIZE := 64k
|
|
- KERNEL = kernel-bin | lzma | fit lzma $$(KDIR)/image-$$(DEVICE_DTS).dtb | pad-to $$(BLOCKSIZE)
|
|
- IMAGE_SIZE := 15616k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-rootfs | pad-rootfs | openmesh-image ce_type=PA1200
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-rootfs | sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += plasmacloud_pa1200
|
|
-
|
|
-define Device/plasmacloud_pa2200
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := Plasma Cloud
|
|
- DEVICE_MODEL := PA2200
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@pc.pa2200
|
|
- BLOCKSIZE := 64k
|
|
- KERNEL = kernel-bin | lzma | fit lzma $$(KDIR)/image-$$(DEVICE_DTS).dtb | pad-to $$(BLOCKSIZE)
|
|
- IMAGE_SIZE := 15552k
|
|
- IMAGES += factory.bin
|
|
- IMAGE/factory.bin := append-rootfs | pad-rootfs | openmesh-image ce_type=PA2200
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-rootfs | sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca9888-ct
|
|
-endef
|
|
-TARGET_DEVICES += plasmacloud_pa2200
|
|
-
|
|
-define Device/qcom_ap-dk01.1-c1
|
|
- DEVICE_VENDOR := Qualcomm Atheros
|
|
- DEVICE_MODEL := AP-DK01.1
|
|
- DEVICE_VARIANT := C1
|
|
- BOARD_NAME := ap-dk01.1-c1
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS := qcom-ipq4019-ap.dk01.1-c1
|
|
- KERNEL_INSTALL := 1
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 26624k
|
|
- $(call Device/FitImage)
|
|
- IMAGE/sysupgrade.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-rootfs | pad-rootfs | append-metadata
|
|
- DEFAULT := n
|
|
-endef
|
|
-TARGET_DEVICES += qcom_ap-dk01.1-c1
|
|
-
|
|
-define Device/qcom_ap-dk04.1-c1
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Qualcomm Atheros
|
|
- DEVICE_MODEL := AP-DK04.1
|
|
- DEVICE_VARIANT := C1
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS := qcom-ipq4019-ap.dk04.1-c1
|
|
- KERNEL_INSTALL := 1
|
|
- KERNEL_SIZE := 4048k
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- BOARD_NAME := ap-dk04.1-c1
|
|
- DEFAULT := n
|
|
-endef
|
|
-TARGET_DEVICES += qcom_ap-dk04.1-c1
|
|
-
|
|
-define Device/qxwlan_e2600ac-c1
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Qxwlan
|
|
- DEVICE_MODEL := E2600AC
|
|
- DEVICE_VARIANT := C1
|
|
- BOARD_NAME := e2600ac-c1
|
|
- SOC := qcom-ipq4019
|
|
- IMAGE_SIZE := 31232k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
-endef
|
|
-TARGET_DEVICES += qxwlan_e2600ac-c1
|
|
-
|
|
-define Device/qxwlan_e2600ac-c2
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Qxwlan
|
|
- DEVICE_MODEL := E2600AC
|
|
- DEVICE_VARIANT := C2
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_INSTALL := 1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
-endef
|
|
-TARGET_DEVICES += qxwlan_e2600ac-c2
|
|
-
|
|
-define Device/sony_ncp-hg100-cellular
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Sony
|
|
- DEVICE_MODEL := NCP-HG100/Cellular
|
|
- DEVICE_DTS_CONFIG := config@ap.dk04.1-c4
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 8192k
|
|
- IMAGE_SIZE := 128m
|
|
- DEVICE_PACKAGES := e2fsprogs kmod-fs-ext4 uqmi
|
|
-endef
|
|
-TARGET_DEVICES += sony_ncp-hg100-cellular
|
|
-
|
|
-define Device/teltonika_rutx10
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Teltonika
|
|
- DEVICE_MODEL := RUTX10
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@5
|
|
- KERNEL_INSTALL := 1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- FILESYSTEMS := squashfs
|
|
- IMAGE/factory.ubi := append-ubi | qsdk-ipq-factory-nand | append-rutx-metadata
|
|
- DEVICE_PACKAGES := kmod-bluetooth
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += teltonika_rutx10
|
|
-
|
|
-define Device/teltonika_rutx50
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Teltonika
|
|
- DEVICE_MODEL := RUTX50
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_DTS_CONFIG := config@5
|
|
- KERNEL_INSTALL := 1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- FILESYSTEMS := squashfs
|
|
- IMAGE/factory.ubi := append-ubi
|
|
- DEVICE_PACKAGES := ipq-wifi-teltonika_rutx kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi
|
|
-endef
|
|
-TARGET_DEVICES += teltonika_rutx50
|
|
-
|
|
-define Device/tel_x1pro
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Telco
|
|
- DEVICE_MODEL := X1 Pro
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 31232k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi
|
|
- DEFAULT := n
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += tel_x1pro
|
|
-
|
|
-define Device/unielec_u4019-32m
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := Unielec
|
|
- DEVICE_MODEL := U4019
|
|
- DEVICE_VARIANT := 32M
|
|
- BOARD_NAME := u4019-32m
|
|
- SOC := qcom-ipq4019
|
|
- KERNEL_SIZE := 4096k
|
|
- IMAGE_SIZE := 31232k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- DEFAULT := n
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += unielec_u4019-32m
|
|
-
|
|
-define Device/wallys_dr40x9
|
|
- $(call Device/FitImage)
|
|
- $(call Device/UbiFit)
|
|
- DEVICE_VENDOR := Wallys
|
|
- DEVICE_MODEL := DR40X9
|
|
- SOC := qcom-ipq40x9
|
|
- DEVICE_DTS_CONFIG := config@ap.dk07.1-c1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- DEVICE_PACKAGES := ipq-wifi-wallys_dr40x9
|
|
-endef
|
|
-TARGET_DEVICES += wallys_dr40x9
|
|
-
|
|
-define Device/zte_mf18a
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := ZTE
|
|
- DEVICE_MODEL := MF18A
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@ap.dk04.1-c1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- KERNEL_IN_UBI := 1
|
|
- DEVICE_PACKAGES := ath10k-firmware-qca99x0-ct
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf18a
|
|
-
|
|
-define Device/zte_mf28x_common
|
|
- $(call Device/FitzImage)
|
|
- DEVICE_VENDOR := ZTE
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_DTS_CONFIG := config@ap.dk04.1-c1
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- KERNEL_IN_UBI := 1
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi
|
|
-endef
|
|
-
|
|
-define Device/zte_mf286d
|
|
- $(call Device/zte_mf28x_common)
|
|
- DEVICE_MODEL := MF286D
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf286d
|
|
-
|
|
-define Device/zte_mf287_common
|
|
- $(call Device/zte_mf28x_common)
|
|
- SOC := qcom-ipq4018
|
|
-# The recovery image is used to return back to stock (an initramfs-based image
|
|
-# that can be flashed to the device via sysupgrade
|
|
-# The factory image is used to install from the stock firmware by using an
|
|
-# exploit for the web interface
|
|
- IMAGES += factory.bin recovery.bin
|
|
- IMAGE/factory.bin := append-ubi
|
|
- IMAGE/recovery.bin := append-squashfs4-fakeroot | sysupgrade-tar kernel=$$$$(BIN_DIR)/$$(KERNEL_INITRAMFS_IMAGE) rootfs=$$$$@ | append-metadata
|
|
-endef
|
|
-
|
|
-define Device/zte_mf287plus
|
|
- $(call Device/zte_mf287_common)
|
|
- DEVICE_PACKAGES += ipq-wifi-zte_mf287plus
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c2
|
|
- DEVICE_MODEL := MF287Plus
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf287plus
|
|
-
|
|
-define Device/zte_mf287
|
|
- $(call Device/zte_mf287_common)
|
|
- DEVICE_PACKAGES += ipq-wifi-zte_mf287
|
|
- DEVICE_DTS_CONFIG := config@ap.dk01.1-c2
|
|
- DEVICE_MODEL := MF287
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf287
|
|
-
|
|
-define Device/zte_mf287pro
|
|
- $(call Device/zte_mf287_common)
|
|
- DEVICE_PACKAGES += ipq-wifi-zte_mf287plus
|
|
- DEVICE_DTS_CONFIG := config@ap.dk04.1-c1
|
|
- DEVICE_MODEL := MF287Pro
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf287pro
|
|
-
|
|
-define Device/zte_mf289f
|
|
- $(call Device/zte_mf28x_common)
|
|
- DEVICE_MODEL := MF289F
|
|
- DEVICE_PACKAGES += ipq-wifi-zte_mf289f ath10k-firmware-qca9984-ct
|
|
-endef
|
|
-TARGET_DEVICES += zte_mf289f
|
|
-
|
|
-define Device/zyxel_nbg6617
|
|
- $(call Device/FitImageLzma)
|
|
- DEVICE_VENDOR := ZyXEL
|
|
- DEVICE_MODEL := NBG6617
|
|
- SOC := qcom-ipq4018
|
|
- KERNEL_SIZE := 4096k
|
|
- ROOTFS_SIZE := 24960k
|
|
- RAS_BOARD := NBG6617
|
|
- RAS_ROOTFS_SIZE := 19840k
|
|
- RAS_VERSION := "$(VERSION_DIST) $(REVISION)"
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | append-metadata
|
|
- IMAGES += factory.bin
|
|
-# The ZyXEL firmware allows flashing thru the web-gui only when the rootfs is
|
|
-# at least as large as the one of the initial firmware image (not the current
|
|
-# one on the device). This only applies to the Web-UI, the bootlaoder ignores
|
|
-# this minimum-size. However, the larger image can be flashed both ways.
|
|
- IMAGE/factory.bin := append-rootfs | pad-rootfs | pad-to 64k | check-size $$$$(ROOTFS_SIZE) | zyxel-ras-image separate-kernel
|
|
- IMAGE/sysupgrade.bin/squashfs := append-rootfs | pad-rootfs | check-size $$$$(ROOTFS_SIZE) | sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
- DEVICE_PACKAGES := kmod-usb-ledtrig-usbport
|
|
-endef
|
|
-TARGET_DEVICES += zyxel_nbg6617
|
|
-
|
|
-define Device/zyxel_wre6606
|
|
- $(call Device/FitImage)
|
|
- DEVICE_VENDOR := ZyXEL
|
|
- DEVICE_MODEL := WRE6606
|
|
- DEVICE_DTS_CONFIG := config@4
|
|
- SOC := qcom-ipq4018
|
|
- IMAGE_SIZE := 13184k
|
|
- IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | check-size | append-metadata
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
-endef
|
|
-# Missing DSA Setup
|
|
-#TARGET_DEVICES += zyxel_wre6606
|
|
diff --git a/target/linux/ipq40xx/image/mikrotik.mk b/target/linux/ipq40xx/image/mikrotik.mk
|
|
deleted file mode 100644
|
|
index f0e1f1aad3..0000000000
|
|
--- a/target/linux/ipq40xx/image/mikrotik.mk
|
|
+++ /dev/null
|
|
@@ -1,100 +0,0 @@
|
|
-define Device/mikrotik_nor
|
|
- DEVICE_VENDOR := MikroTik
|
|
- BLOCKSIZE := 64k
|
|
- IMAGE_SIZE := 16128k
|
|
- KERNEL_NAME := vmlinux
|
|
- KERNEL := kernel-bin | append-dtb-elf
|
|
- IMAGES = sysupgrade.bin
|
|
- IMAGE/sysupgrade.bin := append-kernel | kernel2minor -s 1024 | \
|
|
- pad-to $$$$(BLOCKSIZE) | append-rootfs | pad-rootfs | \
|
|
- check-size | append-metadata
|
|
-endef
|
|
-
|
|
-define Device/mikrotik_nand
|
|
- DEVICE_VENDOR := MikroTik
|
|
- KERNEL_NAME := vmlinux
|
|
- KERNEL_INITRAMFS := kernel-bin | append-dtb-elf
|
|
- KERNEL := kernel-bin | append-dtb-elf | package-kernel-ubifs | \
|
|
- ubinize-kernel
|
|
- IMAGES := sysupgrade.bin
|
|
- IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
|
-endef
|
|
-
|
|
-define Device/mikrotik_cap-ac
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := cAP ac
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_cap-ac
|
|
-
|
|
-define Device/mikrotik_hap-ac2
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := hAP ac2
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_hap-ac2
|
|
-
|
|
-define Device/mikrotik_hap-ac3
|
|
- $(call Device/mikrotik_nand)
|
|
- DEVICE_MODEL := hAP ac3
|
|
- SOC := qcom-ipq4019
|
|
- BLOCKSIZE := 128k
|
|
- PAGESIZE := 2048
|
|
- KERNEL_UBIFS_OPTS = -m $$(PAGESIZE) -e 124KiB -c $$(PAGESIZE) -x none
|
|
- DEVICE_PACKAGES := kmod-ledtrig-gpio
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_hap-ac3
|
|
-
|
|
-define Device/mikrotik_hap-ac3-lte6-kit
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := hAP ac3 LTE6 kit
|
|
- SOC := qcom-ipq4019
|
|
- DEVICE_PACKAGES := kmod-ledtrig-gpio kmod-usb-acm kmod-usb-net-rndis
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_hap-ac3-lte6-kit
|
|
-
|
|
-define Device/mikrotik_lhgg-60ad
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := Wireless Wire Dish LHGG-60ad
|
|
- DEVICE_DTS := qcom-ipq4019-lhgg-60ad
|
|
- DEVICE_PACKAGES += -kmod-ath10k-ct -ath10k-firmware-qca4019-ct kmod-wil6210
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_lhgg-60ad
|
|
-
|
|
-define Device/mikrotik_sxtsq-5-ac
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := SXTsq 5 ac (RBSXTsqG-5acD)
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := rssileds
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_sxtsq-5-ac
|
|
-
|
|
-define Device/mikrotik_wap-ac
|
|
- $(call Device/mikrotik_nor)
|
|
- DEVICE_MODEL := wAP ac
|
|
- SOC := qcom-ipq4018
|
|
- DEVICE_PACKAGES := -kmod-ath10k-ct kmod-ath10k-ct-smallbuffers
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_wap-ac
|
|
-
|
|
-define Device/mikrotik_wap-r-ac
|
|
- $(call Device/mikrotik_wap-ac)
|
|
- DEVICE_MODEL := wAP R ac
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi \
|
|
- kmod-usb-acm kmod-usb-net-rndis
|
|
- DEVICE_DTS := qcom-ipq4018-wap-r-ac
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_wap-r-ac
|
|
-
|
|
-define Device/mikrotik_wap-ac-lte
|
|
- $(call Device/mikrotik_wap-ac)
|
|
- DEVICE_MODEL := wAP ac LTE
|
|
- DEVICE_PACKAGES := kmod-usb-net-qmi-wwan kmod-usb-serial-option uqmi \
|
|
- kmod-usb-acm kmod-usb-net-rndis
|
|
- DEVICE_DTS := qcom-ipq4018-wap-ac-lte
|
|
- DEVICE_ALT0_VENDOR = Mikrotik
|
|
- DEVICE_ALT0_MODEL := wAP ac LTE6
|
|
-endef
|
|
-TARGET_DEVICES += mikrotik_wap-ac-lte
|
|
diff --git a/target/linux/ipq40xx/mikrotik/config-default b/target/linux/ipq40xx/mikrotik/config-default
|
|
deleted file mode 100644
|
|
index 1268d2c810..0000000000
|
|
--- a/target/linux/ipq40xx/mikrotik/config-default
|
|
+++ /dev/null
|
|
@@ -1,5 +0,0 @@
|
|
-CONFIG_MIKROTIK=y
|
|
-CONFIG_MIKROTIK_RB_SYSFS=y
|
|
-CONFIG_MTD_ROUTERBOOT_PARTS=y
|
|
-CONFIG_MTD_SPI_NOR_USE_VARIABLE_ERASE=y
|
|
-CONFIG_MTD_SPLIT_MINOR_FW=y
|
|
diff --git a/target/linux/ipq40xx/mikrotik/target.mk b/target/linux/ipq40xx/mikrotik/target.mk
|
|
deleted file mode 100644
|
|
index 4530a90985..0000000000
|
|
--- a/target/linux/ipq40xx/mikrotik/target.mk
|
|
+++ /dev/null
|
|
@@ -1,4 +0,0 @@
|
|
-BOARDNAME:=MikroTik
|
|
-FEATURES += minor
|
|
-KERNEL_IMAGES:=vmlinux
|
|
-IMAGES_DIR:=compressed
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/104-clk-fix-apss-cpu-overclocking.patch b/target/linux/ipq40xx/patches-5.15/104-clk-fix-apss-cpu-overclocking.patch
|
|
deleted file mode 100644
|
|
index 2de03f7ae0..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/104-clk-fix-apss-cpu-overclocking.patch
|
|
+++ /dev/null
|
|
@@ -1,115 +0,0 @@
|
|
-From f2b87dc1028b710ec8ce25808b9d21f92b376184 Mon Sep 17 00:00:00 2001
|
|
-From: Christian Lamparter <chunkeey@googlemail.com>
|
|
-Date: Sun, 11 Mar 2018 14:41:31 +0100
|
|
-Subject: [PATCH 2/2] clk: fix apss cpu overclocking
|
|
-
|
|
-There's an interaction issue between the clk changes:"
|
|
-clk: qcom: ipq4019: Add the apss cpu pll divider clock node
|
|
-clk: qcom: ipq4019: remove fixed clocks and add pll clocks
|
|
-" and the cpufreq-dt.
|
|
-
|
|
-cpufreq-dt is now spamming the kernel-log with the following:
|
|
-
|
|
-[ 1099.190658] cpu cpu0: dev_pm_opp_set_rate: failed to find current OPP
|
|
-for freq 761142857 (-34)
|
|
-
|
|
-This only happens on certain devices like the Compex WPJ428
|
|
-and AVM FritzBox!4040. However, other devices like the Asus
|
|
-RT-AC58U and Meraki MR33 work just fine.
|
|
-
|
|
-The issue stem from the fact that all higher CPU-Clocks
|
|
-are achieved by switching the clock-parent to the P_DDRPLLAPSS
|
|
-(ddrpllapss). Which is set by Qualcomm's proprietary bootcode
|
|
-as part of the DDR calibration.
|
|
-
|
|
-For example, the FB4040 uses 256 MiB Nanya NT5CC128M16IP clocked
|
|
-at round 533 MHz (ddrpllsdcc = 190285714 Hz).
|
|
-
|
|
-whereas the 128 MiB Nanya NT5CC64M16GP-DI in the ASUS RT-AC58U is
|
|
-clocked at a slightly higher 537 MHz ( ddrpllsdcc = 192000000 Hz).
|
|
-
|
|
-This patch attempts to fix the issue by modifying
|
|
-clk_cpu_div_round_rate(), clk_cpu_div_set_rate(), clk_cpu_div_recalc_rate()
|
|
-to use a new qcom_find_freq_close() function, which returns the closest
|
|
-matching frequency, instead of the next higher. This way, the SoC in
|
|
-the FB4040 (with its max clock speed of 710.4 MHz) will no longer
|
|
-try to overclock to 761 MHz.
|
|
-
|
|
-Fixes: d83dcacea18 ("clk: qcom: ipq4019: Add the apss cpu pll divider clock node")
|
|
-Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
|
|
-Signed-off-by: John Crispin <john@phrozen.org>
|
|
----
|
|
- drivers/clk/qcom/gcc-ipq4019.c | 34 +++++++++++++++++++++++++++++++---
|
|
- 1 file changed, 31 insertions(+), 3 deletions(-)
|
|
-
|
|
---- a/drivers/clk/qcom/gcc-ipq4019.c
|
|
-+++ b/drivers/clk/qcom/gcc-ipq4019.c
|
|
-@@ -1243,6 +1243,29 @@ static const struct clk_fepll_vco gcc_fe
|
|
- .reg = 0x2f020,
|
|
- };
|
|
-
|
|
-+
|
|
-+const struct freq_tbl *qcom_find_freq_close(const struct freq_tbl *f,
|
|
-+ unsigned long rate)
|
|
-+{
|
|
-+ const struct freq_tbl *last = NULL;
|
|
-+
|
|
-+ for ( ; f->freq; f++) {
|
|
-+ if (rate == f->freq)
|
|
-+ return f;
|
|
-+
|
|
-+ if (f->freq > rate) {
|
|
-+ if (!last ||
|
|
-+ (f->freq - rate) < (rate - last->freq))
|
|
-+ return f;
|
|
-+ else
|
|
-+ return last;
|
|
-+ }
|
|
-+ last = f;
|
|
-+ }
|
|
-+
|
|
-+ return last;
|
|
-+}
|
|
-+
|
|
- /*
|
|
- * Round rate function for APSS CPU PLL Clock divider.
|
|
- * It looks up the frequency table and returns the next higher frequency
|
|
-@@ -1255,7 +1278,7 @@ static long clk_cpu_div_round_rate(struc
|
|
- struct clk_hw *p_hw;
|
|
- const struct freq_tbl *f;
|
|
-
|
|
-- f = qcom_find_freq(pll->freq_tbl, rate);
|
|
-+ f = qcom_find_freq_close(pll->freq_tbl, rate);
|
|
- if (!f)
|
|
- return -EINVAL;
|
|
-
|
|
-@@ -1277,7 +1300,7 @@ static int clk_cpu_div_set_rate(struct c
|
|
- const struct freq_tbl *f;
|
|
- u32 mask;
|
|
-
|
|
-- f = qcom_find_freq(pll->freq_tbl, rate);
|
|
-+ f = qcom_find_freq_close(pll->freq_tbl, rate);
|
|
- if (!f)
|
|
- return -EINVAL;
|
|
-
|
|
-@@ -1304,6 +1327,7 @@ static unsigned long
|
|
- clk_cpu_div_recalc_rate(struct clk_hw *hw,
|
|
- unsigned long parent_rate)
|
|
- {
|
|
-+ const struct freq_tbl *f;
|
|
- struct clk_fepll *pll = to_clk_fepll(hw);
|
|
- u32 cdiv, pre_div;
|
|
- u64 rate;
|
|
-@@ -1324,7 +1348,11 @@ clk_cpu_div_recalc_rate(struct clk_hw *h
|
|
- rate = clk_fepll_vco_calc_rate(pll, parent_rate) * 2;
|
|
- do_div(rate, pre_div);
|
|
-
|
|
-- return rate;
|
|
-+ f = qcom_find_freq_close(pll->freq_tbl, rate);
|
|
-+ if (!f)
|
|
-+ return rate;
|
|
-+
|
|
-+ return f->freq;
|
|
- };
|
|
-
|
|
- static const struct clk_ops clk_regmap_cpu_div_ops = {
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/300-clk-qcom-ipq4019-add-ess-reset.patch b/target/linux/ipq40xx/patches-5.15/300-clk-qcom-ipq4019-add-ess-reset.patch
|
|
deleted file mode 100644
|
|
index eb015251a1..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/300-clk-qcom-ipq4019-add-ess-reset.patch
|
|
+++ /dev/null
|
|
@@ -1,52 +0,0 @@
|
|
-From 480c1f7648fc586db12d6003c717c23667a4fcf0 Mon Sep 17 00:00:00 2001
|
|
-From: Ram Chandra Jangir <rjangir@codeaurora.org>
|
|
-Date: Tue, 28 Mar 2017 22:35:33 +0530
|
|
-Subject: [PATCH] clk: qcom: ipq4019: add ess reset
|
|
-
|
|
-Added the ESS reset in IPQ4019 GCC.
|
|
-
|
|
-Signed-off-by: Ram Chandra Jangir <rjangir@codeaurora.org>
|
|
----
|
|
- drivers/clk/qcom/gcc-ipq4019.c | 11 +++++++++++
|
|
- include/dt-bindings/clock/qcom,gcc-ipq4019.h | 11 +++++++++++
|
|
- 2 files changed, 22 insertions(+)
|
|
-
|
|
---- a/drivers/clk/qcom/gcc-ipq4019.c
|
|
-+++ b/drivers/clk/qcom/gcc-ipq4019.c
|
|
-@@ -1735,6 +1735,17 @@ static const struct qcom_reset_map gcc_i
|
|
- [GCC_TCSR_BCR] = {0x22000, 0},
|
|
- [GCC_MPM_BCR] = {0x24000, 0},
|
|
- [GCC_SPDM_BCR] = {0x25000, 0},
|
|
-+ [ESS_MAC1_ARES] = {0x1200C, 0},
|
|
-+ [ESS_MAC2_ARES] = {0x1200C, 1},
|
|
-+ [ESS_MAC3_ARES] = {0x1200C, 2},
|
|
-+ [ESS_MAC4_ARES] = {0x1200C, 3},
|
|
-+ [ESS_MAC5_ARES] = {0x1200C, 4},
|
|
-+ [ESS_PSGMII_ARES] = {0x1200C, 5},
|
|
-+ [ESS_MAC1_CLK_DIS] = {0x1200C, 8},
|
|
-+ [ESS_MAC2_CLK_DIS] = {0x1200C, 9},
|
|
-+ [ESS_MAC3_CLK_DIS] = {0x1200C, 10},
|
|
-+ [ESS_MAC4_CLK_DIS] = {0x1200C, 11},
|
|
-+ [ESS_MAC5_CLK_DIS] = {0x1200C, 12},
|
|
- };
|
|
-
|
|
- static const struct regmap_config gcc_ipq4019_regmap_config = {
|
|
---- a/include/dt-bindings/clock/qcom,gcc-ipq4019.h
|
|
-+++ b/include/dt-bindings/clock/qcom,gcc-ipq4019.h
|
|
-@@ -165,5 +165,16 @@
|
|
- #define GCC_QDSS_BCR 69
|
|
- #define GCC_MPM_BCR 70
|
|
- #define GCC_SPDM_BCR 71
|
|
-+#define ESS_MAC1_ARES 72
|
|
-+#define ESS_MAC2_ARES 73
|
|
-+#define ESS_MAC3_ARES 74
|
|
-+#define ESS_MAC4_ARES 75
|
|
-+#define ESS_MAC5_ARES 76
|
|
-+#define ESS_PSGMII_ARES 77
|
|
-+#define ESS_MAC1_CLK_DIS 78
|
|
-+#define ESS_MAC2_CLK_DIS 79
|
|
-+#define ESS_MAC3_CLK_DIS 80
|
|
-+#define ESS_MAC4_CLK_DIS 81
|
|
-+#define ESS_MAC5_CLK_DIS 82
|
|
-
|
|
- #endif
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/301-arm-compressed-add-appended-DTB-section.patch b/target/linux/ipq40xx/patches-5.15/301-arm-compressed-add-appended-DTB-section.patch
|
|
deleted file mode 100644
|
|
index 0448574e7e..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/301-arm-compressed-add-appended-DTB-section.patch
|
|
+++ /dev/null
|
|
@@ -1,48 +0,0 @@
|
|
-From 0843a61d6913bdac8889eb048ed89f7903059787 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robimarko@gmail.com>
|
|
-Date: Fri, 30 Oct 2020 13:36:31 +0100
|
|
-Subject: [PATCH] arm: compressed: add appended DTB section
|
|
-
|
|
-This adds a appended_dtb section to the ARM decompressor
|
|
-linker script.
|
|
-
|
|
-This allows using the existing ARM zImage appended DTB support for
|
|
-appending a DTB to the raw ELF kernel.
|
|
-
|
|
-Its size is set to 1MB max to match the zImage appended DTB size limit.
|
|
-
|
|
-To use it to pass the DTB to the kernel, objcopy is used:
|
|
-
|
|
-objcopy --set-section-flags=.appended_dtb=alloc,contents \
|
|
- --update-section=.appended_dtb=<target>.dtb vmlinux
|
|
-
|
|
-This is based off the following patch:
|
|
-https://github.com/openwrt/openwrt/commit/c063e27e02a9dcac0e7f5877fb154e58fa3e1a69
|
|
-
|
|
-Signed-off-by: Robert Marko <robimarko@gmail.com>
|
|
----
|
|
- arch/arm/boot/compressed/vmlinux.lds.S | 9 ++++++++-
|
|
- 1 file changed, 8 insertions(+), 1 deletion(-)
|
|
-
|
|
---- a/arch/arm/boot/compressed/vmlinux.lds.S
|
|
-+++ b/arch/arm/boot/compressed/vmlinux.lds.S
|
|
-@@ -103,6 +103,13 @@ SECTIONS
|
|
-
|
|
- _edata = .;
|
|
-
|
|
-+ .appended_dtb : {
|
|
-+ /* leave space for appended DTB */
|
|
-+ . += 0x100000;
|
|
-+ }
|
|
-+
|
|
-+ _edata_dtb = .;
|
|
-+
|
|
- /*
|
|
- * The image_end section appears after any additional loadable sections
|
|
- * that the linker may decide to insert in the binary image. Having
|
|
-@@ -140,4 +147,4 @@ SECTIONS
|
|
-
|
|
- ARM_ASSERTS
|
|
- }
|
|
--ASSERT(_edata_real == _edata, "error: zImage file size is incorrect");
|
|
-+ASSERT(_edata_real == _edata_dtb, "error: zImage file size is incorrect");
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/302-arm-compressed-set-ipq40xx-watchdog-to-allow-boot.patch b/target/linux/ipq40xx/patches-5.15/302-arm-compressed-set-ipq40xx-watchdog-to-allow-boot.patch
|
|
deleted file mode 100644
|
|
index 51891c1f22..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/302-arm-compressed-set-ipq40xx-watchdog-to-allow-boot.patch
|
|
+++ /dev/null
|
|
@@ -1,66 +0,0 @@
|
|
-From 11d6a6128a5a07c429941afc202b6e62a19771be Mon Sep 17 00:00:00 2001
|
|
-From: John Thomson <git@johnthomson.fastmail.com.au>
|
|
-Date: Fri, 23 Oct 2020 19:42:36 +1000
|
|
-Subject: [PATCH 2/2] arm: compressed: set ipq40xx watchdog to allow boot
|
|
-
|
|
-For IPQ40XX systems where the SoC watchdog is activated before linux,
|
|
-the watchdog timer may be too small for linux to finish uncompress,
|
|
-boot, and watchdog management start.
|
|
-If the watchdog is enabled, set the timeout for it to 30 seconds.
|
|
-The functionality and offsets were copied from:
|
|
-drivers/watchdog/qcom-wdt.c qcom_wdt_set_timeout & qcom_wdt_start
|
|
-The watchdog memory address was taken from:
|
|
-arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-
|
|
-This was required on Mikrotik IPQ40XX consumer hardware using Mikrotik's
|
|
-RouterBoot bootloader.
|
|
-
|
|
-Signed-off-by: John Thomson <git@johnthomson.fastmail.com.au>
|
|
----
|
|
- arch/arm/boot/compressed/head.S | 35 +++++++++++++++++++++++++++++++++
|
|
- 1 file changed, 35 insertions(+)
|
|
-
|
|
---- a/arch/arm/boot/compressed/head.S
|
|
-+++ b/arch/arm/boot/compressed/head.S
|
|
-@@ -624,6 +624,41 @@ not_relocated: mov r0, #0
|
|
- bic r4, r4, #1
|
|
- blne cache_on
|
|
-
|
|
-+/* Set the Qualcom IPQ40xx watchdog timeout to 30 seconds
|
|
-+ * if it is enabled, so that there is time for kernel
|
|
-+ * to decompress, boot, and take over the watchdog.
|
|
-+ * data and functionality from drivers/watchdog/qcom-wdt.c
|
|
-+ * address from arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-+ */
|
|
-+#ifdef CONFIG_ARCH_IPQ40XX
|
|
-+watchdog_set:
|
|
-+ /* offsets:
|
|
-+ * 0x04 reset (=1 resets countdown)
|
|
-+ * 0x08 enable (=0 disables)
|
|
-+ * 0x0c status (=1 when SoC was reset by watchdog)
|
|
-+ * 0x10 bark (=timeout warning in ticks)
|
|
-+ * 0x14 bite (=timeout reset in ticks)
|
|
-+ * clock rate is 1<<15 hertz
|
|
-+ */
|
|
-+ .equ watchdog, 0x0b017000 @Store watchdog base address
|
|
-+ movw r0, #:lower16:watchdog
|
|
-+ movt r0, #:upper16:watchdog
|
|
-+ ldr r1, [r0, #0x08] @Get enabled?
|
|
-+ cmp r1, #1 @If not enabled, do not change
|
|
-+ bne watchdog_finished
|
|
-+ mov r1, #0
|
|
-+ str r1, [r0, #0x08] @Disable the watchdog
|
|
-+ mov r1, #1
|
|
-+ str r1, [r0, #0x04] @Pet the watchdog
|
|
-+ mov r1, #30 @30 seconds timeout
|
|
-+ lsl r1, r1, #15 @converted to ticks
|
|
-+ str r1, [r0, #0x10] @Set the bark timeout
|
|
-+ str r1, [r0, #0x14] @Set the bite timeout
|
|
-+ mov r1, #1
|
|
-+ str r1, [r0, #0x08] @Enable the watchdog
|
|
-+watchdog_finished:
|
|
-+#endif /* CONFIG_ARCH_IPQ40XX */
|
|
-+
|
|
- /*
|
|
- * The C runtime environment should now be setup sufficiently.
|
|
- * Set up some pointers, and start decompressing.
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/400-mmc-sdhci-sdhci-msm-use-sdhci_set_clock-instead-of-s.patch b/target/linux/ipq40xx/patches-5.15/400-mmc-sdhci-sdhci-msm-use-sdhci_set_clock-instead-of-s.patch
|
|
deleted file mode 100644
|
|
index 3a3be91709..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/400-mmc-sdhci-sdhci-msm-use-sdhci_set_clock-instead-of-s.patch
|
|
+++ /dev/null
|
|
@@ -1,24 +0,0 @@
|
|
-From f63ea127643a605da97090ce585fdd7c2d17fa42 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Mon, 14 Dec 2020 13:35:35 +0100
|
|
-Subject: [PATCH] mmc: sdhci-msm: use sdhci_set_clock
|
|
-
|
|
-When using sdhci_msm_set_clock clock setting will fail, so lets
|
|
-use the generic sdhci_set_clock.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- drivers/mmc/host/sdhci-msm.c | 2 +-
|
|
- 1 file changed, 1 insertion(+), 1 deletion(-)
|
|
-
|
|
---- a/drivers/mmc/host/sdhci-msm.c
|
|
-+++ b/drivers/mmc/host/sdhci-msm.c
|
|
-@@ -2447,7 +2447,7 @@ MODULE_DEVICE_TABLE(of, sdhci_msm_dt_mat
|
|
-
|
|
- static const struct sdhci_ops sdhci_msm_ops = {
|
|
- .reset = sdhci_msm_reset,
|
|
-- .set_clock = sdhci_msm_set_clock,
|
|
-+ .set_clock = sdhci_set_clock,
|
|
- .get_min_clock = sdhci_msm_get_min_clock,
|
|
- .get_max_clock = sdhci_msm_get_max_clock,
|
|
- .set_bus_width = sdhci_set_bus_width,
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/401-mmc-sdhci-msm-comment-unused-sdhci_msm_set_clock.patch b/target/linux/ipq40xx/patches-5.15/401-mmc-sdhci-msm-comment-unused-sdhci_msm_set_clock.patch
|
|
deleted file mode 100644
|
|
index b297600171..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/401-mmc-sdhci-msm-comment-unused-sdhci_msm_set_clock.patch
|
|
+++ /dev/null
|
|
@@ -1,108 +0,0 @@
|
|
-From 28edd829133766eb3cefaf2e49d3ee701968061b Mon Sep 17 00:00:00 2001
|
|
-From: Christian Marangi <ansuelsmth@gmail.com>
|
|
-Date: Tue, 9 May 2023 01:57:17 +0200
|
|
-Subject: [PATCH] mmc: sdhci-msm: comment unused sdhci_msm_set_clock
|
|
-
|
|
-comment unused sdhci_msm_set_clock and __sdhci_msm_set_clock as due to some
|
|
-current problem, we are forced to use sdhci_set_clock.
|
|
-
|
|
-Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
|
|
----
|
|
- drivers/mmc/host/sdhci-msm.c | 86 ++++++++++++++++++------------------
|
|
- 1 file changed, 43 insertions(+), 43 deletions(-)
|
|
-
|
|
---- a/drivers/mmc/host/sdhci-msm.c
|
|
-+++ b/drivers/mmc/host/sdhci-msm.c
|
|
-@@ -1751,49 +1751,49 @@ static unsigned int sdhci_msm_get_min_cl
|
|
- return SDHCI_MSM_MIN_CLOCK;
|
|
- }
|
|
-
|
|
--/*
|
|
-- * __sdhci_msm_set_clock - sdhci_msm clock control.
|
|
-- *
|
|
-- * Description:
|
|
-- * MSM controller does not use internal divider and
|
|
-- * instead directly control the GCC clock as per
|
|
-- * HW recommendation.
|
|
-- **/
|
|
--static void __sdhci_msm_set_clock(struct sdhci_host *host, unsigned int clock)
|
|
--{
|
|
-- u16 clk;
|
|
--
|
|
-- sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL);
|
|
--
|
|
-- if (clock == 0)
|
|
-- return;
|
|
--
|
|
-- /*
|
|
-- * MSM controller do not use clock divider.
|
|
-- * Thus read SDHCI_CLOCK_CONTROL and only enable
|
|
-- * clock with no divider value programmed.
|
|
-- */
|
|
-- clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL);
|
|
-- sdhci_enable_clk(host, clk);
|
|
--}
|
|
--
|
|
--/* sdhci_msm_set_clock - Called with (host->lock) spinlock held. */
|
|
--static void sdhci_msm_set_clock(struct sdhci_host *host, unsigned int clock)
|
|
--{
|
|
-- struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
|
|
-- struct sdhci_msm_host *msm_host = sdhci_pltfm_priv(pltfm_host);
|
|
--
|
|
-- if (!clock) {
|
|
-- host->mmc->actual_clock = msm_host->clk_rate = 0;
|
|
-- goto out;
|
|
-- }
|
|
--
|
|
-- sdhci_msm_hc_select_mode(host);
|
|
--
|
|
-- msm_set_clock_rate_for_bus_mode(host, clock);
|
|
--out:
|
|
-- __sdhci_msm_set_clock(host, clock);
|
|
--}
|
|
-+// /*
|
|
-+// * __sdhci_msm_set_clock - sdhci_msm clock control.
|
|
-+// *
|
|
-+// * Description:
|
|
-+// * MSM controller does not use internal divider and
|
|
-+// * instead directly control the GCC clock as per
|
|
-+// * HW recommendation.
|
|
-+// **/
|
|
-+// static void __sdhci_msm_set_clock(struct sdhci_host *host, unsigned int clock)
|
|
-+// {
|
|
-+// u16 clk;
|
|
-+
|
|
-+// sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL);
|
|
-+
|
|
-+// if (clock == 0)
|
|
-+// return;
|
|
-+
|
|
-+// /*
|
|
-+// * MSM controller do not use clock divider.
|
|
-+// * Thus read SDHCI_CLOCK_CONTROL and only enable
|
|
-+// * clock with no divider value programmed.
|
|
-+// */
|
|
-+// clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL);
|
|
-+// sdhci_enable_clk(host, clk);
|
|
-+// }
|
|
-+
|
|
-+// /* sdhci_msm_set_clock - Called with (host->lock) spinlock held. */
|
|
-+// static void sdhci_msm_set_clock(struct sdhci_host *host, unsigned int clock)
|
|
-+// {
|
|
-+// struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
|
|
-+// struct sdhci_msm_host *msm_host = sdhci_pltfm_priv(pltfm_host);
|
|
-+
|
|
-+// if (!clock) {
|
|
-+// host->mmc->actual_clock = msm_host->clk_rate = 0;
|
|
-+// goto out;
|
|
-+// }
|
|
-+
|
|
-+// sdhci_msm_hc_select_mode(host);
|
|
-+
|
|
-+// msm_set_clock_rate_for_bus_mode(host, clock);
|
|
-+// out:
|
|
-+// __sdhci_msm_set_clock(host, clock);
|
|
-+// }
|
|
-
|
|
- /*****************************************************************************\
|
|
- * *
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/420-firmware-qcom-scm-disable-SDI.patch b/target/linux/ipq40xx/patches-5.15/420-firmware-qcom-scm-disable-SDI.patch
|
|
deleted file mode 100644
|
|
index a0074103cc..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/420-firmware-qcom-scm-disable-SDI.patch
|
|
+++ /dev/null
|
|
@@ -1,47 +0,0 @@
|
|
---- a/drivers/firmware/qcom_scm.c
|
|
-+++ b/drivers/firmware/qcom_scm.c
|
|
-@@ -404,6 +404,20 @@ static int __qcom_scm_set_dload_mode(str
|
|
- return qcom_scm_call_atomic(__scm->dev, &desc, NULL);
|
|
- }
|
|
-
|
|
-+static int __qcom_scm_disable_sdi(struct device *dev)
|
|
-+{
|
|
-+ struct qcom_scm_desc desc = {
|
|
-+ .svc = QCOM_SCM_SVC_BOOT,
|
|
-+ .cmd = QCOM_SCM_BOOT_CONFIG_SDI,
|
|
-+ .arginfo = QCOM_SCM_ARGS(2),
|
|
-+ .args[0] = 1 /* 1: disable watchdog debug */,
|
|
-+ .args[1] = 0 /* 0: disable SDI */,
|
|
-+ .owner = ARM_SMCCC_OWNER_SIP,
|
|
-+ };
|
|
-+
|
|
-+ return qcom_scm_call(__scm->dev, &desc, NULL);
|
|
-+}
|
|
-+
|
|
- static void qcom_scm_set_download_mode(bool enable)
|
|
- {
|
|
- bool avail;
|
|
-@@ -1314,6 +1328,13 @@ static int qcom_scm_probe(struct platfor
|
|
- if (download_mode)
|
|
- qcom_scm_set_download_mode(true);
|
|
-
|
|
-+ /*
|
|
-+ * Factory firmware leaves SDI (a debug interface), which prevents
|
|
-+ * clean reboot.
|
|
-+ */
|
|
-+ if (of_machine_is_compatible("google,wifi"))
|
|
-+ __qcom_scm_disable_sdi(__scm->dev);
|
|
-+
|
|
- return 0;
|
|
- }
|
|
-
|
|
---- a/drivers/firmware/qcom_scm.h
|
|
-+++ b/drivers/firmware/qcom_scm.h
|
|
-@@ -77,6 +77,7 @@ extern int scm_legacy_call(struct device
|
|
- #define QCOM_SCM_SVC_BOOT 0x01
|
|
- #define QCOM_SCM_BOOT_SET_ADDR 0x01
|
|
- #define QCOM_SCM_BOOT_TERMINATE_PC 0x02
|
|
-+#define QCOM_SCM_BOOT_CONFIG_SDI 0x09
|
|
- #define QCOM_SCM_BOOT_SET_DLOAD_MODE 0x10
|
|
- #define QCOM_SCM_BOOT_SET_REMOTE_STATE 0x0a
|
|
- #define QCOM_SCM_FLUSH_FLAG_MASK 0x3
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/421-firmware-qcom-scm-cold-boot-address.patch b/target/linux/ipq40xx/patches-5.15/421-firmware-qcom-scm-cold-boot-address.patch
|
|
deleted file mode 100644
|
|
index 13ebb5b000..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/421-firmware-qcom-scm-cold-boot-address.patch
|
|
+++ /dev/null
|
|
@@ -1,121 +0,0 @@
|
|
---- a/drivers/firmware/qcom_scm-legacy.c
|
|
-+++ b/drivers/firmware/qcom_scm-legacy.c
|
|
-@@ -13,6 +13,9 @@
|
|
- #include <linux/arm-smccc.h>
|
|
- #include <linux/dma-mapping.h>
|
|
-
|
|
-+#include <asm/cacheflush.h>
|
|
-+#include <asm/outercache.h>
|
|
-+
|
|
- #include "qcom_scm.h"
|
|
-
|
|
- static DEFINE_MUTEX(qcom_scm_lock);
|
|
-@@ -117,6 +120,25 @@ static void __scm_legacy_do(const struct
|
|
- } while (res->a0 == QCOM_SCM_INTERRUPTED);
|
|
- }
|
|
-
|
|
-+static void qcom_scm_inv_range(unsigned long start, unsigned long end)
|
|
-+{
|
|
-+ u32 cacheline_size, ctr;
|
|
-+
|
|
-+ asm volatile("mrc p15, 0, %0, c0, c0, 1" : "=r" (ctr));
|
|
-+ cacheline_size = 4 << ((ctr >> 16) & 0xf);
|
|
-+
|
|
-+ start = round_down(start, cacheline_size);
|
|
-+ end = round_up(end, cacheline_size);
|
|
-+ outer_inv_range(start, end);
|
|
-+ while (start < end) {
|
|
-+ asm ("mcr p15, 0, %0, c7, c6, 1" : : "r" (start)
|
|
-+ : "memory");
|
|
-+ start += cacheline_size;
|
|
-+ }
|
|
-+ dsb();
|
|
-+ isb();
|
|
-+}
|
|
-+
|
|
- /**
|
|
- * scm_legacy_call() - Sends a command to the SCM and waits for the command to
|
|
- * finish processing.
|
|
-@@ -160,10 +182,16 @@ int scm_legacy_call(struct device *dev,
|
|
-
|
|
- rsp = scm_legacy_command_to_response(cmd);
|
|
-
|
|
-- cmd_phys = dma_map_single(dev, cmd, alloc_len, DMA_TO_DEVICE);
|
|
-- if (dma_mapping_error(dev, cmd_phys)) {
|
|
-- kfree(cmd);
|
|
-- return -ENOMEM;
|
|
-+ if (dev) {
|
|
-+ cmd_phys = dma_map_single(dev, cmd, alloc_len, DMA_TO_DEVICE);
|
|
-+ if (dma_mapping_error(dev, cmd_phys)) {
|
|
-+ kfree(cmd);
|
|
-+ return -ENOMEM;
|
|
-+ }
|
|
-+ } else {
|
|
-+ cmd_phys = virt_to_phys(cmd);
|
|
-+ __cpuc_flush_dcache_area(cmd, alloc_len);
|
|
-+ outer_flush_range(cmd_phys, cmd_phys + alloc_len);
|
|
- }
|
|
-
|
|
- smc.args[0] = 1;
|
|
-@@ -179,13 +207,26 @@ int scm_legacy_call(struct device *dev,
|
|
- goto out;
|
|
-
|
|
- do {
|
|
-- dma_sync_single_for_cpu(dev, cmd_phys + sizeof(*cmd) + cmd_len,
|
|
-- sizeof(*rsp), DMA_FROM_DEVICE);
|
|
-+ if (dev) {
|
|
-+ dma_sync_single_for_cpu(dev, cmd_phys + sizeof(*cmd) +
|
|
-+ cmd_len, sizeof(*rsp),
|
|
-+ DMA_FROM_DEVICE);
|
|
-+ } else {
|
|
-+ unsigned long start = (uintptr_t)cmd + sizeof(*cmd) +
|
|
-+ cmd_len;
|
|
-+ qcom_scm_inv_range(start, start + sizeof(*rsp));
|
|
-+ }
|
|
- } while (!rsp->is_complete);
|
|
-
|
|
-- dma_sync_single_for_cpu(dev, cmd_phys + sizeof(*cmd) + cmd_len +
|
|
-- le32_to_cpu(rsp->buf_offset),
|
|
-- resp_len, DMA_FROM_DEVICE);
|
|
-+ if (dev) {
|
|
-+ dma_sync_single_for_cpu(dev, cmd_phys + sizeof(*cmd) + cmd_len +
|
|
-+ le32_to_cpu(rsp->buf_offset),
|
|
-+ resp_len, DMA_FROM_DEVICE);
|
|
-+ } else {
|
|
-+ unsigned long start = (uintptr_t)cmd + sizeof(*cmd) + cmd_len +
|
|
-+ le32_to_cpu(rsp->buf_offset);
|
|
-+ qcom_scm_inv_range(start, start + resp_len);
|
|
-+ }
|
|
-
|
|
- if (res) {
|
|
- res_buf = scm_legacy_get_response_buffer(rsp);
|
|
-@@ -193,7 +234,8 @@ int scm_legacy_call(struct device *dev,
|
|
- res->result[i] = le32_to_cpu(res_buf[i]);
|
|
- }
|
|
- out:
|
|
-- dma_unmap_single(dev, cmd_phys, alloc_len, DMA_TO_DEVICE);
|
|
-+ if (dev)
|
|
-+ dma_unmap_single(dev, cmd_phys, alloc_len, DMA_TO_DEVICE);
|
|
- kfree(cmd);
|
|
- return ret;
|
|
- }
|
|
---- a/drivers/firmware/qcom_scm.c
|
|
-+++ b/drivers/firmware/qcom_scm.c
|
|
-@@ -344,6 +344,17 @@ int qcom_scm_set_cold_boot_addr(void *en
|
|
- desc.args[0] = flags;
|
|
- desc.args[1] = virt_to_phys(entry);
|
|
-
|
|
-+ /*
|
|
-+ * Factory firmware doesn't support the atomic variant. Non-atomic SCMs
|
|
-+ * require ugly DMA invalidation support that was dropped upstream a
|
|
-+ * while ago. For more info, see:
|
|
-+ *
|
|
-+ * [RFC] qcom_scm: IPQ4019 firmware does not support atomic API?
|
|
-+ * https://lore.kernel.org/linux-arm-msm/20200913201608.GA3162100@bDebian/
|
|
-+ */
|
|
-+ if (of_machine_is_compatible("google,wifi"))
|
|
-+ return qcom_scm_call(__scm ? __scm->dev : NULL, &desc, NULL);
|
|
-+
|
|
- return qcom_scm_call_atomic(__scm ? __scm->dev : NULL, &desc, NULL);
|
|
- }
|
|
- EXPORT_SYMBOL(qcom_scm_set_cold_boot_addr);
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/444-mtd-nand-rawnand-add-support-for-Toshiba-TC58NVG0S3H.patch b/target/linux/ipq40xx/patches-5.15/444-mtd-nand-rawnand-add-support-for-Toshiba-TC58NVG0S3H.patch
|
|
deleted file mode 100644
|
|
index 91919b2894..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/444-mtd-nand-rawnand-add-support-for-Toshiba-TC58NVG0S3H.patch
|
|
+++ /dev/null
|
|
@@ -1,29 +0,0 @@
|
|
-From 35ca7e3e6ccd120d694a3425f37fc6374ad2e11e Mon Sep 17 00:00:00 2001
|
|
-From: =?UTF-8?q?Andreas=20B=C3=B6hler?= <dev@aboehler.at>
|
|
-Date: Wed, 20 Apr 2022 12:08:38 +0200
|
|
-Subject: [PATCH] mtd: rawnand: add support for Toshiba TC58NVG0S3HTA00
|
|
- NAND flash
|
|
-MIME-Version: 1.0
|
|
-Content-Type: text/plain; charset=UTF-8
|
|
-Content-Transfer-Encoding: 8bit
|
|
-
|
|
-The Toshiba TC58NVG0S3HTA00 is detected with 64 byte OOB while the flash
|
|
-has 128 bytes OOB. This adds a static NAND ID entry to correct this.
|
|
-
|
|
-Tested on FRITZ!Box 7530 flashed with OpenWrt.
|
|
-
|
|
-Signed-off-by: Andreas Böhler <dev@aboehler.at>
|
|
-(changed id_len to 8, added comment about possible counterfeits)
|
|
----
|
|
---- a/drivers/mtd/nand/raw/nand_ids.c
|
|
-+++ b/drivers/mtd/nand/raw/nand_ids.c
|
|
-@@ -29,6 +29,9 @@ struct nand_flash_dev nand_flash_ids[] =
|
|
- {"TC58NVG0S3E 1G 3.3V 8-bit",
|
|
- { .id = {0x98, 0xd1, 0x90, 0x15, 0x76, 0x14, 0x01, 0x00} },
|
|
- SZ_2K, SZ_128, SZ_128K, 0, 8, 64, NAND_ECC_INFO(1, SZ_512), },
|
|
-+ {"TC58NVG0S3HTA00 1G 3.3V 8-bit", /* possibly counterfeit chip - see commit */
|
|
-+ { .id = {0x98, 0xf1, 0x80, 0x15} }, /* should be more bytes */
|
|
-+ SZ_2K, SZ_128, SZ_128K, 0, 8, 128, NAND_ECC_INFO(8, SZ_512), },
|
|
- {"TC58NVG2S0F 4G 3.3V 8-bit",
|
|
- { .id = {0x98, 0xdc, 0x90, 0x26, 0x76, 0x15, 0x01, 0x08} },
|
|
- SZ_4K, SZ_512, SZ_256K, 0, 8, 224, NAND_ECC_INFO(4, SZ_512) },
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/700-skbuff-add-DSA-specific-data-to-struct-skb_shared_in.patch b/target/linux/ipq40xx/patches-5.15/700-skbuff-add-DSA-specific-data-to-struct-skb_shared_in.patch
|
|
deleted file mode 100644
|
|
index 385364c076..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/700-skbuff-add-DSA-specific-data-to-struct-skb_shared_in.patch
|
|
+++ /dev/null
|
|
@@ -1,43 +0,0 @@
|
|
-From da75807ac41175e9db8c95f7a172b4133763b744 Mon Sep 17 00:00:00 2001
|
|
-From: Gabor Juhos <j4g8y7@gmail.com>
|
|
-Date: Mon, 11 Jan 2021 17:49:36 +0100
|
|
-Subject: [PATCH] skbuff: add DSA specific data to struct skb_shared_info
|
|
-
|
|
-All of the already existing DSA tagging protocol drivers
|
|
-are storing the tagging data directly into the skb. In most
|
|
-cases that is the only way to send the required information
|
|
-to the underlying ethernet switch.
|
|
-
|
|
-However on certain platforms (like the Qualcomm IPQ40xx
|
|
-SoCs) the built-in ethernet switch is connected directly
|
|
-to an ethernet MAC, and the tagging information must be
|
|
-sent out-of-band which is done directly via the hardware
|
|
-TX descriptors of the ethernet MAC.
|
|
-
|
|
-In such cases, putting the information into the skb causes
|
|
-unneccesary overhead, because the ethernet driver must
|
|
-remove that before sending the ethernet frame towards to
|
|
-the hardware.
|
|
-
|
|
-This change adds two new DSA specific fields to struct
|
|
-skb_shared_info which makes it possible to send the
|
|
-tagging information via skb->shinfo. With this approach,
|
|
-the twofold modifications of the skb data can be avoided.
|
|
-
|
|
-Signed-off-by: Gabor Juhos <j4g8y7@gmail.com>
|
|
----
|
|
- include/linux/skbuff.h | 3 +++
|
|
- 1 file changed, 3 insertions(+)
|
|
-
|
|
---- a/include/linux/skbuff.h
|
|
-+++ b/include/linux/skbuff.h
|
|
-@@ -564,6 +564,9 @@ struct skb_shared_info {
|
|
- unsigned int gso_type;
|
|
- u32 tskey;
|
|
-
|
|
-+ unsigned int dsa_tag_proto;
|
|
-+ unsigned char dsa_tag_data[8];
|
|
-+
|
|
- /*
|
|
- * Warning : all fields before dataref are cleared in __alloc_skb()
|
|
- */
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/701-net-dsa-tag_ipq4019-add-shinfo-based-tagging-driver-.patch b/target/linux/ipq40xx/patches-5.15/701-net-dsa-tag_ipq4019-add-shinfo-based-tagging-driver-.patch
|
|
deleted file mode 100644
|
|
index 74079d68a1..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/701-net-dsa-tag_ipq4019-add-shinfo-based-tagging-driver-.patch
|
|
+++ /dev/null
|
|
@@ -1,187 +0,0 @@
|
|
-From 29a0c2fae991cab142575c92276c0afdeb260ebe Mon Sep 17 00:00:00 2001
|
|
-From: Gabor Juhos <j4g8y7@gmail.com>
|
|
-Date: Thu, 28 Oct 2021 21:44:52 +0200
|
|
-Subject: [PATCH] net: dsa: tag_ipq4019: add shinfo based tagging driver for
|
|
- IPQ40xx
|
|
-
|
|
-This change adds a tagging protocol driver for the built-in
|
|
-ethernet switch of the Qualcomm Atheros IPQ4019 SoCs.
|
|
-
|
|
-In comparison to the existing tagging protocols this hardware
|
|
-requires a slightly different approach because the switch does
|
|
-not use in-band tags.
|
|
-
|
|
-On the receive path, the source port information is embedded
|
|
-into the RX descriptors of the ethernet MAC hardware. Similarly,
|
|
-the destination port mask must be sent via the TX descriptors
|
|
-of the ethernet MAC when a packet is sent towards the switch.
|
|
-
|
|
-In order to support this special requirements, this patch
|
|
-adds a new tagging protocol driver.
|
|
-
|
|
-The driver extracts the source port information directly
|
|
-from the 'receive return descriptor' of the ethernet MAC.
|
|
-It is possible because that descriptor is part of the skb
|
|
-received from the ethernet driver.
|
|
-
|
|
-Unfortunatley, it is not possible to put the destination
|
|
-port information directly to the TX descriptors, because
|
|
-those are handled internally by the driver of the ethernet
|
|
-hardware.
|
|
-
|
|
-To overcome this limitation, this tagging driver uses the
|
|
-DSA specific fields in skb->shinfo to send the destination
|
|
-port information to the ethernet driver.
|
|
-
|
|
-A similar tagging driver is exist but that uses skb
|
|
-extensions which causes unnecessary overhead.
|
|
-
|
|
-Signed-off-by: Gabor Juhos <j4g8y7@gmail.com>
|
|
----
|
|
- include/linux/dsa/ipq4019.h | 11 ++++++
|
|
- include/net/dsa.h | 2 +
|
|
- net/dsa/Kconfig | 6 +++
|
|
- net/dsa/Makefile | 1 +
|
|
- net/dsa/tag_ipq4019.c | 79 +++++++++++++++++++++++++++++++++++++
|
|
- 5 files changed, 99 insertions(+)
|
|
- create mode 100644 include/linux/dsa/ipq4019.h
|
|
- create mode 100644 net/dsa/tag_ipq4019.c
|
|
-
|
|
---- /dev/null
|
|
-+++ b/include/linux/dsa/ipq4019.h
|
|
-@@ -0,0 +1,11 @@
|
|
-+/* SPDX-License-Identifier: GPL-2.0-only */
|
|
-+
|
|
-+#ifndef DSA_IPQ40XX_H
|
|
-+#define DSA_IPQ40XX_H
|
|
-+
|
|
-+struct ipq40xx_dsa_tag_data {
|
|
-+ u8 from_cpu;
|
|
-+ u8 dp;
|
|
-+};
|
|
-+
|
|
-+#endif /* DSA_IPQ40XX_H */
|
|
---- a/include/net/dsa.h
|
|
-+++ b/include/net/dsa.h
|
|
-@@ -51,6 +51,7 @@ struct phylink_link_state;
|
|
- #define DSA_TAG_PROTO_SEVILLE_VALUE 21
|
|
- #define DSA_TAG_PROTO_BRCM_LEGACY_VALUE 22
|
|
- #define DSA_TAG_PROTO_SJA1110_VALUE 23
|
|
-+#define DSA_TAG_PROTO_IPQ4019_VALUE 24
|
|
-
|
|
- enum dsa_tag_protocol {
|
|
- DSA_TAG_PROTO_NONE = DSA_TAG_PROTO_NONE_VALUE,
|
|
-@@ -77,6 +78,7 @@ enum dsa_tag_protocol {
|
|
- DSA_TAG_PROTO_OCELOT_8021Q = DSA_TAG_PROTO_OCELOT_8021Q_VALUE,
|
|
- DSA_TAG_PROTO_SEVILLE = DSA_TAG_PROTO_SEVILLE_VALUE,
|
|
- DSA_TAG_PROTO_SJA1110 = DSA_TAG_PROTO_SJA1110_VALUE,
|
|
-+ DSA_TAG_PROTO_IPQ4019 = DSA_TAG_PROTO_IPQ4019_VALUE,
|
|
- };
|
|
-
|
|
- struct dsa_switch;
|
|
---- a/net/dsa/Kconfig
|
|
-+++ b/net/dsa/Kconfig
|
|
-@@ -57,6 +57,12 @@ config NET_DSA_TAG_HELLCREEK
|
|
- Say Y or M if you want to enable support for tagging frames
|
|
- for the Hirschmann Hellcreek TSN switches.
|
|
-
|
|
-+config NET_DSA_TAG_IPQ4019
|
|
-+ tristate "Tag driver for Qualcomm Atheros IPQ4019 SoC built-in switch"
|
|
-+ help
|
|
-+ Say Y or M if you want to enable support for tagging frames for
|
|
-+ the built-in switch of the Qualcomm Atheros IPQ4019 SoC-s.
|
|
-+
|
|
- config NET_DSA_TAG_GSWIP
|
|
- tristate "Tag driver for Lantiq / Intel GSWIP switches"
|
|
- help
|
|
---- a/net/dsa/Makefile
|
|
-+++ b/net/dsa/Makefile
|
|
-@@ -8,6 +8,7 @@ obj-$(CONFIG_NET_DSA_TAG_AR9331) += tag_
|
|
- obj-$(CONFIG_NET_DSA_TAG_BRCM_COMMON) += tag_brcm.o
|
|
- obj-$(CONFIG_NET_DSA_TAG_DSA_COMMON) += tag_dsa.o
|
|
- obj-$(CONFIG_NET_DSA_TAG_GSWIP) += tag_gswip.o
|
|
-+obj-$(CONFIG_NET_DSA_TAG_IPQ4019) += tag_ipq4019.o
|
|
- obj-$(CONFIG_NET_DSA_TAG_HELLCREEK) += tag_hellcreek.o
|
|
- obj-$(CONFIG_NET_DSA_TAG_KSZ) += tag_ksz.o
|
|
- obj-$(CONFIG_NET_DSA_TAG_RTL4_A) += tag_rtl4_a.o
|
|
---- /dev/null
|
|
-+++ b/net/dsa/tag_ipq4019.c
|
|
-@@ -0,0 +1,78 @@
|
|
-+// SPDX-License-Identifier: GPL-2.0-only
|
|
-+
|
|
-+/* Copyright (c) 2021, Gabor Juhos <j4g8y7@gmail.com> */
|
|
-+
|
|
-+#include <linux/bitfield.h>
|
|
-+#include <linux/dsa/ipq4019.h>
|
|
-+
|
|
-+#include "dsa_priv.h"
|
|
-+
|
|
-+/* Receive Return Descriptor */
|
|
-+struct edma_rrd {
|
|
-+ u16 rrd0;
|
|
-+ u16 rrd1;
|
|
-+ u16 rrd2;
|
|
-+ u16 rrd3;
|
|
-+ u16 rrd4;
|
|
-+ u16 rrd5;
|
|
-+ u16 rrd6;
|
|
-+ u16 rrd7;
|
|
-+} __packed;
|
|
-+
|
|
-+#define EDMA_RRD_SIZE sizeof(struct edma_rrd)
|
|
-+
|
|
-+#define EDMA_RRD1_PORT_ID_MASK GENMASK(14, 12)
|
|
-+
|
|
-+static struct sk_buff *ipq4019_sh_tag_xmit(struct sk_buff *skb,
|
|
-+ struct net_device *dev)
|
|
-+{
|
|
-+ struct dsa_port *dp = dsa_slave_to_port(dev);
|
|
-+ struct ipq40xx_dsa_tag_data *tag_data;
|
|
-+
|
|
-+ BUILD_BUG_ON(sizeof_field(struct skb_shared_info, dsa_tag_data) <
|
|
-+ sizeof(struct ipq40xx_dsa_tag_data));
|
|
-+
|
|
-+ skb_shinfo(skb)->dsa_tag_proto = DSA_TAG_PROTO_IPQ4019;
|
|
-+ tag_data = (struct ipq40xx_dsa_tag_data *)skb_shinfo(skb)->dsa_tag_data;
|
|
-+
|
|
-+ tag_data->from_cpu = 1;
|
|
-+ /* set the destination port information */
|
|
-+ tag_data->dp = BIT(dp->index);
|
|
-+
|
|
-+ return skb;
|
|
-+}
|
|
-+
|
|
-+static struct sk_buff *ipq4019_sh_tag_rcv(struct sk_buff *skb,
|
|
-+ struct net_device *dev)
|
|
-+{
|
|
-+ struct edma_rrd *rrd;
|
|
-+ int offset;
|
|
-+ int port;
|
|
-+
|
|
-+ offset = EDMA_RRD_SIZE + ETH_HLEN;
|
|
-+ if (unlikely(skb_headroom(skb) < offset))
|
|
-+ return NULL;
|
|
-+
|
|
-+ rrd = (struct edma_rrd *)(skb->data - offset);
|
|
-+ port = FIELD_GET(EDMA_RRD1_PORT_ID_MASK, rrd->rrd1);
|
|
-+
|
|
-+ skb->dev = dsa_master_find_slave(dev, 0, port);
|
|
-+ if (!skb->dev)
|
|
-+ return NULL;
|
|
-+
|
|
-+ return skb;
|
|
-+}
|
|
-+
|
|
-+const struct dsa_device_ops ipq4019_sh_tag_dsa_ops = {
|
|
-+ .name = "ipq4019-sh",
|
|
-+ .proto = DSA_TAG_PROTO_IPQ4019,
|
|
-+ .xmit = ipq4019_sh_tag_xmit,
|
|
-+ .rcv = ipq4019_sh_tag_rcv,
|
|
-+};
|
|
-+
|
|
-+MODULE_LICENSE("GPL v2");
|
|
-+MODULE_DESCRIPTION("DSA tag driver for the IPQ4019 SoC built-in ethernet switch");
|
|
-+MODULE_AUTHOR("Gabor Juhos <j4g8y7@gmail.com>");
|
|
-+MODULE_ALIAS_DSA_TAG_DRIVER(DSA_TAG_PROTO_IPQ4019);
|
|
-+
|
|
-+module_dsa_tag_driver(ipq4019_sh_tag_dsa_ops);
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/702-net-ethernet-qualcomm-add-IPQESS-support.patch b/target/linux/ipq40xx/patches-5.15/702-net-ethernet-qualcomm-add-IPQESS-support.patch
|
|
deleted file mode 100644
|
|
index 72e9345118..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/702-net-ethernet-qualcomm-add-IPQESS-support.patch
|
|
+++ /dev/null
|
|
@@ -1,43 +0,0 @@
|
|
-From 4f488235f498db43f2412116dea6e02c7fb20216 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Mon, 1 Nov 2021 12:36:51 +0100
|
|
-Subject: [PATCH] net: ethernet: qualcomm: add IPQESS support
|
|
-
|
|
-Allow compiling the IPQESS driver that supports the
|
|
-Qualcomm IPQ40xx SoC built-in ethernet controller.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- drivers/net/ethernet/qualcomm/Kconfig | 11 +++++++++++
|
|
- drivers/net/ethernet/qualcomm/Makefile | 1 +
|
|
- 2 files changed, 12 insertions(+)
|
|
-
|
|
---- a/drivers/net/ethernet/qualcomm/Kconfig
|
|
-+++ b/drivers/net/ethernet/qualcomm/Kconfig
|
|
-@@ -60,6 +60,17 @@ config QCOM_EMAC
|
|
- low power, Receive-Side Scaling (RSS), and IEEE 1588-2008
|
|
- Precision Clock Synchronization Protocol.
|
|
-
|
|
-+config QCOM_IPQ4019_ESS_EDMA
|
|
-+ tristate "Qualcomm Atheros IPQ4019 ESS EDMA support"
|
|
-+ depends on OF
|
|
-+ select PHYLINK
|
|
-+ help
|
|
-+ This driver supports the Qualcomm Atheros IPQ40xx built-in
|
|
-+ ESS EDMA ethernet controller.
|
|
-+
|
|
-+ To compile this driver as a module, choose M here: the
|
|
-+ module will be called ipqess.
|
|
-+
|
|
- source "drivers/net/ethernet/qualcomm/rmnet/Kconfig"
|
|
-
|
|
- endif # NET_VENDOR_QUALCOMM
|
|
---- a/drivers/net/ethernet/qualcomm/Makefile
|
|
-+++ b/drivers/net/ethernet/qualcomm/Makefile
|
|
-@@ -10,5 +10,6 @@ obj-$(CONFIG_QCA7000_UART) += qcauart.o
|
|
- qcauart-objs := qca_uart.o
|
|
-
|
|
- obj-y += emac/
|
|
-+obj-y += ipqess/
|
|
-
|
|
- obj-$(CONFIG_RMNET) += rmnet/
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/703-arm-dts-ipq4019-add-ethernet-controller-DT-node.patch b/target/linux/ipq40xx/patches-5.15/703-arm-dts-ipq4019-add-ethernet-controller-DT-node.patch
|
|
deleted file mode 100644
|
|
index 68fb4eb4ce..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/703-arm-dts-ipq4019-add-ethernet-controller-DT-node.patch
|
|
+++ /dev/null
|
|
@@ -1,81 +0,0 @@
|
|
-From 44327d7098d4f32c24ec8c528e5aff6e030956bc Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Wed, 20 Oct 2021 13:21:45 +0200
|
|
-Subject: [PATCH] arm: dts: ipq4019: add ethernet controller DT node
|
|
-
|
|
-Since IPQ40xx SoC built-in ethernet controller now has a driver,
|
|
-add its DT node so it can be used.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- arch/arm/boot/dts/qcom-ipq4019.dtsi | 48 +++++++++++++++++++++++++++++
|
|
- 1 file changed, 48 insertions(+)
|
|
-
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-@@ -38,6 +38,7 @@
|
|
- spi1 = &blsp1_spi2;
|
|
- i2c0 = &blsp1_i2c3;
|
|
- i2c1 = &blsp1_i2c4;
|
|
-+ ethernet0 = &gmac;
|
|
- };
|
|
-
|
|
- cpus {
|
|
-@@ -589,6 +590,57 @@
|
|
- status = "disabled";
|
|
- };
|
|
-
|
|
-+ gmac: ethernet@c080000 {
|
|
-+ compatible = "qcom,ipq4019-ess-edma";
|
|
-+ reg = <0xc080000 0x8000>;
|
|
-+ resets = <&gcc ESS_RESET>;
|
|
-+ reset-names = "ess_rst";
|
|
-+ clocks = <&gcc GCC_ESS_CLK>;
|
|
-+ clock-names = "ess_clk";
|
|
-+ interrupts = <GIC_SPI 65 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 66 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 67 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 68 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 69 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 70 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 71 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 72 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 74 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 75 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 76 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 77 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 78 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 79 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 80 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 240 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 241 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 242 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 243 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 244 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 245 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 246 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 247 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 248 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 249 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 250 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 251 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 252 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 253 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 254 IRQ_TYPE_EDGE_RISING>,
|
|
-+ <GIC_SPI 255 IRQ_TYPE_EDGE_RISING>;
|
|
-+
|
|
-+ status = "disabled";
|
|
-+
|
|
-+ phy-mode = "internal";
|
|
-+ fixed-link {
|
|
-+ speed = <1000>;
|
|
-+ full-duplex;
|
|
-+ pause;
|
|
-+ asym-pause;
|
|
-+ };
|
|
-+ };
|
|
-+
|
|
- mdio: mdio@90000 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <0>;
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/704-net-phy-define-PSGMII-PHY-interface-mode.patch b/target/linux/ipq40xx/patches-5.15/704-net-phy-define-PSGMII-PHY-interface-mode.patch
|
|
deleted file mode 100644
|
|
index ed5b7b60fb..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/704-net-phy-define-PSGMII-PHY-interface-mode.patch
|
|
+++ /dev/null
|
|
@@ -1,69 +0,0 @@
|
|
-From 157ac9f52fd9b9a22cf12f7755a905fb34ef72f7 Mon Sep 17 00:00:00 2001
|
|
-From: Gabor Juhos <j4g8y7@gmail.com>
|
|
-Date: Fri, 25 Dec 2020 08:02:47 +0100
|
|
-Subject: [PATCH] net: phy: define PSGMII PHY interface mode
|
|
-
|
|
-The PSGMII interface is similar to QSGMII. The main difference
|
|
-is that the PSGMII interface combines five SGMII lines into a
|
|
-single link while in QSGMII only four lines are combined.
|
|
-
|
|
-Similarly to the QSGMII, this interface mode might also needs
|
|
-special handling within the MAC driver.
|
|
-
|
|
-Add definitions for the PHY layer to allow to express this type
|
|
-of connection between the MAC and PHY.
|
|
-
|
|
-Signed-off-by: Gabor Juhos <j4g8y7@gmail.com>
|
|
----
|
|
- Documentation/devicetree/bindings/net/ethernet-controller.yaml | 1 +
|
|
- drivers/net/phy/phylink.c | 2 ++
|
|
- include/linux/phy.h | 3 +++
|
|
- 3 files changed, 6 insertions(+)
|
|
-
|
|
---- a/Documentation/devicetree/bindings/net/ethernet-controller.yaml
|
|
-+++ b/Documentation/devicetree/bindings/net/ethernet-controller.yaml
|
|
-@@ -64,6 +64,7 @@ properties:
|
|
- - mii
|
|
- - gmii
|
|
- - sgmii
|
|
-+ - psgmii
|
|
- - qsgmii
|
|
- - tbi
|
|
- - rev-mii
|
|
---- a/drivers/net/phy/phylink.c
|
|
-+++ b/drivers/net/phy/phylink.c
|
|
-@@ -371,6 +371,7 @@ void phylink_get_linkmodes(unsigned long
|
|
- case PHY_INTERFACE_MODE_RGMII_RXID:
|
|
- case PHY_INTERFACE_MODE_RGMII_ID:
|
|
- case PHY_INTERFACE_MODE_RGMII:
|
|
-+ case PHY_INTERFACE_MODE_PSGMII:
|
|
- case PHY_INTERFACE_MODE_QSGMII:
|
|
- case PHY_INTERFACE_MODE_SGMII:
|
|
- case PHY_INTERFACE_MODE_GMII:
|
|
-@@ -634,6 +635,7 @@ static int phylink_parse_mode(struct phy
|
|
-
|
|
- switch (pl->link_config.interface) {
|
|
- case PHY_INTERFACE_MODE_SGMII:
|
|
-+ case PHY_INTERFACE_MODE_PSGMII:
|
|
- case PHY_INTERFACE_MODE_QSGMII:
|
|
- phylink_set(pl->supported, 10baseT_Half);
|
|
- phylink_set(pl->supported, 10baseT_Full);
|
|
---- a/include/linux/phy.h
|
|
-+++ b/include/linux/phy.h
|
|
-@@ -139,6 +139,7 @@ typedef enum {
|
|
- PHY_INTERFACE_MODE_XGMII,
|
|
- PHY_INTERFACE_MODE_XLGMII,
|
|
- PHY_INTERFACE_MODE_MOCA,
|
|
-+ PHY_INTERFACE_MODE_PSGMII,
|
|
- PHY_INTERFACE_MODE_QSGMII,
|
|
- PHY_INTERFACE_MODE_TRGMII,
|
|
- PHY_INTERFACE_MODE_100BASEX,
|
|
-@@ -244,6 +245,8 @@ static inline const char *phy_modes(phy_
|
|
- return "xlgmii";
|
|
- case PHY_INTERFACE_MODE_MOCA:
|
|
- return "moca";
|
|
-+ case PHY_INTERFACE_MODE_PSGMII:
|
|
-+ return "psgmii";
|
|
- case PHY_INTERFACE_MODE_QSGMII:
|
|
- return "qsgmii";
|
|
- case PHY_INTERFACE_MODE_TRGMII:
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/705-net-dsa-add-Qualcomm-IPQ4019-built-in-switch-support.patch b/target/linux/ipq40xx/patches-5.15/705-net-dsa-add-Qualcomm-IPQ4019-built-in-switch-support.patch
|
|
deleted file mode 100644
|
|
index 13b169e576..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/705-net-dsa-add-Qualcomm-IPQ4019-built-in-switch-support.patch
|
|
+++ /dev/null
|
|
@@ -1,57 +0,0 @@
|
|
-From b5f71652b85a85ea53162e9e2b760b84fd0d254f Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Mon, 1 Nov 2021 18:10:28 +0100
|
|
-Subject: [PATCH] net: dsa: add Qualcomm IPQ4019 built-in switch support
|
|
-
|
|
-Qualcomm IPQ40xx SoC-s have a variant of QCA8337N switch built-in.
|
|
-
|
|
-It shares most of the stuff with its external counterpart, however it is
|
|
-modified for the SoC.
|
|
-Namely, it doesn't have second CPU port (Port 6), so it has 6 ports
|
|
-instead of 7.
|
|
-It also has no built-in PHY-s but rather requires external PSGMII based
|
|
-companion PHY-s (QCA8072 and QCA8075) for which it first needs to carry
|
|
-out calibration before using them.
|
|
-PSGMII has a SoC built-in PHY that is used to connect to the PHY-s which
|
|
-unfortunately requires some magic values as the datasheet doesnt document
|
|
-the bits that are being set or the register at all.
|
|
-
|
|
-Since its built-in it is MMIO like other peripherals and doesn't have its
|
|
-own MDIO bus but depends on the SoC provided one.
|
|
-
|
|
-CPU connection is at Port 0 and it uses some kind of a internal connection
|
|
-and no traditional RGMII/SGMII.
|
|
-It also doesn't use in-band tagging like other qca8k switches so a shinfo
|
|
-based tagger is used.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- drivers/net/dsa/qca/Kconfig | 9 +++++++++
|
|
- drivers/net/dsa/qca/Makefile | 1 +
|
|
- 2 files changed, 10 insertions(+)
|
|
-
|
|
---- a/drivers/net/dsa/qca/Kconfig
|
|
-+++ b/drivers/net/dsa/qca/Kconfig
|
|
-@@ -23,3 +23,13 @@ config NET_DSA_QCA8K_LEDS_SUPPORT
|
|
- help
|
|
- This enabled support for LEDs present on the Qualcomm Atheros
|
|
- QCA8K Ethernet switch chips.
|
|
-+
|
|
-+config NET_DSA_QCA8K_IPQ4019
|
|
-+ tristate "Qualcomm Atheros IPQ4019 built-in Ethernet switch support"
|
|
-+ depends on HAS_IOMEM && NET_DSA
|
|
-+ select NET_DSA_TAG_IPQ4019
|
|
-+ select REGMAP
|
|
-+ help
|
|
-+ This enables support for the Qualcomm Atheros IPQ4019 SoC built-in
|
|
-+ Ethernet switch.
|
|
-+
|
|
---- a/drivers/net/dsa/qca/Makefile
|
|
-+++ b/drivers/net/dsa/qca/Makefile
|
|
-@@ -1,5 +1,6 @@
|
|
- # SPDX-License-Identifier: GPL-2.0-only
|
|
- obj-$(CONFIG_NET_DSA_AR9331) += ar9331.o
|
|
-+obj-$(CONFIG_NET_DSA_QCA8K_IPQ4019) += qca8k-ipq4019.o
|
|
- obj-$(CONFIG_NET_DSA_QCA8K) += qca8k.o
|
|
- qca8k-y += qca8k-common.o qca8k-8xxx.o
|
|
- ifdef CONFIG_NET_DSA_QCA8K_LEDS_SUPPORT
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/706-arm-dts-ipq4019-add-switch-node.patch b/target/linux/ipq40xx/patches-5.15/706-arm-dts-ipq4019-add-switch-node.patch
|
|
deleted file mode 100644
|
|
index a231c7331b..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/706-arm-dts-ipq4019-add-switch-node.patch
|
|
+++ /dev/null
|
|
@@ -1,98 +0,0 @@
|
|
-From ebb62523990a27b3a25e422fa575619f7f725a20 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Mon, 1 Nov 2021 18:15:04 +0100
|
|
-Subject: [PATCH] arm: dts: ipq4019: add switch node
|
|
-
|
|
-Since the built-in IPQ40xx switch now has a driver, add the required node
|
|
-for it to work.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- arch/arm/boot/dts/qcom-ipq4019.dtsi | 78 +++++++++++++++++++++++++++++
|
|
- 1 file changed, 78 insertions(+)
|
|
-
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-@@ -590,6 +590,82 @@
|
|
- status = "disabled";
|
|
- };
|
|
-
|
|
-+ switch: switch@c000000 {
|
|
-+ compatible = "qca,ipq4019-qca8337n";
|
|
-+ reg = <0xc000000 0x80000>, <0x98000 0x800>;
|
|
-+ reg-names = "base", "psgmii_phy";
|
|
-+ resets = <&gcc ESS_PSGMII_ARES>;
|
|
-+ reset-names = "psgmii_rst";
|
|
-+ mdio = <&mdio>;
|
|
-+ psgmii-ethphy = <&psgmiiphy>;
|
|
-+
|
|
-+ status = "disabled";
|
|
-+
|
|
-+ ports {
|
|
-+ #address-cells = <1>;
|
|
-+ #size-cells = <0>;
|
|
-+
|
|
-+ port@0 { /* MAC0 */
|
|
-+ reg = <0>;
|
|
-+ label = "cpu";
|
|
-+ ethernet = <&gmac>;
|
|
-+ phy-mode = "internal";
|
|
-+
|
|
-+ fixed-link {
|
|
-+ speed = <1000>;
|
|
-+ full-duplex;
|
|
-+ pause;
|
|
-+ asym-pause;
|
|
-+ };
|
|
-+ };
|
|
-+
|
|
-+ swport1: port@1 { /* MAC1 */
|
|
-+ reg = <1>;
|
|
-+ label = "lan1";
|
|
-+ phy-handle = <ðphy0>;
|
|
-+ phy-mode = "psgmii";
|
|
-+
|
|
-+ status = "disabled";
|
|
-+ };
|
|
-+
|
|
-+ swport2: port@2 { /* MAC2 */
|
|
-+ reg = <2>;
|
|
-+ label = "lan2";
|
|
-+ phy-handle = <ðphy1>;
|
|
-+ phy-mode = "psgmii";
|
|
-+
|
|
-+ status = "disabled";
|
|
-+ };
|
|
-+
|
|
-+ swport3: port@3 { /* MAC3 */
|
|
-+ reg = <3>;
|
|
-+ label = "lan3";
|
|
-+ phy-handle = <ðphy2>;
|
|
-+ phy-mode = "psgmii";
|
|
-+
|
|
-+ status = "disabled";
|
|
-+ };
|
|
-+
|
|
-+ swport4: port@4 { /* MAC4 */
|
|
-+ reg = <4>;
|
|
-+ label = "lan4";
|
|
-+ phy-handle = <ðphy3>;
|
|
-+ phy-mode = "psgmii";
|
|
-+
|
|
-+ status = "disabled";
|
|
-+ };
|
|
-+
|
|
-+ swport5: port@5 { /* MAC5 */
|
|
-+ reg = <5>;
|
|
-+ label = "wan";
|
|
-+ phy-handle = <ðphy4>;
|
|
-+ phy-mode = "psgmii";
|
|
-+
|
|
-+ status = "disabled";
|
|
-+ };
|
|
-+ };
|
|
-+ };
|
|
-+
|
|
- gmac: ethernet@c080000 {
|
|
- compatible = "qcom,ipq4019-ess-edma";
|
|
- reg = <0xc080000 0x8000>;
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/707-dt-bindings-net-add-QCA807x-PHY.patch b/target/linux/ipq40xx/patches-5.15/707-dt-bindings-net-add-QCA807x-PHY.patch
|
|
deleted file mode 100644
|
|
index dfb8d692ab..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/707-dt-bindings-net-add-QCA807x-PHY.patch
|
|
+++ /dev/null
|
|
@@ -1,61 +0,0 @@
|
|
-From c66863c1ba8995b61e6d727d78a241c734f5bb57 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Thu, 1 Oct 2020 15:05:35 +0200
|
|
-Subject: [PATCH] dt-bindings: net: add QCA807x PHY
|
|
-
|
|
-Add DT bindings for Qualcomm QCA807x PHY series.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- include/dt-bindings/net/qcom-qca807x.h | 45 ++++++++++++++++++++++++++
|
|
- 1 file changed, 45 insertions(+)
|
|
- create mode 100644 include/dt-bindings/net/qcom-qca807x.h
|
|
-
|
|
---- /dev/null
|
|
-+++ b/include/dt-bindings/net/qcom-qca807x.h
|
|
-@@ -0,0 +1,45 @@
|
|
-+/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
-+/*
|
|
-+ * Device Tree constants for the Qualcomm QCA807X PHYs
|
|
-+ */
|
|
-+
|
|
-+#ifndef _DT_BINDINGS_QCOM_QCA807X_H
|
|
-+#define _DT_BINDINGS_QCOM_QCA807X_H
|
|
-+
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_140MV 0
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_160MV 1
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_180MV 2
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_200MV 3
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_220MV 4
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_240MV 5
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_260MV 6
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_280MV 7
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_300MV 8
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_320MV 9
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_400MV 10
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_500MV 11
|
|
-+/* Default value */
|
|
-+#define PSGMII_QSGMII_TX_DRIVER_600MV 12
|
|
-+
|
|
-+/* Full amplitude, full bias current */
|
|
-+#define QCA807X_CONTROL_DAC_FULL_VOLT_BIAS 0
|
|
-+/* Amplitude follow DSP (amplitude is adjusted based on cable length), half bias current */
|
|
-+#define QCA807X_CONTROL_DAC_DSP_VOLT_HALF_BIAS 1
|
|
-+/* Full amplitude, bias current follow DSP (bias current is adjusted based on cable length) */
|
|
-+#define QCA807X_CONTROL_DAC_FULL_VOLT_DSP_BIAS 2
|
|
-+/* Both amplitude and bias current follow DSP */
|
|
-+#define QCA807X_CONTROL_DAC_DSP_VOLT_BIAS 3
|
|
-+/* Full amplitude, half bias current */
|
|
-+#define QCA807X_CONTROL_DAC_FULL_VOLT_HALF_BIAS 4
|
|
-+/* Amplitude follow DSP setting; 1/4 bias current when cable<10m,
|
|
-+ * otherwise half bias current
|
|
-+ */
|
|
-+#define QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS 5
|
|
-+/* Full amplitude; same bias current setting with “010” and “011”,
|
|
-+ * but half more bias is reduced when cable <10m
|
|
-+ */
|
|
-+#define QCA807X_CONTROL_DAC_FULL_VOLT_HALF_BIAS_SHORT 6
|
|
-+/* Amplitude follow DSP; same bias current setting with “110”, default value */
|
|
-+#define QCA807X_CONTROL_DAC_DSP_VOLT_HALF_BIAS_SHORT 7
|
|
-+
|
|
-+#endif
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/708-net-phy-Add-Qualcom-QCA807x-driver.patch b/target/linux/ipq40xx/patches-5.15/708-net-phy-Add-Qualcom-QCA807x-driver.patch
|
|
deleted file mode 100644
|
|
index 6a92a103d6..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/708-net-phy-Add-Qualcom-QCA807x-driver.patch
|
|
+++ /dev/null
|
|
@@ -1,50 +0,0 @@
|
|
-From f825cdc8bfde7616a14e2163f16303a8973031d2 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Wed, 7 Oct 2020 17:38:48 +0200
|
|
-Subject: [PATCH] net: phy: Add Qualcom QCA807x driver
|
|
-
|
|
-This adds driver for the Qualcomm QCA8072 and QCA8075 PHY-s.
|
|
-
|
|
-They are 2 or 5 port IEEE 802.3 clause 22 compliant 10BASE-Te, 100BASE-TX and 1000BASE-T PHY-s.
|
|
-
|
|
-They feature 2 SerDes, one for PSGMII or QSGMII connection with MAC, while second one is SGMII for connection to MAC or fiber.
|
|
-
|
|
-Both models have a combo port that supports 1000BASE-X and 100BASE-FX fiber.
|
|
-
|
|
-Each PHY inside of QCA807x series has 4 digitally controlled output only pins that natively drive LED-s.
|
|
-But some vendors used these to driver generic LED-s controlled by userspace,
|
|
-so lets enable registering each PHY as GPIO controller and add driver for it.
|
|
-
|
|
-These are commonly used in Qualcomm IPQ40xx, IPQ60xx and IPQ807x boards.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- drivers/net/phy/Kconfig | 6 ++++++
|
|
- drivers/net/phy/Makefile | 1 +
|
|
- 2 files changed, 7 insertions(+)
|
|
-
|
|
---- a/drivers/net/phy/Kconfig
|
|
-+++ b/drivers/net/phy/Kconfig
|
|
-@@ -347,6 +347,12 @@ config AT803X_PHY
|
|
- Currently supports the AR8030, AR8031, AR8033, AR8035 and internal
|
|
- QCA8337(Internal qca8k PHY) model
|
|
-
|
|
-+config QCA807X_PHY
|
|
-+ tristate "Qualcomm QCA807X PHYs"
|
|
-+ depends on OF_MDIO
|
|
-+ help
|
|
-+ Currently supports the QCA8072 and QCA8075 models.
|
|
-+
|
|
- config QSEMI_PHY
|
|
- tristate "Quality Semiconductor PHYs"
|
|
- help
|
|
---- a/drivers/net/phy/Makefile
|
|
-+++ b/drivers/net/phy/Makefile
|
|
-@@ -92,6 +92,7 @@ obj-$(CONFIG_NATIONAL_PHY) += national.o
|
|
- obj-$(CONFIG_NXP_C45_TJA11XX_PHY) += nxp-c45-tja11xx.o
|
|
- obj-$(CONFIG_NXP_TJA11XX_PHY) += nxp-tja11xx.o
|
|
- obj-$(CONFIG_QSEMI_PHY) += qsemi.o
|
|
-+obj-$(CONFIG_QCA807X_PHY) += qca807x.o
|
|
- obj-$(CONFIG_REALTEK_PHY) += realtek.o
|
|
- obj-$(CONFIG_RENESAS_PHY) += uPD60620.o
|
|
- obj-$(CONFIG_ROCKCHIP_PHY) += rockchip.o
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/709-arm-dts-ipq4019-QCA807x-properties.patch b/target/linux/ipq40xx/patches-5.15/709-arm-dts-ipq4019-QCA807x-properties.patch
|
|
deleted file mode 100644
|
|
index cc4b44b393..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/709-arm-dts-ipq4019-QCA807x-properties.patch
|
|
+++ /dev/null
|
|
@@ -1,61 +0,0 @@
|
|
-From e0fa88eaa3c176b71e563da68949ac2ab45aaa61 Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robert.marko@sartura.hr>
|
|
-Date: Fri, 2 Oct 2020 10:43:26 +0200
|
|
-Subject: [PATCH] arm: dts: ipq4019: QCA807x properties
|
|
-
|
|
-This adds necessary DT properties for QCA807x PHY-s to IPQ4019 DTSI.
|
|
-
|
|
-Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|
----
|
|
- arch/arm/boot/dts/qcom-ipq4019.dtsi | 18 ++++++++++++++++++
|
|
- 1 file changed, 18 insertions(+)
|
|
-
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019.dtsi
|
|
-@@ -8,6 +8,7 @@
|
|
- #include <dt-bindings/clock/qcom,gcc-ipq4019.h>
|
|
- #include <dt-bindings/interrupt-controller/arm-gic.h>
|
|
- #include <dt-bindings/interrupt-controller/irq.h>
|
|
-+#include <dt-bindings/net/qcom-qca807x.h>
|
|
-
|
|
- / {
|
|
- #address-cells = <1>;
|
|
-@@ -726,22 +727,38 @@
|
|
-
|
|
- ethphy0: ethernet-phy@0 {
|
|
- reg = <0>;
|
|
-+
|
|
-+ qcom,control-dac = <QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS>;
|
|
- };
|
|
-
|
|
- ethphy1: ethernet-phy@1 {
|
|
- reg = <1>;
|
|
-+
|
|
-+ qcom,control-dac = <QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS>;
|
|
- };
|
|
-
|
|
- ethphy2: ethernet-phy@2 {
|
|
- reg = <2>;
|
|
-+
|
|
-+ qcom,control-dac = <QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS>;
|
|
- };
|
|
-
|
|
- ethphy3: ethernet-phy@3 {
|
|
- reg = <3>;
|
|
-+
|
|
-+ qcom,control-dac = <QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS>;
|
|
- };
|
|
-
|
|
- ethphy4: ethernet-phy@4 {
|
|
- reg = <4>;
|
|
-+
|
|
-+ qcom,control-dac = <QCA807X_CONTROL_DAC_DSP_VOLT_QUARTER_BIAS>;
|
|
-+ };
|
|
-+
|
|
-+ psgmiiphy: psgmii-phy@5 {
|
|
-+ reg = <5>;
|
|
-+
|
|
-+ qcom,tx-driver-strength = <PSGMII_QSGMII_TX_DRIVER_300MV>;
|
|
- };
|
|
- };
|
|
-
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/850-soc-add-qualcomm-syscon.patch b/target/linux/ipq40xx/patches-5.15/850-soc-add-qualcomm-syscon.patch
|
|
deleted file mode 100644
|
|
index 9b44a4c885..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/850-soc-add-qualcomm-syscon.patch
|
|
+++ /dev/null
|
|
@@ -1,180 +0,0 @@
|
|
-From: Christian Lamparter <chunkeey@googlemail.com>
|
|
-Subject: SoC: add qualcomm syscon
|
|
---- a/drivers/soc/qcom/Makefile
|
|
-+++ b/drivers/soc/qcom/Makefile
|
|
-@@ -21,6 +21,7 @@ obj-$(CONFIG_QCOM_SMP2P) += smp2p.o
|
|
- obj-$(CONFIG_QCOM_SMSM) += smsm.o
|
|
- obj-$(CONFIG_QCOM_SOCINFO) += socinfo.o
|
|
- obj-$(CONFIG_QCOM_WCNSS_CTRL) += wcnss_ctrl.o
|
|
-+obj-$(CONFIG_QCOM_TCSR) += qcom_tcsr.o
|
|
- obj-$(CONFIG_QCOM_APR) += apr.o
|
|
- obj-$(CONFIG_QCOM_LLCC) += llcc-qcom.o
|
|
- obj-$(CONFIG_QCOM_RPMHPD) += rpmhpd.o
|
|
---- a/drivers/soc/qcom/Kconfig
|
|
-+++ b/drivers/soc/qcom/Kconfig
|
|
-@@ -192,6 +192,13 @@ config QCOM_SOCINFO
|
|
- Say yes here to support the Qualcomm socinfo driver, providing
|
|
- information about the SoC to user space.
|
|
-
|
|
-+config QCOM_TCSR
|
|
-+ tristate "QCOM Top Control and Status Registers"
|
|
-+ depends on ARCH_QCOM
|
|
-+ help
|
|
-+ Say y here to enable TCSR support. The TCSR provides control
|
|
-+ functions for various peripherals.
|
|
-+
|
|
- config QCOM_WCNSS_CTRL
|
|
- tristate "Qualcomm WCNSS control driver"
|
|
- depends on ARCH_QCOM || COMPILE_TEST
|
|
---- /dev/null
|
|
-+++ b/drivers/soc/qcom/qcom_tcsr.c
|
|
-@@ -0,0 +1,98 @@
|
|
-+/*
|
|
-+ * Copyright (c) 2014, The Linux foundation. All rights reserved.
|
|
-+ *
|
|
-+ * This program is free software; you can redistribute it and/or modify
|
|
-+ * it under the terms of the GNU General Public License rev 2 and
|
|
-+ * only rev 2 as published by the free Software foundation.
|
|
-+ *
|
|
-+ * This program is distributed in the hope that it will be useful,
|
|
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
-+ * MERCHANTABILITY or fITNESS fOR A PARTICULAR PURPOSE. See the
|
|
-+ * GNU General Public License for more details.
|
|
-+ */
|
|
-+
|
|
-+#include <linux/clk.h>
|
|
-+#include <linux/err.h>
|
|
-+#include <linux/io.h>
|
|
-+#include <linux/module.h>
|
|
-+#include <linux/of.h>
|
|
-+#include <linux/of_platform.h>
|
|
-+#include <linux/platform_device.h>
|
|
-+
|
|
-+#define TCSR_USB_PORT_SEL 0xb0
|
|
-+#define TCSR_USB_HSPHY_CONFIG 0xC
|
|
-+
|
|
-+#define TCSR_ESS_INTERFACE_SEL_OFFSET 0x0
|
|
-+#define TCSR_ESS_INTERFACE_SEL_MASK 0xf
|
|
-+
|
|
-+#define TCSR_WIFI0_GLB_CFG_OFFSET 0x0
|
|
-+#define TCSR_WIFI1_GLB_CFG_OFFSET 0x4
|
|
-+#define TCSR_PNOC_SNOC_MEMTYPE_M0_M2 0x4
|
|
-+
|
|
-+static int tcsr_probe(struct platform_device *pdev)
|
|
-+{
|
|
-+ struct resource *res;
|
|
-+ const struct device_node *node = pdev->dev.of_node;
|
|
-+ void __iomem *base;
|
|
-+ u32 val;
|
|
-+
|
|
-+ res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
|
-+ base = devm_ioremap_resource(&pdev->dev, res);
|
|
-+ if (IS_ERR(base))
|
|
-+ return PTR_ERR(base);
|
|
-+
|
|
-+ if (!of_property_read_u32(node, "qcom,usb-ctrl-select", &val)) {
|
|
-+ dev_err(&pdev->dev, "setting usb port select = %d\n", val);
|
|
-+ writel(val, base + TCSR_USB_PORT_SEL);
|
|
-+ }
|
|
-+
|
|
-+ if (!of_property_read_u32(node, "qcom,usb-hsphy-mode-select", &val)) {
|
|
-+ dev_info(&pdev->dev, "setting usb hs phy mode select = %x\n", val);
|
|
-+ writel(val, base + TCSR_USB_HSPHY_CONFIG);
|
|
-+ }
|
|
-+
|
|
-+ if (!of_property_read_u32(node, "qcom,ess-interface-select", &val)) {
|
|
-+ u32 tmp = 0;
|
|
-+ dev_info(&pdev->dev, "setting ess interface select = %x\n", val);
|
|
-+ tmp = readl(base + TCSR_ESS_INTERFACE_SEL_OFFSET);
|
|
-+ tmp = tmp & (~TCSR_ESS_INTERFACE_SEL_MASK);
|
|
-+ tmp = tmp | (val&TCSR_ESS_INTERFACE_SEL_MASK);
|
|
-+ writel(tmp, base + TCSR_ESS_INTERFACE_SEL_OFFSET);
|
|
-+ }
|
|
-+
|
|
-+ if (!of_property_read_u32(node, "qcom,wifi_glb_cfg", &val)) {
|
|
-+ dev_info(&pdev->dev, "setting wifi_glb_cfg = %x\n", val);
|
|
-+ writel(val, base + TCSR_WIFI0_GLB_CFG_OFFSET);
|
|
-+ writel(val, base + TCSR_WIFI1_GLB_CFG_OFFSET);
|
|
-+ }
|
|
-+
|
|
-+ if (!of_property_read_u32(node, "qcom,wifi_noc_memtype_m0_m2", &val)) {
|
|
-+ dev_info(&pdev->dev,
|
|
-+ "setting wifi_noc_memtype_m0_m2 = %x\n", val);
|
|
-+ writel(val, base + TCSR_PNOC_SNOC_MEMTYPE_M0_M2);
|
|
-+ }
|
|
-+
|
|
-+ return 0;
|
|
-+}
|
|
-+
|
|
-+static const struct of_device_id tcsr_dt_match[] = {
|
|
-+ { .compatible = "qcom,tcsr", },
|
|
-+ { },
|
|
-+};
|
|
-+
|
|
-+MODULE_DEVICE_TABLE(of, tcsr_dt_match);
|
|
-+
|
|
-+static struct platform_driver tcsr_driver = {
|
|
-+ .driver = {
|
|
-+ .name = "tcsr",
|
|
-+ .owner = THIS_MODULE,
|
|
-+ .of_match_table = tcsr_dt_match,
|
|
-+ },
|
|
-+ .probe = tcsr_probe,
|
|
-+};
|
|
-+
|
|
-+module_platform_driver(tcsr_driver);
|
|
-+
|
|
-+MODULE_AUTHOR("Andy Gross <agross@codeaurora.org>");
|
|
-+MODULE_DESCRIPTION("QCOM TCSR driver");
|
|
-+MODULE_LICENSE("GPL v2");
|
|
---- /dev/null
|
|
-+++ b/include/dt-bindings/soc/qcom,tcsr.h
|
|
-@@ -0,0 +1,48 @@
|
|
-+/* Copyright (c) 2014, The Linux Foundation. All rights reserved.
|
|
-+ *
|
|
-+ * This program is free software; you can redistribute it and/or modify
|
|
-+ * it under the terms of the GNU General Public License version 2 and
|
|
-+ * only version 2 as published by the Free Software Foundation.
|
|
-+ *
|
|
-+ * This program is distributed in the hope that it will be useful,
|
|
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
-+ * GNU General Public License for more details.
|
|
-+ */
|
|
-+#ifndef __DT_BINDINGS_QCOM_TCSR_H
|
|
-+#define __DT_BINDINGS_QCOM_TCSR_H
|
|
-+
|
|
-+#define TCSR_USB_SELECT_USB3_P0 0x1
|
|
-+#define TCSR_USB_SELECT_USB3_P1 0x2
|
|
-+#define TCSR_USB_SELECT_USB3_DUAL 0x3
|
|
-+
|
|
-+/* IPQ40xx HS PHY Mode Select */
|
|
-+#define TCSR_USB_HSPHY_HOST_MODE 0x00E700E7
|
|
-+#define TCSR_USB_HSPHY_DEVICE_MODE 0x00C700E7
|
|
-+
|
|
-+/* IPQ40xx ess interface mode select */
|
|
-+#define TCSR_ESS_PSGMII 0
|
|
-+#define TCSR_ESS_PSGMII_RGMII5 1
|
|
-+#define TCSR_ESS_PSGMII_RMII0 2
|
|
-+#define TCSR_ESS_PSGMII_RMII1 4
|
|
-+#define TCSR_ESS_PSGMII_RMII0_RMII1 6
|
|
-+#define TCSR_ESS_PSGMII_RGMII4 9
|
|
-+
|
|
-+/*
|
|
-+ * IPQ40xx WiFi Global Config
|
|
-+ * Bit 30:AXID_EN
|
|
-+ * Enable AXI master bus Axid translating to confirm all txn submitted by order
|
|
-+ * Bit 24: Use locally generated socslv_wxi_bvalid
|
|
-+ * 1: use locally generate socslv_wxi_bvalid for performance.
|
|
-+ * 0: use SNOC socslv_wxi_bvalid.
|
|
-+ */
|
|
-+#define TCSR_WIFI_GLB_CFG 0x41000000
|
|
-+
|
|
-+/* IPQ40xx MEM_TYPE_SEL_M0_M2 Select Bit 26:24 - 2 NORMAL */
|
|
-+#define TCSR_WIFI_NOC_MEMTYPE_M0_M2 0x02222222
|
|
-+
|
|
-+/* TCSR A/B REG */
|
|
-+#define IPQ806X_TCSR_REG_A_ADM_CRCI_MUX_SEL 0
|
|
-+#define IPQ806X_TCSR_REG_B_ADM_CRCI_MUX_SEL 1
|
|
-+
|
|
-+#endif
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/900-dts-ipq4019-ap-dk01.1.patch b/target/linux/ipq40xx/patches-5.15/900-dts-ipq4019-ap-dk01.1.patch
|
|
deleted file mode 100644
|
|
index 145d3f49ed..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/900-dts-ipq4019-ap-dk01.1.patch
|
|
+++ /dev/null
|
|
@@ -1,164 +0,0 @@
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019-ap.dk01.1.dtsi
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019-ap.dk01.1.dtsi
|
|
-@@ -15,6 +15,7 @@
|
|
- */
|
|
-
|
|
- #include "qcom-ipq4019.dtsi"
|
|
-+#include <dt-bindings/soc/qcom,tcsr.h>
|
|
-
|
|
- / {
|
|
- model = "Qualcomm Technologies, Inc. IPQ4019/AP-DK01.1";
|
|
-@@ -29,6 +30,32 @@
|
|
- };
|
|
-
|
|
- soc {
|
|
-+ tcsr@194b000 {
|
|
-+ /* select hostmode */
|
|
-+ compatible = "qcom,tcsr";
|
|
-+ reg = <0x194b000 0x100>;
|
|
-+ qcom,usb-hsphy-mode-select = <TCSR_USB_HSPHY_HOST_MODE>;
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ ess_tcsr@1953000 {
|
|
-+ compatible = "qcom,tcsr";
|
|
-+ reg = <0x1953000 0x1000>;
|
|
-+ qcom,ess-interface-select = <TCSR_ESS_PSGMII>;
|
|
-+ };
|
|
-+
|
|
-+ tcsr@1949000 {
|
|
-+ compatible = "qcom,tcsr";
|
|
-+ reg = <0x1949000 0x100>;
|
|
-+ qcom,wifi_glb_cfg = <TCSR_WIFI_GLB_CFG>;
|
|
-+ };
|
|
-+
|
|
-+ tcsr@1957000 {
|
|
-+ compatible = "qcom,tcsr";
|
|
-+ reg = <0x1957000 0x100>;
|
|
-+ qcom,wifi_noc_memtype_m0_m2 = <TCSR_WIFI_NOC_MEMTYPE_M0_M2>;
|
|
-+ };
|
|
-+
|
|
- rng@22000 {
|
|
- status = "okay";
|
|
- };
|
|
-@@ -74,14 +101,6 @@
|
|
- pinctrl-names = "default";
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 54 0>;
|
|
--
|
|
-- mx25l25635e@0 {
|
|
-- #address-cells = <1>;
|
|
-- #size-cells = <1>;
|
|
-- reg = <0>;
|
|
-- compatible = "mx25l25635e";
|
|
-- spi-max-frequency = <24000000>;
|
|
-- };
|
|
- };
|
|
-
|
|
- serial@78af000 {
|
|
-@@ -109,5 +128,29 @@
|
|
- wifi@a800000 {
|
|
- status = "okay";
|
|
- };
|
|
-+
|
|
-+ mdio@90000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3_ss_phy: ssphy@9a000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3_hs_phy: hsphy@a6000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3: usb3@8af8800 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb2_hs_phy: hsphy@a8000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb2: usb2@60f8800 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
- };
|
|
- };
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019-ap.dk01.1-c1.dts
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019-ap.dk01.1-c1.dts
|
|
-@@ -18,5 +18,73 @@
|
|
-
|
|
- / {
|
|
- model = "Qualcomm Technologies, Inc. IPQ40xx/AP-DK01.1-C1";
|
|
-+ compatible = "qcom,ap-dk01.1-c1", "qcom,ap-dk01.2-c1";
|
|
-
|
|
-+ memory {
|
|
-+ device_type = "memory";
|
|
-+ reg = <0x80000000 0x10000000>;
|
|
-+ };
|
|
-+};
|
|
-+
|
|
-+&blsp1_spi1 {
|
|
-+ mx25l25635f@0 {
|
|
-+ compatible = "mx25l25635f", "jedec,spi-nor";
|
|
-+ #address-cells = <1>;
|
|
-+ #size-cells = <1>;
|
|
-+ reg = <0>;
|
|
-+ spi-max-frequency = <24000000>;
|
|
-+
|
|
-+ SBL1@0 {
|
|
-+ label = "SBL1";
|
|
-+ reg = <0x0 0x40000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ MIBIB@40000 {
|
|
-+ label = "MIBIB";
|
|
-+ reg = <0x40000 0x20000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ QSEE@60000 {
|
|
-+ label = "QSEE";
|
|
-+ reg = <0x60000 0x60000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ CDT@c0000 {
|
|
-+ label = "CDT";
|
|
-+ reg = <0xc0000 0x10000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ DDRPARAMS@d0000 {
|
|
-+ label = "DDRPARAMS";
|
|
-+ reg = <0xd0000 0x10000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ APPSBLENV@e0000 {
|
|
-+ label = "APPSBLENV";
|
|
-+ reg = <0xe0000 0x10000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ APPSBL@f0000 {
|
|
-+ label = "APPSBL";
|
|
-+ reg = <0xf0000 0x80000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ ART@170000 {
|
|
-+ label = "ART";
|
|
-+ reg = <0x170000 0x10000>;
|
|
-+ read-only;
|
|
-+ };
|
|
-+ kernel@180000 {
|
|
-+ label = "kernel";
|
|
-+ reg = <0x180000 0x400000>;
|
|
-+ };
|
|
-+ rootfs@580000 {
|
|
-+ label = "rootfs";
|
|
-+ reg = <0x580000 0x1600000>;
|
|
-+ };
|
|
-+ firmware@180000 {
|
|
-+ label = "firmware";
|
|
-+ reg = <0x180000 0x1a00000>;
|
|
-+ };
|
|
-+ };
|
|
- };
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/902-dts-ipq4019-ap-dk04.1.patch b/target/linux/ipq40xx/patches-5.15/902-dts-ipq4019-ap-dk04.1.patch
|
|
deleted file mode 100644
|
|
index c7688de7e8..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/902-dts-ipq4019-ap-dk04.1.patch
|
|
+++ /dev/null
|
|
@@ -1,164 +0,0 @@
|
|
---- a/arch/arm/boot/dts/qcom-ipq4019-ap.dk04.1.dtsi
|
|
-+++ b/arch/arm/boot/dts/qcom-ipq4019-ap.dk04.1.dtsi
|
|
-@@ -17,53 +17,79 @@
|
|
- stdout-path = "serial0:115200n8";
|
|
- };
|
|
-
|
|
-- memory {
|
|
-- device_type = "memory";
|
|
-- reg = <0x80000000 0x10000000>; /* 256MB */
|
|
-- };
|
|
--
|
|
- soc {
|
|
-+ rng@22000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
- pinctrl@1000000 {
|
|
- serial_0_pins: serial0-pinmux {
|
|
-- pins = "gpio16", "gpio17";
|
|
-- function = "blsp_uart0";
|
|
-- bias-disable;
|
|
-+ mux {
|
|
-+ pins = "gpio16", "gpio17";
|
|
-+ function = "blsp_uart0";
|
|
-+ bias-disable;
|
|
-+ };
|
|
- };
|
|
-
|
|
- serial_1_pins: serial1-pinmux {
|
|
-- pins = "gpio8", "gpio9",
|
|
-- "gpio10", "gpio11";
|
|
-- function = "blsp_uart1";
|
|
-- bias-disable;
|
|
-+ mux {
|
|
-+ pins = "gpio8", "gpio9";
|
|
-+ function = "blsp_uart1";
|
|
-+ bias-disable;
|
|
-+ };
|
|
- };
|
|
-
|
|
- spi_0_pins: spi-0-pinmux {
|
|
- pinmux {
|
|
- function = "blsp_spi0";
|
|
- pins = "gpio13", "gpio14", "gpio15";
|
|
-- bias-disable;
|
|
- };
|
|
- pinmux_cs {
|
|
- function = "gpio";
|
|
- pins = "gpio12";
|
|
-+ };
|
|
-+ pinconf {
|
|
-+ pins = "gpio13", "gpio14", "gpio15";
|
|
-+ drive-strength = <12>;
|
|
-+ bias-disable;
|
|
-+ };
|
|
-+ pinconf_cs {
|
|
-+ pins = "gpio12";
|
|
-+ drive-strength = <2>;
|
|
- bias-disable;
|
|
- output-high;
|
|
- };
|
|
- };
|
|
-
|
|
- i2c_0_pins: i2c-0-pinmux {
|
|
-- pins = "gpio20", "gpio21";
|
|
-- function = "blsp_i2c0";
|
|
-- bias-disable;
|
|
-+ pinmux {
|
|
-+ function = "blsp_i2c0";
|
|
-+ pins = "gpio10", "gpio11";
|
|
-+ };
|
|
-+ pinconf {
|
|
-+ pins = "gpio10", "gpio11";
|
|
-+ drive-strength = <16>;
|
|
-+ bias-disable;
|
|
-+ };
|
|
- };
|
|
-
|
|
- nand_pins: nand-pins {
|
|
-- pins = "gpio53", "gpio55", "gpio56",
|
|
-- "gpio57", "gpio58", "gpio59",
|
|
-- "gpio60", "gpio62", "gpio63",
|
|
-- "gpio64", "gpio65", "gpio66",
|
|
-- "gpio67", "gpio68", "gpio69";
|
|
-- function = "qpic";
|
|
-+ pullups {
|
|
-+ pins = "gpio52", "gpio53", "gpio58",
|
|
-+ "gpio59";
|
|
-+ function = "qpic";
|
|
-+ bias-pull-up;
|
|
-+ };
|
|
-+
|
|
-+ pulldowns {
|
|
-+ pins = "gpio54", "gpio55", "gpio56",
|
|
-+ "gpio57", "gpio60", "gpio61",
|
|
-+ "gpio62", "gpio63", "gpio64",
|
|
-+ "gpio65", "gpio66", "gpio67",
|
|
-+ "gpio68", "gpio69";
|
|
-+ function = "qpic";
|
|
-+ bias-pull-down;
|
|
-+ };
|
|
- };
|
|
- };
|
|
-
|
|
-@@ -89,11 +115,11 @@
|
|
- status = "okay";
|
|
- cs-gpios = <&tlmm 12 0>;
|
|
-
|
|
-- m25p80@0 {
|
|
-+ mx25l25635e@0 {
|
|
- #address-cells = <1>;
|
|
- #size-cells = <1>;
|
|
- reg = <0>;
|
|
-- compatible = "n25q128a11";
|
|
-+ compatible = "mx25l25635e";
|
|
- spi-max-frequency = <24000000>;
|
|
- };
|
|
- };
|
|
-@@ -102,6 +128,45 @@
|
|
- status = "okay";
|
|
- perst-gpio = <&tlmm 38 0x1>;
|
|
- };
|
|
-+
|
|
-+ i2c0: i2c@78b7000 { /* BLSP1 QUP2 */
|
|
-+ pinctrl-0 = <&i2c_0_pins>;
|
|
-+ pinctrl-names = "default";
|
|
-+
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3_ss_phy: ssphy@9a000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3_hs_phy: hsphy@a6000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb3: usb3@8af8800 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb2_hs_phy: hsphy@a8000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ usb2: usb2@60f8800 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ cryptobam: dma@8e04000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ crypto@8e3a000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
-+
|
|
-+ watchdog@b017000 {
|
|
-+ status = "okay";
|
|
-+ };
|
|
- };
|
|
- };
|
|
-
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/910-Revert-firmware-qcom_scm-Clear-download-bit-during-r.patch b/target/linux/ipq40xx/patches-5.15/910-Revert-firmware-qcom_scm-Clear-download-bit-during-r.patch
|
|
deleted file mode 100644
|
|
index e24895deec..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/910-Revert-firmware-qcom_scm-Clear-download-bit-during-r.patch
|
|
+++ /dev/null
|
|
@@ -1,27 +0,0 @@
|
|
-From c87df89a82c17411cd6b98e5afaa1203ee9508dc Mon Sep 17 00:00:00 2001
|
|
-From: Robert Marko <robimarko@gmail.com>
|
|
-Date: Thu, 18 May 2023 12:16:02 +0200
|
|
-Subject: [PATCH] Revert "firmware: qcom_scm: Clear download bit during reboot"
|
|
-
|
|
-This reverts commit a3ea89b5978dbcd0fa55f675c5a1e04611093709.
|
|
-
|
|
-It is breaking reboot on IPQ4019 boards, so revert until a proper fix
|
|
-is found.
|
|
-
|
|
-Signed-off-by: Robert Marko <robimarko@gmail.com>
|
|
----
|
|
- drivers/firmware/qcom_scm.c | 3 ++-
|
|
- 1 file changed, 2 insertions(+), 1 deletion(-)
|
|
-
|
|
---- a/drivers/firmware/qcom_scm.c
|
|
-+++ b/drivers/firmware/qcom_scm.c
|
|
-@@ -1352,7 +1352,8 @@ static int qcom_scm_probe(struct platfor
|
|
- static void qcom_scm_shutdown(struct platform_device *pdev)
|
|
- {
|
|
- /* Clean shutdown, disable download mode to allow normal restart */
|
|
-- qcom_scm_set_download_mode(false);
|
|
-+ if (download_mode)
|
|
-+ qcom_scm_set_download_mode(false);
|
|
- }
|
|
-
|
|
- static const struct of_device_id qcom_scm_dt_match[] = {
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/998-lantiq-atm-hacks.patch b/target/linux/ipq40xx/patches-5.15/998-lantiq-atm-hacks.patch
|
|
deleted file mode 100644
|
|
index c15a4b3ae3..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/998-lantiq-atm-hacks.patch
|
|
+++ /dev/null
|
|
@@ -1,43 +0,0 @@
|
|
-From: John Crispin <blogic@openwrt.org>
|
|
-Date: Fri, 3 Aug 2012 10:27:25 +0200
|
|
-Subject: [PATCH 04/36] MIPS: lantiq: add atm hack
|
|
-
|
|
-Signed-off-by: John Crispin <blogic@openwrt.org>
|
|
---- a/include/uapi/linux/atm.h
|
|
-+++ b/include/uapi/linux/atm.h
|
|
-@@ -131,8 +131,14 @@
|
|
- #define ATM_ABR 4
|
|
- #define ATM_ANYCLASS 5 /* compatible with everything */
|
|
-
|
|
-+#define ATM_VBR_NRT ATM_VBR
|
|
-+#define ATM_VBR_RT 6
|
|
-+#define ATM_UBR_PLUS 7
|
|
-+#define ATM_GFR 8
|
|
-+
|
|
- #define ATM_MAX_PCR -1 /* maximum available PCR */
|
|
-
|
|
-+
|
|
- struct atm_trafprm {
|
|
- unsigned char traffic_class; /* traffic class (ATM_UBR, ...) */
|
|
- int max_pcr; /* maximum PCR in cells per second */
|
|
-@@ -155,6 +161,9 @@ struct atm_trafprm {
|
|
- unsigned int adtf :10; /* ACR Decrease Time Factor (10-bit) */
|
|
- unsigned int cdf :3; /* Cutoff Decrease Factor (3-bit) */
|
|
- unsigned int spare :9; /* spare bits */
|
|
-+ int scr; /* sustained rate in cells per second */
|
|
-+ int mbs; /* maximum burst size (MBS) in cells */
|
|
-+ int cdv; /* Cell delay variation */
|
|
- };
|
|
-
|
|
- struct atm_qos {
|
|
---- a/net/atm/proc.c
|
|
-+++ b/net/atm/proc.c
|
|
-@@ -141,7 +141,7 @@ static void *vcc_seq_next(struct seq_fil
|
|
- static void pvc_info(struct seq_file *seq, struct atm_vcc *vcc)
|
|
- {
|
|
- static const char *const class_name[] = {
|
|
-- "off", "UBR", "CBR", "VBR", "ABR"};
|
|
-+ "off","UBR","CBR","NTR-VBR","ABR","ANY","RT-VBR","UBR+","GFR"};
|
|
- static const char *const aal_name[] = {
|
|
- "---", "1", "2", "3/4", /* 0- 3 */
|
|
- "???", "5", "???", "???", /* 4- 7 */
|
|
diff --git a/target/linux/ipq40xx/patches-5.15/999-atm-mpoa-intel-dsl-phy-support.patch b/target/linux/ipq40xx/patches-5.15/999-atm-mpoa-intel-dsl-phy-support.patch
|
|
deleted file mode 100644
|
|
index b774fc39d8..0000000000
|
|
--- a/target/linux/ipq40xx/patches-5.15/999-atm-mpoa-intel-dsl-phy-support.patch
|
|
+++ /dev/null
|
|
@@ -1,137 +0,0 @@
|
|
-From: Subhra Banerjee <subhrax.banerjee@intel.com>
|
|
-Date: Fri, 31 Aug 2018 12:01:19 +0530
|
|
-Subject: [PATCH] UGW_SW-29163: ATM oam support
|
|
-
|
|
---- a/drivers/net/ppp/ppp_generic.c
|
|
-+++ b/drivers/net/ppp/ppp_generic.c
|
|
-@@ -2952,6 +2952,22 @@ char *ppp_dev_name(struct ppp_channel *c
|
|
- return name;
|
|
- }
|
|
-
|
|
-+/*
|
|
-+ * Return the PPP device interface pointer
|
|
-+ */
|
|
-+struct net_device *ppp_device(struct ppp_channel *chan)
|
|
-+{
|
|
-+ struct channel *pch = chan->ppp;
|
|
-+ struct net_device *dev = NULL;
|
|
-+
|
|
-+ if (pch) {
|
|
-+ read_lock_bh(&pch->upl);
|
|
-+ if (pch->ppp && pch->ppp->dev)
|
|
-+ dev = pch->ppp->dev;
|
|
-+ read_unlock_bh(&pch->upl);
|
|
-+ }
|
|
-+ return dev;
|
|
-+}
|
|
-
|
|
- /*
|
|
- * Disconnect a channel from the generic layer.
|
|
-@@ -3598,6 +3614,7 @@ EXPORT_SYMBOL(ppp_unregister_channel);
|
|
- EXPORT_SYMBOL(ppp_channel_index);
|
|
- EXPORT_SYMBOL(ppp_unit_number);
|
|
- EXPORT_SYMBOL(ppp_dev_name);
|
|
-+EXPORT_SYMBOL(ppp_device);
|
|
- EXPORT_SYMBOL(ppp_input);
|
|
- EXPORT_SYMBOL(ppp_input_error);
|
|
- EXPORT_SYMBOL(ppp_output_wakeup);
|
|
---- a/include/linux/ppp_channel.h
|
|
-+++ b/include/linux/ppp_channel.h
|
|
-@@ -74,6 +74,9 @@ extern int ppp_unit_number(struct ppp_ch
|
|
- /* Get the device name associated with a channel, or NULL if none */
|
|
- extern char *ppp_dev_name(struct ppp_channel *);
|
|
-
|
|
-+/* Get the device pointer associated with a channel, or NULL if none */
|
|
-+extern struct net_device *ppp_device(struct ppp_channel *);
|
|
-+
|
|
- /*
|
|
- * SMP locking notes:
|
|
- * The channel code must ensure that when it calls ppp_unregister_channel,
|
|
---- a/net/atm/Kconfig
|
|
-+++ b/net/atm/Kconfig
|
|
-@@ -56,6 +56,12 @@ config ATM_MPOA
|
|
- subnetwork boundaries. These shortcut connections bypass routers
|
|
- enhancing overall network performance.
|
|
-
|
|
-+config ATM_MPOA_INTEL_DSL_PHY_SUPPORT
|
|
-+ bool "Intel DSL Phy MPOA support"
|
|
-+ depends on ATM && INET && ATM_MPOA!=n
|
|
-+ help
|
|
-+ Add support for Intel DSL Phy ATM MPOA
|
|
-+
|
|
- config ATM_BR2684
|
|
- tristate "RFC1483/2684 Bridged protocols"
|
|
- depends on ATM && INET
|
|
---- a/net/atm/br2684.c
|
|
-+++ b/net/atm/br2684.c
|
|
-@@ -596,6 +596,11 @@ static int br2684_regvcc(struct atm_vcc
|
|
- atmvcc->push = br2684_push;
|
|
- atmvcc->pop = br2684_pop;
|
|
- atmvcc->release_cb = br2684_release_cb;
|
|
-+#if IS_ENABLED(CONFIG_ATM_MPOA_INTEL_DSL_PHY_SUPPORT)
|
|
-+ if (atm_hook_mpoa_setup) /* IPoA or EoA w/o FCS */
|
|
-+ atm_hook_mpoa_setup(atmvcc, brdev->payload == p_routed ? 3 : 0,
|
|
-+ brvcc->encaps == BR2684_ENCAPS_LLC ? 1 : 0, net_dev);
|
|
-+#endif
|
|
- atmvcc->owner = THIS_MODULE;
|
|
-
|
|
- /* initialize netdev carrier state */
|
|
---- a/net/atm/common.c
|
|
-+++ b/net/atm/common.c
|
|
-@@ -137,6 +137,11 @@ static struct proto vcc_proto = {
|
|
- .release_cb = vcc_release_cb,
|
|
- };
|
|
-
|
|
-+#if IS_ENABLED(CONFIG_ATM_MPOA_INTEL_DSL_PHY_SUPPORT)
|
|
-+void (*atm_hook_mpoa_setup)(struct atm_vcc *, int, int, struct net_device *) = NULL;
|
|
-+EXPORT_SYMBOL(atm_hook_mpoa_setup);
|
|
-+#endif
|
|
-+
|
|
- int vcc_create(struct net *net, struct socket *sock, int protocol, int family, int kern)
|
|
- {
|
|
- struct sock *sk;
|
|
---- a/net/atm/common.h
|
|
-+++ b/net/atm/common.h
|
|
-@@ -53,4 +53,6 @@ int svc_change_qos(struct atm_vcc *vcc,s
|
|
-
|
|
- void atm_dev_release_vccs(struct atm_dev *dev);
|
|
-
|
|
-+extern void (*atm_hook_mpoa_setup)(struct atm_vcc *, int, int, struct net_device *);
|
|
-+
|
|
- #endif
|
|
---- a/net/atm/mpc.c
|
|
-+++ b/net/atm/mpc.c
|
|
-@@ -31,6 +31,7 @@
|
|
- /* Modular too */
|
|
- #include <linux/module.h>
|
|
-
|
|
-+#include "common.h"
|
|
- #include "lec.h"
|
|
- #include "mpc.h"
|
|
- #include "resources.h"
|
|
-@@ -645,6 +646,10 @@ static int atm_mpoa_vcc_attach(struct at
|
|
- vcc->proto_data = mpc->dev;
|
|
- vcc->push = mpc_push;
|
|
-
|
|
-+#if IS_ENABLED(CONFIG_ATM_MPOA_INTEL_DSL_PHY_SUPPORT)
|
|
-+ if (atm_hook_mpoa_setup) /* IPoA, LLC */
|
|
-+ atm_hook_mpoa_setup(vcc, 3, 1, mpc->dev);
|
|
-+#endif
|
|
- return 0;
|
|
- }
|
|
-
|
|
---- a/net/atm/pppoatm.c
|
|
-+++ b/net/atm/pppoatm.c
|
|
-@@ -422,6 +422,12 @@ static int pppoatm_assign_vcc(struct atm
|
|
- atmvcc->user_back = pvcc;
|
|
- atmvcc->push = pppoatm_push;
|
|
- atmvcc->pop = pppoatm_pop;
|
|
-+#if IS_ENABLED(CONFIG_ATM_MPOA_INTEL_DSL_PHY_SUPPORT)
|
|
-+ if (atm_hook_mpoa_setup) /* PPPoA */
|
|
-+ atm_hook_mpoa_setup(atmvcc, 2,
|
|
-+ pvcc->encaps == e_llc ? 1 : 0,
|
|
-+ ppp_device(&pvcc->chan));
|
|
-+#endif
|
|
- atmvcc->release_cb = pppoatm_release_cb;
|
|
- __module_get(THIS_MODULE);
|
|
- atmvcc->owner = THIS_MODULE;
|
|
--
|
|
2.34.1
|
|
|