162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/dts-v1/;
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#include "x1830.dtsi"
562306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h>
662306a36Sopenharmony_ci#include <dt-bindings/clock/ingenic,sysost.h>
762306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/irq.h>
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci/ {
1062306a36Sopenharmony_ci	compatible = "yna,cu1830-neo", "ingenic,x1830";
1162306a36Sopenharmony_ci	model = "YSH & ATIL General Board CU1830-Neo";
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci	aliases {
1462306a36Sopenharmony_ci		serial1 = &uart1;
1562306a36Sopenharmony_ci	};
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci	chosen {
1862306a36Sopenharmony_ci		stdout-path = "serial1:115200n8";
1962306a36Sopenharmony_ci	};
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci	memory {
2262306a36Sopenharmony_ci		device_type = "memory";
2362306a36Sopenharmony_ci		reg = <0x0 0x08000000>;
2462306a36Sopenharmony_ci	};
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	leds {
2762306a36Sopenharmony_ci		compatible = "gpio-leds";
2862306a36Sopenharmony_ci		led-0 {
2962306a36Sopenharmony_ci			gpios = <&gpc 17 GPIO_ACTIVE_HIGH>;
3062306a36Sopenharmony_ci			linux,default-trigger = "mmc0";
3162306a36Sopenharmony_ci		};
3262306a36Sopenharmony_ci	};
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci	wlan_pwrseq: msc1-pwrseq {
3562306a36Sopenharmony_ci		compatible = "mmc-pwrseq-simple";
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci		reset-gpios = <&gpc 13 GPIO_ACTIVE_LOW>;
3862306a36Sopenharmony_ci		post-power-on-delay-ms = <200>;
3962306a36Sopenharmony_ci	};
4062306a36Sopenharmony_ci};
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci&exclk {
4362306a36Sopenharmony_ci	clock-frequency = <24000000>;
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci&cgu {
4762306a36Sopenharmony_ci	/*
4862306a36Sopenharmony_ci	 * Use the 32.768 kHz oscillator as the parent of the RTC for a higher
4962306a36Sopenharmony_ci	 * precision.
5062306a36Sopenharmony_ci	 */
5162306a36Sopenharmony_ci	assigned-clocks = <&cgu X1830_CLK_RTC>;
5262306a36Sopenharmony_ci	assigned-clock-parents = <&cgu X1830_CLK_RTCLK>;
5362306a36Sopenharmony_ci};
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci&ost {
5662306a36Sopenharmony_ci	/* 1500 kHz for the system timer and clocksource */
5762306a36Sopenharmony_ci	assigned-clocks = <&ost OST_CLK_EVENT_TIMER>, <&ost OST_CLK_GLOBAL_TIMER>;
5862306a36Sopenharmony_ci	assigned-clock-rates = <1500000>, <1500000>;
5962306a36Sopenharmony_ci};
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci&uart1 {
6262306a36Sopenharmony_ci	status = "okay";
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci	pinctrl-names = "default";
6562306a36Sopenharmony_ci	pinctrl-0 = <&pins_uart1>;
6662306a36Sopenharmony_ci};
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci&ssi0 {
6962306a36Sopenharmony_ci	status = "okay";
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci	num-cs = <2>;
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci	pinctrl-names = "default";
7462306a36Sopenharmony_ci	pinctrl-0 = <&pins_ssi0>;
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci	sc16is752: expander@0 {
7762306a36Sopenharmony_ci		compatible = "nxp,sc16is752";
7862306a36Sopenharmony_ci		reg = <0>; /* CE0 */
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci		spi-rx-bus-width = <1>;
8162306a36Sopenharmony_ci		spi-tx-bus-width = <1>;
8262306a36Sopenharmony_ci		spi-max-frequency = <4000000>;
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ci		clocks = <&exclk_sc16is752>;
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci		interrupt-parent = <&gpb>;
8762306a36Sopenharmony_ci		interrupts = <18 IRQ_TYPE_EDGE_FALLING>;
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci		gpio-controller;
9062306a36Sopenharmony_ci		#gpio-cells = <2>;
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci		exclk_sc16is752: sc16is752 {
9362306a36Sopenharmony_ci			compatible = "fixed-clock";
9462306a36Sopenharmony_ci			#clock-cells = <0>;
9562306a36Sopenharmony_ci			clock-frequency = <48000000>;
9662306a36Sopenharmony_ci		};
9762306a36Sopenharmony_ci	};
9862306a36Sopenharmony_ci};
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci&i2c0 {
10162306a36Sopenharmony_ci	status = "okay";
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ci	clock-frequency = <400000>;
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ci	pinctrl-names = "default";
10662306a36Sopenharmony_ci	pinctrl-0 = <&pins_i2c0>;
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci	ads7830: adc@48 {
10962306a36Sopenharmony_ci		compatible = "ti,ads7830";
11062306a36Sopenharmony_ci		reg = <0x48>;
11162306a36Sopenharmony_ci	};
11262306a36Sopenharmony_ci};
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci&dtrng {
11562306a36Sopenharmony_ci	status = "okay";
11662306a36Sopenharmony_ci};
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_ci&msc0 {
11962306a36Sopenharmony_ci	status = "okay";
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci	bus-width = <4>;
12262306a36Sopenharmony_ci	max-frequency = <50000000>;
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci	pinctrl-names = "default";
12562306a36Sopenharmony_ci	pinctrl-0 = <&pins_msc0>;
12662306a36Sopenharmony_ci
12762306a36Sopenharmony_ci	non-removable;
12862306a36Sopenharmony_ci};
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci&msc1 {
13162306a36Sopenharmony_ci	status = "okay";
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci	#address-cells = <1>;
13462306a36Sopenharmony_ci	#size-cells = <0>;
13562306a36Sopenharmony_ci	bus-width = <4>;
13662306a36Sopenharmony_ci	max-frequency = <50000000>;
13762306a36Sopenharmony_ci
13862306a36Sopenharmony_ci	pinctrl-names = "default";
13962306a36Sopenharmony_ci	pinctrl-0 = <&pins_msc1>;
14062306a36Sopenharmony_ci
14162306a36Sopenharmony_ci	non-removable;
14262306a36Sopenharmony_ci
14362306a36Sopenharmony_ci	mmc-pwrseq = <&wlan_pwrseq>;
14462306a36Sopenharmony_ci
14562306a36Sopenharmony_ci	ap6212a: wifi@1 {
14662306a36Sopenharmony_ci		compatible = "brcm,bcm4329-fmac";
14762306a36Sopenharmony_ci		reg = <1>;
14862306a36Sopenharmony_ci
14962306a36Sopenharmony_ci		interrupt-parent = <&gpc>;
15062306a36Sopenharmony_ci		interrupts = <25 IRQ_TYPE_EDGE_FALLING>;
15162306a36Sopenharmony_ci		interrupt-names = "host-wake";
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_ci		brcm,drive-strength = <10>;
15462306a36Sopenharmony_ci	};
15562306a36Sopenharmony_ci};
15662306a36Sopenharmony_ci
15762306a36Sopenharmony_ci&mac {
15862306a36Sopenharmony_ci	status = "okay";
15962306a36Sopenharmony_ci
16062306a36Sopenharmony_ci	phy-mode = "rmii";
16162306a36Sopenharmony_ci	phy-handle = <&ip101gr>;
16262306a36Sopenharmony_ci
16362306a36Sopenharmony_ci	pinctrl-names = "default";
16462306a36Sopenharmony_ci	pinctrl-0 = <&pins_mac>;
16562306a36Sopenharmony_ci
16662306a36Sopenharmony_ci	snps,reset-gpio = <&gpb 28 GPIO_ACTIVE_LOW>; /* PB28 */
16762306a36Sopenharmony_ci	snps,reset-active-low;
16862306a36Sopenharmony_ci	snps,reset-delays-us = <0 10000 30000>;
16962306a36Sopenharmony_ci};
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_ci&mdio {
17262306a36Sopenharmony_ci	status = "okay";
17362306a36Sopenharmony_ci
17462306a36Sopenharmony_ci	ip101gr: ethernet-phy@0 {
17562306a36Sopenharmony_ci		compatible = "ethernet-phy-id0243.0c54", "ethernet-phy-ieee802.3-c22";
17662306a36Sopenharmony_ci		reg = <0>;
17762306a36Sopenharmony_ci	};
17862306a36Sopenharmony_ci};
17962306a36Sopenharmony_ci
18062306a36Sopenharmony_ci&otg_phy {
18162306a36Sopenharmony_ci	status = "okay";
18262306a36Sopenharmony_ci};
18362306a36Sopenharmony_ci
18462306a36Sopenharmony_ci&otg {
18562306a36Sopenharmony_ci	status = "okay";
18662306a36Sopenharmony_ci};
18762306a36Sopenharmony_ci
18862306a36Sopenharmony_ci&pinctrl {
18962306a36Sopenharmony_ci	pins_uart1: uart1 {
19062306a36Sopenharmony_ci		function = "uart1";
19162306a36Sopenharmony_ci		groups = "uart1-data";
19262306a36Sopenharmony_ci		bias-pull-up;
19362306a36Sopenharmony_ci	};
19462306a36Sopenharmony_ci
19562306a36Sopenharmony_ci	pins_ssi0: ssi0 {
19662306a36Sopenharmony_ci		function = "ssi0";
19762306a36Sopenharmony_ci		groups = "ssi0-dt", "ssi0-dr", "ssi0-clk", "ssi0-ce0", "ssi0-ce1";
19862306a36Sopenharmony_ci		bias-disable;
19962306a36Sopenharmony_ci	};
20062306a36Sopenharmony_ci
20162306a36Sopenharmony_ci	pins_i2c0: i2c0 {
20262306a36Sopenharmony_ci		function = "i2c0";
20362306a36Sopenharmony_ci		groups = "i2c0-data";
20462306a36Sopenharmony_ci		bias-pull-up;
20562306a36Sopenharmony_ci	};
20662306a36Sopenharmony_ci
20762306a36Sopenharmony_ci	pins_msc0: msc0 {
20862306a36Sopenharmony_ci		function = "mmc0";
20962306a36Sopenharmony_ci		groups = "mmc0-1bit", "mmc0-4bit";
21062306a36Sopenharmony_ci		bias-disable;
21162306a36Sopenharmony_ci	};
21262306a36Sopenharmony_ci
21362306a36Sopenharmony_ci	pins_msc1: msc1 {
21462306a36Sopenharmony_ci		function = "mmc1";
21562306a36Sopenharmony_ci		groups = "mmc1-1bit", "mmc1-4bit";
21662306a36Sopenharmony_ci		bias-disable;
21762306a36Sopenharmony_ci	};
21862306a36Sopenharmony_ci
21962306a36Sopenharmony_ci	pins_mac: mac {
22062306a36Sopenharmony_ci		function = "mac";
22162306a36Sopenharmony_ci		groups = "mac";
22262306a36Sopenharmony_ci		bias-disable;
22362306a36Sopenharmony_ci	};
22462306a36Sopenharmony_ci};
225