xref: /linux/scripts/dtc/include-prefixes/arm64/amlogic/meson-gxl-s805x-p241.dts (revision 2f24482304ebd32c5aa374f31465b9941a860b92)
1fd477164SNeil Armstrong// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2fd477164SNeil Armstrong/*
3fd477164SNeil Armstrong * Copyright (c) 2018 BayLibre, SAS.
4fd477164SNeil Armstrong * Author: Neil Armstrong <narmstrong@baylibre.com>
5fd477164SNeil Armstrong * Author: Jerome Brunet <jbrunet@baylibre.com>
6fd477164SNeil Armstrong */
7fd477164SNeil Armstrong
8fd477164SNeil Armstrong/dts-v1/;
9fd477164SNeil Armstrong
10fd477164SNeil Armstrong#include <dt-bindings/input/input.h>
110a62b3ccSJerome Brunet#include <dt-bindings/sound/meson-aiu.h>
12fd477164SNeil Armstrong
13b2037dafSNeil Armstrong#include "meson-gxl-s805x.dtsi"
14fd477164SNeil Armstrong
15fd477164SNeil Armstrong/ {
16fd477164SNeil Armstrong	compatible = "amlogic,p241", "amlogic,s805x", "amlogic,meson-gxl";
17fd477164SNeil Armstrong	model = "Amlogic Meson GXL (S805X) P241 Development Board";
18fd477164SNeil Armstrong
19fd477164SNeil Armstrong	aliases {
20fd477164SNeil Armstrong		serial0 = &uart_AO;
21fd477164SNeil Armstrong		serial1 = &uart_A;
22fd477164SNeil Armstrong		ethernet0 = &ethmac;
23fd477164SNeil Armstrong	};
24fd477164SNeil Armstrong
250a62b3ccSJerome Brunet	au2: analog-amplifier {
260a62b3ccSJerome Brunet		compatible = "simple-audio-amplifier";
270a62b3ccSJerome Brunet		sound-name-prefix = "AU2";
280a62b3ccSJerome Brunet		VCC-supply = <&vcc_5v>;
290a62b3ccSJerome Brunet		enable-gpios = <&gpio GPIOH_5 GPIO_ACTIVE_HIGH>;
300a62b3ccSJerome Brunet	};
310a62b3ccSJerome Brunet
32fd477164SNeil Armstrong	chosen {
33fd477164SNeil Armstrong		stdout-path = "serial0:115200n8";
34fd477164SNeil Armstrong	};
35fd477164SNeil Armstrong
36fd477164SNeil Armstrong	cvbs-connector {
37fd477164SNeil Armstrong		compatible = "composite-video-connector";
38fd477164SNeil Armstrong
39fd477164SNeil Armstrong		port {
40fd477164SNeil Armstrong			cvbs_connector_in: endpoint {
41fd477164SNeil Armstrong				remote-endpoint = <&cvbs_vdac_out>;
42fd477164SNeil Armstrong			};
43fd477164SNeil Armstrong		};
44fd477164SNeil Armstrong	};
45fd477164SNeil Armstrong
46fd477164SNeil Armstrong	emmc_pwrseq: emmc-pwrseq {
47fd477164SNeil Armstrong		compatible = "mmc-pwrseq-emmc";
48fd477164SNeil Armstrong		reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>;
49fd477164SNeil Armstrong	};
50fd477164SNeil Armstrong
51fd477164SNeil Armstrong	hdmi-connector {
52fd477164SNeil Armstrong		compatible = "hdmi-connector";
53fd477164SNeil Armstrong		type = "a";
54fd477164SNeil Armstrong
55fd477164SNeil Armstrong		port {
56fd477164SNeil Armstrong			hdmi_connector_in: endpoint {
57fd477164SNeil Armstrong				remote-endpoint = <&hdmi_tx_tmds_out>;
58fd477164SNeil Armstrong			};
59fd477164SNeil Armstrong		};
60fd477164SNeil Armstrong	};
61fd477164SNeil Armstrong
62fd477164SNeil Armstrong	memory@0 {
63fd477164SNeil Armstrong		device_type = "memory";
64fd477164SNeil Armstrong		reg = <0x0 0x0 0x0 0x20000000>;
65fd477164SNeil Armstrong	};
66fd477164SNeil Armstrong
67f0ed445eSKrzysztof Kozlowski	vddio_boot: regulator-vddio-boot {
68fd477164SNeil Armstrong		compatible = "regulator-fixed";
69fd477164SNeil Armstrong		regulator-name = "VDDIO_BOOT";
70fd477164SNeil Armstrong		regulator-min-microvolt = <1800000>;
71fd477164SNeil Armstrong		regulator-max-microvolt = <1800000>;
72fd477164SNeil Armstrong	};
73fd477164SNeil Armstrong
74f0ed445eSKrzysztof Kozlowski	vddao_3v3: regulator-vddao-3v3 {
75fd477164SNeil Armstrong		compatible = "regulator-fixed";
76fd477164SNeil Armstrong		regulator-name = "VDDAO_3V3";
77fd477164SNeil Armstrong		regulator-min-microvolt = <3300000>;
78fd477164SNeil Armstrong		regulator-max-microvolt = <3300000>;
79fd477164SNeil Armstrong	};
80fd477164SNeil Armstrong
81f0ed445eSKrzysztof Kozlowski	vddio_ao18: regulator-vddio-ao18 {
82fd477164SNeil Armstrong		compatible = "regulator-fixed";
83fd477164SNeil Armstrong		regulator-name = "VDDIO_AO18";
84fd477164SNeil Armstrong		regulator-min-microvolt = <1800000>;
85fd477164SNeil Armstrong		regulator-max-microvolt = <1800000>;
86fd477164SNeil Armstrong	};
87fd477164SNeil Armstrong
88f0ed445eSKrzysztof Kozlowski	vcc_3v3: regulator-vcc-3v3 {
89fd477164SNeil Armstrong		compatible = "regulator-fixed";
90fd477164SNeil Armstrong		regulator-name = "VCC_3V3";
91fd477164SNeil Armstrong		regulator-min-microvolt = <3300000>;
92fd477164SNeil Armstrong		regulator-max-microvolt = <3300000>;
93fd477164SNeil Armstrong	};
94fd477164SNeil Armstrong
9575fb3b1bSJerome Brunet	vcc_5v: regulator-vcc-5v {
9675fb3b1bSJerome Brunet		compatible = "regulator-fixed";
9775fb3b1bSJerome Brunet		regulator-name = "VCC_5V";
9875fb3b1bSJerome Brunet		regulator-min-microvolt = <5000000>;
9975fb3b1bSJerome Brunet		regulator-max-microvolt = <5000000>;
10075fb3b1bSJerome Brunet	};
10175fb3b1bSJerome Brunet
10275fb3b1bSJerome Brunet
103fd477164SNeil Armstrong	emmc_pwrseq: emmc-pwrseq {
104fd477164SNeil Armstrong		compatible = "mmc-pwrseq-emmc";
105fd477164SNeil Armstrong		reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>;
106fd477164SNeil Armstrong	};
107fd477164SNeil Armstrong
108fd477164SNeil Armstrong	wifi32k: wifi32k {
109fd477164SNeil Armstrong		compatible = "pwm-clock";
110fd477164SNeil Armstrong		#clock-cells = <0>;
111fd477164SNeil Armstrong		clock-frequency = <32768>;
112fd477164SNeil Armstrong		pwms = <&pwm_ef 0 30518 0>; /* PWM_E at 32.768KHz */
113fd477164SNeil Armstrong	};
114fd477164SNeil Armstrong
115fd477164SNeil Armstrong	sdio_pwrseq: sdio-pwrseq {
116fd477164SNeil Armstrong		compatible = "mmc-pwrseq-simple";
117fd477164SNeil Armstrong		reset-gpios = <&gpio GPIOX_6 GPIO_ACTIVE_LOW>;
118fd477164SNeil Armstrong		clocks = <&wifi32k>;
119fd477164SNeil Armstrong		clock-names = "ext_clock";
120fd477164SNeil Armstrong	};
1210a62b3ccSJerome Brunet
1220a62b3ccSJerome Brunet	sound {
1230a62b3ccSJerome Brunet		compatible = "amlogic,gx-sound-card";
1240a62b3ccSJerome Brunet		model = "GXL-P241";
1250a62b3ccSJerome Brunet		audio-aux-devs = <&au2>;
1260a62b3ccSJerome Brunet		audio-widgets = "Line", "Lineout";
1270a62b3ccSJerome Brunet		audio-routing = "AU2 INL", "ACODEC LOLN",
1280a62b3ccSJerome Brunet				"AU2 INR", "ACODEC LORN",
1290a62b3ccSJerome Brunet				"Lineout", "AU2 OUTL",
1300a62b3ccSJerome Brunet				"Lineout", "AU2 OUTR";
131*9b5d2511SNeil Armstrong		clocks = <&clkc CLKID_MPLL0>,
132*9b5d2511SNeil Armstrong			 <&clkc CLKID_MPLL1>,
133*9b5d2511SNeil Armstrong			 <&clkc CLKID_MPLL2>;
134*9b5d2511SNeil Armstrong
1350a62b3ccSJerome Brunet		assigned-clocks = <&clkc CLKID_MPLL0>,
1360a62b3ccSJerome Brunet				  <&clkc CLKID_MPLL1>,
1370a62b3ccSJerome Brunet				  <&clkc CLKID_MPLL2>;
1380a62b3ccSJerome Brunet		assigned-clock-parents = <0>, <0>, <0>;
1390a62b3ccSJerome Brunet		assigned-clock-rates = <294912000>,
1400a62b3ccSJerome Brunet				       <270950400>,
1410a62b3ccSJerome Brunet				       <393216000>;
1420a62b3ccSJerome Brunet
1430a62b3ccSJerome Brunet		dai-link-0 {
1440a62b3ccSJerome Brunet			sound-dai = <&aiu AIU_CPU CPU_I2S_FIFO>;
1450a62b3ccSJerome Brunet		};
1460a62b3ccSJerome Brunet
1470a62b3ccSJerome Brunet		dai-link-1 {
1480a62b3ccSJerome Brunet			sound-dai = <&aiu AIU_CPU CPU_I2S_ENCODER>;
1490a62b3ccSJerome Brunet			dai-format = "i2s";
1500a62b3ccSJerome Brunet			mclk-fs = <256>;
1510a62b3ccSJerome Brunet
1520a62b3ccSJerome Brunet			codec-0 {
1530a62b3ccSJerome Brunet				sound-dai = <&aiu AIU_HDMI CTRL_I2S>;
1540a62b3ccSJerome Brunet			};
1550a62b3ccSJerome Brunet
1560a62b3ccSJerome Brunet			codec-1 {
1570a62b3ccSJerome Brunet				sound-dai = <&aiu AIU_ACODEC CTRL_I2S>;
1580a62b3ccSJerome Brunet			};
1590a62b3ccSJerome Brunet		};
1600a62b3ccSJerome Brunet
1610a62b3ccSJerome Brunet		dai-link-2 {
1620a62b3ccSJerome Brunet			sound-dai = <&aiu AIU_HDMI CTRL_OUT>;
1630a62b3ccSJerome Brunet
1640a62b3ccSJerome Brunet			codec-0 {
1650a62b3ccSJerome Brunet				sound-dai = <&hdmi_tx>;
1660a62b3ccSJerome Brunet			};
1670a62b3ccSJerome Brunet		};
1680a62b3ccSJerome Brunet
1690a62b3ccSJerome Brunet		dai-link-3 {
1700a62b3ccSJerome Brunet			sound-dai = <&aiu AIU_ACODEC CTRL_OUT>;
1710a62b3ccSJerome Brunet
1720a62b3ccSJerome Brunet			codec-0 {
1730a62b3ccSJerome Brunet				sound-dai = <&acodec>;
1740a62b3ccSJerome Brunet			};
1750a62b3ccSJerome Brunet		};
1760a62b3ccSJerome Brunet	};
1770a62b3ccSJerome Brunet};
1780a62b3ccSJerome Brunet
1790a62b3ccSJerome Brunet&acodec {
1800a62b3ccSJerome Brunet	AVDD-supply = <&vddio_ao18>;
1810a62b3ccSJerome Brunet	status = "okay";
1820a62b3ccSJerome Brunet};
1830a62b3ccSJerome Brunet
1840a62b3ccSJerome Brunet&aiu {
1850a62b3ccSJerome Brunet	status = "okay";
186fd477164SNeil Armstrong};
187fd477164SNeil Armstrong
188fd477164SNeil Armstrong&cec_AO {
189fd477164SNeil Armstrong	status = "okay";
190fd477164SNeil Armstrong	pinctrl-0 = <&ao_cec_pins>;
191fd477164SNeil Armstrong	pinctrl-names = "default";
192fd477164SNeil Armstrong	hdmi-phandle = <&hdmi_tx>;
193fd477164SNeil Armstrong};
194fd477164SNeil Armstrong
195fd477164SNeil Armstrong&cvbs_vdac_port {
196fd477164SNeil Armstrong	cvbs_vdac_out: endpoint {
197fd477164SNeil Armstrong		remote-endpoint = <&cvbs_connector_in>;
198fd477164SNeil Armstrong	};
199fd477164SNeil Armstrong};
200fd477164SNeil Armstrong
201fd477164SNeil Armstrong&ethmac {
202fd477164SNeil Armstrong	status = "okay";
203fd477164SNeil Armstrong};
204fd477164SNeil Armstrong
205fd477164SNeil Armstrong&internal_phy {
206fd477164SNeil Armstrong	pinctrl-0 = <&eth_link_led_pins>, <&eth_act_led_pins>;
207fd477164SNeil Armstrong	pinctrl-names = "default";
208fd477164SNeil Armstrong};
209fd477164SNeil Armstrong
210fd477164SNeil Armstrong&ir {
211fd477164SNeil Armstrong	status = "okay";
212fd477164SNeil Armstrong	pinctrl-0 = <&remote_input_ao_pins>;
213fd477164SNeil Armstrong	pinctrl-names = "default";
214fd477164SNeil Armstrong};
215fd477164SNeil Armstrong
216fd477164SNeil Armstrong&hdmi_tx {
217fd477164SNeil Armstrong	status = "okay";
218fd477164SNeil Armstrong	pinctrl-0 = <&hdmi_hpd_pins>, <&hdmi_i2c_pins>;
219fd477164SNeil Armstrong	pinctrl-names = "default";
22075fb3b1bSJerome Brunet	hdmi-supply = <&vcc_5v>;
221fd477164SNeil Armstrong};
222fd477164SNeil Armstrong
223fd477164SNeil Armstrong&hdmi_tx_tmds_port {
224fd477164SNeil Armstrong	hdmi_tx_tmds_out: endpoint {
225fd477164SNeil Armstrong		remote-endpoint = <&hdmi_connector_in>;
226fd477164SNeil Armstrong	};
227fd477164SNeil Armstrong};
228fd477164SNeil Armstrong
229fd477164SNeil Armstrong&saradc {
230fd477164SNeil Armstrong	status = "okay";
231fd477164SNeil Armstrong	vref-supply = <&vddio_ao18>;
232fd477164SNeil Armstrong};
233fd477164SNeil Armstrong
234fd477164SNeil Armstrong/* Wireless SDIO Module */
235fd477164SNeil Armstrong&sd_emmc_a {
236fd477164SNeil Armstrong	status = "okay";
237fd477164SNeil Armstrong	pinctrl-0 = <&sdio_pins>;
238fd477164SNeil Armstrong	pinctrl-1 = <&sdio_clk_gate_pins>;
239fd477164SNeil Armstrong	pinctrl-names = "default", "clk-gate";
240fd477164SNeil Armstrong	#address-cells = <1>;
241fd477164SNeil Armstrong	#size-cells = <0>;
242fd477164SNeil Armstrong
243fd477164SNeil Armstrong	bus-width = <4>;
244fd477164SNeil Armstrong	cap-sd-highspeed;
245adc52bf7SJerome Brunet	max-frequency = <50000000>;
246fd477164SNeil Armstrong
247fd477164SNeil Armstrong	non-removable;
248fd477164SNeil Armstrong	disable-wp;
249fd477164SNeil Armstrong
250cfd7a215SNeil Armstrong	/* WiFi firmware requires power to be kept while in suspend */
251cfd7a215SNeil Armstrong	keep-power-in-suspend;
252cfd7a215SNeil Armstrong
253fd477164SNeil Armstrong	mmc-pwrseq = <&sdio_pwrseq>;
254fd477164SNeil Armstrong
255fd477164SNeil Armstrong	vmmc-supply = <&vddao_3v3>;
256fd477164SNeil Armstrong	vqmmc-supply = <&vddio_boot>;
257fd477164SNeil Armstrong};
258fd477164SNeil Armstrong
259fd477164SNeil Armstrong/* eMMC */
260fd477164SNeil Armstrong&sd_emmc_c {
261fd477164SNeil Armstrong	status = "okay";
262fd477164SNeil Armstrong	pinctrl-0 = <&emmc_pins>, <&emmc_ds_pins>;
263fd477164SNeil Armstrong	pinctrl-1 = <&emmc_clk_gate_pins>;
264fd477164SNeil Armstrong	pinctrl-names = "default", "clk-gate";
265fd477164SNeil Armstrong
266fd477164SNeil Armstrong	bus-width = <8>;
267fd477164SNeil Armstrong	cap-mmc-highspeed;
268fd477164SNeil Armstrong	max-frequency = <200000000>;
269fd477164SNeil Armstrong	non-removable;
270fd477164SNeil Armstrong	disable-wp;
271fd477164SNeil Armstrong	mmc-ddr-1_8v;
272fd477164SNeil Armstrong	mmc-hs200-1_8v;
273fd477164SNeil Armstrong
274fd477164SNeil Armstrong	mmc-pwrseq = <&emmc_pwrseq>;
275fd477164SNeil Armstrong	vmmc-supply = <&vcc_3v3>;
276fd477164SNeil Armstrong	vqmmc-supply = <&vddio_boot>;
277fd477164SNeil Armstrong};
278fd477164SNeil Armstrong
279fd477164SNeil Armstrong&pwm_ef {
280fd477164SNeil Armstrong	status = "okay";
281fd477164SNeil Armstrong	pinctrl-0 = <&pwm_e_pins>;
282fd477164SNeil Armstrong	pinctrl-names = "default";
283fd477164SNeil Armstrong};
284fd477164SNeil Armstrong
285fd477164SNeil Armstrong/* This is connected to the Bluetooth module: */
286fd477164SNeil Armstrong&uart_A {
287fd477164SNeil Armstrong	status = "okay";
288fd477164SNeil Armstrong	pinctrl-0 = <&uart_a_pins>, <&uart_a_cts_rts_pins>;
289fd477164SNeil Armstrong	pinctrl-names = "default";
290fd477164SNeil Armstrong	uart-has-rtscts;
291fd477164SNeil Armstrong};
292fd477164SNeil Armstrong
293fd477164SNeil Armstrong&uart_AO {
294fd477164SNeil Armstrong	status = "okay";
295fd477164SNeil Armstrong	pinctrl-0 = <&uart_ao_a_pins>;
296fd477164SNeil Armstrong	pinctrl-names = "default";
297fd477164SNeil Armstrong};
298fd477164SNeil Armstrong
2992f9139c2SMartin Blumenstingl&usb {
300fd477164SNeil Armstrong	status = "okay";
3012f9139c2SMartin Blumenstingl	dr_mode = "host";
302fd477164SNeil Armstrong};
30375fb3b1bSJerome Brunet
30475fb3b1bSJerome Brunet&usb2_phy0 {
30575fb3b1bSJerome Brunet	phy-supply = <&vcc_5v>;
30675fb3b1bSJerome Brunet};
307