2 * Device tree for LEGO MINDSTORMS EV3
4 * Copyright (C) 2017 David Lechner <david@lechnology.com>
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation, version 2.
12 #include <dt-bindings/gpio/gpio.h>
13 #include <dt-bindings/input/linux-event-codes.h>
14 #include <dt-bindings/pwm/pwm.h>
19 compatible = "lego,ev3", "ti,da850";
20 model = "LEGO MINDSTORMS EV3";
27 device_type = "memory";
28 reg = <0xc0000000 0x04000000>;
32 * The buttons on the EV3 are mapped to keyboard keys.
35 compatible = "gpio-keys";
38 label = "EV3 Brick Buttons";
39 pinctrl-names = "default";
40 pinctrl-0 = <&button_pins>, <&button_bias>;
44 linux,code = <KEY_ENTER>;
45 gpios = <&gpio 29 GPIO_ACTIVE_HIGH>;
50 linux,code = <KEY_LEFT>;
51 gpios = <&gpio 102 GPIO_ACTIVE_HIGH>;
56 linux,code = <KEY_BACKSPACE>;
57 gpios = <&gpio 106 GPIO_ACTIVE_HIGH>;
62 linux,code = <KEY_RIGHT>;
63 gpios = <&gpio 124 GPIO_ACTIVE_HIGH>;
68 linux,code = <KEY_DOWN>;
69 gpios = <&gpio 126 GPIO_ACTIVE_HIGH>;
74 linux,code = <KEY_UP>;
75 gpios = <&gpio 127 GPIO_ACTIVE_HIGH>;
80 * The EV3 has two built-in bi-color LEDs behind the buttons.
83 compatible = "gpio-leds";
84 pinctrl-names = "default";
85 pinctrl-0 = <&led_pins>;
88 label = "led0:green:brick-status";
90 gpios = <&gpio 103 GPIO_ACTIVE_HIGH>;
91 linux,default-trigger = "default-on";
95 label = "led1:red:brick-status";
97 gpios = <&gpio 108 GPIO_ACTIVE_HIGH>;
98 linux,default-trigger = "default-on";
102 label = "led0:red:brick-status";
104 gpios = <&gpio 109 GPIO_ACTIVE_HIGH>;
105 linux,default-trigger = "default-on";
109 label = "led1:green:brick-status";
111 gpios = <&gpio 110 GPIO_ACTIVE_HIGH>;
112 linux,default-trigger = "default-on";
117 * The EV3 is powered down by turning off the main 5V supply.
120 compatible = "gpio-poweroff";
121 gpios = <&gpio 107 GPIO_ACTIVE_LOW>;
122 pinctrl-names = "default";
123 pinctrl-0 = <&system_power_pin>;
127 compatible = "pwm-beeper";
128 pinctrl-names = "default";
129 pinctrl-0 = <&ehrpwm0b_pins>;
130 pwms = <&ehrpwm0 1 1000000 0>;
135 * This is a 5V current limiting regulator that is shared by USB,
136 * the sensor (input) ports, the motor (output) ports and the A/DC.
139 pinctrl-names = "default";
140 pinctrl-0 = <&vcc5v_pins>;
141 compatible = "regulator-fixed";
142 regulator-name = "vcc5v";
143 regulator-min-microvolt = <5000000>;
144 regulator-max-microvolt = <5000000>;
145 gpio = <&gpio 101 0>;
146 over-current-gpios = <&gpio 99 GPIO_ACTIVE_LOW>;
152 * This is a simple voltage divider on VCC5V to provide a 2.5V
153 * reference signal to the ADC.
155 adc_ref: regulator2 {
156 compatible = "regulator-fixed";
157 regulator-name = "adc ref";
158 regulator-min-microvolt = <2500000>;
159 regulator-max-microvolt = <2500000>;
161 vin-supply = <&vcc5v>;
165 * This is the amplifier for the speaker.
168 pinctrl-names = "default";
169 pinctrl-0 = <&_pins>;
170 compatible = "regulator-fixed";
171 regulator-name = "amp";
172 gpio = <&gpio 111 GPIO_ACTIVE_HIGH>;
177 * The EV3 can use 6-AA batteries or a rechargeable Li-ion battery pack.
180 pinctrl-names = "default";
181 pintctrl-0 = <&battery_pins>;
182 compatible = "lego,ev3-battery";
183 io-channels = <&adc 4>, <&adc 3>;
184 io-channel-names = "voltage", "current";
185 rechargeable-gpios = <&gpio 136 GPIO_ACTIVE_LOW>;
192 mmc0_cd_pin: pinmux_mmc0_cd {
193 pinctrl-single,bits = <
195 0x2C 0x00000080 0x000000f0
199 button_pins: pinmux_button_pins {
200 pinctrl-single,bits = <
202 0x8 0x00000800 0x00000f00
204 0x34 0x00800000 0x00f00000
206 0x38 0x00000080 0x000000f0
207 /* GP7[12], GP7[14], GP7[15] */
208 0x40 0x00808800 0x00f0ff00
212 led_pins: pinmux_led_pins {
213 pinctrl-single,bits = <
214 /* GP6[12], GP6[13], GP6[14] */
215 0x34 0x00008880 0x0000fff0
217 0x38 0x00000008 0x0000000f
221 system_power_pin: pinmux_system_power {
222 pinctrl-single,bits = <
224 0x34 0x00080000 0x000f0000
228 vcc5v_pins: pinmux_vcc5v {
229 pinctrl-single,bits = <
231 0x40 0x00000080 0x000000f0
233 0x4c 0x00008000 0x0000f000
237 amp_pins: pinmux_amp_pins {
238 pinctrl-single,bits = <
240 0x34 0x00000008 0x0000000f
244 battery_pins: pinmux_battery_pins {
245 pinctrl-single,bits = <
247 0x04 0x00000080 0x000000f0
249 0x4c 0x00000080 0x000000f0
253 ev3_lcd_pins: pinmux_lcd {
254 pinctrl-single,bits = <
255 /* SIMO, GP2[11], GP2[12], CLK */
256 0x14 0x00188100 0x00ffff00
258 0x30 0x80000000 0xf0000000
266 /* Buttons have external pulldown resistors */
267 button_bias: button-bias-groups {
269 groups = "cp5", "cp24", "cp25", "cp28";
278 pinctrl-names = "default";
279 pinctrl-0 = <&serial1_rxtx_pins>;
288 clock-frequency = <400000>;
289 pinctrl-names = "default";
290 pinctrl-0 = <&i2c0_pins>;
293 * EEPROM contains the first stage bootloader, HW ID and Bluetooth MAC.
296 compatible = "microchip,24c128";
309 max-frequency = <50000000>;
311 cd-gpios = <&gpio 94 GPIO_ACTIVE_LOW>;
312 pinctrl-names = "default";
313 pinctrl-0 = <&mmc0_pins>, <&mmc0_cd_pin>;
318 pinctrl-names = "default";
319 pinctrl-0 = <&spi0_pins>, <&spi0_cs0_pin>, <&spi0_cs3_pin>;
322 compatible = "n25q128a13", "jedec,spi-nor";
324 spi-max-frequency = <50000000>;
327 /* Partitions are based on the official firmware from LEGO */
329 compatible = "fixed-partitions";
330 #address-cells = <1>;
339 label = "U-Boot Env";
340 reg = <0x40000 0x10000>;
345 reg = <0x50000 0x200000>;
349 label = "Filesystem";
350 reg = <0x250000 0xa50000>;
355 reg = <0xcb0000 0x2f0000>;
361 compatible = "ti,ads7957";
363 #io-channel-cells = <1>;
364 spi-max-frequency = <10000000>;
365 vref-supply = <&adc_ref>;
371 pinctrl-0 = <&ev3_lcd_pins>;
372 pinctrl-names = "default";
373 cs-gpios = <&gpio 44 GPIO_ACTIVE_LOW>;
376 compatible = "lego,ev3-lcd";
378 spi-max-frequency = <10000000>;
379 a0-gpios = <&gpio 43 GPIO_ACTIVE_HIGH>;
380 reset-gpios = <&gpio 80 GPIO_ACTIVE_HIGH>;
391 /* Don't pull down battery voltage adc io channel */
394 gpios = <6 GPIO_ACTIVE_HIGH>;
409 vbus-supply = <&vcc5v>;