lantiq - vgv7519: add pci-rst entry into dts
[oweals/openwrt.git] / target / linux / lantiq / dts / VGV7519.dtsi
1 /include/ "vr9.dtsi"
2
3 / {
4
5     model = "VGV7519 - KPN Experiabox V8";
6
7         chosen {
8                 bootargs = "console=ttyLTQ0,115200 init=/etc/preinit";
9         };
10
11         memory@0 {
12                 reg = <0x0 0x4000000>;
13         };
14         
15         fpi@10000000 {
16                 #address-cells = <1>;
17                 #size-cells = <1>;
18                 compatible = "lantiq,fpi", "simple-bus";
19                 ranges = <0x0 0x10000000 0xEEFFFFF>;
20                 reg = <0x10000000 0xEF00000>;
21
22                 localbus@0 {
23                         #address-cells = <2>;
24                         #size-cells = <1>;
25                         compatible = "lantiq,localbus", "simple-bus";
26                 };
27
28                 gpio: pinmux@E100B10 {
29                         compatible = "lantiq,pinctrl-xr9";
30                         pinctrl-names = "default";
31                         pinctrl-0 = <&state_default>;
32                         
33                         interrupt-parent = <&icu0>;
34                         interrupts = <166 135 66 40 41 42 38>;
35
36                         #gpio-cells = <2>;
37                         gpio-controller;
38                         reg = <0xE100B10 0xA0>;
39
40                         state_default: pinmux {
41                                 stp {
42                                         lantiq,groups = "stp";
43                                         lantiq,function = "stp";
44                                 };
45                                 spi {
46                                         lantiq,groups = "spi", "spi_cs4";
47                                         lantiq,function = "spi";
48                                 };
49                                 mdio {
50                                         lantiq,groups = "mdio";
51                                         lantiq,function = "mdio";
52                                 };
53                                 gphy-leds_out {
54                                         lantiq,pins = "io7", "io44";
55                                         lantiq,pull = <0>;
56                                         lantiq,output = <1>;
57                                 };
58                                 pci-rst {
59                                         lantiq,pins = "io21";
60                                         lantiq,open-drain = <0>;
61                                         lantiq,pull = <0>;
62                                         lantiq,output = <1>;
63                                 };
64                                 conf_out {
65                                         lantiq,pins = "io4", "io5", "io6", /* stp */
66                                                         "io21",
67                                                         "io33";
68                                         lantiq,open-drain;
69                                         lantiq,pull = <0>;
70                                         lantiq,output = <1>;
71                                 };
72                                 gphy-leds {
73                                         lantiq,groups = "gphy0 led1", "gphy1 led0";
74                                         lantiq,function = "gphy";
75                                         lantiq,open-drain = <0>;
76                                 };
77                         };
78                 };
79
80                 eth@E108000 {
81                         #address-cells = <1>;
82                         #size-cells = <0>;
83                         compatible = "lantiq,xrx200-net";
84                         reg = < 0xE108000 0x3000 /* switch */
85                                 0xE10B100 0x70 /* mdio */
86                                 0xE10B1D8 0x30 /* mii */
87                                 0xE10B308 0x30 /* pmac */
88                         >;
89                         interrupt-parent = <&icu0>;
90                         interrupts = <73 72>;
91
92                         lan: interface@0 {
93                                 compatible = "lantiq,xrx200-pdi";
94                                 #address-cells = <1>;
95                                 #size-cells = <0>;
96                                 reg = <0>;
97                                 mac-address = [ 00 11 22 33 44 55 ];
98
99                                 ethernet@0 {
100                                         compatible = "lantiq,xrx200-pdi-port";
101                                         reg = <0>;
102                                         phy-mode = "rgmii";
103                                         phy-handle = <&phy0>;
104                                 };
105                                 ethernet@1 {
106                                         compatible = "lantiq,xrx200-pdi-port";
107                                         reg = <1>;
108                                         phy-mode = "rgmii";
109                                         phy-handle = <&phy1>;
110                                 };
111                                 ethernet@2 {
112                                         compatible = "lantiq,xrx200-pdi-port";
113                                         reg = <2>;
114                                         phy-mode = "gmii";
115                                         phy-handle = <&phy11>;
116                                 };
117                                 ethernet@4 {
118                                         compatible = "lantiq,xrx200-pdi-port";
119                                         reg = <4>;
120                                         phy-mode = "gmii";
121                                         phy-handle = <&phy13>;
122                                 };
123                         };
124
125                         wan: interface@1 {
126                                 compatible = "lantiq,xrx200-pdi";
127                                 #address-cells = <1>;
128                                 #size-cells = <0>;
129                                 reg = <1>;
130                                 mac-address = [ 00 11 22 33 44 56 ];
131                                 lantiq,wan;
132                                 ethernet@5 {
133                                         compatible = "lantiq,xrx200-pdi-port";
134                                         reg = <5>;
135                                         phy-mode = "rgmii";
136                                         phy-handle = <&phy5>;
137                                 };
138                         };
139
140                         mdio@0 {
141                                 #address-cells = <1>;
142                                 #size-cells = <0>;
143                                 compatible = "lantiq,xrx200-mdio";
144                                 phy0: ethernet-phy@0 {
145                                         reg = <0x0>;
146                                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
147                                         lantiq,c45-reg-init = <1 0 0 0>; 
148                                 };
149                                 phy1: ethernet-phy@1 {
150                                         reg = <0x1>;
151                                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
152                                         lantiq,c45-reg-init = <1 0 0 0>; 
153                                 };
154                                 phy5: ethernet-phy@5 {
155                                         reg = <0x5>;
156                                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
157                                         lantiq,c45-reg-init = <1 0 0 0>; 
158                                 };
159                                 phy11: ethernet-phy@11 {
160                                         reg = <0x11>;
161                                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
162                                         lantiq,c45-reg-init = <1 0 0 0>; 
163                                 };
164                                 phy13: ethernet-phy@13 {
165                                         reg = <0x13>;
166                                         compatible = "lantiq,phy11g", "ethernet-phy-ieee802.3-c22";
167                                         lantiq,c45-reg-init = <1 0 0 0>; 
168                                 };
169                         };
170                 };
171
172                 stp: stp@E100BB0 {
173                         compatible = "lantiq,gpio-stp-xway";
174                         reg = <0xE100BB0 0x40>;
175                         #gpio-cells = <2>;
176                         gpio-controller;
177
178                         lantiq,shadow = <0xffff>;
179                         lantiq,groups = <0x3>;
180                         lantiq,dsl = <0x0>;
181                         lantiq,phy1 = <0x0>;
182                         lantiq,phy2 = <0x0>;
183                         /* lantiq,rising; */
184                 };
185
186                 ifxhcd@E101000 {
187                         status = "okay";
188                         gpios = <&gpio 32 0>;
189                         lantiq,portmask = <0x3>;
190                 };
191
192                 pci@E105400 {
193                         #address-cells = <3>;
194                         #size-cells = <2>;
195                         #interrupt-cells = <1>;
196                         compatible = "lantiq,pci-xway1";
197                         bus-range = <0x0 0x0>;
198                         ranges = <0x2000000 0 0x8000000 0x8000000 0 0x2000000   /* pci memory */
199                                 0x1000000 0 0x00000000 0xAE00000 0 0x200000>; /* io space */
200                         reg = <0x7000000 0x8000         /* config space */
201                                 0xE105400 0x400>;       /* pci bridge */
202                         lantiq,bus-clock = <33333333>;
203                         /*lantiq,external-clock;*/
204                         lantiq,delay-hi = <0>; /* 0ns delay */
205                         lantiq,delay-lo = <0>; /* 0.0ns delay */
206                         interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
207                         interrupt-map = <
208                                 0x7000 0 0 1 &icu0 29 1 // slot 14, irq 29
209                                 >;
210                         gpios-reset = <&gpio 21 0>;
211                         req-mask = <0x1>;       /* GNT1 */
212                 };
213         };
214
215         gphy-xrx200 {
216                 compatible = "lantiq,phy-xrx200";
217                 firmware = "lantiq/vr9_phy11g_a1x.bin";
218                 phys = [ 00 01 ];
219         };
220
221         gpio-keys-polled {
222                 compatible = "gpio-keys-polled";
223                 #address-cells = <1>;
224                 #size-cells = <0>;
225                 poll-interval = <100>;
226                 reset {
227                         label = "reset";
228                         gpios = <&gpio 9 1>;
229                         linux,code = <0x198>;
230                 };
231                 eco {
232                         label = "eco";
233                         gpios = <&gpio 41 1>;
234                         linux,code = <247>;
235                 };
236                 rfkill {
237                         label = "rfkill";
238                         gpios = <&gpio 45 1>;
239                         linux,code = <0xf7>;
240                 };
241                 wps {
242                         label = "wps";
243                         gpios = <&gpio 10 1>;
244                         linux,code = <0x211>;
245                 };
246         };
247
248         gpio-leds {
249                 compatible = "gpio-leds";
250
251                 eco {                                   /* blue */
252                         label = "eco";
253                         gpios = <&stp 2 1>;
254                 };
255                 wps_red {                               /* red */
256                         label = "wps_red";
257                         gpios = <&stp 3 1>;
258                 };
259                 wps_yellow {                            /* yellow */
260                         label = "wps_yellow";
261                         gpios = <&stp 4 1>;
262                 };
263                 upgrade {                               /* blue */
264                         label = "upgrade";
265                         gpios = <&stp 5 1>;
266                 };
267                 tv {                                    /* yellow */
268                         label = "tv";
269                         gpios = <&stp 6 1>;
270                 };
271                 internet_yellow {                       /* yellow */
272                         label = "internet_yellow";
273                         gpios = <&stp 7 1>;
274                 };
275                 internet_red {                          /* red */
276                         label = "internet_red";
277                         gpios = <&stp 8 1>;
278                 };
279                 broadband_red {                         /* red */
280                         label = "broadband_red";
281                         gpios = <&stp 9 1>;
282                 };
283                 broadband_yellow {                      /* yellow */
284                         label = "broadband_yellow";
285                         gpios = <&stp 10 1>;
286                 };
287                 voice {                                 /* yellow */
288                         label = "voice";
289                         gpios = <&stp 11 1>;
290                 };
291                 wireless_red {                          /* red */
292                         label = "wireless_red";
293                         gpios = <&stp 12 1>;
294                 };
295                 wireless_yellow {                       /* yellow */
296                         label = "wireless_yellow";
297                         gpios = <&stp 13 1>;
298                 };
299                 power2 {                                /* yellow */
300                         label = "power2";
301                         gpios = <&stp 14 1>;
302                 };
303                 power {                                 /* red */
304                         label = "power";
305                         gpios = <&stp 15 1>;
306                         default-state = "on";
307                 };
308         };
309 };