ipq806x: onhub: Enable adm_dma node
[openwrt/openwrt.git] / target / linux / ipq806x / files / arch / arm / boot / dts / qcom-ipq8064-onhub.dtsi
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright 2014 The ChromiumOS Authors
4 */
5
6 #include "qcom-ipq8064-smb208.dtsi"
7 #include <dt-bindings/gpio/gpio.h>
8 #include <dt-bindings/input/input.h>
9 #include <dt-bindings/soc/qcom,tcsr.h>
10
11 / {
12 aliases {
13 ethernet0 = &gmac0;
14 ethernet1 = &gmac2;
15 mdio-gpio0 = &mdio;
16 serial0 = &gsbi4_serial;
17 };
18
19 chosen {
20 stdout-path = "serial0:115200n8";
21 };
22
23 reserved-memory {
24 #address-cells = <1>;
25 #size-cells = <1>;
26 ranges;
27
28 rsvd@41200000 {
29 reg = <0x41200000 0x300000>;
30 no-map;
31 };
32 };
33
34 keys {
35 compatible = "gpio-keys";
36 pinctrl-0 = <&button_pins>;
37 pinctrl-names = "default";
38
39 reset {
40 label = "reset";
41 gpios = <&qcom_pinmux 16 GPIO_ACTIVE_LOW>;
42 linux,code = <KEY_RESTART>;
43 debounce-interval = <60>;
44 wakeup-source;
45 };
46
47 dev {
48 label = "dev";
49 gpios = <&qcom_pinmux 15 GPIO_ACTIVE_LOW>;
50 linux,code = <KEY_CONFIG>;
51 debounce-interval = <60>;
52 wakeup-source;
53 };
54 };
55
56 mdio: mdio {
57 compatible = "virtual,mdio-gpio";
58 #address-cells = <1>;
59 #size-cells = <0>;
60 gpios = <&qcom_pinmux 1 GPIO_ACTIVE_HIGH>,
61 <&qcom_pinmux 0 GPIO_ACTIVE_HIGH>;
62 pinctrl-0 = <&mdio_pins>;
63 pinctrl-names = "default";
64
65 phy0: ethernet-phy@0 {
66 reg = <0>;
67 qca,ar8327-initvals = <
68 0x00004 0x7600000 /* PAD0_MODE */
69 0x00008 0x1000000 /* PAD5_MODE */
70 0x0000c 0x80 /* PAD6_MODE */
71 0x000e4 0xaa545 /* MAC_POWER_SEL */
72 0x000e0 0xc74164de /* SGMII_CTRL */
73 0x0007c 0x4e /* PORT0_STATUS */
74 0x00094 0x4e /* PORT6_STATUS */
75 >;
76 };
77
78 phy1: ethernet-phy@1 {
79 reg = <1>;
80 };
81 };
82
83 soc {
84 rng@1a500000 {
85 status = "disabled";
86 };
87
88 sound {
89 compatible = "google,storm-audio";
90 qcom,model = "ipq806x-storm";
91 cpu = <&lpass>;
92 codec = <&max98357a>;
93 };
94
95 lpass: lpass@28100000 {
96 status = "okay";
97 pinctrl-names = "default", "idle";
98 pinctrl-0 = <&mi2s_default>;
99 pinctrl-1 = <&mi2s_idle>;
100 };
101
102 max98357a: max98357a {
103 compatible = "maxim,max98357a";
104 #sound-dai-cells = <1>;
105 pinctrl-names = "default";
106 pinctrl-0 = <&sdmode_pins>;
107 sdmode-gpios = <&qcom_pinmux 25 GPIO_ACTIVE_HIGH>;
108 };
109 };
110 };
111
112 &qcom_pinmux {
113 rgmii0_pins: rgmii0_pins {
114 mux {
115 pins = "gpio2", "gpio66";
116 drive-strength = <8>;
117 bias-disable;
118 };
119 };
120 mi2s_pins {
121 mi2s_default: mi2s_default {
122 dout {
123 pins = "gpio32";
124 function = "mi2s";
125 drive-strength = <16>;
126 bias-disable;
127 };
128 sync {
129 pins = "gpio27";
130 function = "mi2s";
131 drive-strength = <16>;
132 bias-disable;
133 };
134 clk {
135 pins = "gpio28";
136 function = "mi2s";
137 drive-strength = <16>;
138 bias-disable;
139 };
140 };
141 mi2s_idle: mi2s_idle {
142 dout {
143 pins = "gpio32";
144 function = "mi2s";
145 drive-strength = <2>;
146 bias-pull-down;
147 };
148 sync {
149 pins = "gpio27";
150 function = "mi2s";
151 drive-strength = <2>;
152 bias-pull-down;
153 };
154 clk {
155 pins = "gpio28";
156 function = "mi2s";
157 drive-strength = <2>;
158 bias-pull-down;
159 };
160 };
161 };
162
163 mdio_pins: mdio_pins {
164 mux {
165 pins = "gpio0", "gpio1";
166 function = "gpio";
167 drive-strength = <8>;
168 bias-disable;
169 };
170 rst {
171 pins = "gpio26";
172 output-low;
173 };
174 };
175
176 sdmode_pins: sdmode_pinmux {
177 pins = "gpio25";
178 function = "gpio";
179 drive-strength = <16>;
180 bias-disable;
181 };
182
183 sdcc1_pins: sdcc1_pinmux {
184 mux {
185 pins = "gpio38", "gpio39", "gpio40",
186 "gpio41", "gpio42", "gpio43",
187 "gpio44", "gpio45", "gpio46",
188 "gpio47";
189 function = "sdc1";
190 };
191 cmd {
192 pins = "gpio45";
193 drive-strength = <10>;
194 bias-pull-up;
195 };
196 data {
197 pins = "gpio38", "gpio39", "gpio40",
198 "gpio41", "gpio43", "gpio44",
199 "gpio46", "gpio47";
200 drive-strength = <10>;
201 bias-pull-up;
202 };
203 clk {
204 pins = "gpio42";
205 drive-strength = <16>;
206 bias-pull-down;
207 };
208 };
209
210 i2c1_pins: i2c1_pinmux {
211 pins = "gpio53", "gpio54";
212 function = "gsbi1";
213 bias-disable;
214 };
215
216 rpm_i2c_pinmux: rpm_i2c_pinmux {
217 mux {
218 pins = "gpio12", "gpio13";
219 function = "gsbi4";
220 drive-strength = <12>;
221 bias-disable;
222 };
223 };
224
225 spi_pins: spi_pins {
226 mux {
227 pins = "gpio18", "gpio19", "gpio21";
228 function = "gsbi5";
229 bias-pull-down;
230 /delete-property/ bias-none;
231 /delete-property/ drive-strength;
232 };
233 data {
234 pins = "gpio18", "gpio19";
235 drive-strength = <10>;
236 };
237 cs {
238 pins = "gpio20";
239 drive-strength = <10>;
240 bias-pull-up;
241 };
242 clk {
243 pins = "gpio21";
244 drive-strength = <12>;
245 };
246 };
247
248 fw_pinmux {
249 wp {
250 pins = "gpio17";
251 output-low;
252 };
253 };
254
255 button_pins: button_pins {
256 recovery {
257 pins = "gpio16";
258 function = "gpio";
259 bias-none;
260 };
261 developer {
262 pins = "gpio15";
263 function = "gpio";
264 bias-none;
265 };
266 };
267
268 spi6_pins: spi6_pins {
269 mux {
270 pins = "gpio55", "gpio56", "gpio58";
271 function = "gsbi6";
272 bias-pull-down;
273 };
274 data {
275 pins = "gpio55", "gpio56";
276 drive-strength = <10>;
277 };
278 cs {
279 pins = "gpio57";
280 drive-strength = <10>;
281 bias-pull-up;
282 output-high;
283 };
284 clk {
285 pins = "gpio58";
286 drive-strength = <12>;
287 };
288 };
289 };
290
291 &adm_dma {
292 status = "okay";
293 };
294
295 &gmac0 {
296 status = "okay";
297 phy-mode = "rgmii";
298 qcom,id = <0>;
299 phy-handle = <&phy1>;
300
301 pinctrl-0 = <&rgmii0_pins>;
302 pinctrl-names = "default";
303
304 fixed-link {
305 speed = <1000>;
306 full-duplex;
307 };
308 };
309
310 &gmac2 {
311 status = "okay";
312 phy-mode = "sgmii";
313 qcom,id = <2>;
314 phy-handle = <&phy0>;
315
316 fixed-link {
317 speed = <1000>;
318 full-duplex;
319 };
320 };
321
322 &gsbi1 {
323 status = "okay";
324 qcom,mode = <GSBI_PROT_I2C_UART>;
325 };
326
327 &gsbi1_i2c {
328 status = "okay";
329
330 clock-frequency = <100000>;
331
332 pinctrl-0 = <&i2c1_pins>;
333 pinctrl-names = "default";
334
335 tpm@20 {
336 compatible = "infineon,slb9645tt";
337 reg = <0x20>;
338 powered-while-suspended;
339 };
340 };
341
342 &gsbi4 {
343 status = "okay";
344 qcom,mode = <GSBI_PROT_I2C_UART>;
345 };
346
347 &gsbi4_serial {
348 status = "okay";
349 };
350
351 &gsbi5 {
352 status = "okay";
353 qcom,mode = <GSBI_PROT_SPI>;
354
355 spi4: spi@1a280000 {
356 status = "okay";
357 spi-max-frequency = <50000000>;
358 pinctrl-0 = <&spi_pins>;
359 pinctrl-names = "default";
360
361 cs-gpios = <&qcom_pinmux 20 0>;
362
363 flash: flash@0 {
364 compatible = "jedec,spi-nor";
365 spi-max-frequency = <50000000>;
366 reg = <0>;
367 };
368 };
369 };
370
371 &gsbi6 {
372 status = "okay";
373 qcom,mode = <GSBI_PROT_SPI>;
374 };
375
376 &gsbi6_spi {
377 status = "okay";
378 spi-max-frequency = <25000000>;
379
380 pinctrl-0 = <&spi6_pins>;
381 pinctrl-names = "default";
382
383 cs-gpios = <&qcom_pinmux 57 GPIO_ACTIVE_HIGH>;
384
385 dmas = <&adm_dma 8 0xb>,
386 <&adm_dma 7 0x14>;
387 dma-names = "rx", "tx";
388
389 /*
390 * This "spidev" was included in the manufacturer device tree. I suspect
391 * it's the (unused) Zigbee radio -- SiliconLabs EM3581 Zigbee? There's
392 * no driver or binding for this at the moment.
393 */
394 spidev@0 {
395 compatible = "spidev";
396 reg = <0>;
397 spi-max-frequency = <25000000>;
398 };
399 };
400
401 &pcie0 {
402 status = "okay";
403
404 pcie@0 {
405 reg = <0 0 0 0 0>;
406 #interrupt-cells = <1>;
407 #size-cells = <2>;
408 #address-cells = <3>;
409 device_type = "pci";
410
411 ath10k@0,0 {
412 reg = <0 0 0 0 0>;
413 device_type = "pci";
414 qcom,ath10k-sa-gpio = <2 3 4 0>;
415 qcom,ath10k-sa-gpio-func = <5 5 5 0>;
416 };
417 };
418 };
419
420 &pcie1 {
421 status = "okay";
422
423 pcie@0 {
424 reg = <0 0 0 0 0>;
425 #interrupt-cells = <1>;
426 #size-cells = <2>;
427 #address-cells = <3>;
428 device_type = "pci";
429
430 ath10k@0,0 {
431 reg = <0 0 0 0 0>;
432 device_type = "pci";
433 qcom,ath10k-sa-gpio = <2 3 4 0>;
434 qcom,ath10k-sa-gpio-func = <5 5 5 0>;
435 };
436 };
437 };
438
439 &pcie2 {
440 status = "okay";
441
442 pcie@0 {
443 reg = <0 0 0 0 0>;
444 #interrupt-cells = <1>;
445 #size-cells = <2>;
446 #address-cells = <3>;
447 device_type = "pci";
448
449 ath10k@0,0 {
450 reg = <0 0 0 0 0>;
451 device_type = "pci";
452 };
453 };
454 };
455
456 &rpm {
457 pinctrl-0 = <&rpm_i2c_pinmux>;
458 pinctrl-names = "default";
459 };
460
461 &sdcc1 {
462 status = "okay";
463 pinctrl-0 = <&sdcc1_pins>;
464 pinctrl-names = "default";
465 /delete-property/ mmc-ddr-1_8v;
466 };
467
468 &tcsr {
469 compatible = "qcom,tcsr-ipq8064", "qcom,tcsr", "syscon";
470 qcom,usb-ctrl-select = <TCSR_USB_SELECT_USB3_DUAL>;
471 };
472
473 &hs_phy_0 {
474 status = "okay";
475 };
476
477 &ss_phy_0 {
478 status = "okay";
479 };
480
481 &usb3_0 {
482 status = "okay";
483 };
484
485 &hs_phy_1 {
486 status = "okay";
487 };
488
489 &ss_phy_1 {
490 status = "okay";
491 };
492
493 &usb3_1 {
494 status = "okay";
495 };