tegra124.dtsi 30 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072
  1. #include <dt-bindings/clock/tegra124-car.h>
  2. #include <dt-bindings/gpio/tegra-gpio.h>
  3. #include <dt-bindings/memory/tegra124-mc.h>
  4. #include <dt-bindings/pinctrl/pinctrl-tegra.h>
  5. #include <dt-bindings/pinctrl/pinctrl-tegra-xusb.h>
  6. #include <dt-bindings/interrupt-controller/arm-gic.h>
  7. #include <dt-bindings/reset/tegra124-car.h>
  8. #include <dt-bindings/thermal/tegra124-soctherm.h>
  9. #include "skeleton.dtsi"
  10. / {
  11. compatible = "nvidia,tegra124";
  12. interrupt-parent = <&lic>;
  13. pcie-controller@01003000 {
  14. compatible = "nvidia,tegra124-pcie";
  15. device_type = "pci";
  16. reg = <0x01003000 0x00000800 /* PADS registers */
  17. 0x01003800 0x00000800 /* AFI registers */
  18. 0x02000000 0x10000000>; /* configuration space */
  19. reg-names = "pads", "afi", "cs";
  20. interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */
  21. <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */
  22. interrupt-names = "intr", "msi";
  23. #interrupt-cells = <1>;
  24. interrupt-map-mask = <0 0 0 0>;
  25. interrupt-map = <0 0 0 0 &gic GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
  26. bus-range = <0x00 0xff>;
  27. #address-cells = <3>;
  28. #size-cells = <2>;
  29. ranges = <0x82000000 0 0x01000000 0x01000000 0 0x00001000 /* port 0 configuration space */
  30. 0x82000000 0 0x01001000 0x01001000 0 0x00001000 /* port 1 configuration space */
  31. 0x81000000 0 0x0 0x12000000 0 0x00010000 /* downstream I/O (64 KiB) */
  32. 0x82000000 0 0x13000000 0x13000000 0 0x0d000000 /* non-prefetchable memory (208 MiB) */
  33. 0xc2000000 0 0x20000000 0x20000000 0 0x20000000>; /* prefetchable memory (512 MiB) */
  34. clocks = <&tegra_car TEGRA124_CLK_PCIE>,
  35. <&tegra_car TEGRA124_CLK_AFI>,
  36. <&tegra_car TEGRA124_CLK_PLL_E>,
  37. <&tegra_car TEGRA124_CLK_CML0>;
  38. clock-names = "pex", "afi", "pll_e", "cml";
  39. resets = <&tegra_car 70>,
  40. <&tegra_car 72>,
  41. <&tegra_car 74>;
  42. reset-names = "pex", "afi", "pcie_x";
  43. status = "disabled";
  44. phys = <&padctl TEGRA_XUSB_PADCTL_PCIE>;
  45. phy-names = "pcie";
  46. pci@1,0 {
  47. device_type = "pci";
  48. assigned-addresses = <0x82000800 0 0x01000000 0 0x1000>;
  49. reg = <0x000800 0 0 0 0>;
  50. status = "disabled";
  51. #address-cells = <3>;
  52. #size-cells = <2>;
  53. ranges;
  54. nvidia,num-lanes = <2>;
  55. };
  56. pci@2,0 {
  57. device_type = "pci";
  58. assigned-addresses = <0x82001000 0 0x01001000 0 0x1000>;
  59. reg = <0x001000 0 0 0 0>;
  60. status = "disabled";
  61. #address-cells = <3>;
  62. #size-cells = <2>;
  63. ranges;
  64. nvidia,num-lanes = <1>;
  65. };
  66. };
  67. host1x@50000000 {
  68. compatible = "nvidia,tegra124-host1x", "simple-bus";
  69. reg = <0x50000000 0x00034000>;
  70. interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */
  71. <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */
  72. clocks = <&tegra_car TEGRA124_CLK_HOST1X>;
  73. resets = <&tegra_car 28>;
  74. reset-names = "host1x";
  75. #address-cells = <1>;
  76. #size-cells = <1>;
  77. ranges = <0x54000000 0x54000000 0x01000000>;
  78. dc@54200000 {
  79. compatible = "nvidia,tegra124-dc";
  80. reg = <0x54200000 0x00040000>;
  81. interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
  82. clocks = <&tegra_car TEGRA124_CLK_DISP1>,
  83. <&tegra_car TEGRA124_CLK_PLL_P>;
  84. clock-names = "dc", "parent";
  85. resets = <&tegra_car 27>;
  86. reset-names = "dc";
  87. iommus = <&mc TEGRA_SWGROUP_DC>;
  88. nvidia,head = <0>;
  89. };
  90. dc@54240000 {
  91. compatible = "nvidia,tegra124-dc";
  92. reg = <0x54240000 0x00040000>;
  93. interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
  94. clocks = <&tegra_car TEGRA124_CLK_DISP2>,
  95. <&tegra_car TEGRA124_CLK_PLL_P>;
  96. clock-names = "dc", "parent";
  97. resets = <&tegra_car 26>;
  98. reset-names = "dc";
  99. iommus = <&mc TEGRA_SWGROUP_DCB>;
  100. nvidia,head = <1>;
  101. };
  102. hdmi@54280000 {
  103. compatible = "nvidia,tegra124-hdmi";
  104. reg = <0x54280000 0x00040000>;
  105. interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
  106. clocks = <&tegra_car TEGRA124_CLK_HDMI>,
  107. <&tegra_car TEGRA124_CLK_PLL_D2_OUT0>;
  108. clock-names = "hdmi", "parent";
  109. resets = <&tegra_car 51>;
  110. reset-names = "hdmi";
  111. status = "disabled";
  112. };
  113. sor@54540000 {
  114. compatible = "nvidia,tegra124-sor";
  115. reg = <0x54540000 0x00040000>;
  116. interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
  117. clocks = <&tegra_car TEGRA124_CLK_SOR0>,
  118. <&tegra_car TEGRA124_CLK_PLL_D_OUT0>,
  119. <&tegra_car TEGRA124_CLK_PLL_DP>,
  120. <&tegra_car TEGRA124_CLK_CLK_M>;
  121. clock-names = "sor", "parent", "dp", "safe";
  122. resets = <&tegra_car 182>;
  123. reset-names = "sor";
  124. status = "disabled";
  125. };
  126. dpaux: dpaux@545c0000 {
  127. compatible = "nvidia,tegra124-dpaux";
  128. reg = <0x545c0000 0x00040000>;
  129. interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
  130. clocks = <&tegra_car TEGRA124_CLK_DPAUX>,
  131. <&tegra_car TEGRA124_CLK_PLL_DP>;
  132. clock-names = "dpaux", "parent";
  133. resets = <&tegra_car 181>;
  134. reset-names = "dpaux";
  135. status = "disabled";
  136. };
  137. };
  138. gic: interrupt-controller@50041000 {
  139. compatible = "arm,cortex-a15-gic";
  140. #interrupt-cells = <3>;
  141. interrupt-controller;
  142. reg = <0x50041000 0x1000>,
  143. <0x50042000 0x2000>,
  144. <0x50044000 0x2000>,
  145. <0x50046000 0x2000>;
  146. interrupts = <GIC_PPI 9
  147. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
  148. interrupt-parent = <&gic>;
  149. };
  150. gpu@57000000 {
  151. compatible = "nvidia,gk20a";
  152. reg = <0x57000000 0x01000000>,
  153. <0x58000000 0x01000000>;
  154. interrupts = <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>,
  155. <GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>;
  156. interrupt-names = "stall", "nonstall";
  157. clocks = <&tegra_car TEGRA124_CLK_GPU>,
  158. <&tegra_car TEGRA124_CLK_PLL_P_OUT5>;
  159. clock-names = "gpu", "pwr";
  160. resets = <&tegra_car 184>;
  161. reset-names = "gpu";
  162. iommus = <&mc TEGRA_SWGROUP_GPU>;
  163. status = "disabled";
  164. };
  165. lic: interrupt-controller@60004000 {
  166. compatible = "nvidia,tegra124-ictlr", "nvidia,tegra30-ictlr";
  167. reg = <0x0 0x60004000 0x0 0x100>,
  168. <0x0 0x60004100 0x0 0x100>,
  169. <0x0 0x60004200 0x0 0x100>,
  170. <0x0 0x60004300 0x0 0x100>,
  171. <0x0 0x60004400 0x0 0x100>;
  172. interrupt-controller;
  173. #interrupt-cells = <3>;
  174. interrupt-parent = <&gic>;
  175. };
  176. timer@60005000 {
  177. compatible = "nvidia,tegra124-timer", "nvidia,tegra30-timer", "nvidia,tegra20-timer";
  178. reg = <0x60005000 0x400>;
  179. interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
  180. <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
  181. <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
  182. <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
  183. <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
  184. <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
  185. clocks = <&tegra_car TEGRA124_CLK_TIMER>;
  186. };
  187. tegra_car: clock@60006000 {
  188. compatible = "nvidia,tegra124-car";
  189. reg = <0x60006000 0x1000>;
  190. #clock-cells = <1>;
  191. #reset-cells = <1>;
  192. nvidia,external-memory-controller = <&emc>;
  193. };
  194. flow-controller@60007000 {
  195. compatible = "nvidia,tegra124-flowctrl";
  196. reg = <0x60007000 0x1000>;
  197. };
  198. actmon@6000c800 {
  199. compatible = "nvidia,tegra124-actmon";
  200. reg = <0x6000c800 0x400>;
  201. interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
  202. clocks = <&tegra_car TEGRA124_CLK_ACTMON>,
  203. <&tegra_car TEGRA124_CLK_EMC>;
  204. clock-names = "actmon", "emc";
  205. resets = <&tegra_car 119>;
  206. reset-names = "actmon";
  207. };
  208. gpio: gpio@6000d000 {
  209. compatible = "nvidia,tegra124-gpio", "nvidia,tegra30-gpio";
  210. reg = <0x6000d000 0x1000>;
  211. interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
  212. <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
  213. <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
  214. <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
  215. <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
  216. <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
  217. <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
  218. <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>;
  219. #gpio-cells = <2>;
  220. gpio-controller;
  221. #interrupt-cells = <2>;
  222. interrupt-controller;
  223. /*
  224. gpio-ranges = <&pinmux 0 0 251>;
  225. */
  226. };
  227. apbdma: dma@60020000 {
  228. compatible = "nvidia,tegra124-apbdma", "nvidia,tegra148-apbdma";
  229. reg = <0x60020000 0x1400>;
  230. interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
  231. <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
  232. <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
  233. <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
  234. <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
  235. <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
  236. <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
  237. <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
  238. <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
  239. <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
  240. <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
  241. <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
  242. <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
  243. <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
  244. <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
  245. <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
  246. <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
  247. <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
  248. <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
  249. <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
  250. <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
  251. <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
  252. <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
  253. <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
  254. <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
  255. <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
  256. <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
  257. <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
  258. <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
  259. <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
  260. <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
  261. <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
  262. clocks = <&tegra_car TEGRA124_CLK_APBDMA>;
  263. resets = <&tegra_car 34>;
  264. reset-names = "dma";
  265. #dma-cells = <1>;
  266. };
  267. apbmisc@70000800 {
  268. compatible = "nvidia,tegra124-apbmisc", "nvidia,tegra20-apbmisc";
  269. reg = <0x70000800 0x64>, /* Chip revision */
  270. <0x7000e864 0x04>; /* Strapping options */
  271. };
  272. pinmux: pinmux@70000868 {
  273. compatible = "nvidia,tegra124-pinmux";
  274. reg = <0x70000868 0x164>, /* Pad control registers */
  275. <0x70003000 0x434>, /* Mux registers */
  276. <0x70000820 0x008>; /* MIPI pad control */
  277. };
  278. /*
  279. * There are two serial driver i.e. 8250 based simple serial
  280. * driver and APB DMA based serial driver for higher baudrate
  281. * and performace. To enable the 8250 based driver, the compatible
  282. * is "nvidia,tegra124-uart", "nvidia,tegra20-uart" and to enable
  283. * the APB DMA based serial driver, the compatible is
  284. * "nvidia,tegra124-hsuart", "nvidia,tegra30-hsuart".
  285. */
  286. uarta: serial@70006000 {
  287. compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
  288. reg = <0x70006000 0x40>;
  289. reg-shift = <2>;
  290. interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
  291. clocks = <&tegra_car TEGRA124_CLK_UARTA>;
  292. resets = <&tegra_car 6>;
  293. reset-names = "serial";
  294. dmas = <&apbdma 8>, <&apbdma 8>;
  295. dma-names = "rx", "tx";
  296. status = "disabled";
  297. };
  298. uartb: serial@70006040 {
  299. compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
  300. reg = <0x70006040 0x40>;
  301. reg-shift = <2>;
  302. interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
  303. clocks = <&tegra_car TEGRA124_CLK_UARTB>;
  304. resets = <&tegra_car 7>;
  305. reset-names = "serial";
  306. dmas = <&apbdma 9>, <&apbdma 9>;
  307. dma-names = "rx", "tx";
  308. status = "disabled";
  309. };
  310. uartc: serial@70006200 {
  311. compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
  312. reg = <0x70006200 0x40>;
  313. reg-shift = <2>;
  314. interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
  315. clocks = <&tegra_car TEGRA124_CLK_UARTC>;
  316. resets = <&tegra_car 55>;
  317. reset-names = "serial";
  318. dmas = <&apbdma 10>, <&apbdma 10>;
  319. dma-names = "rx", "tx";
  320. status = "disabled";
  321. };
  322. uartd: serial@70006300 {
  323. compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
  324. reg = <0x70006300 0x40>;
  325. reg-shift = <2>;
  326. interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
  327. clocks = <&tegra_car TEGRA124_CLK_UARTD>;
  328. resets = <&tegra_car 65>;
  329. reset-names = "serial";
  330. dmas = <&apbdma 19>, <&apbdma 19>;
  331. dma-names = "rx", "tx";
  332. status = "disabled";
  333. };
  334. pwm: pwm@7000a000 {
  335. compatible = "nvidia,tegra124-pwm", "nvidia,tegra20-pwm";
  336. reg = <0x7000a000 0x100>;
  337. #pwm-cells = <2>;
  338. clocks = <&tegra_car TEGRA124_CLK_PWM>;
  339. resets = <&tegra_car 17>;
  340. reset-names = "pwm";
  341. status = "disabled";
  342. };
  343. i2c@7000c000 {
  344. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  345. reg = <0x7000c000 0x100>;
  346. interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
  347. #address-cells = <1>;
  348. #size-cells = <0>;
  349. clocks = <&tegra_car TEGRA124_CLK_I2C1>;
  350. clock-names = "div-clk";
  351. resets = <&tegra_car 12>;
  352. reset-names = "i2c";
  353. dmas = <&apbdma 21>, <&apbdma 21>;
  354. dma-names = "rx", "tx";
  355. status = "disabled";
  356. };
  357. i2c@7000c400 {
  358. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  359. reg = <0x7000c400 0x100>;
  360. interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
  361. #address-cells = <1>;
  362. #size-cells = <0>;
  363. clocks = <&tegra_car TEGRA124_CLK_I2C2>;
  364. clock-names = "div-clk";
  365. resets = <&tegra_car 54>;
  366. reset-names = "i2c";
  367. dmas = <&apbdma 22>, <&apbdma 22>;
  368. dma-names = "rx", "tx";
  369. status = "disabled";
  370. };
  371. i2c@7000c500 {
  372. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  373. reg = <0x7000c500 0x100>;
  374. interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
  375. #address-cells = <1>;
  376. #size-cells = <0>;
  377. clocks = <&tegra_car TEGRA124_CLK_I2C3>;
  378. clock-names = "div-clk";
  379. resets = <&tegra_car 67>;
  380. reset-names = "i2c";
  381. dmas = <&apbdma 23>, <&apbdma 23>;
  382. dma-names = "rx", "tx";
  383. status = "disabled";
  384. };
  385. i2c@7000c700 {
  386. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  387. reg = <0x7000c700 0x100>;
  388. interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
  389. #address-cells = <1>;
  390. #size-cells = <0>;
  391. clocks = <&tegra_car TEGRA124_CLK_I2C4>;
  392. clock-names = "div-clk";
  393. resets = <&tegra_car 103>;
  394. reset-names = "i2c";
  395. dmas = <&apbdma 26>, <&apbdma 26>;
  396. dma-names = "rx", "tx";
  397. status = "disabled";
  398. };
  399. i2c@7000d000 {
  400. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  401. reg = <0x7000d000 0x100>;
  402. interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
  403. #address-cells = <1>;
  404. #size-cells = <0>;
  405. clocks = <&tegra_car TEGRA124_CLK_I2C5>;
  406. clock-names = "div-clk";
  407. resets = <&tegra_car 47>;
  408. reset-names = "i2c";
  409. dmas = <&apbdma 24>, <&apbdma 24>;
  410. dma-names = "rx", "tx";
  411. status = "disabled";
  412. };
  413. i2c@7000d100 {
  414. compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
  415. reg = <0x7000d100 0x100>;
  416. interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
  417. #address-cells = <1>;
  418. #size-cells = <0>;
  419. clocks = <&tegra_car TEGRA124_CLK_I2C6>;
  420. clock-names = "div-clk";
  421. resets = <&tegra_car 166>;
  422. reset-names = "i2c";
  423. dmas = <&apbdma 30>, <&apbdma 30>;
  424. dma-names = "rx", "tx";
  425. status = "disabled";
  426. };
  427. spi@7000d400 {
  428. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  429. reg = <0x7000d400 0x200>;
  430. interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
  431. #address-cells = <1>;
  432. #size-cells = <0>;
  433. clocks = <&tegra_car TEGRA124_CLK_SBC1>;
  434. clock-names = "spi";
  435. resets = <&tegra_car 41>;
  436. reset-names = "spi";
  437. dmas = <&apbdma 15>, <&apbdma 15>;
  438. dma-names = "rx", "tx";
  439. status = "disabled";
  440. };
  441. spi@7000d600 {
  442. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  443. reg = <0x7000d600 0x200>;
  444. interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
  445. #address-cells = <1>;
  446. #size-cells = <0>;
  447. clocks = <&tegra_car TEGRA124_CLK_SBC2>;
  448. clock-names = "spi";
  449. resets = <&tegra_car 44>;
  450. reset-names = "spi";
  451. dmas = <&apbdma 16>, <&apbdma 16>;
  452. dma-names = "rx", "tx";
  453. status = "disabled";
  454. };
  455. spi@7000d800 {
  456. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  457. reg = <0x7000d800 0x200>;
  458. interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
  459. #address-cells = <1>;
  460. #size-cells = <0>;
  461. clocks = <&tegra_car TEGRA124_CLK_SBC3>;
  462. clock-names = "spi";
  463. resets = <&tegra_car 46>;
  464. reset-names = "spi";
  465. dmas = <&apbdma 17>, <&apbdma 17>;
  466. dma-names = "rx", "tx";
  467. status = "disabled";
  468. };
  469. spi@7000da00 {
  470. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  471. reg = <0x7000da00 0x200>;
  472. interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
  473. #address-cells = <1>;
  474. #size-cells = <0>;
  475. clocks = <&tegra_car TEGRA124_CLK_SBC4>;
  476. clock-names = "spi";
  477. resets = <&tegra_car 68>;
  478. reset-names = "spi";
  479. dmas = <&apbdma 18>, <&apbdma 18>;
  480. dma-names = "rx", "tx";
  481. status = "disabled";
  482. };
  483. spi@7000dc00 {
  484. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  485. reg = <0x7000dc00 0x200>;
  486. interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
  487. #address-cells = <1>;
  488. #size-cells = <0>;
  489. clocks = <&tegra_car TEGRA124_CLK_SBC5>;
  490. clock-names = "spi";
  491. resets = <&tegra_car 104>;
  492. reset-names = "spi";
  493. dmas = <&apbdma 27>, <&apbdma 27>;
  494. dma-names = "rx", "tx";
  495. status = "disabled";
  496. };
  497. spi@7000de00 {
  498. compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
  499. reg = <0x7000de00 0x200>;
  500. interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
  501. #address-cells = <1>;
  502. #size-cells = <0>;
  503. clocks = <&tegra_car TEGRA124_CLK_SBC6>;
  504. clock-names = "spi";
  505. resets = <&tegra_car 105>;
  506. reset-names = "spi";
  507. dmas = <&apbdma 28>, <&apbdma 28>;
  508. dma-names = "rx", "tx";
  509. status = "disabled";
  510. };
  511. rtc@7000e000 {
  512. compatible = "nvidia,tegra124-rtc", "nvidia,tegra20-rtc";
  513. reg = <0x7000e000 0x100>;
  514. interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
  515. clocks = <&tegra_car TEGRA124_CLK_RTC>;
  516. };
  517. pmc@7000e400 {
  518. compatible = "nvidia,tegra124-pmc";
  519. reg = <0x7000e400 0x400>;
  520. clocks = <&tegra_car TEGRA124_CLK_PCLK>, <&clk32k_in>;
  521. clock-names = "pclk", "clk32k_in";
  522. };
  523. fuse@7000f800 {
  524. compatible = "nvidia,tegra124-efuse";
  525. reg = <0x7000f800 0x400>;
  526. clocks = <&tegra_car TEGRA124_CLK_FUSE>;
  527. clock-names = "fuse";
  528. resets = <&tegra_car 39>;
  529. reset-names = "fuse";
  530. };
  531. mc: memory-controller@70019000 {
  532. compatible = "nvidia,tegra124-mc";
  533. reg = <0x70019000 0x1000>;
  534. clocks = <&tegra_car TEGRA124_CLK_MC>;
  535. clock-names = "mc";
  536. interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
  537. #iommu-cells = <1>;
  538. };
  539. emc: emc@7001b000 {
  540. compatible = "nvidia,tegra124-emc";
  541. reg = <0x7001b000 0x1000>;
  542. nvidia,memory-controller = <&mc>;
  543. };
  544. sata@70020000 {
  545. compatible = "nvidia,tegra124-ahci";
  546. reg = <0x70027000 0x2000>, /* AHCI */
  547. <0x70020000 0x7000>; /* SATA */
  548. interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
  549. clocks = <&tegra_car TEGRA124_CLK_SATA>,
  550. <&tegra_car TEGRA124_CLK_SATA_OOB>,
  551. <&tegra_car TEGRA124_CLK_CML1>,
  552. <&tegra_car TEGRA124_CLK_PLL_E>;
  553. clock-names = "sata", "sata-oob", "cml1", "pll_e";
  554. resets = <&tegra_car 124>,
  555. <&tegra_car 123>,
  556. <&tegra_car 129>;
  557. reset-names = "sata", "sata-oob", "sata-cold";
  558. phys = <&padctl TEGRA_XUSB_PADCTL_SATA>;
  559. phy-names = "sata-phy";
  560. status = "disabled";
  561. };
  562. hda@70030000 {
  563. compatible = "nvidia,tegra124-hda", "nvidia,tegra30-hda";
  564. reg = <0x70030000 0x10000>;
  565. interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
  566. clocks = <&tegra_car TEGRA124_CLK_HDA>,
  567. <&tegra_car TEGRA124_CLK_HDA2HDMI>,
  568. <&tegra_car TEGRA124_CLK_HDA2CODEC_2X>;
  569. clock-names = "hda", "hda2hdmi", "hda2codec_2x";
  570. resets = <&tegra_car 125>, /* hda */
  571. <&tegra_car 128>, /* hda2hdmi */
  572. <&tegra_car 111>; /* hda2codec_2x */
  573. reset-names = "hda", "hda2hdmi", "hda2codec_2x";
  574. status = "disabled";
  575. };
  576. usb@70090000 {
  577. compatible = "nvidia,tegra124-xusb";
  578. reg = <0x70090000 0x8000>,
  579. <0x70098000 0x1000>,
  580. <0x70099000 0x1000>;
  581. reg-names = "hcd", "fpci", "ipfs";
  582. interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
  583. <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
  584. clocks = <&tegra_car TEGRA124_CLK_XUSB_HOST>,
  585. <&tegra_car TEGRA124_CLK_XUSB_HOST_SRC>,
  586. <&tegra_car TEGRA124_CLK_XUSB_FALCON_SRC>,
  587. <&tegra_car TEGRA124_CLK_XUSB_SS>,
  588. <&tegra_car TEGRA124_CLK_XUSB_SS_DIV2>,
  589. <&tegra_car TEGRA124_CLK_XUSB_SS_SRC>,
  590. <&tegra_car TEGRA124_CLK_XUSB_HS_SRC>,
  591. <&tegra_car TEGRA124_CLK_XUSB_FS_SRC>,
  592. <&tegra_car TEGRA124_CLK_PLL_U_480M>,
  593. <&tegra_car TEGRA124_CLK_CLK_M>,
  594. <&tegra_car TEGRA124_CLK_PLL_E>;
  595. clock-names = "xusb_host", "xusb_host_src",
  596. "xusb_falcon_src", "xusb_ss",
  597. "xusb_ss_div2", "xusb_ss_src",
  598. "xusb_hs_src", "xusb_fs_src",
  599. "pll_u_480m", "clk_m", "pll_e";
  600. resets = <&tegra_car 89>, <&tegra_car 156>,
  601. <&tegra_car 143>;
  602. reset-names = "xusb_host", "xusb_ss", "xusb_src";
  603. nvidia,xusb-padctl = <&padctl>;
  604. status = "disabled";
  605. };
  606. padctl: padctl@7009f000 {
  607. compatible = "nvidia,tegra124-xusb-padctl";
  608. reg = <0x7009f000 0x1000>;
  609. resets = <&tegra_car 142>;
  610. reset-names = "padctl";
  611. #phy-cells = <1>;
  612. };
  613. sdhci@700b0000 {
  614. compatible = "nvidia,tegra124-sdhci";
  615. reg = <0x700b0000 0x200>;
  616. interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
  617. clocks = <&tegra_car TEGRA124_CLK_SDMMC1>;
  618. resets = <&tegra_car 14>;
  619. reset-names = "sdhci";
  620. status = "disabled";
  621. };
  622. sdhci@700b0200 {
  623. compatible = "nvidia,tegra124-sdhci";
  624. reg = <0x700b0200 0x200>;
  625. interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
  626. clocks = <&tegra_car TEGRA124_CLK_SDMMC2>;
  627. resets = <&tegra_car 9>;
  628. reset-names = "sdhci";
  629. status = "disabled";
  630. };
  631. sdhci@700b0400 {
  632. compatible = "nvidia,tegra124-sdhci";
  633. reg = <0x700b0400 0x200>;
  634. interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
  635. clocks = <&tegra_car TEGRA124_CLK_SDMMC3>;
  636. resets = <&tegra_car 69>;
  637. reset-names = "sdhci";
  638. status = "disabled";
  639. };
  640. sdhci@700b0600 {
  641. compatible = "nvidia,tegra124-sdhci";
  642. reg = <0x700b0600 0x200>;
  643. interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
  644. clocks = <&tegra_car TEGRA124_CLK_SDMMC4>;
  645. resets = <&tegra_car 15>;
  646. reset-names = "sdhci";
  647. status = "disabled";
  648. };
  649. soctherm: thermal-sensor@700e2000 {
  650. compatible = "nvidia,tegra124-soctherm";
  651. reg = <0x700e2000 0x1000>;
  652. interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
  653. clocks = <&tegra_car TEGRA124_CLK_TSENSOR>,
  654. <&tegra_car TEGRA124_CLK_SOC_THERM>;
  655. clock-names = "tsensor", "soctherm";
  656. resets = <&tegra_car 78>;
  657. reset-names = "soctherm";
  658. #thermal-sensor-cells = <1>;
  659. };
  660. dfll: clock@70110000 {
  661. compatible = "nvidia,tegra124-dfll";
  662. reg = <0x70110000 0x100>, /* DFLL control */
  663. <0x70110000 0x100>, /* I2C output control */
  664. <0x70110100 0x100>, /* Integrated I2C controller */
  665. <0x70110200 0x100>; /* Look-up table RAM */
  666. interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
  667. clocks = <&tegra_car TEGRA124_CLK_DFLL_SOC>,
  668. <&tegra_car TEGRA124_CLK_DFLL_REF>,
  669. <&tegra_car TEGRA124_CLK_I2C5>;
  670. clock-names = "soc", "ref", "i2c";
  671. resets = <&tegra_car TEGRA124_RST_DFLL_DVCO>;
  672. reset-names = "dvco";
  673. #clock-cells = <0>;
  674. clock-output-names = "dfllCPU_out";
  675. nvidia,sample-rate = <12500>;
  676. nvidia,droop-ctrl = <0x00000f00>;
  677. nvidia,force-mode = <1>;
  678. nvidia,cf = <10>;
  679. nvidia,ci = <0>;
  680. nvidia,cg = <2>;
  681. status = "disabled";
  682. };
  683. ahub@70300000 {
  684. compatible = "nvidia,tegra124-ahub";
  685. reg = <0x70300000 0x200>,
  686. <0x70300800 0x800>,
  687. <0x70300200 0x600>;
  688. interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
  689. clocks = <&tegra_car TEGRA124_CLK_D_AUDIO>,
  690. <&tegra_car TEGRA124_CLK_APBIF>;
  691. clock-names = "d_audio", "apbif";
  692. resets = <&tegra_car 106>, /* d_audio */
  693. <&tegra_car 107>, /* apbif */
  694. <&tegra_car 30>, /* i2s0 */
  695. <&tegra_car 11>, /* i2s1 */
  696. <&tegra_car 18>, /* i2s2 */
  697. <&tegra_car 101>, /* i2s3 */
  698. <&tegra_car 102>, /* i2s4 */
  699. <&tegra_car 108>, /* dam0 */
  700. <&tegra_car 109>, /* dam1 */
  701. <&tegra_car 110>, /* dam2 */
  702. <&tegra_car 10>, /* spdif */
  703. <&tegra_car 153>, /* amx */
  704. <&tegra_car 185>, /* amx1 */
  705. <&tegra_car 154>, /* adx */
  706. <&tegra_car 180>, /* adx1 */
  707. <&tegra_car 186>, /* afc0 */
  708. <&tegra_car 187>, /* afc1 */
  709. <&tegra_car 188>, /* afc2 */
  710. <&tegra_car 189>, /* afc3 */
  711. <&tegra_car 190>, /* afc4 */
  712. <&tegra_car 191>; /* afc5 */
  713. reset-names = "d_audio", "apbif", "i2s0", "i2s1", "i2s2",
  714. "i2s3", "i2s4", "dam0", "dam1", "dam2",
  715. "spdif", "amx", "amx1", "adx", "adx1",
  716. "afc0", "afc1", "afc2", "afc3", "afc4", "afc5";
  717. dmas = <&apbdma 1>, <&apbdma 1>,
  718. <&apbdma 2>, <&apbdma 2>,
  719. <&apbdma 3>, <&apbdma 3>,
  720. <&apbdma 4>, <&apbdma 4>,
  721. <&apbdma 6>, <&apbdma 6>,
  722. <&apbdma 7>, <&apbdma 7>,
  723. <&apbdma 12>, <&apbdma 12>,
  724. <&apbdma 13>, <&apbdma 13>,
  725. <&apbdma 14>, <&apbdma 14>,
  726. <&apbdma 29>, <&apbdma 29>;
  727. dma-names = "rx0", "tx0", "rx1", "tx1", "rx2", "tx2",
  728. "rx3", "tx3", "rx4", "tx4", "rx5", "tx5",
  729. "rx6", "tx6", "rx7", "tx7", "rx8", "tx8",
  730. "rx9", "tx9";
  731. ranges;
  732. #address-cells = <1>;
  733. #size-cells = <1>;
  734. tegra_i2s0: i2s@70301000 {
  735. compatible = "nvidia,tegra124-i2s";
  736. reg = <0x70301000 0x100>;
  737. nvidia,ahub-cif-ids = <4 4>;
  738. clocks = <&tegra_car TEGRA124_CLK_I2S0>;
  739. resets = <&tegra_car 30>;
  740. reset-names = "i2s";
  741. status = "disabled";
  742. };
  743. tegra_i2s1: i2s@70301100 {
  744. compatible = "nvidia,tegra124-i2s";
  745. reg = <0x70301100 0x100>;
  746. nvidia,ahub-cif-ids = <5 5>;
  747. clocks = <&tegra_car TEGRA124_CLK_I2S1>;
  748. resets = <&tegra_car 11>;
  749. reset-names = "i2s";
  750. status = "disabled";
  751. };
  752. tegra_i2s2: i2s@70301200 {
  753. compatible = "nvidia,tegra124-i2s";
  754. reg = <0x70301200 0x100>;
  755. nvidia,ahub-cif-ids = <6 6>;
  756. clocks = <&tegra_car TEGRA124_CLK_I2S2>;
  757. resets = <&tegra_car 18>;
  758. reset-names = "i2s";
  759. status = "disabled";
  760. };
  761. tegra_i2s3: i2s@70301300 {
  762. compatible = "nvidia,tegra124-i2s";
  763. reg = <0x70301300 0x100>;
  764. nvidia,ahub-cif-ids = <7 7>;
  765. clocks = <&tegra_car TEGRA124_CLK_I2S3>;
  766. resets = <&tegra_car 101>;
  767. reset-names = "i2s";
  768. status = "disabled";
  769. };
  770. tegra_i2s4: i2s@70301400 {
  771. compatible = "nvidia,tegra124-i2s";
  772. reg = <0x70301400 0x100>;
  773. nvidia,ahub-cif-ids = <8 8>;
  774. clocks = <&tegra_car TEGRA124_CLK_I2S4>;
  775. resets = <&tegra_car 102>;
  776. reset-names = "i2s";
  777. status = "disabled";
  778. };
  779. };
  780. usb@7d000000 {
  781. compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci";
  782. reg = <0x7d000000 0x4000>;
  783. interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
  784. phy_type = "utmi";
  785. clocks = <&tegra_car TEGRA124_CLK_USBD>;
  786. resets = <&tegra_car 22>;
  787. reset-names = "usb";
  788. nvidia,phy = <&phy1>;
  789. status = "disabled";
  790. };
  791. phy1: usb-phy@7d000000 {
  792. compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
  793. reg = <0x7d000000 0x4000>,
  794. <0x7d000000 0x4000>;
  795. phy_type = "utmi";
  796. clocks = <&tegra_car TEGRA124_CLK_USBD>,
  797. <&tegra_car TEGRA124_CLK_PLL_U>,
  798. <&tegra_car TEGRA124_CLK_USBD>;
  799. clock-names = "reg", "pll_u", "utmi-pads";
  800. resets = <&tegra_car 22>, <&tegra_car 22>;
  801. reset-names = "usb", "utmi-pads";
  802. nvidia,hssync-start-delay = <0>;
  803. nvidia,idle-wait-delay = <17>;
  804. nvidia,elastic-limit = <16>;
  805. nvidia,term-range-adj = <6>;
  806. nvidia,xcvr-setup = <9>;
  807. nvidia,xcvr-lsfslew = <0>;
  808. nvidia,xcvr-lsrslew = <3>;
  809. nvidia,hssquelch-level = <2>;
  810. nvidia,hsdiscon-level = <5>;
  811. nvidia,xcvr-hsslew = <12>;
  812. nvidia,has-utmi-pad-registers;
  813. status = "disabled";
  814. };
  815. usb@7d004000 {
  816. compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci";
  817. reg = <0x7d004000 0x4000>;
  818. interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
  819. phy_type = "utmi";
  820. clocks = <&tegra_car TEGRA124_CLK_USB2>;
  821. resets = <&tegra_car 58>;
  822. reset-names = "usb";
  823. nvidia,phy = <&phy2>;
  824. status = "disabled";
  825. };
  826. phy2: usb-phy@7d004000 {
  827. compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
  828. reg = <0x7d004000 0x4000>,
  829. <0x7d000000 0x4000>;
  830. phy_type = "utmi";
  831. clocks = <&tegra_car TEGRA124_CLK_USB2>,
  832. <&tegra_car TEGRA124_CLK_PLL_U>,
  833. <&tegra_car TEGRA124_CLK_USBD>;
  834. clock-names = "reg", "pll_u", "utmi-pads";
  835. resets = <&tegra_car 58>, <&tegra_car 22>;
  836. reset-names = "usb", "utmi-pads";
  837. nvidia,hssync-start-delay = <0>;
  838. nvidia,idle-wait-delay = <17>;
  839. nvidia,elastic-limit = <16>;
  840. nvidia,term-range-adj = <6>;
  841. nvidia,xcvr-setup = <9>;
  842. nvidia,xcvr-lsfslew = <0>;
  843. nvidia,xcvr-lsrslew = <3>;
  844. nvidia,hssquelch-level = <2>;
  845. nvidia,hsdiscon-level = <5>;
  846. nvidia,xcvr-hsslew = <12>;
  847. status = "disabled";
  848. };
  849. usb@7d008000 {
  850. compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci";
  851. reg = <0x7d008000 0x4000>;
  852. interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
  853. phy_type = "utmi";
  854. clocks = <&tegra_car TEGRA124_CLK_USB3>;
  855. resets = <&tegra_car 59>;
  856. reset-names = "usb";
  857. nvidia,phy = <&phy3>;
  858. status = "disabled";
  859. };
  860. phy3: usb-phy@7d008000 {
  861. compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
  862. reg = <0x7d008000 0x4000>,
  863. <0x7d000000 0x4000>;
  864. phy_type = "utmi";
  865. clocks = <&tegra_car TEGRA124_CLK_USB3>,
  866. <&tegra_car TEGRA124_CLK_PLL_U>,
  867. <&tegra_car TEGRA124_CLK_USBD>;
  868. clock-names = "reg", "pll_u", "utmi-pads";
  869. resets = <&tegra_car 59>, <&tegra_car 22>;
  870. reset-names = "usb", "utmi-pads";
  871. nvidia,hssync-start-delay = <0>;
  872. nvidia,idle-wait-delay = <17>;
  873. nvidia,elastic-limit = <16>;
  874. nvidia,term-range-adj = <6>;
  875. nvidia,xcvr-setup = <9>;
  876. nvidia,xcvr-lsfslew = <0>;
  877. nvidia,xcvr-lsrslew = <3>;
  878. nvidia,hssquelch-level = <2>;
  879. nvidia,hsdiscon-level = <5>;
  880. nvidia,xcvr-hsslew = <12>;
  881. status = "disabled";
  882. };
  883. cpus {
  884. #address-cells = <1>;
  885. #size-cells = <0>;
  886. cpu@0 {
  887. device_type = "cpu";
  888. compatible = "arm,cortex-a15";
  889. reg = <0>;
  890. clocks = <&tegra_car TEGRA124_CLK_CCLK_G>,
  891. <&tegra_car TEGRA124_CLK_CCLK_LP>,
  892. <&tegra_car TEGRA124_CLK_PLL_X>,
  893. <&tegra_car TEGRA124_CLK_PLL_P>,
  894. <&dfll>;
  895. clock-names = "cpu_g", "cpu_lp", "pll_x", "pll_p", "dfll";
  896. /* FIXME: what's the actual transition time? */
  897. clock-latency = <300000>;
  898. };
  899. cpu@1 {
  900. device_type = "cpu";
  901. compatible = "arm,cortex-a15";
  902. reg = <1>;
  903. };
  904. cpu@2 {
  905. device_type = "cpu";
  906. compatible = "arm,cortex-a15";
  907. reg = <2>;
  908. };
  909. cpu@3 {
  910. device_type = "cpu";
  911. compatible = "arm,cortex-a15";
  912. reg = <3>;
  913. };
  914. };
  915. pmu {
  916. compatible = "arm,cortex-a15-pmu";
  917. interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>,
  918. <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
  919. <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>,
  920. <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>;
  921. interrupt-affinity = <&{/cpus/cpu@0}>,
  922. <&{/cpus/cpu@1}>,
  923. <&{/cpus/cpu@2}>,
  924. <&{/cpus/cpu@3}>;
  925. };
  926. thermal-zones {
  927. cpu {
  928. polling-delay-passive = <1000>;
  929. polling-delay = <1000>;
  930. thermal-sensors =
  931. <&soctherm TEGRA124_SOCTHERM_SENSOR_CPU>;
  932. };
  933. mem {
  934. polling-delay-passive = <1000>;
  935. polling-delay = <1000>;
  936. thermal-sensors =
  937. <&soctherm TEGRA124_SOCTHERM_SENSOR_MEM>;
  938. };
  939. gpu {
  940. polling-delay-passive = <1000>;
  941. polling-delay = <1000>;
  942. thermal-sensors =
  943. <&soctherm TEGRA124_SOCTHERM_SENSOR_GPU>;
  944. };
  945. pllx {
  946. polling-delay-passive = <1000>;
  947. polling-delay = <1000>;
  948. thermal-sensors =
  949. <&soctherm TEGRA124_SOCTHERM_SENSOR_PLLX>;
  950. };
  951. };
  952. timer {
  953. compatible = "arm,armv7-timer";
  954. interrupts = <GIC_PPI 13
  955. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  956. <GIC_PPI 14
  957. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  958. <GIC_PPI 11
  959. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
  960. <GIC_PPI 10
  961. (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
  962. interrupt-parent = <&gic>;
  963. };
  964. };