Openwrt/target/linux/ramips/dts/mt7621_netgear_ex6150.dts
Stijn Segers af1b6799c6 ramips: overwrite reset gpio properties in EX6150 DTS
The Netgear EX6150 can, just like the D-Link DIR-860L rev B1, fail to
initialise both radios in some cases. Add the reset GPIOs explicitly
so the PCI-E devices get re-initialised properly. See also FS #3632.

Error shows up in dmesg as follows:

  [    1.560764] mt7621-pci 1e140000.pcie: pcie1 no card, disable it (RST & CLK)

Tested-by: Kurt Roeckx <kurt@roeckx.be>
Signed-off-by: Stijn Segers <foss@volatilesystems.org>
[removed period from commit title]
Signed-off-by: David Bauer <mail@david-bauer.net>
2021-02-20 01:27:00 +01:00

249 lines
4.0 KiB
Plaintext

// 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>
/ {
compatible = "netgear,ex6150", "mediatek,mt7621-soc";
model = "Netgear EX6150";
aliases {
led-boot = &power_green;
led-failsafe = &power_amber;
led-running = &power_green;
led-upgrade = &power_amber;
};
leds {
compatible = "gpio-leds";
power_amber: power_amber {
label = "amber:power";
gpios = <&gpio 15 GPIO_ACTIVE_LOW>;
};
power_green: power_green {
label = "green:power";
gpios = <&gpio 13 GPIO_ACTIVE_LOW>;
};
wps {
label = "green:wps";
gpios = <&gpio 16 GPIO_ACTIVE_LOW>;
};
rightarrow {
label = "blue:rightarrow";
gpios = <&gpio 28 GPIO_ACTIVE_LOW>;
};
leftarrow {
label = "blue:leftarrow";
gpios = <&gpio 31 GPIO_ACTIVE_LOW>;
};
router_green {
label = "green:router";
gpios = <&gpio 29 GPIO_ACTIVE_LOW>;
linux,default-trigger = "phy1tpt";
};
router_red {
label = "red:router";
gpios = <&gpio 30 GPIO_ACTIVE_LOW>;
};
client_green {
label = "green:client";
gpios = <&gpio 33 GPIO_ACTIVE_LOW>;
linux,default-trigger = "phy0tpt";
};
client_red {
label = "red:client";
gpios = <&gpio 32 GPIO_ACTIVE_LOW>;
};
};
keys {
compatible = "gpio-keys";
wps {
label = "wps";
gpios = <&gpio 47 GPIO_ACTIVE_LOW>;
linux,code = <KEY_WPS_BUTTON>;
};
reset {
label = "reset";
gpios = <&gpio 46 GPIO_ACTIVE_LOW>;
linux,code = <KEY_RESTART>;
};
toggle {
label = "AP/Extender toggle";
gpios = <&gpio 48 GPIO_ACTIVE_LOW>;
linux,code = <BTN_0>;
linux,input-type = <EV_SW>;
/* Active when switch is set to "Access Point" */
};
};
};
&spi0 {
status = "okay";
flash@0 {
compatible = "jedec,spi-nor";
reg = <0>;
spi-max-frequency = <10000000>;
partitions {
compatible = "fixed-partitions";
#address-cells = <1>;
#size-cells = <1>;
partition@0 {
label = "u-boot";
reg = <0x0 0x30000>;
read-only;
};
partition@30000 {
label = "config";
reg = <0x30000 0x10000>;
read-only;
};
factory: partition@40000 {
label = "factory";
reg = <0x40000 0x10000>;
read-only;
};
partition@50000 {
compatible = "denx,uimage";
label = "firmware";
reg = <0x50000 0xe80000>;
};
partition@ed0000 {
label = "ML1";
reg = <0xed0000 0x10000>;
read-only;
};
partition@ef0000 {
label = "ML2";
reg = <0xef0000 0x20000>;
read-only;
};
partition@f10000 {
label = "ML3";
reg = <0xf10000 0x20000>;
read-only;
};
partition@f30000 {
label = "ML4";
reg = <0xf30000 0x20000>;
read-only;
};
partition@f50000 {
label = "ML5";
reg = <0xf50000 0x20000>;
read-only;
};
partition@f70000 {
label = "ML6";
reg = <0xf70000 0x20000>;
read-only;
};
partition@f90000 {
label = "ML7";
reg = <0xf90000 0x20000>;
read-only;
};
partition@fb0000 {
label = "T_Meter1";
reg = <0xfb0000 0x10000>;
read-only;
};
partition@fc0000 {
label = "T_Meter2";
reg = <0xfc0000 0x10000>;
read-only;
};
partition@fd0000 {
label = "POT";
reg = <0xfd0000 0x10000>;
read-only;
};
partition@fe0000 {
label = "board_data";
reg = <0xfe0000 0x10000>;
read-only;
};
partition@ff0000 {
label = "nvram";
reg = <0xff0000 0x10000>;
read-only;
};
};
};
};
&pcie {
status = "okay";
reset-gpios = <&gpio 19 GPIO_ACTIVE_LOW>,
<&gpio 8 GPIO_ACTIVE_LOW>;
};
&pcie0 {
wifi@0,0 {
reg = <0x0000 0 0 0 0>;
mediatek,mtd-eeprom = <&factory 0x8000>;
ieee80211-freq-limit = <5000000 6000000>;
};
};
&pcie1 {
wifi@0,0 {
reg = <0x0000 0 0 0 0>;
mediatek,mtd-eeprom = <&factory 0x0000>;
ieee80211-freq-limit = <2400000 2500000>;
};
};
&gmac0 {
mtd-mac-address = <&factory 0x4>;
};
&switch0 {
ports {
port@0 {
status = "okay";
label = "lan";
};
};
};
&state_default {
gpio {
groups = "sdhci", "rgmii2", "jtag";
function = "gpio";
};
};