xref: /linux/scripts/dtc/include-prefixes/arm64/amlogic/meson-g12b-a311d-libretech-cc.dts (revision ec71f661a572a770d7c861cd52a50cbbb0e1a8d1)
1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * Copyright (c) 2023 BayLibre, SAS.
4 * Author: Jerome Brunet <jbrunet@baylibre.com>
5 */
6
7/dts-v1/;
8
9#include <dt-bindings/clock/g12a-clkc.h>
10#include "meson-g12b-a311d.dtsi"
11#include "meson-libretech-cottonwood.dtsi"
12
13/ {
14	compatible = "libretech,aml-a311d-cc", "amlogic,a311d", "amlogic,g12b";
15	model = "Libre Computer AML-A311D-CC Alta";
16
17	vddcpu_a: regulator-vddcpu-a {
18		compatible = "pwm-regulator";
19		regulator-name = "VDDCPU_A";
20		regulator-min-microvolt = <730000>;
21		regulator-max-microvolt = <1011000>;
22		regulator-boot-on;
23		regulator-always-on;
24		pwm-supply = <&dc_in>;
25		pwms = <&pwm_ab 0 1250 0>;
26		pwm-dutycycle-range = <100 0>;
27	};
28
29	sound {
30		model = "LC-ALTA";
31		audio-routing = "TDMOUT_A IN 0", "FRDDR_A OUT 0",
32				"TDMOUT_A IN 1", "FRDDR_B OUT 0",
33				"TDMOUT_A IN 2", "FRDDR_C OUT 0",
34				"TDM_A Playback", "TDMOUT_A OUT",
35				"TDMOUT_B IN 0", "FRDDR_A OUT 1",
36				"TDMOUT_B IN 1", "FRDDR_B OUT 1",
37				"TDMOUT_B IN 2", "FRDDR_C OUT 1",
38				"TDM_B Playback", "TDMOUT_B OUT",
39				"TDMOUT_C IN 0", "FRDDR_A OUT 2",
40				"TDMOUT_C IN 1", "FRDDR_B OUT 2",
41				"TDMOUT_C IN 2", "FRDDR_C OUT 2",
42				"TDM_C Playback", "TDMOUT_C OUT",
43				"TDMIN_A IN 0", "TDM_A Capture",
44				"TDMIN_B IN 0", "TDM_A Capture",
45				"TDMIN_C IN 0", "TDM_A Capture",
46				"TDMIN_A IN 3", "TDM_A Loopback",
47				"TDMIN_B IN 3", "TDM_A Loopback",
48				"TDMIN_C IN 3", "TDM_A Loopback",
49				"TDMIN_A IN 1", "TDM_B Capture",
50				"TDMIN_B IN 1", "TDM_B Capture",
51				"TDMIN_C IN 1", "TDM_B Capture",
52				"TDMIN_A IN 4", "TDM_B Loopback",
53				"TDMIN_B IN 4", "TDM_B Loopback",
54				"TDMIN_C IN 4", "TDM_B Loopback",
55				"TDMIN_A IN 2", "TDM_C Capture",
56				"TDMIN_B IN 2", "TDM_C Capture",
57				"TDMIN_C IN 2", "TDM_C Capture",
58				"TDMIN_A IN 5", "TDM_C Loopback",
59				"TDMIN_B IN 5", "TDM_C Loopback",
60				"TDMIN_C IN 5", "TDM_C Loopback",
61				"TODDR_A IN 0", "TDMIN_A OUT",
62				"TODDR_B IN 0", "TDMIN_A OUT",
63				"TODDR_C IN 0", "TDMIN_A OUT",
64				"TODDR_A IN 1", "TDMIN_B OUT",
65				"TODDR_B IN 1", "TDMIN_B OUT",
66				"TODDR_C IN 1", "TDMIN_B OUT",
67				"TODDR_A IN 2", "TDMIN_C OUT",
68				"TODDR_B IN 2", "TDMIN_C OUT",
69				"TODDR_C IN 2", "TDMIN_C OUT",
70				"Lineout", "ACODEC LOLP",
71				"Lineout", "ACODEC LORP";
72	};
73};
74
75&cpu0 {
76	cpu-supply = <&vddcpu_b>;
77	operating-points-v2 = <&cpu_opp_table_0>;
78	clocks = <&clkc CLKID_CPU_CLK>;
79};
80
81&cpu1 {
82	cpu-supply = <&vddcpu_b>;
83	operating-points-v2 = <&cpu_opp_table_0>;
84	clocks = <&clkc CLKID_CPU_CLK>;
85};
86
87&cpu100 {
88	cpu-supply = <&vddcpu_a>;
89	operating-points-v2 = <&cpub_opp_table_1>;
90	clocks = <&clkc CLKID_CPUB_CLK>;
91};
92
93&cpu101 {
94	cpu-supply = <&vddcpu_a>;
95	operating-points-v2 = <&cpub_opp_table_1>;
96	clocks = <&clkc CLKID_CPUB_CLK>;
97};
98
99&cpu102 {
100	cpu-supply = <&vddcpu_a>;
101	operating-points-v2 = <&cpub_opp_table_1>;
102	clocks = <&clkc CLKID_CPUB_CLK>;
103};
104
105&cpu103 {
106	cpu-supply = <&vddcpu_a>;
107	operating-points-v2 = <&cpub_opp_table_1>;
108	clocks = <&clkc CLKID_CPUB_CLK>;
109};
110
111&pwm_ab {
112	pinctrl-0 = <&pwm_a_e_pins>, <&pwm_b_x7_pins>;
113};
114