162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci/dts-v1/;
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h>
662306a36Sopenharmony_ci#include <dt-bindings/input/linux-event-codes.h>
762306a36Sopenharmony_ci#include <dt-bindings/pinctrl/rockchip.h>
862306a36Sopenharmony_ci#include "rk3566-anbernic-rgxx3.dtsi"
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci/ {
1162306a36Sopenharmony_ci	model = "RG503";
1262306a36Sopenharmony_ci	compatible = "anbernic,rg503", "rockchip,rk3566";
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci	aliases {
1562306a36Sopenharmony_ci		mmc0 = &sdmmc0;
1662306a36Sopenharmony_ci		mmc1 = &sdmmc1;
1762306a36Sopenharmony_ci		mmc2 = &sdmmc2;
1862306a36Sopenharmony_ci	};
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	battery: battery {
2162306a36Sopenharmony_ci		compatible = "simple-battery";
2262306a36Sopenharmony_ci		charge-full-design-microamp-hours = <3472000>;
2362306a36Sopenharmony_ci		charge-term-current-microamp = <300000>;
2462306a36Sopenharmony_ci		constant-charge-current-max-microamp = <2000000>;
2562306a36Sopenharmony_ci		constant-charge-voltage-max-microvolt = <4200000>;
2662306a36Sopenharmony_ci		factory-internal-resistance-micro-ohms = <117000>;
2762306a36Sopenharmony_ci		voltage-max-design-microvolt = <4172000>;
2862306a36Sopenharmony_ci		voltage-min-design-microvolt = <3400000>;
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci		ocv-capacity-celsius = <20>;
3162306a36Sopenharmony_ci		ocv-capacity-table-0 =	<4172000 100>, <4054000 95>, <3984000 90>, <3926000 85>,
3262306a36Sopenharmony_ci					<3874000 80>, <3826000 75>, <3783000 70>, <3746000 65>,
3362306a36Sopenharmony_ci					<3714000 60>, <3683000 55>, <3650000 50>, <3628000 45>,
3462306a36Sopenharmony_ci					<3612000 40>, <3600000 35>, <3587000 30>, <3571000 25>,
3562306a36Sopenharmony_ci					<3552000 20>, <3525000 15>, <3492000 10>, <3446000 5>,
3662306a36Sopenharmony_ci					<3400000 0>;
3762306a36Sopenharmony_ci	};
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci	gpio_spi: spi {
4062306a36Sopenharmony_ci		compatible = "spi-gpio";
4162306a36Sopenharmony_ci		pinctrl-names = "default";
4262306a36Sopenharmony_ci		pinctrl-0 = <&spi_pins>;
4362306a36Sopenharmony_ci		#address-cells = <1>;
4462306a36Sopenharmony_ci		#size-cells = <0>;
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci		sck-gpios = <&gpio4 RK_PB3 GPIO_ACTIVE_HIGH>;
4762306a36Sopenharmony_ci		mosi-gpios = <&gpio4 RK_PB0 GPIO_ACTIVE_HIGH>;
4862306a36Sopenharmony_ci		cs-gpios = <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>;
4962306a36Sopenharmony_ci		num-chipselects = <0>;
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci		panel@0 {
5262306a36Sopenharmony_ci			compatible = "samsung,ams495qa01";
5362306a36Sopenharmony_ci			reg = <0>;
5462306a36Sopenharmony_ci			pinctrl-names = "default";
5562306a36Sopenharmony_ci			pinctrl-0 = <&lcd_reset>;
5662306a36Sopenharmony_ci			reset-gpios = <&gpio4 RK_PA0 GPIO_ACTIVE_LOW>;
5762306a36Sopenharmony_ci			vdd-supply = <&vcc_3v3>;
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci			port {
6062306a36Sopenharmony_ci				mipi_in_panel: endpoint {
6162306a36Sopenharmony_ci					remote-endpoint = <&mipi_out_panel>;
6262306a36Sopenharmony_ci				};
6362306a36Sopenharmony_ci			};
6462306a36Sopenharmony_ci		};
6562306a36Sopenharmony_ci	};
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci	/* Channels reversed for both headphones and speakers. */
6862306a36Sopenharmony_ci	sound {
6962306a36Sopenharmony_ci		compatible = "simple-audio-card";
7062306a36Sopenharmony_ci		simple-audio-card,name = "rk817_ext";
7162306a36Sopenharmony_ci		simple-audio-card,aux-devs = <&spk_amp>;
7262306a36Sopenharmony_ci		simple-audio-card,format = "i2s";
7362306a36Sopenharmony_ci		simple-audio-card,hp-det-gpio = <&gpio4 RK_PC6 GPIO_ACTIVE_HIGH>;
7462306a36Sopenharmony_ci		simple-audio-card,mclk-fs = <256>;
7562306a36Sopenharmony_ci		simple-audio-card,widgets =
7662306a36Sopenharmony_ci			"Microphone", "Mic Jack",
7762306a36Sopenharmony_ci			"Headphone", "Headphones",
7862306a36Sopenharmony_ci			"Speaker", "Internal Speakers";
7962306a36Sopenharmony_ci		simple-audio-card,routing =
8062306a36Sopenharmony_ci			"MICL", "Mic Jack",
8162306a36Sopenharmony_ci			"Headphones", "HPOL",
8262306a36Sopenharmony_ci			"Headphones", "HPOR",
8362306a36Sopenharmony_ci			"Internal Speakers", "Speaker Amp OUTL",
8462306a36Sopenharmony_ci			"Internal Speakers", "Speaker Amp OUTR",
8562306a36Sopenharmony_ci			"Speaker Amp INL", "HPOL",
8662306a36Sopenharmony_ci			"Speaker Amp INR", "HPOR";
8762306a36Sopenharmony_ci		simple-audio-card,pin-switches = "Internal Speakers";
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci		simple-audio-card,codec {
9062306a36Sopenharmony_ci			sound-dai = <&rk817>;
9162306a36Sopenharmony_ci		};
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci		simple-audio-card,cpu {
9462306a36Sopenharmony_ci			sound-dai = <&i2s1_8ch>;
9562306a36Sopenharmony_ci		};
9662306a36Sopenharmony_ci	};
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci	spk_amp: audio-amplifier {
9962306a36Sopenharmony_ci		compatible = "simple-audio-amplifier";
10062306a36Sopenharmony_ci		enable-gpios = <&gpio4 RK_PC2 GPIO_ACTIVE_HIGH>;
10162306a36Sopenharmony_ci		pinctrl-0 = <&spk_amp_enable_h>;
10262306a36Sopenharmony_ci		pinctrl-names = "default";
10362306a36Sopenharmony_ci		sound-name-prefix = "Speaker Amp";
10462306a36Sopenharmony_ci	};
10562306a36Sopenharmony_ci};
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci&cru {
10862306a36Sopenharmony_ci	assigned-clocks = <&pmucru CLK_RTC_32K>, <&cru PLL_GPLL>,
10962306a36Sopenharmony_ci			  <&pmucru PLL_PPLL>, <&cru PLL_VPLL>;
11062306a36Sopenharmony_ci	assigned-clock-rates = <32768>, <1200000000>,
11162306a36Sopenharmony_ci			       <200000000>, <500000000>;
11262306a36Sopenharmony_ci};
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci&dsi_dphy0 {
11562306a36Sopenharmony_ci	status = "okay";
11662306a36Sopenharmony_ci};
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_ci&dsi0 {
11962306a36Sopenharmony_ci	status = "okay";
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci	ports {
12262306a36Sopenharmony_ci		dsi0_in: port@0 {
12362306a36Sopenharmony_ci			reg = <0>;
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_ci			dsi0_in_vp1: endpoint {
12662306a36Sopenharmony_ci				remote-endpoint = <&vp1_out_dsi0>;
12762306a36Sopenharmony_ci			};
12862306a36Sopenharmony_ci		};
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci		dsi0_out: port@1 {
13162306a36Sopenharmony_ci			reg = <1>;
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci			mipi_out_panel: endpoint {
13462306a36Sopenharmony_ci				remote-endpoint = <&mipi_in_panel>;
13562306a36Sopenharmony_ci			};
13662306a36Sopenharmony_ci		};
13762306a36Sopenharmony_ci	};
13862306a36Sopenharmony_ci};
13962306a36Sopenharmony_ci
14062306a36Sopenharmony_ci&gpio_keys_control {
14162306a36Sopenharmony_ci	button-a {
14262306a36Sopenharmony_ci		gpios = <&gpio3 RK_PC1 GPIO_ACTIVE_LOW>;
14362306a36Sopenharmony_ci		label = "EAST";
14462306a36Sopenharmony_ci		linux,code = <BTN_EAST>;
14562306a36Sopenharmony_ci	};
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci	button-left {
14862306a36Sopenharmony_ci		gpios = <&gpio3 RK_PA5 GPIO_ACTIVE_LOW>;
14962306a36Sopenharmony_ci		label = "DPAD-LEFT";
15062306a36Sopenharmony_ci		linux,code = <BTN_DPAD_LEFT>;
15162306a36Sopenharmony_ci	};
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_ci	button-right {
15462306a36Sopenharmony_ci		gpios = <&gpio3 RK_PA6 GPIO_ACTIVE_LOW>;
15562306a36Sopenharmony_ci		label = "DPAD-RIGHT";
15662306a36Sopenharmony_ci		linux,code = <BTN_DPAD_RIGHT>;
15762306a36Sopenharmony_ci	};
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci	button-r1 {
16062306a36Sopenharmony_ci		gpios = <&gpio3 RK_PB3 GPIO_ACTIVE_LOW>;
16162306a36Sopenharmony_ci		label = "TR";
16262306a36Sopenharmony_ci		linux,code = <BTN_TR>;
16362306a36Sopenharmony_ci	};
16462306a36Sopenharmony_ci
16562306a36Sopenharmony_ci	button-r2 {
16662306a36Sopenharmony_ci		gpios = <&gpio3 RK_PB4 GPIO_ACTIVE_LOW>;
16762306a36Sopenharmony_ci		label = "TR2";
16862306a36Sopenharmony_ci		linux,code = <BTN_TR2>;
16962306a36Sopenharmony_ci	};
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_ci	button-right {
17262306a36Sopenharmony_ci		gpios = <&gpio3 RK_PA6 GPIO_ACTIVE_LOW>;
17362306a36Sopenharmony_ci		label = "DPAD-RIGHT";
17462306a36Sopenharmony_ci		linux,code = <BTN_DPAD_RIGHT>;
17562306a36Sopenharmony_ci	};
17662306a36Sopenharmony_ci
17762306a36Sopenharmony_ci	button-y {
17862306a36Sopenharmony_ci		gpios = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
17962306a36Sopenharmony_ci		label = "WEST";
18062306a36Sopenharmony_ci		linux,code = <BTN_WEST>;
18162306a36Sopenharmony_ci	};
18262306a36Sopenharmony_ci};
18362306a36Sopenharmony_ci
18462306a36Sopenharmony_ci&pinctrl {
18562306a36Sopenharmony_ci	audio-amplifier {
18662306a36Sopenharmony_ci		spk_amp_enable_h: spk-amp-enable-h {
18762306a36Sopenharmony_ci			rockchip,pins =
18862306a36Sopenharmony_ci				<4 RK_PC2 RK_FUNC_GPIO &pcfg_pull_none>;
18962306a36Sopenharmony_ci		};
19062306a36Sopenharmony_ci	};
19162306a36Sopenharmony_ci
19262306a36Sopenharmony_ci	gpio-lcd {
19362306a36Sopenharmony_ci		lcd_reset: lcd-reset {
19462306a36Sopenharmony_ci			rockchip,pins =
19562306a36Sopenharmony_ci				<4 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>;
19662306a36Sopenharmony_ci		};
19762306a36Sopenharmony_ci	};
19862306a36Sopenharmony_ci
19962306a36Sopenharmony_ci	gpio-spi {
20062306a36Sopenharmony_ci		spi_pins: spi-pins {
20162306a36Sopenharmony_ci			rockchip,pins =
20262306a36Sopenharmony_ci				<4 RK_PA7 RK_FUNC_GPIO &pcfg_pull_none>,
20362306a36Sopenharmony_ci				<4 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>,
20462306a36Sopenharmony_ci				<4 RK_PB3 RK_FUNC_GPIO &pcfg_pull_none>;
20562306a36Sopenharmony_ci		};
20662306a36Sopenharmony_ci	};
20762306a36Sopenharmony_ci};
20862306a36Sopenharmony_ci
20962306a36Sopenharmony_ci&rk817 {
21062306a36Sopenharmony_ci	rk817_charger: charger {
21162306a36Sopenharmony_ci		monitored-battery = <&battery>;
21262306a36Sopenharmony_ci		rockchip,resistor-sense-micro-ohms = <10000>;
21362306a36Sopenharmony_ci		rockchip,sleep-enter-current-microamp = <300000>;
21462306a36Sopenharmony_ci		rockchip,sleep-filter-current-microamp = <100000>;
21562306a36Sopenharmony_ci	};
21662306a36Sopenharmony_ci};
21762306a36Sopenharmony_ci
21862306a36Sopenharmony_ci&vp1 {
21962306a36Sopenharmony_ci	vp1_out_dsi0: endpoint@ROCKCHIP_VOP2_EP_MIPI0 {
22062306a36Sopenharmony_ci		reg = <ROCKCHIP_VOP2_EP_MIPI0>;
22162306a36Sopenharmony_ci		remote-endpoint = <&dsi0_in_vp1>;
22262306a36Sopenharmony_ci	};
22362306a36Sopenharmony_ci};
224