ramips: add support for Sercomm CPJ routers
[openwrt/openwrt.git] / target / linux / ramips / dts / mt7620a_netis_wf2770.dts
1 // SPDX-License-Identifier: GPL-2.0-or-later OR MIT
2
3 #include "mt7620a.dtsi"
4
5 #include <dt-bindings/gpio/gpio.h>
6 #include <dt-bindings/input/input.h>
7
8 / {
9 compatible = "netis,wf2770", "ralink,mt7620a-soc";
10 model = "NETIS WF2770";
11
12 leds {
13 compatible = "gpio-leds";
14
15 wlan {
16 label = "blue:wlan";
17 gpios = <&gpio0 14 GPIO_ACTIVE_LOW>;
18 linux,default-trigger = "phy0tpt";
19 };
20 };
21
22 keys {
23 compatible = "gpio-keys";
24
25 reset {
26 label = "reset";
27 gpios = <&gpio0 1 GPIO_ACTIVE_LOW>;
28 linux,code = <KEY_RESTART>;
29 };
30
31 wps {
32 label = "wps";
33 gpios = <&gpio0 2 GPIO_ACTIVE_LOW>;
34 linux,code = <KEY_WPS_BUTTON>;
35 };
36
37 rfkill {
38 label = "rfkill";
39 gpios = <&gpio0 7 GPIO_ACTIVE_LOW>;
40 linux,code = <KEY_RFKILL>;
41 };
42
43 led-toggle {
44 label = "led-toggle";
45 gpios = <&gpio0 11 GPIO_ACTIVE_LOW>;
46 linux,code = <KEY_LIGHTS_TOGGLE>;
47 };
48 };
49 };
50
51 &spi0 {
52 status = "okay";
53
54 flash@0 {
55 compatible = "jedec,spi-nor";
56 reg = <0>;
57 spi-max-frequency = <50000000>;
58
59 partitions {
60 compatible = "fixed-partitions";
61 #address-cells = <1>;
62 #size-cells = <1>;
63
64 partition@0 {
65 label = "u-boot";
66 reg = <0x0 0x30000>;
67 read-only;
68 };
69
70 partition@30000 {
71 label = "config";
72 reg = <0x30000 0x10000>;
73 read-only;
74 };
75
76 factory: partition@40000 {
77 compatible = "nvmem-cells";
78 label = "factory";
79 reg = <0x40000 0x10000>;
80 #address-cells = <1>;
81 #size-cells = <1>;
82 read-only;
83
84 eeprom_factory_0: eeprom@0 {
85 reg = <0x0 0x200>;
86 };
87
88 eeprom_factory_8000: eeprom@8000 {
89 reg = <0x8000 0x200>;
90 };
91
92 macaddr_factory_4: macaddr@4 {
93 reg = <0x4 0x6>;
94 };
95 };
96
97 partition@50000 {
98 compatible = "denx,uimage";
99 label = "firmware";
100 reg = <0x50000 0xfb0000>;
101 };
102 };
103 };
104 };
105
106 &state_default {
107 gpio {
108 groups = "i2c", "uartf";
109 function = "gpio";
110 };
111 };
112
113 &ethernet {
114 pinctrl-names = "default";
115 pinctrl-0 = <&rgmii1_pins &mdio_pins>;
116
117 nvmem-cells = <&macaddr_factory_4>;
118 nvmem-cell-names = "mac-address";
119
120 port@5 {
121 status = "okay";
122 mediatek,fixed-link = <1000 1 1 1>;
123 phy-mode = "rgmii";
124 };
125
126 mdio-bus {
127 status = "okay";
128
129 ethernet-phy@0 {
130 reg = <0>;
131 phy-mode = "rgmii";
132 };
133
134 ethernet-phy@1 {
135 reg = <1>;
136 phy-mode = "rgmii";
137 };
138
139 ethernet-phy@2 {
140 reg = <2>;
141 phy-mode = "rgmii";
142 };
143
144 ethernet-phy@3 {
145 reg = <3>;
146 phy-mode = "rgmii";
147 };
148
149 ethernet-phy@4 {
150 reg = <4>;
151 phy-mode = "rgmii";
152 };
153
154 ethernet-phy@1f {
155 reg = <0x1f>;
156 phy-mode = "rgmii";
157 };
158 };
159 };
160
161 &gsw {
162 mediatek,ephy-base = /bits/ 8 <12>;
163 };
164
165 &pcie {
166 status = "okay";
167 };
168
169 &pcie0 {
170 wifi@0,0 {
171 compatible = "mediatek,mt76";
172 reg = <0x0000 0 0 0 0>;
173 nvmem-cells = <&eeprom_factory_8000>;
174 nvmem-cell-names = "eeprom";
175 ieee80211-freq-limit = <5000000 6000000>;
176 };
177 };
178
179 &wmac {
180 nvmem-cells = <&eeprom_factory_0>;
181 nvmem-cell-names = "eeprom";
182 };