162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0+ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2019-20 Sean Anderson <seanga2@gmail.com> 462306a36Sopenharmony_ci * Copyright (C) 2020 Western Digital Corporation or its affiliates. 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci/dts-v1/; 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include "k210.dtsi" 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h> 1262306a36Sopenharmony_ci#include <dt-bindings/input/input.h> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci/ { 1562306a36Sopenharmony_ci model = "Kendryte KD233"; 1662306a36Sopenharmony_ci compatible = "canaan,kendryte-kd233", "canaan,kendryte-k210"; 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci chosen { 1962306a36Sopenharmony_ci bootargs = "earlycon console=ttySIF0"; 2062306a36Sopenharmony_ci stdout-path = "serial0:115200n8"; 2162306a36Sopenharmony_ci }; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci gpio-leds { 2462306a36Sopenharmony_ci compatible = "gpio-leds"; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci led0 { 2762306a36Sopenharmony_ci gpios = <&gpio0 8 GPIO_ACTIVE_LOW>; 2862306a36Sopenharmony_ci }; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci led1 { 3162306a36Sopenharmony_ci gpios = <&gpio0 9 GPIO_ACTIVE_LOW>; 3262306a36Sopenharmony_ci }; 3362306a36Sopenharmony_ci }; 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci gpio-keys { 3662306a36Sopenharmony_ci compatible = "gpio-keys"; 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci key { 3962306a36Sopenharmony_ci label = "KEY0"; 4062306a36Sopenharmony_ci linux,code = <BTN_0>; 4162306a36Sopenharmony_ci gpios = <&gpio0 10 GPIO_ACTIVE_LOW>; 4262306a36Sopenharmony_ci }; 4362306a36Sopenharmony_ci }; 4462306a36Sopenharmony_ci}; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci&fpioa { 4762306a36Sopenharmony_ci pinctrl-0 = <&jtag_pinctrl>; 4862306a36Sopenharmony_ci pinctrl-names = "default"; 4962306a36Sopenharmony_ci status = "okay"; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci jtag_pinctrl: jtag-pinmux { 5262306a36Sopenharmony_ci pinmux = <K210_FPIOA(0, K210_PCF_JTAG_TCLK)>, 5362306a36Sopenharmony_ci <K210_FPIOA(1, K210_PCF_JTAG_TDI)>, 5462306a36Sopenharmony_ci <K210_FPIOA(2, K210_PCF_JTAG_TMS)>, 5562306a36Sopenharmony_ci <K210_FPIOA(3, K210_PCF_JTAG_TDO)>; 5662306a36Sopenharmony_ci }; 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci uarths_pinctrl: uarths-pinmux { 5962306a36Sopenharmony_ci pinmux = <K210_FPIOA(4, K210_PCF_UARTHS_RX)>, 6062306a36Sopenharmony_ci <K210_FPIOA(5, K210_PCF_UARTHS_TX)>; 6162306a36Sopenharmony_ci }; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci spi0_pinctrl: spi0-pinmux { 6462306a36Sopenharmony_ci pinmux = <K210_FPIOA(6, K210_PCF_GPIOHS20)>, /* cs */ 6562306a36Sopenharmony_ci <K210_FPIOA(7, K210_PCF_SPI0_SCLK)>, /* wr */ 6662306a36Sopenharmony_ci <K210_FPIOA(8, K210_PCF_GPIOHS21)>; /* dc */ 6762306a36Sopenharmony_ci }; 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci dvp_pinctrl: dvp-pinmux { 7062306a36Sopenharmony_ci pinmux = <K210_FPIOA(9, K210_PCF_SCCB_SCLK)>, 7162306a36Sopenharmony_ci <K210_FPIOA(10, K210_PCF_SCCB_SDA)>, 7262306a36Sopenharmony_ci <K210_FPIOA(11, K210_PCF_DVP_RST)>, 7362306a36Sopenharmony_ci <K210_FPIOA(12, K210_PCF_DVP_VSYNC)>, 7462306a36Sopenharmony_ci <K210_FPIOA(13, K210_PCF_DVP_PWDN)>, 7562306a36Sopenharmony_ci <K210_FPIOA(14, K210_PCF_DVP_XCLK)>, 7662306a36Sopenharmony_ci <K210_FPIOA(15, K210_PCF_DVP_PCLK)>, 7762306a36Sopenharmony_ci <K210_FPIOA(17, K210_PCF_DVP_HSYNC)>; 7862306a36Sopenharmony_ci }; 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci gpiohs_pinctrl: gpiohs-pinmux { 8162306a36Sopenharmony_ci pinmux = <K210_FPIOA(16, K210_PCF_GPIOHS0)>, 8262306a36Sopenharmony_ci <K210_FPIOA(20, K210_PCF_GPIOHS4)>, /* Rot. dip sw line 8 */ 8362306a36Sopenharmony_ci <K210_FPIOA(21, K210_PCF_GPIOHS5)>, /* Rot. dip sw line 4 */ 8462306a36Sopenharmony_ci <K210_FPIOA(22, K210_PCF_GPIOHS6)>, /* Rot. dip sw line 2 */ 8562306a36Sopenharmony_ci <K210_FPIOA(23, K210_PCF_GPIOHS7)>, /* Rot. dip sw line 1 */ 8662306a36Sopenharmony_ci <K210_FPIOA(24, K210_PCF_GPIOHS8)>, 8762306a36Sopenharmony_ci <K210_FPIOA(25, K210_PCF_GPIOHS9)>, 8862306a36Sopenharmony_ci <K210_FPIOA(26, K210_PCF_GPIOHS10)>; 8962306a36Sopenharmony_ci }; 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci spi1_pinctrl: spi1-pinmux { 9262306a36Sopenharmony_ci pinmux = <K210_FPIOA(29, K210_PCF_SPI1_SCLK)>, 9362306a36Sopenharmony_ci <K210_FPIOA(30, K210_PCF_SPI1_D0)>, 9462306a36Sopenharmony_ci <K210_FPIOA(31, K210_PCF_SPI1_D1)>, 9562306a36Sopenharmony_ci <K210_FPIOA(32, K210_PCF_GPIOHS16)>; /* cs */ 9662306a36Sopenharmony_ci }; 9762306a36Sopenharmony_ci 9862306a36Sopenharmony_ci i2s0_pinctrl: i2s0-pinmux { 9962306a36Sopenharmony_ci pinmux = <K210_FPIOA(33, K210_PCF_I2S0_IN_D0)>, 10062306a36Sopenharmony_ci <K210_FPIOA(34, K210_PCF_I2S0_WS)>, 10162306a36Sopenharmony_ci <K210_FPIOA(35, K210_PCF_I2S0_SCLK)>; 10262306a36Sopenharmony_ci }; 10362306a36Sopenharmony_ci}; 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci&uarths0 { 10662306a36Sopenharmony_ci pinctrl-0 = <&uarths_pinctrl>; 10762306a36Sopenharmony_ci pinctrl-names = "default"; 10862306a36Sopenharmony_ci status = "okay"; 10962306a36Sopenharmony_ci}; 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci&gpio0 { 11262306a36Sopenharmony_ci pinctrl-0 = <&gpiohs_pinctrl>; 11362306a36Sopenharmony_ci pinctrl-names = "default"; 11462306a36Sopenharmony_ci status = "okay"; 11562306a36Sopenharmony_ci}; 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_ci&i2s0 { 11862306a36Sopenharmony_ci #sound-dai-cells = <1>; 11962306a36Sopenharmony_ci pinctrl-0 = <&i2s0_pinctrl>; 12062306a36Sopenharmony_ci pinctrl-names = "default"; 12162306a36Sopenharmony_ci}; 12262306a36Sopenharmony_ci 12362306a36Sopenharmony_ci&spi0 { 12462306a36Sopenharmony_ci pinctrl-0 = <&spi0_pinctrl>; 12562306a36Sopenharmony_ci pinctrl-names = "default"; 12662306a36Sopenharmony_ci num-cs = <1>; 12762306a36Sopenharmony_ci cs-gpios = <&gpio0 20 GPIO_ACTIVE_HIGH>; 12862306a36Sopenharmony_ci 12962306a36Sopenharmony_ci panel@0 { 13062306a36Sopenharmony_ci compatible = "canaan,kd233-tft", "ilitek,ili9341"; 13162306a36Sopenharmony_ci reg = <0>; 13262306a36Sopenharmony_ci dc-gpios = <&gpio0 21 GPIO_ACTIVE_HIGH>; 13362306a36Sopenharmony_ci spi-max-frequency = <10000000>; 13462306a36Sopenharmony_ci status = "disabled"; 13562306a36Sopenharmony_ci }; 13662306a36Sopenharmony_ci}; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci&spi1 { 13962306a36Sopenharmony_ci pinctrl-0 = <&spi1_pinctrl>; 14062306a36Sopenharmony_ci pinctrl-names = "default"; 14162306a36Sopenharmony_ci num-cs = <1>; 14262306a36Sopenharmony_ci cs-gpios = <&gpio0 16 GPIO_ACTIVE_LOW>; 14362306a36Sopenharmony_ci status = "okay"; 14462306a36Sopenharmony_ci 14562306a36Sopenharmony_ci mmc@0 { 14662306a36Sopenharmony_ci compatible = "mmc-spi-slot"; 14762306a36Sopenharmony_ci reg = <0>; 14862306a36Sopenharmony_ci voltage-ranges = <3300 3300>; 14962306a36Sopenharmony_ci spi-max-frequency = <25000000>; 15062306a36Sopenharmony_ci broken-cd; 15162306a36Sopenharmony_ci }; 15262306a36Sopenharmony_ci}; 153