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>
11fd477164SNeil Armstrong
12fd477164SNeil Armstrong#include "meson-gxl-s905x.dtsi"
13fd477164SNeil Armstrong
14fd477164SNeil Armstrong/ {
15fd477164SNeil Armstrong	compatible = "amlogic,p241", "amlogic,s805x", "amlogic,meson-gxl";
16fd477164SNeil Armstrong	model = "Amlogic Meson GXL (S805X) P241 Development Board";
17fd477164SNeil Armstrong
18fd477164SNeil Armstrong	aliases {
19fd477164SNeil Armstrong		serial0 = &uart_AO;
20fd477164SNeil Armstrong		serial1 = &uart_A;
21fd477164SNeil Armstrong		ethernet0 = &ethmac;
22fd477164SNeil Armstrong	};
23fd477164SNeil Armstrong
24fd477164SNeil Armstrong	chosen {
25fd477164SNeil Armstrong		stdout-path = "serial0:115200n8";
26fd477164SNeil Armstrong	};
27fd477164SNeil Armstrong
28fd477164SNeil Armstrong	cvbs-connector {
29fd477164SNeil Armstrong		compatible = "composite-video-connector";
30fd477164SNeil Armstrong
31fd477164SNeil Armstrong		port {
32fd477164SNeil Armstrong			cvbs_connector_in: endpoint {
33fd477164SNeil Armstrong				remote-endpoint = <&cvbs_vdac_out>;
34fd477164SNeil Armstrong			};
35fd477164SNeil Armstrong		};
36fd477164SNeil Armstrong	};
37fd477164SNeil Armstrong
38fd477164SNeil Armstrong	emmc_pwrseq: emmc-pwrseq {
39fd477164SNeil Armstrong		compatible = "mmc-pwrseq-emmc";
40fd477164SNeil Armstrong		reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>;
41fd477164SNeil Armstrong	};
42fd477164SNeil Armstrong
43fd477164SNeil Armstrong	hdmi-connector {
44fd477164SNeil Armstrong		compatible = "hdmi-connector";
45fd477164SNeil Armstrong		type = "a";
46fd477164SNeil Armstrong
47fd477164SNeil Armstrong		port {
48fd477164SNeil Armstrong			hdmi_connector_in: endpoint {
49fd477164SNeil Armstrong				remote-endpoint = <&hdmi_tx_tmds_out>;
50fd477164SNeil Armstrong			};
51fd477164SNeil Armstrong		};
52fd477164SNeil Armstrong	};
53fd477164SNeil Armstrong
54fd477164SNeil Armstrong	memory@0 {
55fd477164SNeil Armstrong		device_type = "memory";
56fd477164SNeil Armstrong		reg = <0x0 0x0 0x0 0x20000000>;
57fd477164SNeil Armstrong	};
58fd477164SNeil Armstrong
59fd477164SNeil Armstrong	vddio_boot: regulator-vddio_boot {
60fd477164SNeil Armstrong		compatible = "regulator-fixed";
61fd477164SNeil Armstrong		regulator-name = "VDDIO_BOOT";
62fd477164SNeil Armstrong		regulator-min-microvolt = <1800000>;
63fd477164SNeil Armstrong		regulator-max-microvolt = <1800000>;
64fd477164SNeil Armstrong	};
65fd477164SNeil Armstrong
66fd477164SNeil Armstrong	vddao_3v3: regulator-vddao_3v3 {
67fd477164SNeil Armstrong		compatible = "regulator-fixed";
68fd477164SNeil Armstrong		regulator-name = "VDDAO_3V3";
69fd477164SNeil Armstrong		regulator-min-microvolt = <3300000>;
70fd477164SNeil Armstrong		regulator-max-microvolt = <3300000>;
71fd477164SNeil Armstrong	};
72fd477164SNeil Armstrong
73fd477164SNeil Armstrong	vddio_ao18: regulator-vddio_ao18 {
74fd477164SNeil Armstrong		compatible = "regulator-fixed";
75fd477164SNeil Armstrong		regulator-name = "VDDIO_AO18";
76fd477164SNeil Armstrong		regulator-min-microvolt = <1800000>;
77fd477164SNeil Armstrong		regulator-max-microvolt = <1800000>;
78fd477164SNeil Armstrong	};
79fd477164SNeil Armstrong
80fd477164SNeil Armstrong	vcc_3v3: regulator-vcc_3v3 {
81fd477164SNeil Armstrong		compatible = "regulator-fixed";
82fd477164SNeil Armstrong		regulator-name = "VCC_3V3";
83fd477164SNeil Armstrong		regulator-min-microvolt = <3300000>;
84fd477164SNeil Armstrong		regulator-max-microvolt = <3300000>;
85fd477164SNeil Armstrong	};
86fd477164SNeil Armstrong
87fd477164SNeil Armstrong	emmc_pwrseq: emmc-pwrseq {
88fd477164SNeil Armstrong		compatible = "mmc-pwrseq-emmc";
89fd477164SNeil Armstrong		reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>;
90fd477164SNeil Armstrong	};
91fd477164SNeil Armstrong
92fd477164SNeil Armstrong	wifi32k: wifi32k {
93fd477164SNeil Armstrong		compatible = "pwm-clock";
94fd477164SNeil Armstrong		#clock-cells = <0>;
95fd477164SNeil Armstrong		clock-frequency = <32768>;
96fd477164SNeil Armstrong		pwms = <&pwm_ef 0 30518 0>; /* PWM_E at 32.768KHz */
97fd477164SNeil Armstrong	};
98fd477164SNeil Armstrong
99fd477164SNeil Armstrong	sdio_pwrseq: sdio-pwrseq {
100fd477164SNeil Armstrong		compatible = "mmc-pwrseq-simple";
101fd477164SNeil Armstrong		reset-gpios = <&gpio GPIOX_6 GPIO_ACTIVE_LOW>;
102fd477164SNeil Armstrong		clocks = <&wifi32k>;
103fd477164SNeil Armstrong		clock-names = "ext_clock";
104fd477164SNeil Armstrong	};
105fd477164SNeil Armstrong};
106fd477164SNeil Armstrong
107fd477164SNeil Armstrong&cec_AO {
108fd477164SNeil Armstrong	status = "okay";
109fd477164SNeil Armstrong	pinctrl-0 = <&ao_cec_pins>;
110fd477164SNeil Armstrong	pinctrl-names = "default";
111fd477164SNeil Armstrong	hdmi-phandle = <&hdmi_tx>;
112fd477164SNeil Armstrong};
113fd477164SNeil Armstrong
114fd477164SNeil Armstrong&cvbs_vdac_port {
115fd477164SNeil Armstrong	cvbs_vdac_out: endpoint {
116fd477164SNeil Armstrong		remote-endpoint = <&cvbs_connector_in>;
117fd477164SNeil Armstrong	};
118fd477164SNeil Armstrong};
119fd477164SNeil Armstrong
120fd477164SNeil Armstrong&ethmac {
121fd477164SNeil Armstrong	status = "okay";
122fd477164SNeil Armstrong};
123fd477164SNeil Armstrong
124fd477164SNeil Armstrong&internal_phy {
125fd477164SNeil Armstrong	pinctrl-0 = <&eth_link_led_pins>, <&eth_act_led_pins>;
126fd477164SNeil Armstrong	pinctrl-names = "default";
127fd477164SNeil Armstrong};
128fd477164SNeil Armstrong
129fd477164SNeil Armstrong&ir {
130fd477164SNeil Armstrong	status = "okay";
131fd477164SNeil Armstrong	pinctrl-0 = <&remote_input_ao_pins>;
132fd477164SNeil Armstrong	pinctrl-names = "default";
133fd477164SNeil Armstrong};
134fd477164SNeil Armstrong
135fd477164SNeil Armstrong&hdmi_tx {
136fd477164SNeil Armstrong	status = "okay";
137fd477164SNeil Armstrong	pinctrl-0 = <&hdmi_hpd_pins>, <&hdmi_i2c_pins>;
138fd477164SNeil Armstrong	pinctrl-names = "default";
139fd477164SNeil Armstrong};
140fd477164SNeil Armstrong
141fd477164SNeil Armstrong&hdmi_tx_tmds_port {
142fd477164SNeil Armstrong	hdmi_tx_tmds_out: endpoint {
143fd477164SNeil Armstrong		remote-endpoint = <&hdmi_connector_in>;
144fd477164SNeil Armstrong	};
145fd477164SNeil Armstrong};
146fd477164SNeil Armstrong
147fd477164SNeil Armstrong&saradc {
148fd477164SNeil Armstrong	status = "okay";
149fd477164SNeil Armstrong	vref-supply = <&vddio_ao18>;
150fd477164SNeil Armstrong};
151fd477164SNeil Armstrong
152fd477164SNeil Armstrong/* Wireless SDIO Module */
153fd477164SNeil Armstrong&sd_emmc_a {
154fd477164SNeil Armstrong	status = "okay";
155fd477164SNeil Armstrong	pinctrl-0 = <&sdio_pins>;
156fd477164SNeil Armstrong	pinctrl-1 = <&sdio_clk_gate_pins>;
157fd477164SNeil Armstrong	pinctrl-names = "default", "clk-gate";
158fd477164SNeil Armstrong	#address-cells = <1>;
159fd477164SNeil Armstrong	#size-cells = <0>;
160fd477164SNeil Armstrong
161fd477164SNeil Armstrong	bus-width = <4>;
162fd477164SNeil Armstrong	cap-sd-highspeed;
163adc52bf7SJerome Brunet	max-frequency = <50000000>;
164fd477164SNeil Armstrong
165fd477164SNeil Armstrong	non-removable;
166fd477164SNeil Armstrong	disable-wp;
167fd477164SNeil Armstrong
168fd477164SNeil Armstrong	mmc-pwrseq = <&sdio_pwrseq>;
169fd477164SNeil Armstrong
170fd477164SNeil Armstrong	vmmc-supply = <&vddao_3v3>;
171fd477164SNeil Armstrong	vqmmc-supply = <&vddio_boot>;
172fd477164SNeil Armstrong};
173fd477164SNeil Armstrong
174fd477164SNeil Armstrong/* eMMC */
175fd477164SNeil Armstrong&sd_emmc_c {
176fd477164SNeil Armstrong	status = "okay";
177fd477164SNeil Armstrong	pinctrl-0 = <&emmc_pins>, <&emmc_ds_pins>;
178fd477164SNeil Armstrong	pinctrl-1 = <&emmc_clk_gate_pins>;
179fd477164SNeil Armstrong	pinctrl-names = "default", "clk-gate";
180fd477164SNeil Armstrong
181fd477164SNeil Armstrong	bus-width = <8>;
182fd477164SNeil Armstrong	cap-mmc-highspeed;
183fd477164SNeil Armstrong	max-frequency = <200000000>;
184fd477164SNeil Armstrong	non-removable;
185fd477164SNeil Armstrong	disable-wp;
186fd477164SNeil Armstrong	mmc-ddr-1_8v;
187fd477164SNeil Armstrong	mmc-hs200-1_8v;
188fd477164SNeil Armstrong
189fd477164SNeil Armstrong	mmc-pwrseq = <&emmc_pwrseq>;
190fd477164SNeil Armstrong	vmmc-supply = <&vcc_3v3>;
191fd477164SNeil Armstrong	vqmmc-supply = <&vddio_boot>;
192fd477164SNeil Armstrong};
193fd477164SNeil Armstrong
194fd477164SNeil Armstrong&pwm_ef {
195fd477164SNeil Armstrong	status = "okay";
196fd477164SNeil Armstrong	pinctrl-0 = <&pwm_e_pins>;
197fd477164SNeil Armstrong	pinctrl-names = "default";
198fd477164SNeil Armstrong	clocks = <&clkc CLKID_FCLK_DIV4>;
199fd477164SNeil Armstrong	clock-names = "clkin0";
200fd477164SNeil Armstrong};
201fd477164SNeil Armstrong
202fd477164SNeil Armstrong/* This is connected to the Bluetooth module: */
203fd477164SNeil Armstrong&uart_A {
204fd477164SNeil Armstrong	status = "okay";
205fd477164SNeil Armstrong	pinctrl-0 = <&uart_a_pins>, <&uart_a_cts_rts_pins>;
206fd477164SNeil Armstrong	pinctrl-names = "default";
207fd477164SNeil Armstrong	uart-has-rtscts;
208fd477164SNeil Armstrong};
209fd477164SNeil Armstrong
210fd477164SNeil Armstrong&uart_AO {
211fd477164SNeil Armstrong	status = "okay";
212fd477164SNeil Armstrong	pinctrl-0 = <&uart_ao_a_pins>;
213fd477164SNeil Armstrong	pinctrl-names = "default";
214fd477164SNeil Armstrong};
215fd477164SNeil Armstrong
216fd477164SNeil Armstrong&usb0 {
217fd477164SNeil Armstrong	status = "okay";
218fd477164SNeil Armstrong};
219