ramips: mt7620a: convert to nvmem-layout
[openwrt/staging/hauke.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 label = "factory";
78 reg = <0x40000 0x10000>;
79 read-only;
80
81 nvmem-layout {
82 compatible = "fixed-layout";
83 #address-cells = <1>;
84 #size-cells = <1>;
85
86 eeprom_factory_0: eeprom@0 {
87 reg = <0x0 0x200>;
88 };
89
90 eeprom_factory_8000: eeprom@8000 {
91 reg = <0x8000 0x200>;
92 };
93
94 macaddr_factory_4: macaddr@4 {
95 reg = <0x4 0x6>;
96 };
97 };
98 };
99
100 partition@50000 {
101 compatible = "denx,uimage";
102 label = "firmware";
103 reg = <0x50000 0xfb0000>;
104 };
105 };
106 };
107 };
108
109 &state_default {
110 gpio {
111 groups = "i2c", "uartf";
112 function = "gpio";
113 };
114 };
115
116 &ethernet {
117 pinctrl-names = "default";
118 pinctrl-0 = <&rgmii1_pins &mdio_pins>;
119
120 nvmem-cells = <&macaddr_factory_4>;
121 nvmem-cell-names = "mac-address";
122
123 port@5 {
124 status = "okay";
125 mediatek,fixed-link = <1000 1 1 1>;
126 phy-mode = "rgmii";
127 };
128
129 mdio-bus {
130 status = "okay";
131
132 ethernet-phy@0 {
133 reg = <0>;
134 phy-mode = "rgmii";
135 };
136
137 ethernet-phy@1 {
138 reg = <1>;
139 phy-mode = "rgmii";
140 };
141
142 ethernet-phy@2 {
143 reg = <2>;
144 phy-mode = "rgmii";
145 };
146
147 ethernet-phy@3 {
148 reg = <3>;
149 phy-mode = "rgmii";
150 };
151
152 ethernet-phy@4 {
153 reg = <4>;
154 phy-mode = "rgmii";
155 };
156
157 ethernet-phy@1f {
158 reg = <0x1f>;
159 phy-mode = "rgmii";
160 };
161 };
162 };
163
164 &gsw {
165 mediatek,ephy-base = /bits/ 8 <12>;
166 };
167
168 &pcie {
169 status = "okay";
170 };
171
172 &pcie0 {
173 wifi@0,0 {
174 compatible = "mediatek,mt76";
175 reg = <0x0000 0 0 0 0>;
176 nvmem-cells = <&eeprom_factory_8000>;
177 nvmem-cell-names = "eeprom";
178 ieee80211-freq-limit = <5000000 6000000>;
179 };
180 };
181
182 &wmac {
183 nvmem-cells = <&eeprom_factory_0>;
184 nvmem-cell-names = "eeprom";
185 };