// SPDX-License-Identifier: GPL-2.0-or-later OR MIT #include "mt7621.dtsi" #include <dt-bindings/gpio/gpio.h> #include <dt-bindings/input/input.h> #include <dt-bindings/leds/common.h> / { compatible = "tplink,tl-wpa8631p-v3", "mediatek,mt7621-soc"; model = "TP-Link TL-WPA8631P v3"; aliases { label-mac-device = &gmac0; led-boot = &led_power; led-failsafe = &led_power; led-running = &led_power; led-upgrade = &led_power; }; keys { compatible = "gpio-keys"; reset { label = "reset"; linux,code = <KEY_RESTART>; gpios = <&gpio 31 GPIO_ACTIVE_LOW>; debounce-interval = <60>; }; led { label = "led"; linux,code = <KEY_LIGHTS_TOGGLE>; gpios = <&gpio 30 GPIO_ACTIVE_LOW>; debounce-interval = <60>; }; pair { label = "pair"; linux,code = <BTN_1>; gpios = <&gpio 32 GPIO_ACTIVE_LOW>; debounce-interval = <60>; }; wifi { label = "wifi"; linux,code = <KEY_RFKILL>; gpios = <&gpio 33 GPIO_ACTIVE_LOW>; debounce-interval = <60>; }; }; leds { compatible = "gpio-leds"; led_power: power { function = LED_FUNCTION_POWER; color = <LED_COLOR_ID_GREEN>; gpios = <&gpio 22 GPIO_ACTIVE_LOW>; }; lan { function = LED_FUNCTION_LAN; color = <LED_COLOR_ID_GREEN>; gpios = <&gpio 29 GPIO_ACTIVE_LOW>; }; wifi2g { label = "green:wifi2g"; gpios = <&gpio 23 GPIO_ACTIVE_LOW>; linux,default-trigger = "phy0tpt"; }; wifi5g { label = "green:wifi5g"; gpios = <&gpio 24 GPIO_ACTIVE_LOW>; linux,default-trigger = "phy1tpt"; }; }; gpio-export { compatible = "gpio-export"; led_control { gpio-export,name = "tp-link:led:control"; gpio-export,output = <0>; gpios = <&gpio 25 GPIO_ACTIVE_LOW>; }; }; }; &spi0 { status = "okay"; flash@0 { compatible = "jedec,spi-nor"; reg = <0>; spi-max-frequency = <25000000>; partitions { compatible = "fixed-partitions"; #address-cells = <1>; #size-cells = <1>; partition@0 { label = "u-boot"; reg = <0x0 0x20000>; read-only; }; partition@20000 { compatible = "tplink,firmware"; label = "firmware"; reg = <0x20000 0x710000>; }; config: partition@730000 { label = "config"; reg = <0x730000 0xc0000>; read-only; nvmem-layout { compatible = "fixed-layout"; #address-cells = <1>; #size-cells = <1>; macaddr_config_2008: macaddr@2008 { compatible = "mac-base"; reg = <0x2008 0x6>; #nvmem-cell-cells = <1>; }; }; }; radio: partition@7f0000 { label = "radio"; reg = <0x7f0000 0x10000>; read-only; nvmem-layout { compatible = "fixed-layout"; #address-cells = <1>; #size-cells = <1>; eeprom_radio_0: eeprom@0 { reg = <0x0 0x400>; }; eeprom_radio_8000: eeprom@8000 { reg = <0x8000 0x4da8>; }; }; }; }; }; }; &state_default { gpio { groups = "rgmii2", "wdt"; function = "gpio"; }; }; &pcie { status = "okay"; }; &pcie0 { wifi@0,0 { compatible = "mediatek,mt76"; reg = <0x0000 0 0 0 0>; nvmem-cells = <&eeprom_radio_0>, <&macaddr_config_2008 0>; nvmem-cell-names = "eeprom", "mac-address"; ieee80211-freq-limit = <2400000 2500000>; }; }; &pcie1 { wifi@0,0 { compatible = "mediatek,mt76"; reg = <0x0000 0 0 0 0>; nvmem-cells = <&eeprom_radio_8000>, <&macaddr_config_2008 1>; nvmem-cell-names = "eeprom", "mac-address"; ieee80211-freq-limit = <5000000 6000000>; }; }; ðernet { pinctrl-0 = <&mdio_pins>, <&rgmii1_pins>; }; &gmac0 { nvmem-cells = <&macaddr_config_2008 0>; nvmem-cell-names = "mac-address"; }; &switch0 { ports { port@0 { status = "okay"; label = "plc0"; }; port@1 { status = "okay"; label = "lan1"; }; port@2 { status = "okay"; label = "lan2"; }; port@3 { status = "okay"; label = "lan3"; }; }; };