// SPDX-License-Identifier: GPL-2.0-or-later OR MIT #include "qca953x.dtsi" #include <dt-bindings/gpio/gpio.h> #include <dt-bindings/input/input.h> #include <dt-bindings/leds/common.h> / { chosen { /delete-property/ bootargs; }; aliases { led-boot = &led_power_blue; led-failsafe = &led_power_blue; led-running = &led_power_blue; led-upgrade = &led_power_blue; label-mac-device = ð0; }; keys { compatible = "gpio-keys"; pinctrl-names = "default"; pinctrl-0 = <&jtag_disable_pins>; reset { label = "reset"; linux,code = <KEY_RESTART>; gpios = <&gpio 1 GPIO_ACTIVE_LOW>; }; }; leds { compatible = "gpio-leds"; led_power_blue: power_blue { function = LED_FUNCTION_POWER; color = <LED_COLOR_ID_BLUE>; gpios = <&gpio 0 GPIO_ACTIVE_LOW>; default-state = "on"; }; wifi_green { label = "green:wifi"; gpios = <&gpio 2 GPIO_ACTIVE_LOW>; linux,default-trigger = "phy0tpt"; }; wifi_yellow { label = "yellow:wifi"; gpios = <&gpio 3 GPIO_ACTIVE_LOW>; }; wifi_red { label = "red:wifi"; gpios = <&gpio 4 GPIO_ACTIVE_LOW>; }; wan_blue { function = LED_FUNCTION_WAN; color = <LED_COLOR_ID_BLUE>; gpios = <&gpio 13 GPIO_ACTIVE_LOW>; }; lan_blue { function = LED_FUNCTION_LAN; color = <LED_COLOR_ID_BLUE>; gpios = <&gpio 14 GPIO_ACTIVE_LOW>; }; }; watchdog { compatible = "linux,wdt-gpio"; gpios = <&gpio 12 GPIO_ACTIVE_LOW>; hw_algo = "toggle"; /* hw_margin_ms is actually 300s but driver limits it to 60s */ hw_margin_ms = <60000>; always-running; }; }; &spi { status = "okay"; flash@0 { compatible = "jedec,spi-nor"; reg = <0>; spi-max-frequency = <25000000>; /* partitions are passed via bootloader */ partitions { compatible = "fixed-partitions"; #address-cells = <1>; #size-cells = <1>; partition@0 { label = "u-boot"; reg = <0x000000 0x040000>; read-only; }; partition@40000 { label = "u-boot-env"; reg = <0x040000 0x040000>; }; partition@80000 { label = "custom"; reg = <0x080000 0x140000>; read-only; }; partition@1c0000 { label = "inactive"; reg = <0x1c0000 0x700000>; }; partition@8c0000 { label = "inactive2"; reg = <0x8c0000 0x700000>; }; partition@fc0000 { label = "ART"; reg = <0xfc0000 0x040000>; read-only; nvmem-layout { compatible = "fixed-layout"; #address-cells = <1>; #size-cells = <1>; macaddr_art_0: macaddr@0 { compatible = "mac-base"; reg = <0x0 0x6>; #nvmem-cell-cells = <1>; }; macaddr_art_6: macaddr@6 { reg = <0x6 0x6>; }; cal_art_1000: calibration@1000 { reg = <0x1000 0x440>; }; }; }; }; }; }; ð0 { status = "okay"; phy-handle = <&swphy4>; nvmem-cells = <&macaddr_art_0 0>; nvmem-cell-names = "mac-address"; }; ð1 { /* Workaround: keep the Ethernet interfaces order/mapping correct * (GMAC0 -> eth0, GMAC1 -> eth1, same as in old ar71xx target) */ compatible = "qca,qca9530-eth", "syscon", "simple-mfd"; nvmem-cells = <&macaddr_art_6>; nvmem-cell-names = "mac-address"; }; &wmac { status = "okay"; nvmem-cells = <&macaddr_art_0 2>, <&cal_art_1000>; nvmem-cell-names = "mac-address", "calibration"; };