|  | // 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>; | 
|  | }; |