lantiq: dts: assign the GPHY LED pins to the Ethernet controller node
[oweals/openwrt.git] / target / linux / lantiq / files / arch / mips / boot / dts / VGV7519.dtsi
1 #include "vr9.dtsi"
2
3 #include <dt-bindings/input/input.h>
4 #include <dt-bindings/mips/lantiq_rcu_gphy.h>
5
6 / {
7         compatible = "arcadyan,vgv7519", "lantiq,xway", "lantiq,vr9";
8
9         chosen {
10                 bootargs = "console=ttyLTQ0,115200 mem=62M vpe1_load_addr=0x83e00000 vpe1_mem=2M maxvpes=1 maxtcs=1 nosmp";
11         };
12
13         aliases {
14                 led-boot = &power_green;
15                 led-failsafe = &power_red;
16                 led-running = &power_green;
17                 led-upgrade = &power_green;
18
19                 led-dsl = &broadband_green;
20                 led-internet = &internet_green;
21                 led-wifi = &wireless_green;
22         };
23
24         memory@0 {
25                 device_type = "memory";
26                 reg = <0x0 0x4000000>;
27         };
28
29         keys {
30                 compatible = "gpio-keys-polled";
31                 poll-interval = <100>;
32                 reset {
33                         label = "reset";
34                         gpios = <&gpio 9 GPIO_ACTIVE_LOW>;
35                         linux,code = <KEY_RESTART>;
36                 };
37                 eco {
38                         label = "eco";
39                         gpios = <&gpio 41 GPIO_ACTIVE_LOW>;
40                         linux,code = <BTN_0>;
41                 };
42                 rfkill {
43                         label = "rfkill";
44                         gpios = <&gpio 45 GPIO_ACTIVE_LOW>;
45                         linux,code = <KEY_RFKILL>;
46                 };
47                 wps {
48                         label = "wps";
49                         gpios = <&gpio 10 GPIO_ACTIVE_LOW>;
50                         linux,code = <KEY_WPS_BUTTON>;
51                 };
52         };
53
54         leds {
55                 compatible = "gpio-leds";
56
57                 eco {
58                         label = "vgv7519:blue:eco";
59                         gpios = <&stp 2 GPIO_ACTIVE_LOW>;
60                 };
61                 wps_red {
62                         label = "vgv7519:red:wps";
63                         gpios = <&stp 3 GPIO_ACTIVE_LOW>;
64                 };
65                 wps_green {
66                         label = "vgv7519:green:wps";
67                         gpios = <&stp 4 GPIO_ACTIVE_LOW>;
68                 };
69                 upgrade {
70                         label = "vgv7519:blue:upgrade";
71                         gpios = <&stp 5 GPIO_ACTIVE_LOW>;
72                 };
73                 tv {
74                         label = "vgv7519:green:tv";
75                         gpios = <&stp 6 GPIO_ACTIVE_LOW>;
76                 };
77                 internet_green: internet_green {
78                         label = "vgv7519:green:internet";
79                         gpios = <&stp 7 GPIO_ACTIVE_LOW>;
80                 };
81                 internet_red {
82                         label = "vgv7519:red:internet";
83                         gpios = <&stp 8 GPIO_ACTIVE_LOW>;
84                 };
85                 broadband_red {
86                         label = "vgv7519:red:broadband";
87                         gpios = <&stp 9 GPIO_ACTIVE_LOW>;
88                 };
89                 broadband_green: broadband_green {
90                         label = "vgv7519:green:broadband";
91                         gpios = <&stp 10 GPIO_ACTIVE_LOW>;
92                 };
93                 voice {
94                         label = "vgv7519:green:voice";
95                         gpios = <&stp 11 GPIO_ACTIVE_LOW>;
96                 };
97                 wireless_red {
98                         label = "vgv7519:red:wireless";
99                         gpios = <&stp 12 GPIO_ACTIVE_LOW>;
100                 };
101                 wireless_green: wireless_green {
102                         label = "vgv7519:green:wireless";
103                         gpios = <&stp 13 GPIO_ACTIVE_LOW>;
104                 };
105                 power_green: power2 {
106                         label = "vgv7519:green:power";
107                         gpios = <&stp 14 GPIO_ACTIVE_LOW>;
108                         default-state = "keep";
109                 };
110                 power_red: power {
111                         label = "vgv7519:red:power";
112                         gpios = <&stp 15 GPIO_ACTIVE_LOW>;
113                 };
114         };
115
116         usb_vbus: regulator-usb-vbus {
117                 compatible = "regulator-fixed";
118
119                 regulator-name = "USB_VBUS";
120
121                 regulator-min-microvolt = <5000000>;
122                 regulator-max-microvolt = <5000000>;
123
124                 gpio = <&gpio 32 GPIO_ACTIVE_HIGH>;
125                 enable-active-high;
126         };
127 };
128
129 &eth0 {
130         pinctrl-0 = <&mdio_pins>, <&gphy0_led1_pins>, <&gphy1_led0_pins>;
131         pinctrl-names = "default";
132
133         lan: interface@0 {
134                 compatible = "lantiq,xrx200-pdi";
135                 #address-cells = <1>;
136                 #size-cells = <0>;
137                 reg = <0>;
138                 mtd-mac-address = <&boardconfig 0x16>;
139                 mtd-mac-address-increment = <1>;
140                 lantiq,switch;
141
142                 ethernet@0 {
143                         compatible = "lantiq,xrx200-pdi-port";
144                         reg = <0>;
145                         phy-mode = "rgmii";
146                         phy-handle = <&phy0>;
147                 };
148                 ethernet@1 {
149                         compatible = "lantiq,xrx200-pdi-port";
150                         reg = <1>;
151                         phy-mode = "rgmii";
152                         phy-handle = <&phy1>;
153                 };
154                 ethernet@2 {
155                         compatible = "lantiq,xrx200-pdi-port";
156                         reg = <2>;
157                         phy-mode = "gmii";
158                         phy-handle = <&phy11>;
159                 };
160                 ethernet@4 {
161                         compatible = "lantiq,xrx200-pdi-port";
162                         reg = <4>;
163                         phy-mode = "gmii";
164                         phy-handle = <&phy13>;
165                 };
166                 ethernet@5 {
167                         compatible = "lantiq,xrx200-pdi-port";
168                         reg = <5>;
169                         phy-mode = "rgmii";
170                         phy-handle = <&phy5>;
171                 };
172         };
173
174         mdio {
175                 #address-cells = <1>;
176                 #size-cells = <0>;
177                 compatible = "lantiq,xrx200-mdio";
178
179                 phy0: ethernet-phy@0 {
180                         reg = <0x0>;
181                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
182                 };
183                 phy1: ethernet-phy@1 {
184                         reg = <0x1>;
185                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
186                 };
187                 phy5: ethernet-phy@5 {
188                         reg = <0x5>;
189                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
190                 };
191                 phy11: ethernet-phy@11 {
192                         reg = <0x11>;
193                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
194                 };
195                 phy13: ethernet-phy@13 {
196                         reg = <0x13>;
197                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
198                 };
199         };
200 };
201
202 &gphy0 {
203         lantiq,gphy-mode = <GPHY_MODE_GE>;
204 };
205
206 &gphy1 {
207         lantiq,gphy-mode = <GPHY_MODE_GE>;
208 };
209
210 &gpio {
211         pinctrl-names = "default";
212         pinctrl-0 = <&state_default>;
213
214         state_default: pinmux {
215                 stp {
216                         lantiq,groups = "stp";
217                         lantiq,function = "stp";
218                         lantiq,open-drain = <0>;
219                         lantiq,output = <1>;
220                         lantiq,pull = <0>;
221                 };
222                 pci-rst {
223                         lantiq,pins = "io21";
224                         lantiq,open-drain = <0>;
225                         lantiq,pull = <0>;
226                         lantiq,output = <1>;
227                 };
228         };
229 };
230
231 &localbus {
232         flash@0 {
233                 compatible = "lantiq,nor";
234                 bank-width = <2>;
235                 reg = <0 0x0 0x800000>, <1 0x800000 0x800000>;
236
237                 partitions {
238                         compatible = "fixed-partitions";
239                         #address-cells = <1>;
240                         #size-cells = <1>;
241
242                         boardconfig: partition@40000 {
243                                 label = "board_config";
244                                 reg = <0x40000 0x10000>;
245                                 read-only;
246                         };
247                 };
248         };
249 };
250
251 &pci0 {
252         status = "okay";
253         gpio-reset = <&gpio 21 GPIO_ACTIVE_HIGH>;
254
255         wifi@1814,3091 {
256                 compatible = "pci1814,3091";
257                 reg = <0x7000 0 0 0 0>;
258                 ralink,mtd-eeprom = <&boardconfig 0x410>;
259                 ralink,mtd-eeprom-swap;
260                 mtd-mac-address = <&boardconfig 0x16>;
261                 mtd-mac-address-increment = <1>;
262         };
263 };
264
265 &pcie0 {
266         status = "disabled";
267 };
268
269 &stp {
270         status = "okay";
271         lantiq,shadow = <0xffff>;
272         lantiq,groups = <0x3>;
273         lantiq,dsl = <0x0>;
274         lantiq,phy1 = <0x0>;
275         lantiq,phy2 = <0x0>;
276         /* lantiq,rising; */
277 };
278
279 &usb_phy0 {
280         status = "okay";
281 };
282
283 &usb_phy1 {
284         status = "okay";
285 };
286
287 &usb0 {
288         status = "okay";
289         vbus-supply = <&usb_vbus>;
290 };
291
292 &usb1 {
293         status = "okay";
294         vbus-supply = <&usb_vbus>;
295 };
296
297 &vmmc {
298         status = "okay";
299         gpios = <&gpio 30 GPIO_ACTIVE_HIGH  //fxs relay
300                  &gpio 31 GPIO_ACTIVE_HIGH  //still unknown
301                  &gpio 3  GPIO_ACTIVE_HIGH>; //reset_slic?
302 };