imx8qm.dtsi 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2018-2019 NXP
  4. * Dong Aisheng <[email protected]>
  5. */
  6. #include <dt-bindings/clock/imx8-lpcg.h>
  7. #include <dt-bindings/firmware/imx/rsrc.h>
  8. #include <dt-bindings/gpio/gpio.h>
  9. #include <dt-bindings/interrupt-controller/arm-gic.h>
  10. #include <dt-bindings/pinctrl/pads-imx8qm.h>
  11. / {
  12. interrupt-parent = <&gic>;
  13. #address-cells = <2>;
  14. #size-cells = <2>;
  15. aliases {
  16. mmc0 = &usdhc1;
  17. mmc1 = &usdhc2;
  18. mmc2 = &usdhc3;
  19. serial0 = &lpuart0;
  20. serial1 = &lpuart1;
  21. serial2 = &lpuart2;
  22. serial3 = &lpuart3;
  23. };
  24. cpus {
  25. #address-cells = <2>;
  26. #size-cells = <0>;
  27. cpu-map {
  28. cluster0 {
  29. core0 {
  30. cpu = <&A53_0>;
  31. };
  32. core1 {
  33. cpu = <&A53_1>;
  34. };
  35. core2 {
  36. cpu = <&A53_2>;
  37. };
  38. core3 {
  39. cpu = <&A53_3>;
  40. };
  41. };
  42. cluster1 {
  43. core0 {
  44. cpu = <&A72_0>;
  45. };
  46. core1 {
  47. cpu = <&A72_1>;
  48. };
  49. };
  50. };
  51. A53_0: cpu@0 {
  52. device_type = "cpu";
  53. compatible = "arm,cortex-a53";
  54. reg = <0x0 0x0>;
  55. enable-method = "psci";
  56. i-cache-size = <0x8000>;
  57. i-cache-line-size = <64>;
  58. i-cache-sets = <256>;
  59. d-cache-size = <0x8000>;
  60. d-cache-line-size = <64>;
  61. d-cache-sets = <128>;
  62. next-level-cache = <&A53_L2>;
  63. };
  64. A53_1: cpu@1 {
  65. device_type = "cpu";
  66. compatible = "arm,cortex-a53";
  67. reg = <0x0 0x1>;
  68. enable-method = "psci";
  69. i-cache-size = <0x8000>;
  70. i-cache-line-size = <64>;
  71. i-cache-sets = <256>;
  72. d-cache-size = <0x8000>;
  73. d-cache-line-size = <64>;
  74. d-cache-sets = <128>;
  75. next-level-cache = <&A53_L2>;
  76. };
  77. A53_2: cpu@2 {
  78. device_type = "cpu";
  79. compatible = "arm,cortex-a53";
  80. reg = <0x0 0x2>;
  81. enable-method = "psci";
  82. i-cache-size = <0x8000>;
  83. i-cache-line-size = <64>;
  84. i-cache-sets = <256>;
  85. d-cache-size = <0x8000>;
  86. d-cache-line-size = <64>;
  87. d-cache-sets = <128>;
  88. next-level-cache = <&A53_L2>;
  89. };
  90. A53_3: cpu@3 {
  91. device_type = "cpu";
  92. compatible = "arm,cortex-a53";
  93. reg = <0x0 0x3>;
  94. enable-method = "psci";
  95. i-cache-size = <0x8000>;
  96. i-cache-line-size = <64>;
  97. i-cache-sets = <256>;
  98. d-cache-size = <0x8000>;
  99. d-cache-line-size = <64>;
  100. d-cache-sets = <128>;
  101. next-level-cache = <&A53_L2>;
  102. };
  103. A72_0: cpu@100 {
  104. device_type = "cpu";
  105. compatible = "arm,cortex-a72";
  106. reg = <0x0 0x100>;
  107. enable-method = "psci";
  108. i-cache-size = <0xC000>;
  109. i-cache-line-size = <64>;
  110. i-cache-sets = <256>;
  111. d-cache-size = <0x8000>;
  112. d-cache-line-size = <64>;
  113. d-cache-sets = <256>;
  114. next-level-cache = <&A72_L2>;
  115. };
  116. A72_1: cpu@101 {
  117. device_type = "cpu";
  118. compatible = "arm,cortex-a72";
  119. reg = <0x0 0x101>;
  120. enable-method = "psci";
  121. next-level-cache = <&A72_L2>;
  122. };
  123. A53_L2: l2-cache0 {
  124. compatible = "cache";
  125. cache-level = <2>;
  126. cache-size = <0x100000>;
  127. cache-line-size = <64>;
  128. cache-sets = <1024>;
  129. };
  130. A72_L2: l2-cache1 {
  131. compatible = "cache";
  132. cache-level = <2>;
  133. cache-size = <0x100000>;
  134. cache-line-size = <64>;
  135. cache-sets = <1024>;
  136. };
  137. };
  138. gic: interrupt-controller@51a00000 {
  139. compatible = "arm,gic-v3";
  140. reg = <0x0 0x51a00000 0 0x10000>, /* GIC Dist */
  141. <0x0 0x51b00000 0 0xC0000>, /* GICR */
  142. <0x0 0x52000000 0 0x2000>, /* GICC */
  143. <0x0 0x52010000 0 0x1000>, /* GICH */
  144. <0x0 0x52020000 0 0x20000>; /* GICV */
  145. #interrupt-cells = <3>;
  146. interrupt-controller;
  147. interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
  148. interrupt-parent = <&gic>;
  149. };
  150. pmu {
  151. compatible = "arm,armv8-pmuv3";
  152. interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>;
  153. };
  154. psci {
  155. compatible = "arm,psci-1.0";
  156. method = "smc";
  157. };
  158. timer {
  159. compatible = "arm,armv8-timer";
  160. interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* Physical Secure */
  161. <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* Physical Non-Secure */
  162. <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* Virtual */
  163. <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* Hypervisor */
  164. };
  165. system-controller {
  166. compatible = "fsl,imx-scu";
  167. mbox-names = "tx0",
  168. "rx0",
  169. "gip3";
  170. mboxes = <&lsio_mu1 0 0
  171. &lsio_mu1 1 0
  172. &lsio_mu1 3 3>;
  173. pd: power-controller {
  174. compatible = "fsl,imx8qm-scu-pd", "fsl,scu-pd";
  175. #power-domain-cells = <1>;
  176. };
  177. clk: clock-controller {
  178. compatible = "fsl,imx8qm-clk", "fsl,scu-clk";
  179. #clock-cells = <2>;
  180. };
  181. iomuxc: pinctrl {
  182. compatible = "fsl,imx8qm-iomuxc";
  183. };
  184. rtc: rtc {
  185. compatible = "fsl,imx8qxp-sc-rtc";
  186. };
  187. };
  188. /* sorted in register address */
  189. #include "imx8-ss-img.dtsi"
  190. #include "imx8-ss-dma.dtsi"
  191. #include "imx8-ss-conn.dtsi"
  192. #include "imx8-ss-lsio.dtsi"
  193. };
  194. #include "imx8qm-ss-img.dtsi"
  195. #include "imx8qm-ss-dma.dtsi"
  196. #include "imx8qm-ss-conn.dtsi"
  197. #include "imx8qm-ss-lsio.dtsi"