blob: 661c2b425da35c3756965fd1c47a485fe15a3f83 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/remoteproc/qcom,adsp.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Qualcomm ADSP Peripheral Image Loader
8
9maintainers:
10 - Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
11
12description:
13 This document defines the binding for a component that loads and boots
14 firmware on the Qualcomm ADSP Hexagon core.
15
16properties:
17 compatible:
18 enum:
19 - qcom,msm8226-adsp-pil
20 - qcom,msm8953-adsp-pil
21 - qcom,msm8974-adsp-pil
22 - qcom,msm8996-adsp-pil
23 - qcom,msm8996-slpi-pil
24 - qcom,msm8998-adsp-pas
25 - qcom,msm8998-slpi-pas
26 - qcom,sdm660-adsp-pas
27 - qcom,sdm845-adsp-pas
28 - qcom,sdm845-cdsp-pas
29 - qcom,sdm845-slpi-pas
30
31 reg:
32 maxItems: 1
33
34 cx-supply:
35 description: Phandle to the CX regulator
36
37 px-supply:
38 description: Phandle to the PX regulator
39
40 qcom,qmp:
41 $ref: /schemas/types.yaml#/definitions/phandle
42 description: Reference to the AOSS side-channel message RAM.
43
44 memory-region:
45 maxItems: 1
46 description: Reference to the reserved-memory for the Hexagon core
47
48 firmware-name:
49 maxItems: 1
50 description: Firmware name for the Hexagon core
51
52required:
53 - compatible
54 - memory-region
55
56unevaluatedProperties: false
57
58allOf:
59 - $ref: /schemas/remoteproc/qcom,pas-common.yaml#
60 - if:
61 properties:
62 compatible:
63 contains:
64 enum:
65 - qcom,msm8226-adsp-pil
66 - qcom,msm8953-adsp-pil
67 - qcom,msm8974-adsp-pil
68 - qcom,msm8996-adsp-pil
69 - qcom,msm8996-slpi-pil
70 - qcom,msm8998-adsp-pas
71 - qcom,msm8998-slpi-pas
72 - qcom,sdm845-adsp-pas
73 - qcom,sdm845-cdsp-pas
74 - qcom,sdm845-slpi-pas
75 then:
76 properties:
77 clocks:
78 items:
79 - description: XO clock
80 clock-names:
81 items:
82 - const: xo
83
84 - if:
85 properties:
86 compatible:
87 contains:
88 enum:
89 - qcom,msm8226-adsp-pil
90 - qcom,msm8953-adsp-pil
91 - qcom,msm8974-adsp-pil
92 - qcom,msm8996-adsp-pil
93 - qcom,msm8996-slpi-pil
94 - qcom,msm8998-adsp-pas
95 - qcom,msm8998-slpi-pas
96 - qcom,sdm845-adsp-pas
97 - qcom,sdm845-cdsp-pas
98 - qcom,sdm845-slpi-pas
99 then:
100 properties:
101 interrupts:
102 maxItems: 5
103 interrupt-names:
104 maxItems: 5
105
106 - if:
107 properties:
108 compatible:
109 contains:
110 enum:
111 - qcom,msm8974-adsp-pil
112 then:
113 required:
114 - cx-supply
115
116 - if:
117 properties:
118 compatible:
119 contains:
120 enum:
121 - qcom,msm8226-adsp-pil
122 - qcom,msm8953-adsp-pil
123 - qcom,msm8996-adsp-pil
124 - qcom,msm8998-adsp-pas
125 then:
126 properties:
127 power-domains:
128 items:
129 - description: CX power domain
130 power-domain-names:
131 items:
132 - const: cx
133
134 - if:
135 properties:
136 compatible:
137 contains:
138 enum:
139 - qcom,msm8996-slpi-pil
140 - qcom,msm8998-slpi-pas
141 then:
142 properties:
143 power-domains:
144 items:
145 - description: SSC-CX power domain
146 power-domain-names:
147 items:
148 - const: ssc_cx
149 required:
150 - px-supply
151
152 - if:
153 properties:
154 compatible:
155 enum:
156 - qcom,sdm845-slpi-pas
157 then:
158 properties:
159 power-domains:
160 items:
161 - description: LCX power domain
162 - description: LMX power domain
163 power-domain-names:
164 items:
165 - const: lcx
166 - const: lmx
167
168 - if:
169 properties:
170 compatible:
171 contains:
172 enum:
173 - qcom,msm8226-adsp-pil
174 - qcom,msm8953-adsp-pil
175 - qcom,msm8974-adsp-pil
176 - qcom,msm8996-adsp-pil
177 - qcom,msm8996-slpi-pil
178 - qcom,msm8998-adsp-pas
179 - qcom,msm8998-slpi-pas
180 - qcom,sdm660-adsp-pas
181 then:
182 properties:
183 qcom,qmp: false
184
185examples:
186 - |
187 #include <dt-bindings/clock/qcom,rpmcc.h>
188 #include <dt-bindings/interrupt-controller/arm-gic.h>
189 #include <dt-bindings/interrupt-controller/irq.h>
190 adsp {
191 compatible = "qcom,msm8974-adsp-pil";
192
193 interrupts-extended = <&intc GIC_SPI 162 IRQ_TYPE_EDGE_RISING>,
194 <&adsp_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
195 <&adsp_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
196 <&adsp_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
197 <&adsp_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
198 interrupt-names = "wdog",
199 "fatal",
200 "ready",
201 "handover",
202 "stop-ack";
203
204 clocks = <&rpmcc RPM_CXO_CLK>;
205 clock-names = "xo";
206
207 cx-supply = <&pm8841_s2>;
208
209 memory-region = <&adsp_region>;
210
211 qcom,smem-states = <&adsp_smp2p_out 0>;
212 qcom,smem-state-names = "stop";
213
214 smd-edge {
215 interrupts = <GIC_SPI 156 IRQ_TYPE_EDGE_RISING>;
216
217 qcom,ipc = <&apcs 8 8>;
218 qcom,smd-edge = <1>;
219 };
220 };