1 // SPDX-License-Identifier: GPL-2.0 OR MIT
3 * Copyright 2015 Endless Mobile, Inc.
4 * Author: Carlo Caione <carlo@endlessm.com>
8 #include "meson8b.dtsi"
9 #include <dt-bindings/gpio/gpio.h>
12 model = "Hardkernel ODROID-C1";
13 compatible = "hardkernel,odroid-c1", "amlogic,meson8b";
21 stdout-path = "serial0:115200n8";
25 device_type = "memory";
26 reg = <0x40000000 0x40000000>;
30 compatible = "gpio-leds";
32 label = "c1:blue:alive";
33 gpios = <&gpio_ao GPIOAO_13 GPIO_ACTIVE_LOW>;
34 linux,default-trigger = "heartbeat";
35 default-state = "off";
39 p5v0: regulator-p5v0 {
40 compatible = "regulator-fixed";
42 regulator-name = "P5V0";
43 regulator-min-microvolt = <5000000>;
44 regulator-max-microvolt = <5000000>;
47 tflash_vdd: regulator-tflash_vdd {
49 * signal name from schematics: TFLASH_VDD_EN
51 compatible = "regulator-fixed";
53 regulator-name = "TFLASH_VDD";
54 regulator-min-microvolt = <3300000>;
55 regulator-max-microvolt = <3300000>;
57 vin-supply = <&vcc_3v3>;
59 gpio = <&gpio GPIOY_12 GPIO_ACTIVE_HIGH>;
63 tf_io: gpio-regulator-tf_io {
64 compatible = "regulator-gpio";
66 regulator-name = "TF_IO";
67 regulator-min-microvolt = <1800000>;
68 regulator-max-microvolt = <3300000>;
70 vin-supply = <&vcc_3v3>;
73 * signal name from schematics: TF_3V3N_1V8_EN
75 gpios = <&gpio_ao GPIOAO_3 GPIO_ACTIVE_HIGH>;
83 compatible = "iio-hwmon";
84 io-channels = <&saradc 8>;
87 rtc32k_xtal: rtc32k-xtal-clk {
88 /* X3 in the schematics */
89 compatible = "fixed-clock";
90 clock-frequency = <32768>;
91 clock-output-names = "RTC32K";
95 vcc_1v8: regulator-vcc-1v8 {
97 * RICHTEK RT9179 configured for a fixed output voltage of
98 * 1.8V. This supplies not only VCC1V8 but also IOREF_1V8 and
99 * VDD1V8 according to the schematics.
101 compatible = "regulator-fixed";
103 regulator-name = "VCC1V8";
104 regulator-min-microvolt = <1800000>;
105 regulator-max-microvolt = <1800000>;
107 vin-supply = <&p5v0>;
110 vcc_3v3: regulator-vcc-3v3 {
112 * Monolithic Power Systems MP2161 configured for a fixed
113 * output voltage of 3.3V. This supplies not only VCC3V3 but
114 * also VDD3V3 and VDDIO_AO3V3 according to the schematics.
116 compatible = "regulator-fixed";
118 regulator-name = "VCC3V3";
119 regulator-min-microvolt = <3300000>;
120 regulator-max-microvolt = <3300000>;
122 vin-supply = <&p5v0>;
125 vcck: regulator-vcck {
126 /* Monolithic Power Systems MP2161 */
127 compatible = "pwm-regulator";
129 regulator-name = "VCCK";
130 regulator-min-microvolt = <860000>;
131 regulator-max-microvolt = <1140000>;
133 vin-supply = <&p5v0>;
135 pwms = <&pwm_cd 0 12218 0>;
136 pwm-dutycycle-range = <91 0>;
142 vddc_ddr: regulator-vddc-ddr {
144 * Monolithic Power Systems MP2161 configured for a fixed
145 * output voltage of 1.5V. This supplies not only DDR_VDDC but
146 * also DDR3_1V5 according to the schematics.
148 compatible = "regulator-fixed";
150 regulator-name = "DDR_VDDC";
151 regulator-min-microvolt = <1500000>;
152 regulator-max-microvolt = <1500000>;
154 vin-supply = <&p5v0>;
157 vddee: regulator-vddee {
158 /* Monolithic Power Systems MP2161 */
159 compatible = "pwm-regulator";
161 regulator-name = "VDDEE";
162 regulator-min-microvolt = <860000>;
163 regulator-max-microvolt = <1140000>;
165 vin-supply = <&p5v0>;
167 pwms = <&pwm_cd 1 12218 0>;
168 pwm-dutycycle-range = <91 0>;
174 vdd_rtc: regulator-vdd-rtc {
176 * Torex Semiconductor XC6215 configured for a fixed output of
179 compatible = "regulator-fixed";
181 regulator-name = "VDD_RTC";
182 regulator-min-microvolt = <900000>;
183 regulator-max-microvolt = <900000>;
185 vin-supply = <&vcc_3v3>;
190 cpu-supply = <&vcck>;
194 ethernet_mac_address: mac@1b4 {
202 pinctrl-0 = <ð_rgmii_pins>;
203 pinctrl-names = "default";
205 phy-handle = <ð_phy>;
206 phy-mode = "rgmii-id";
208 nvmem-cells = <ðernet_mac_address>;
209 nvmem-cell-names = "mac-address";
212 compatible = "snps,dwmac-mdio";
213 #address-cells = <1>;
216 /* Realtek RTL8211F (0x001cc916) */
217 eth_phy: ethernet-phy@0 {
220 reset-assert-us = <10000>;
221 reset-deassert-us = <30000>;
222 reset-gpios = <&gpio GPIOH_4 GPIO_ACTIVE_LOW>;
224 interrupt-parent = <&gpio_intc>;
226 interrupts = <17 IRQ_TYPE_LEVEL_LOW>;
232 gpio-line-names = /* Bank GPIOX */
233 "J2 Header Pin 35", "J2 Header Pin 36",
234 "J2 Header Pin 32", "J2 Header Pin 31",
235 "J2 Header Pin 29", "J2 Header Pin 18",
236 "J2 Header Pin 22", "J2 Header Pin 16",
237 "J2 Header Pin 23", "J2 Header Pin 21",
238 "J2 Header Pin 19", "J2 Header Pin 33",
239 "J2 Header Pin 8", "J2 Header Pin 10",
240 "J2 Header Pin 15", "J2 Header Pin 13",
241 "J2 Header Pin 24", "J2 Header Pin 26",
243 "Revision (upper)", "Revision (lower)",
244 "J2 Header Pin 7", "", "J2 Header Pin 12",
245 "J2 Header Pin 11", "", "", "",
246 "TFLASH_VDD_EN", "", "",
248 "VCCK_PWM (PWM_C)", "I2CA_SDA", "I2CA_SCL",
249 "I2CB_SDA", "I2CB_SCL", "VDDEE_PWM (PWM_D)",
252 "HDMI_HPD", "HDMI_I2C_SDA", "HDMI_I2C_SCL",
253 "ETH_PHY_INTR", "ETH_PHY_NRST", "ETH_TXD1",
254 "ETH_TXD0", "ETH_TXD3", "ETH_TXD2",
257 "SD_DATA1 (SDB_D1)", "SD_DATA0 (SDB_D0)",
258 "SD_CLK", "SD_CMD", "SD_DATA3 (SDB_D3)",
259 "SD_DATA2 (SDB_D2)", "SD_CDN (SD_DET_N)",
261 "SDC_D0 (EMMC)", "SDC_D1 (EMMC)",
262 "SDC_D2 (EMMC)", "SDC_D3 (EMMC)",
263 "SDC_D4 (EMMC)", "SDC_D5 (EMMC)",
264 "SDC_D6 (EMMC)", "SDC_D7 (EMMC)",
265 "SDC_CLK (EMMC)", "SDC_RSTn (EMMC)",
266 "SDC_CMD (EMMC)", "BOOT_SEL", "", "", "",
269 "ETH_RXD1", "ETH_RXD0", "ETH_RX_DV",
270 "RGMII_RX_CLK", "ETH_RXD3", "ETH_RXD2",
271 "ETH_TXEN", "ETH_PHY_REF_CLK_25MOUT",
272 "ETH_MDC", "ETH_MDIO";
276 gpio-line-names = "UART TX", "UART RX", "",
277 "TF_3V3N_1V8_EN", "USB_HUB_RST_N",
278 "USB_OTG_PWREN", "J7 Header Pin 2",
279 "IR_IN", "J7 Header Pin 4",
280 "J7 Header Pin 6", "J7 Header Pin 5",
281 "J7 Header Pin 7", "HDMI_CEC",
285 * WARNING: The USB Hub on the Odroid-C1/C1+ needs a reset signal
286 * to be turned high in order to be detected by the USB Controller.
287 * This signal should be handled by a USB specific power sequence
288 * in order to reset the Hub when USB bus is powered down.
292 gpios = <GPIOAO_4 GPIO_ACTIVE_HIGH>;
294 line-name = "usb-hub-reset";
300 pinctrl-0 = <&ir_recv_pins>;
301 pinctrl-names = "default";
305 mali-supply = <&vddee>;
310 vref-supply = <&vcc_1v8>;
316 pinctrl-0 = <&sd_b_pins>;
317 pinctrl-names = "default";
320 sd_card_slot: slot@1 {
321 compatible = "mmc-slot";
331 cd-gpios = <&gpio CARD_6 GPIO_ACTIVE_LOW>;
333 vmmc-supply = <&tflash_vdd>;
334 vqmmc-supply = <&tf_io>;
340 pinctrl-0 = <&pwm_c1_pins>, <&pwm_d_pins>;
341 pinctrl-names = "default";
342 clocks = <&xtal>, <&xtal>;
343 clock-names = "clkin0", "clkin1";
347 /* needs to be enabled manually when a battery is connected */
348 clocks = <&rtc32k_xtal>;
349 vdd-supply = <&vdd_rtc>;
354 pinctrl-0 = <&uart_ao_a_pins>;
355 pinctrl-names = "default";