// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) /* * MYIR Tech MYD-LPC4357 Development Board with 800x480 7" TFT panel * * Copyright (C) 2016-2018 Vladimir Zapolskiy <vz@mleia.com> */ /dts-v1/; #include "lpc18xx.dtsi" #include "lpc4357.dtsi" #include <dt-bindings/gpio/gpio.h> / { model = "MYIR Tech LPC4357 Development Board"; compatible = "myir,myd-lpc4357", "nxp,lpc4357"; chosen { stdout-path = "serial3:115200n8"; }; memory@28000000 { device_type = "memory"; reg = <0x28000000 0x2000000>; }; leds { compatible = "gpio-leds"; pinctrl-names = "default"; pinctrl-0 = <&led_pins>; led1 { gpios = <&gpio LPC_GPIO(6,15) GPIO_ACTIVE_LOW>; default-state = "off"; }; led2 { gpios = <&gpio LPC_GPIO(6,16) GPIO_ACTIVE_LOW>; default-state = "off"; }; led3 { gpios = <&gpio LPC_GPIO(6,17) GPIO_ACTIVE_LOW>; default-state = "off"; }; led4 { gpios = <&gpio LPC_GPIO(6,10) GPIO_ACTIVE_LOW>; default-state = "off"; }; led5 { gpios = <&gpio LPC_GPIO(7,14) GPIO_ACTIVE_LOW>; default-state = "off"; }; led6 { gpios = <&gpio LPC_GPIO(6,14) GPIO_ACTIVE_LOW>; default-state = "off"; }; }; panel: panel { compatible = "innolux,at070tn92"; port { panel_input: endpoint { remote-endpoint = <&lcdc_output>; }; }; }; vcc: vcc_fixed { compatible = "regulator-fixed"; regulator-name = "vcc-supply"; regulator-min-microvolt = <3300000>; regulator-max-microvolt = <3300000>; }; vmmc: vmmc_fixed { compatible = "regulator-fixed"; regulator-name = "vmmc-supply"; regulator-min-microvolt = <3300000>; regulator-max-microvolt = <3300000>; }; }; &pinctrl { can0_pins: can0-pins { can_rd_cfg { pins = "p3_1"; function = "can0"; input-enable; }; can_td_cfg { pins = "p3_2"; function = "can0"; }; }; can1_pins: can1-pins { can_rd_cfg { pins = "pe_1"; function = "can1"; input-enable; }; can_td_cfg { pins = "pe_0"; function = "can1"; }; }; emc_pins: emc-pins { emc_addr0_22_cfg { pins = "p2_9", "p2_10", "p2_11", "p2_12", "p2_13", "p1_0", "p1_1", "p1_2", "p2_8", "p2_7", "p2_6", "p2_2", "p2_1", "p2_0", "p6_8", "p6_7", "pd_16", "pd_15", "pe_0", "pe_1", "pe_2", "pe_3", "pe_4"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_data0_15_cfg { pins = "p1_7", "p1_8", "p1_9", "p1_10", "p1_11", "p1_12", "p1_13", "p1_14", "p5_4", "p5_5", "p5_6", "p5_7", "p5_0", "p5_1", "p5_2", "p5_3"; function = "emc"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; emc_we_oe_cfg { pins = "p1_6", "p1_3"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_cs0_cfg { pins = "p1_5"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_sdram_dqm0_1_cfg { pins = "p6_12", "p6_10"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_sdram_ras_cas_cfg { pins = "p6_5", "p6_4"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_sdram_dycs0_cfg { pins = "p6_9"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_sdram_cke_cfg { pins = "p6_11"; function = "emc"; slew-rate = <1>; bias-disable; }; emc_sdram_clock_cfg { pins = "clk0"; function = "emc"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; }; enet_rmii_pins: enet-rmii-pins { enet_rmii_rxd_cfg { pins = "p1_15", "p0_0"; function = "enet"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; enet_rmii_txd_cfg { pins = "p1_18", "p1_20"; function = "enet"; slew-rate = <1>; bias-disable; }; enet_rmii_rx_dv_cfg { pins = "p1_16"; function = "enet"; input-enable; input-schmitt-disable; bias-disable; }; enet_mdio_cfg { pins = "p1_17"; function = "enet"; input-enable; input-schmitt-disable; bias-disable; }; enet_mdc_cfg { pins = "pc_1"; function = "enet"; slew-rate = <1>; bias-disable; }; enet_rmii_tx_en_cfg { pins = "p0_1"; function = "enet"; bias-disable; }; enet_ref_clk_cfg { pins = "p1_19"; function = "enet"; slew-rate = <1>; input-enable; input-schmitt-disable; bias-disable; }; }; i2c0_pins: i2c0-pins { i2c0_pins_cfg { pins = "i2c0_scl", "i2c0_sda"; function = "i2c0"; input-enable; }; }; i2c1_pins: i2c1-pins { i2c1_pins_cfg { pins = "pe_15", "pe_13"; function = "i2c1"; input-enable; }; }; lcd_pins: lcd-pins { lcd_vd0_23_cfg { pins = "p4_1", "p4_4", "p4_3", "p4_2", "p8_7", "p8_6", "p8_5", "p8_4", "p7_5", "p4_8", "p4_10", "p4_9", "p8_3", "pb_6", "pb_5", "pb_4", "p7_4", "p7_3", "p7_2", "p7_1", "pb_3", "pb_2", "pb_1", "pb_0"; function = "lcd"; }; lcd_vsync_en_dclk_lp_pwr_cfg { pins = "p4_5", "p4_6", "p4_7", "p7_6", "p7_7"; function = "lcd"; }; }; led_pins: led-pins { led_1_6_cfg { pins = "pd_1", "pd_2", "pd_3", "pc_11", "pe_14", "pd_0"; function = "gpio"; bias-pull-down; }; }; sdmmc_pins: sdmmc-pins { sdmmc_clk_cfg { pins = "pc_0"; function = "sdmmc"; slew-rate = <1>; bias-pull-down; }; sdmmc_cmd_dat0_3_cfg { pins = "pc_4", "pc_5", "pc_6", "pc_7", "pc_10"; function = "sdmmc"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; sdmmc_cd_cfg { pins = "pc_8"; function = "sdmmc"; input-enable; bias-pull-down; }; }; spifi_pins: spifi-pins { spifi_sck_cfg { pins = "p3_3"; function = "spifi"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; spifi_mosi_miso_sio2_sio3_cfg { pins = "p3_7", "p3_6", "p3_5", "p3_4"; function = "spifi"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-disable; }; spifi_cs_cfg { pins = "p3_8"; function = "spifi"; bias-disable; }; }; ssp1_pins: ssp1-pins { ssp1_sck_cfg { pins = "pf_4"; function = "ssp1"; slew-rate = <1>; bias-pull-down; }; ssp1_miso_cfg { pins = "pf_6"; function = "ssp1"; input-enable; input-schmitt-disable; slew-rate = <1>; bias-pull-down; }; ssp1_mosi_cfg { pins = "pf_7"; function = "ssp1"; slew-rate = <1>; bias-pull-down; }; ssp1_ssel_cfg { pins = "pf_5"; function = "gpio"; bias-disable; }; }; uart0_pins: uart0-pins { uart0_rxd_cfg { pins = "pf_11"; function = "uart0"; input-enable; input-schmitt-disable; bias-disable; }; uart0_clk_dir_txd_cfg { pins = "pf_8", "pf_9", "pf_10"; function = "uart0"; bias-pull-down; }; }; uart1_pins: uart1-pins { uart1_rxd_cfg { pins = "pc_14"; function = "uart1"; bias-disable; input-enable; input-schmitt-disable; }; uart1_dtr_txd_cfg { pins = "pc_12", "pc_13"; function = "uart1"; bias-pull-down; }; }; uart2_pins: uart2-pins { uart2_rxd_cfg { pins = "pa_2"; function = "uart2"; bias-disable; input-enable; input-schmitt-disable; }; uart2_txd_cfg { pins = "pa_1"; function = "uart2"; bias-pull-down; }; }; uart3_pins: uart3-pins { uart3_rx_cfg { pins = "p2_4"; function = "uart3"; bias-disable; input-enable; input-schmitt-disable; }; uart3_tx_cfg { pins = "p2_3"; function = "uart3"; bias-pull-down; }; }; usb0_pins: usb0-pins { usb0_pwr_enable_cfg { pins = "p6_3"; function = "usb0"; }; usb0_pwr_fault_cfg { pins = "p8_0"; function = "usb0"; bias-disable; input-enable; }; }; }; &adc1 { status = "okay"; vref-supply = <&vcc>; }; &can0 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&can0_pins>; }; /* Pin conflict with EMC, muxed by JP5 and JP6 */ &can1 { status = "disabled"; pinctrl-names = "default"; pinctrl-0 = <&can1_pins>; }; &emc { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&emc_pins>; cs0 { #address-cells = <2>; #size-cells = <1>; ranges; mpmc,cs = <0>; mpmc,memory-width = <16>; mpmc,byte-lane-low; mpmc,write-enable-delay = <0>; mpmc,output-enable-delay = <0>; mpmc,read-access-delay = <70>; mpmc,page-mode-read-delay = <70>; /* SST/Microchip SST39VF1601 */ flash@0,0 { compatible = "cfi-flash"; reg = <0 0 0x400000>; bank-width = <2>; }; }; }; &enet_tx_clk { clock-frequency = <50000000>; }; &i2c0 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&i2c0_pins>; clock-frequency = <400000>; }; &i2c1 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&i2c1_pins>; clock-frequency = <400000>; sensor@49 { compatible = "lm75"; reg = <0x49>; }; eeprom@50 { compatible = "atmel,24c512"; reg = <0x50>; }; }; &lcdc { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&lcd_pins>; max-memory-bandwidth = <92240000>; port { lcdc_output: endpoint { remote-endpoint = <&panel_input>; arm,pl11x,tft-r0g0b0-pads = <0 8 16>; }; }; }; &mac { status = "okay"; phy-mode = "rmii"; pinctrl-names = "default"; pinctrl-0 = <&enet_rmii_pins>; phy-handle = <&phy1>; mdio0 { #address-cells = <1>; #size-cells = <0>; compatible = "snps,dwmac-mdio"; phy1: ethernet-phy@1 { reg = <1>; }; }; }; &mmcsd { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&sdmmc_pins>; bus-width = <4>; vmmc-supply = <&vmmc>; }; /* Pin conflict with SSP0, the latter is routed to J17 pin header */ &spifi { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&spifi_pins>; /* Atmel AT25DF321A */ flash { compatible = "jedec,spi-nor"; spi-max-frequency = <51000000>; spi-cpol; spi-cpha; }; }; &ssp1 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&ssp1_pins>; num-cs = <1>; cs-gpios = <&gpio LPC_GPIO(7,19) GPIO_ACTIVE_LOW>; }; /* Routed to J17 pin header */ &uart0 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&uart0_pins>; }; /* RS485 */ &uart1 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&uart1_pins>; }; /* Routed to J17 pin header */ &uart2 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&uart2_pins>; }; &uart3 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&uart3_pins>; }; &usb0 { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&usb0_pins>; };