1// SPDX-License-Identifier: GPL-2.0-only 2/* 3 * Copyright (C) 2014 Joachim Eastwood <manabian@gmail.com> 4 */ 5 6#include <dt-bindings/input/input.h> 7 8/ { 9 aliases { 10 display0 = &hdmi0; 11 }; 12 13 leds { 14 compatible = "gpio-leds"; 15 pinctrl-names = "default"; 16 pinctrl-0 = <&gpio_led_pins>; 17 18 led0 { 19 label = "var:green:led0"; 20 gpios = <&gpio6 13 GPIO_ACTIVE_HIGH>; /* gpio 173 */ 21 linux,default-trigger = "heartbeat"; 22 }; 23 24 led1 { 25 label = "var:green:led1"; 26 gpios = <&gpio6 12 GPIO_ACTIVE_HIGH>; /* gpio 172 */ 27 }; 28 }; 29 30 gpio-keys { 31 compatible = "gpio-keys"; 32 pinctrl-names = "default"; 33 pinctrl-0 = <&gpio_key_pins>; 34 #address-cells = <1>; 35 #size-cells = <0>; 36 37 user-key@184 { 38 label = "user"; 39 gpios = <&gpio6 24 GPIO_ACTIVE_HIGH>; /* gpio 184 */ 40 linux,code = <BTN_EXTRA>; 41 wakeup-source; 42 }; 43 }; 44 45 hdmi0: connector { 46 compatible = "hdmi-connector"; 47 pinctrl-names = "default"; 48 pinctrl-0 = <&hdmi_hpd_pins>; 49 label = "hdmi"; 50 type = "a"; 51 52 hpd-gpios = <&gpio2 31 GPIO_ACTIVE_HIGH>; /* gpio_63 */ 53 54 port { 55 hdmi_connector_in: endpoint { 56 remote-endpoint = <&hdmi_out>; 57 }; 58 }; 59 }; 60}; 61 62&omap4_pmx_core { 63 uart1_pins: pinmux_uart1_pins { 64 pinctrl-single,pins = < 65 OMAP4_IOPAD(0x13c, PIN_INPUT_PULLUP | MUX_MODE1) /* mcspi1_cs2.uart1_cts */ 66 OMAP4_IOPAD(0x13e, PIN_OUTPUT | MUX_MODE1) /* mcspi1_cs3.uart1_rts */ 67 OMAP4_IOPAD(0x126, PIN_INPUT_PULLUP | MUX_MODE1) /* i2c2_scl.uart1_rx */ 68 OMAP4_IOPAD(0x128, PIN_OUTPUT | MUX_MODE1) /* i2c2_sda.uart1_tx */ 69 >; 70 }; 71 72 mcspi1_pins: pinmux_mcspi1_pins { 73 pinctrl-single,pins = < 74 OMAP4_IOPAD(0x132, PIN_INPUT | MUX_MODE0) /* mcspi1_clk.mcspi1_clk */ 75 OMAP4_IOPAD(0x134, PIN_INPUT | MUX_MODE0) /* mcspi1_somi.mcspi1_somi */ 76 OMAP4_IOPAD(0x136, PIN_INPUT | MUX_MODE0) /* mcspi1_simo.mcspi1_simo */ 77 OMAP4_IOPAD(0x138, PIN_INPUT | MUX_MODE0) /* mcspi1_cs0.mcspi1_cs0 */ 78 >; 79 }; 80 81 mcasp_pins: pinmux_mcsasp_pins { 82 pinctrl-single,pins = < 83 OMAP4_IOPAD(0x0f8, PIN_OUTPUT | MUX_MODE2) /* mcbsp2_dr.abe_mcasp_axr */ 84 >; 85 }; 86 87 dss_dpi_pins: pinmux_dss_dpi_pins { 88 pinctrl-single,pins = < 89 OMAP4_IOPAD(0x162, PIN_OUTPUT | MUX_MODE5) /* dispc2_data23 */ 90 OMAP4_IOPAD(0x164, PIN_OUTPUT | MUX_MODE5) /* dispc2_data22 */ 91 OMAP4_IOPAD(0x166, PIN_OUTPUT | MUX_MODE5) /* dispc2_data21 */ 92 OMAP4_IOPAD(0x168, PIN_OUTPUT | MUX_MODE5) /* dispc2_data20 */ 93 OMAP4_IOPAD(0x16a, PIN_OUTPUT | MUX_MODE5) /* dispc2_data19 */ 94 OMAP4_IOPAD(0x16c, PIN_OUTPUT | MUX_MODE5) /* dispc2_data18 */ 95 OMAP4_IOPAD(0x16e, PIN_OUTPUT | MUX_MODE5) /* dispc2_data15 */ 96 OMAP4_IOPAD(0x170, PIN_OUTPUT | MUX_MODE5) /* dispc2_data14 */ 97 OMAP4_IOPAD(0x172, PIN_OUTPUT | MUX_MODE5) /* dispc2_data13 */ 98 OMAP4_IOPAD(0x174, PIN_OUTPUT | MUX_MODE5) /* dispc2_data12 */ 99 OMAP4_IOPAD(0x176, PIN_OUTPUT | MUX_MODE5) /* dispc2_data11 */ 100 OMAP4_IOPAD(0x1b4, PIN_OUTPUT | MUX_MODE5) /* dispc2_data10 */ 101 OMAP4_IOPAD(0x1b6, PIN_OUTPUT | MUX_MODE5) /* dispc2_data9 */ 102 OMAP4_IOPAD(0x1b8, PIN_OUTPUT | MUX_MODE5) /* dispc2_data16 */ 103 OMAP4_IOPAD(0x1ba, PIN_OUTPUT | MUX_MODE5) /* dispc2_data17 */ 104 OMAP4_IOPAD(0x1bc, PIN_OUTPUT | MUX_MODE5) /* dispc2_hsync */ 105 OMAP4_IOPAD(0x1be, PIN_OUTPUT | MUX_MODE5) /* dispc2_pclk */ 106 OMAP4_IOPAD(0x1c0, PIN_OUTPUT | MUX_MODE5) /* dispc2_vsync */ 107 OMAP4_IOPAD(0x1c2, PIN_OUTPUT | MUX_MODE5) /* dispc2_de */ 108 OMAP4_IOPAD(0x1c4, PIN_OUTPUT | MUX_MODE5) /* dispc2_data8 */ 109 OMAP4_IOPAD(0x1c6, PIN_OUTPUT | MUX_MODE5) /* dispc2_data7 */ 110 OMAP4_IOPAD(0x1c8, PIN_OUTPUT | MUX_MODE5) /* dispc2_data6 */ 111 OMAP4_IOPAD(0x1ca, PIN_OUTPUT | MUX_MODE5) /* dispc2_data5 */ 112 OMAP4_IOPAD(0x1cc, PIN_OUTPUT | MUX_MODE5) /* dispc2_data4 */ 113 OMAP4_IOPAD(0x1ce, PIN_OUTPUT | MUX_MODE5) /* dispc2_data3 */ 114 OMAP4_IOPAD(0x1d0, PIN_OUTPUT | MUX_MODE5) /* dispc2_data2 */ 115 OMAP4_IOPAD(0x1d2, PIN_OUTPUT | MUX_MODE5) /* dispc2_data1 */ 116 OMAP4_IOPAD(0x1d4, PIN_OUTPUT | MUX_MODE5) /* dispc2_data0 */ 117 >; 118 }; 119 120 dss_hdmi_pins: pinmux_dss_hdmi_pins { 121 pinctrl-single,pins = < 122 OMAP4_IOPAD(0x09a, PIN_INPUT | MUX_MODE0) /* hdmi_cec.hdmi_cec */ 123 OMAP4_IOPAD(0x09c, PIN_INPUT_PULLUP | MUX_MODE0) /* hdmi_scl.hdmi_scl */ 124 OMAP4_IOPAD(0x09e, PIN_INPUT_PULLUP | MUX_MODE0) /* hdmi_sda.hdmi_sda */ 125 >; 126 }; 127 128 i2c4_pins: pinmux_i2c4_pins { 129 pinctrl-single,pins = < 130 OMAP4_IOPAD(0x12e, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c4_scl */ 131 OMAP4_IOPAD(0x130, PIN_INPUT_PULLUP | MUX_MODE0) /* i2c4_sda */ 132 >; 133 }; 134 135 mmc5_pins: pinmux_mmc5_pins { 136 pinctrl-single,pins = < 137 OMAP4_IOPAD(0x0f6, PIN_INPUT | MUX_MODE3) /* abe_mcbsp2_clkx.gpio_110 */ 138 OMAP4_IOPAD(0x148, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_clk.sdmmc5_clk */ 139 OMAP4_IOPAD(0x14a, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_cmd.sdmmc5_cmd */ 140 OMAP4_IOPAD(0x14c, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_dat0.sdmmc5_dat0 */ 141 OMAP4_IOPAD(0x14e, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_dat1.sdmmc5_dat1 */ 142 OMAP4_IOPAD(0x150, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_dat2.sdmmc5_dat2 */ 143 OMAP4_IOPAD(0x152, PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc5_dat3.sdmmc5_dat3 */ 144 >; 145 }; 146 147 gpio_led_pins: pinmux_gpio_led_pins { 148 pinctrl-single,pins = < 149 OMAP4_IOPAD(0x17e, PIN_OUTPUT | MUX_MODE3) /* kpd_col4.gpio_172 */ 150 OMAP4_IOPAD(0x180, PIN_OUTPUT | MUX_MODE3) /* kpd_col5.gpio_173 */ 151 >; 152 }; 153 154 gpio_key_pins: pinmux_gpio_key_pins { 155 pinctrl-single,pins = < 156 OMAP4_IOPAD(0x1a2, PIN_INPUT | MUX_MODE3) /* sys_boot0.gpio_184 */ 157 >; 158 }; 159 160 ks8851_irq_pins: pinmux_ks8851_irq_pins { 161 pinctrl-single,pins = < 162 OMAP4_IOPAD(0x17c, PIN_INPUT_PULLUP | MUX_MODE3) /* kpd_col3.gpio_171 */ 163 >; 164 }; 165 166 hdmi_hpd_pins: pinmux_hdmi_hpd_pins { 167 pinctrl-single,pins = < 168 OMAP4_IOPAD(0x098, PIN_INPUT_PULLDOWN | MUX_MODE3) /* hdmi_hpd.gpio_63 */ 169 >; 170 }; 171 172 backlight_pins: pinmux_backlight_pins { 173 pinctrl-single,pins = < 174 OMAP4_IOPAD(0x116, PIN_OUTPUT | MUX_MODE3) /* abe_dmic_din3.gpio_122 */ 175 >; 176 }; 177}; 178 179&i2c4 { 180 pinctrl-names = "default"; 181 pinctrl-0 = <&i2c4_pins>; 182 clock-frequency = <400000>; 183 status = "okay"; 184}; 185 186&uart1 { 187 pinctrl-names = "default"; 188 pinctrl-0 = <&uart1_pins>; 189 status = "okay"; 190}; 191 192&mcspi1 { 193 pinctrl-names = "default"; 194 pinctrl-0 = <&mcspi1_pins>; 195 status = "okay"; 196 197 eth@0 { 198 compatible = "ks8851"; 199 pinctrl-names = "default"; 200 pinctrl-0 = <&ks8851_irq_pins>; 201 spi-max-frequency = <24000000>; 202 reg = <0>; 203 interrupt-parent = <&gpio6>; 204 interrupts = <11 IRQ_TYPE_LEVEL_LOW>; /* gpio 171 */ 205 }; 206}; 207 208&mmc5 { 209 pinctrl-names = "default"; 210 pinctrl-0 = <&mmc5_pins>; 211 vmmc-supply = <&vbat>; 212 bus-width = <4>; 213 cd-gpios = <&gpio4 14 GPIO_ACTIVE_HIGH>; /* gpio 110 */ 214 status = "okay"; 215}; 216 217&dss { 218 status = "okay"; 219}; 220 221&hdmi { 222 status = "okay"; 223 pinctrl-names = "default"; 224 pinctrl-0 = <&dss_hdmi_pins>; 225 vdda-supply = <&vdac>; 226 227 port { 228 hdmi_out: endpoint { 229 remote-endpoint = <&hdmi_connector_in>; 230 }; 231 }; 232}; 233