ramips: set usb led trigger via devicetree
[oweals/openwrt.git] / target / linux / ramips / dts / D240.dts
1 /*
2  *  BSD LICENSE
3  *
4  *  Copyright(c) 2017 Kristian Evensen <kristian.evensen@gmail.com>.
5  *  All rights reserved.
6  *
7  *  Redistribution and use in source and binary forms, with or without
8  *  modification, are permitted provided that the following conditions
9  *  are met:
10  *
11  *    * Redistributions of source code must retain the above copyright
12  *      notice, this list of conditions and the following disclaimer.
13  *    * Redistributions in binary form must reproduce the above copyright
14  *      notice, this list of conditions and the following disclaimer in
15  *      the documentation and/or other materials provided with the
16  *      distribution.
17  *    * Neither the name of Broadcom Corporation nor the names of its
18  *      contributors may be used to endorse or promote products derived
19  *      from this software without specific prior written permission.
20  *
21  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24  *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25  *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26  *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27  *  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  *  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  *  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33
34 /dts-v1/;
35
36 #include "mt7620a.dtsi"
37
38 #include <dt-bindings/gpio/gpio.h>
39 #include <dt-bindings/input/input.h>
40
41 / {
42         compatible = "sanlinking,d240", "ralink,mt7620a-soc";
43         model = "Sanlinking Technologies D240";
44
45         aliases {
46                 led-status = &led_power;
47         };
48
49         chosen {
50                 bootargs = "console=ttyS0,115200";
51         };
52
53         gpio-export {
54                 compatible = "gpio-export";
55                 #size-cells = <0>;
56
57                 power_mpcie2 {
58                         gpio-export,name = "power_mpcie2";
59                         gpio-export,output = <1>;
60                         gpios = <&gpio2 5 GPIO_ACTIVE_HIGH>;
61                 };
62
63                 power_mpcie1 {
64                         gpio-export,name = "power_mpcie1";
65                         gpio-export,output = <1>;
66                         gpios = <&gpio2 6 GPIO_ACTIVE_HIGH>;
67                 };
68         };
69
70         gpio-leds {
71                 compatible = "gpio-leds";
72
73                 led_power: power {
74                         label = "d240:blue:power";
75                         gpios = <&gpio1 14 GPIO_ACTIVE_HIGH>;
76                 };
77
78                 usb {
79                         label = "d240:blue:usb";
80                         gpios = <&gpio1 15 GPIO_ACTIVE_HIGH>;
81                         trigger-sources = <&ohci_port1>, <&ehci_port1>;
82                         linux,default-trigger = "usbport";
83                 };
84
85                 air {
86                         label = "d240:blue:wifi";
87                         gpios = <&gpio3 0 GPIO_ACTIVE_LOW>;
88                 };
89         };
90
91         gpio-keys-polled {
92                 compatible = "gpio-keys-polled";
93                 poll-interval = <20>;
94
95                 reset {
96                         label = "reset";
97                         gpios = <&gpio0 1 GPIO_ACTIVE_LOW>;
98                         linux,code = <KEY_RESTART>;
99                 };
100         };
101 };
102
103 &gpio1 {
104         status = "okay";
105 };
106
107 &gpio2 {
108         status = "okay";
109 };
110
111 &gpio3 {
112         status = "okay";
113 };
114
115 &spi0 {
116         status = "okay";
117
118         en25q128@0 {
119                 compatible = "jedec,spi-nor";
120                 reg = <0>;
121                 spi-max-frequency = <10000000>;
122
123                 partitions {
124                         compatible = "fixed-partitions";
125                         #address-cells = <1>;
126                         #size-cells = <1>;
127
128                         partition@0 {
129                                 label = "u-boot";
130                                 reg = <0x0 0x30000>;
131                                 read-only;
132                         };
133
134                         partition@30000 {
135                                 label = "u-boot-env";
136                                 reg = <0x30000 0x10000>;
137                                 read-only;
138                         };
139
140                         factory: partition@40000 {
141                                 label = "factory";
142                                 reg = <0x40000 0x10000>;
143                                 read-only;
144                         };
145
146                         partition@50000 {
147                                 label = "firmware";
148                                 reg = <0x50000 0xfb0000>;
149                         };
150                 };
151         };
152 };
153
154 &sdhci {
155         status = "okay";
156 };
157
158 &ehci {
159         status = "okay";
160 };
161
162 &ohci {
163         status = "okay";
164 };
165
166 &ethernet {
167         mtd-mac-address = <&factory 0x4>;
168         mediatek,portmap = "wllll";
169 };
170
171 &wmac {
172         ralink,mtd-eeprom = <&factory 0>;
173 };
174
175 &pinctrl {
176         state_default: pinctrl0 {
177                 default {
178                         ralink,group = "i2c", "uartf", "wled", "spi refclk", "pa";
179                         ralink,function = "gpio";
180                 };
181         };
182 };
183
184 &pcie {
185         status = "okay";
186 };