/* * Copyright (c) 2018, NXP * * SPDX-License-Identifier: Apache-2.0 */ /dts-v1/; #include #include "mimxrt1064_evk-pinctrl.dtsi" #include / { model = "NXP MIMXRT1064-EVK board"; compatible = "nxp,mimxrt1064"; aliases { led0 = &green_led; pwm-led0 = &green_pwm_led; sw0 = &user_button; watchdog0 = &wdog0; sdhc0 = &usdhc1; mcuboot-button0 = &user_button; }; chosen { zephyr,flash-controller = &is25wp064; zephyr,flash = &w25q32jvwj0; zephyr,code-partition = &slot0_partition; zephyr,uart-mcumgr = &lpuart1; zephyr,sram = &sdram0; zephyr,itcm = &itcm; zephyr,dtcm = &dtcm; zephyr,console = &lpuart1; zephyr,shell-uart = &lpuart1; zephyr,canbus = &flexcan2; zephyr,touch = &ft5336; }; sdram0: memory@80000000 { /* Micron MT48LC16M16A2B4-6AIT:G */ device_type = "memory"; reg = <0x80000000 DT_SIZE_M(32)>; }; /* * This node describes the GPIO pins of the parallel FPC interface, * This interface is standard to several NXP EVKs, and is used with * several parallel LCD displays (available as zephyr shields) */ nxp_parallel_lcd_connector: parallel-connector { compatible = "nxp,parallel-lcd-connector"; #gpio-cells = <2>; gpio-map-mask = <0xffffffff 0xffffffc0>; gpio-map-pass-thru = <0 0x3f>; gpio-map = <0 0 &gpio2 31 0>; /* Pin 1, BL+ */ }; /* * This node describes the GPIO pins of the I2C display FPC interface, * This interface is standard to several NXP EVKs, and is used with * several parallel LCD displays (available as zephyr shields) */ nxp_i2c_touch_fpc: i2c-touch-connector { compatible = "nxp,i2c-tsc-fpc"; #gpio-cells = <2>; gpio-map-mask = <0xffffffff 0xffffffc0>; gpio-map-pass-thru = <0 0x3f>; gpio-map = <1 0 &gpio1 2 0>, /* Pin 2, LCD touch RST */ <2 0 &gpio1 11 0>; /* Pin 3, LCD touch INT */ }; leds { compatible = "gpio-leds"; green_led: led-1 { gpios = <&gpio1 9 GPIO_ACTIVE_LOW>; label = "User LD1"; }; }; pwmleds { compatible = "pwm-leds"; green_pwm_led: green_pwm_led { pwms = <&flexpwm2_pwm3 0 PWM_MSEC(20) PWM_POLARITY_NORMAL>; }; }; gpio_keys { compatible = "gpio-keys"; user_button: button-1 { label = "User SW8"; gpios = <&gpio5 0 (GPIO_PULL_UP | GPIO_ACTIVE_LOW)>; zephyr,code = ; }; }; lvgl_pointer { compatible = "zephyr,lvgl-pointer-input"; input = <&ft5336>; }; arduino_header: connector { compatible = "arduino-header-r3"; #gpio-cells = <2>; gpio-map-mask = <0xffffffff 0xffffffc0>; gpio-map-pass-thru = <0 0x3f>; gpio-map = <0 0 &gpio1 26 0>, /* A0 */ <1 0 &gpio1 27 0>, /* A1 */ <2 0 &gpio1 20 0>, /* A2 */ <3 0 &gpio1 21 0>, /* A3 */ <4 0 &gpio1 17 0>, /* A4 */ <5 0 &gpio1 16 0>, /* A5 */ <6 0 &gpio1 23 0>, /* D0 */ <7 0 &gpio1 22 0>, /* D1 */ <8 0 &gpio1 11 0>, /* D2 */ <9 0 &gpio1 24 0>, /* D3 */ <10 0 &gpio1 9 0>, /* D4 */ <11 0 &gpio1 10 0>, /* D5 */ <12 0 &gpio1 18 0>, /* D6 */ <13 0 &gpio1 19 0>, /* D7 */ <14 0 &gpio1 3 0>, /* D8 */ <15 0 &gpio1 2 0>, /* D9 */ <16 0 &gpio3 13 0>, /* D10 */ <17 0 &gpio3 14 0>, /* D11 */ <18 0 &gpio3 15 0>, /* D12 */ <19 0 &gpio3 12 0>, /* D13 */ <20 0 &gpio1 17 0>, /* D14 */ <21 0 &gpio1 16 0>; /* D15 */ }; }; nxp_touch_i2c: &lpi2c1 {}; zephyr_lcdif: &lcdif { pinctrl-0 = <&pinmux_lcdif>; pinctrl-names = "default"; }; nxp_parallel_i2c: &lpi2c1 {}; &lpi2c1 { status = "okay"; pinctrl-0 = <&pinmux_lpi2c1>; pinctrl-names = "default"; ft5336: ft5336@38 { compatible = "focaltech,ft5336"; reg = <0x38>; int-gpios = <&gpio1 11 GPIO_ACTIVE_LOW>; }; }; &flexspi { status = "okay"; pinctrl-0 = <&pinmux_flexspi1>; pinctrl-names = "default"; ahb-prefetch; ahb-read-addr-opt; rx-clock-source = <1>; reg = <0x402a8000 0x4000>, <0x60000000 DT_SIZE_M(8)>; is25wp064: is25wp064@0 { compatible = "nxp,imx-flexspi-nor"; size = <67108864>; reg = <0>; spi-max-frequency = <104000000>; status = "okay"; jedec-id = [9d 70 17]; partitions { compatible = "fixed-partitions"; #address-cells = <1>; #size-cells = <1>; storage_partition: partition@0 { label = "storage"; reg = <0x00000000 DT_SIZE_M(8)>; }; }; }; }; &w25q32jvwj0 { partitions { compatible = "fixed-partitions"; #address-cells = <1>; #size-cells = <1>; boot_partition: partition@0 { label = "mcuboot"; reg = <0x00000000 DT_SIZE_K(128)>; }; /* The MCUBoot swap-move algorithm uses the last 2 sectors * of the primary slot0 for swap status and move. */ slot0_partition: partition@20000 { label = "image-0"; reg = <0x00020000 (DT_SIZE_K(1980) + DT_SIZE_K(8))>; }; slot1_partition: partition@211000 { label = "image-1"; reg = <0x00211000 DT_SIZE_K(1980)>; }; /* The storage partition is located in is25wp064 */ }; }; &lpuart1 { status = "okay"; pinctrl-0 = <&pinmux_lpuart1>; pinctrl-1 = <&pinmux_lpuart1_sleep>; pinctrl-names = "default", "sleep"; current-speed = <115200>; }; arduino_serial: &lpuart3 { current-speed = <115200>; pinctrl-0 = <&pinmux_lpuart3>; pinctrl-1 = <&pinmux_lpuart3_sleep>; pinctrl-names = "default", "sleep"; }; &enet_mac { status = "okay"; pinctrl-0 = <&pinmux_enet>; pinctrl-names = "default"; phy-handle = <&phy>; zephyr,random-mac-address; phy-connection-type = "rmii"; }; &enet_mdio { status = "okay"; pinctrl-0 = <&pinmux_enet_mdio>; pinctrl-names = "default"; phy: phy@0 { compatible = "microchip,ksz8081"; reg = <0>; status = "okay"; reset-gpios = <&gpio1 9 GPIO_ACTIVE_HIGH>; int-gpios = <&gpio1 10 GPIO_ACTIVE_HIGH>; microchip,interface-type = "rmii"; }; }; &enet_ptp_clock { status = "okay"; pinctrl-0 = <&pinmux_ptp>; pinctrl-names = "default"; }; zephyr_udc0: &usb1 { status = "okay"; }; &csi { pinctrl-0 = <&pinmux_csi>; pinctrl-names = "default"; }; &flexpwm2_pwm3 { status = "okay"; pinctrl-0 = <&pinmux_flexpwm2>; pinctrl-names = "default"; }; &usdhc1 { status = "okay"; pwr-gpios = <&gpio1 19 GPIO_ACTIVE_HIGH>; cd-gpios = <&gpio2 28 GPIO_ACTIVE_LOW>; pinctrl-0 = <&pinmux_usdhc1>; pinctrl-1 = <&pinmux_usdhc1_slow>; pinctrl-2 = <&pinmux_usdhc1_med>; pinctrl-3 = <&pinmux_usdhc1_fast>; pinctrl-names = "default", "slow", "med", "fast"; sdmmc { compatible = "zephyr,sdmmc-disk"; disk-name = "SD"; status = "okay"; }; }; &edma0 { status = "okay"; }; &flexcan2 { status = "okay"; pinctrl-0 = <&pinmux_flexcan2>; pinctrl-names = "default"; can-transceiver { max-bitrate = <5000000>; }; }; &wdog0 { status = "okay"; }; &lpspi1 { status = "okay"; /* DMA channels 0 and 1, muxed to LPSPI1 RX and TX */ dmas = <&edma0 0 13>, <&edma0 1 14>; dma-names = "rx", "tx"; pinctrl-0 = <&pinmux_lpspi1>; pinctrl-names = "default"; }; &lpspi3 { status = "okay"; /* DMA channels 2 and 3, muxed to LPSPI3 RX and TX */ dmas = <&edma0 2 15>, <&edma0 3 16>; dma-names = "rx", "tx"; pinctrl-0 = <&pinmux_lpspi3>; pinctrl-names = "default"; }; &adc1 { status = "okay"; pinctrl-0 = <&pinmux_adc1>; pinctrl-names = "default"; }; /* GPT and Systick are enabled. If power management is enabled, the GPT * timer will be used instead of systick, as allows the core clock to * be gated. */ &gpt_hw_timer { status = "okay"; }; &systick { status = "okay"; }; &itm { pinctrl-0 = <&pinmux_swo>; pinctrl-names = "default"; }; &pxp { status = "okay"; }; &pit0 { status = "okay"; }; dvp_fpc24_i2c: &lpi2c1 {}; dvp_fpc24_interface: &csi {};