| // SPDX-License-Identifier: GPL-2.0 |
| /* |
| * Device Tree for the ST Microelectronics Nomadik NHK8815 board |
| */ |
| |
| /dts-v1/; |
| #include <dt-bindings/interrupt-controller/irq.h> |
| #include <dt-bindings/gpio/gpio.h> |
| #include "ste-nomadik-stn8815.dtsi" |
| |
| / { |
| model = "Nomadik STN8815NHK"; |
| compatible = "st,nomadik-nhk-15"; |
| |
| chosen { |
| bootargs = "root=/dev/ram0 console=ttyAMA1,115200n8 earlyprintk"; |
| }; |
| |
| aliases { |
| serial0 = &uart0; |
| serial1 = &uart1; |
| stmpe-i2c0 = &stmpe0; |
| stmpe-i2c1 = &stmpe1; |
| }; |
| |
| pinctrl { |
| uart0 { |
| uart0_nhk_mode: uart0_mux { |
| u0_default_mux { |
| function = "u0"; |
| groups = "u0txrx_a_1", "u0ctsrts_a_1"; |
| }; |
| }; |
| }; |
| |
| stmpe2401_1 { |
| stmpe2401_1_nhk_mode: stmpe2401_1_nhk { |
| nhk_cfg1 { |
| pins = "GPIO76_B20"; // IRQ line |
| ste,input = <0>; |
| }; |
| nhk_cfg2 { |
| pins = "GPIO77_B8"; // reset line |
| ste,output = <1>; |
| }; |
| }; |
| }; |
| stmpe2401_2 { |
| stmpe2401_2_nhk_mode: stmpe2401_2_nhk { |
| nhk_cfg1 { |
| pins = "GPIO78_A8"; // IRQ line |
| ste,input = <0>; |
| }; |
| nhk_cfg2 { |
| pins = "GPIO79_C9"; // reset line |
| ste,output = <1>; |
| }; |
| }; |
| }; |
| lis3lv02dl { |
| lis3lv02dl_nhk_mode: lis3lv02dl_nhk { |
| nhk_cfg1 { |
| pins = "GPIO82_C10"; // IRQ line |
| ste,input = <0>; |
| }; |
| }; |
| }; |
| }; |
| src@101e0000 { |
| /* These chrystal outputs are not used on this board */ |
| disable-sxtalo; |
| disable-mxtalo; |
| }; |
| |
| /* This is where the interrupt is routed on the NHK-15 debug board */ |
| external-bus@34000000 { |
| compatible = "simple-bus"; |
| reg = <0x34000000 0x1000000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges = <0 0x34000000 0x1000000>; |
| ethernet@300 { |
| compatible = "smsc,lan91c111"; |
| reg = <0x300 0x0fd00>; |
| reg-io-width = <2>; |
| reset-gpios = <&stmpe_gpio44 10 GPIO_ACTIVE_HIGH>; |
| interrupt-parent = <&stmpe_gpio44>; |
| interrupts = <11 IRQ_TYPE_EDGE_RISING>; |
| }; |
| }; |
| |
| i2c0 { |
| lis3lv02dl@1d { |
| /* Accelerometer */ |
| compatible = "st,lis3lv02dl-accel"; |
| interrupt-parent = <&gpio2>; |
| interrupts = <18 IRQ_TYPE_EDGE_RISING>; // GPIO 82 |
| pinctrl-0 = <&lis3lv02dl_nhk_mode>; |
| pinctrl-names = "default"; |
| reg = <0x1d>; |
| }; |
| stmpe0: stmpe2401@43 { |
| compatible = "st,stmpe2401"; |
| reg = <0x43>; |
| reset-gpios = <&gpio2 13 GPIO_ACTIVE_LOW>; // GPIO77 |
| interrupts = <12 IRQ_TYPE_EDGE_FALLING>; // GPIO76 |
| interrupt-parent = <&gpio2>; |
| interrupt-controller; |
| wakeup-source; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&stmpe2401_1_nhk_mode>; |
| stmpe_gpio43: stmpe_gpio { |
| compatible = "st,stmpe-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| /* Some pins in alternate functions */ |
| st,norequest-mask = <0xf0f002>; |
| }; |
| stmpe_keypad { |
| compatible = "st,stmpe-keypad"; |
| debounce-interval = <64>; |
| st,scan-count = <8>; |
| st,no-autorepeat; |
| keypad,num-rows = <8>; |
| keypad,num-columns = <8>; |
| linux,keymap = <0x00020072 // Vol down |
| 0x00030073 // Vol up |
| 0x0100009e // Back |
| 0x010100e3 // TV out |
| 0x01020098 // Lock |
| 0x0103013b // Start |
| 0x020000a3 // Next |
| 0x020100a4 // Play |
| 0x020200a5 // Prev |
| 0x02030160 // OK |
| 0x03000069 // Left |
| 0x0301006a // Right |
| 0x03020067 // Up |
| 0x0303006c>; // Down |
| }; |
| stmpe0_pwm: stmpe_pwm { |
| compatible = "st,stmpe-pwm"; |
| #pwm-cells = <2>; |
| }; |
| }; |
| stmpe1: stmpe2401@44 { |
| compatible = "st,stmpe2401"; |
| reg = <0x44>; |
| reset-gpios = <&gpio2 15 GPIO_ACTIVE_LOW>; // GPIO79 |
| interrupts = <14 IRQ_TYPE_EDGE_FALLING>; // GPIO78 |
| interrupt-parent = <&gpio2>; |
| interrupt-controller; |
| wakeup-source; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&stmpe2401_2_nhk_mode>; |
| stmpe_gpio44: stmpe_gpio { |
| compatible = "st,stmpe-gpio"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| /* |
| * This will turn off SATA so that MMC/SD |
| * can thrive |
| */ |
| mmcsd-gpio { |
| gpio-hog; |
| gpios = <2 0x0>; |
| output-low; |
| line-name = "SATA EN"; |
| }; |
| }; |
| }; |
| }; |
| |
| amba { |
| clcd@10120000 { |
| status = "okay"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&clcd_24bit_mux>; |
| port { |
| nomadik_clcd: endpoint { |
| remote-endpoint = <&nomadik_clcd_panel>; |
| arm,pl11x,tft-r0g0b0-pads = <16 8 0>; |
| }; |
| }; |
| |
| }; |
| |
| /* Activate RX/TX and CTS/RTS on UART 0 */ |
| uart0: uart@101fd000 { |
| pinctrl-names = "default"; |
| pinctrl-0 = <&uart0_nhk_mode>; |
| status = "okay"; |
| }; |
| mmcsd: sdi@101f6000 { |
| cd-gpios = <&stmpe_gpio44 7 GPIO_ACTIVE_LOW>; |
| wp-gpios = <&stmpe_gpio44 18 GPIO_ACTIVE_HIGH>; |
| }; |
| }; |
| |
| spi { |
| compatible = "spi-gpio"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| /* |
| * As we're dealing with 3wire SPI, we only define SCK |
| * and MOSI (in the spec MOSI is called "SDA"). |
| */ |
| gpio-sck = <&gpio0 5 GPIO_ACTIVE_HIGH>; |
| gpio-mosi = <&gpio0 4 GPIO_ACTIVE_HIGH>; |
| /* |
| * It's not actually active high, but the frameworks assume |
| * the polarity of the passed-in GPIO is "normal" (active |
| * high) then actively drives the line low to select the |
| * chip. |
| */ |
| cs-gpios = <&gpio0 6 GPIO_ACTIVE_HIGH>; |
| num-chipselects = <1>; |
| |
| /* |
| * WVGA connector 21 |
| * WVGA (800x480): 4.3" TPG110 TDO43MTEA2 24-bit RGB |
| * with TPO touch screen. |
| */ |
| panel: display@0 { |
| /* |
| * The TPO display driver is connected to a |
| * 5.7" OSD OSD057VA01CT TFT display. |
| */ |
| compatible = "tpo,tpg110"; |
| reg = <0>; |
| spi-3wire; |
| /* 320 ns min period ~= 3 MHz */ |
| spi-max-frequency = <3000000>; |
| /* Width and height from the OSD data sheet */ |
| width-mm = <116>; |
| height-mm = <87>; |
| grestb-gpios = <&stmpe_gpio44 5 GPIO_ACTIVE_LOW>; |
| backlight = <&bl>; |
| |
| port { |
| nomadik_clcd_panel: endpoint { |
| remote-endpoint = <&nomadik_clcd>; |
| }; |
| }; |
| }; |
| }; |
| |
| bl: backlight { |
| compatible = "pwm-backlight"; |
| pwms = <&stmpe0_pwm 0 500000>; |
| pwm-names = "backlight"; |
| brightness-levels = < |
| 0 1 2 3 4 5 6 7 8 9 |
| 10 11 12 13 14 15 16 17 18 19 |
| 20 21 22 23 24 25 26 27 28 29 |
| 30 31 32 33 34 35 36 37 38 39 |
| 40 41 42 43 44 45 46 47 48 49 |
| 50 51 52 53 54 55 56 57 58 59 |
| 60 61 62 63 64 65 66 67 68 69 |
| 70 71 72 73 74 75 76 77 78 79 |
| 80 81 82 83 84 85 86 87 88 89 |
| 90 91 92 93 94 95 96 97 98 99 |
| 100 |
| >; |
| default-brightness-level = <100>; |
| }; |
| }; |