blob: cb11a87dbc426d18426ac0ae6c83d041e231f680 [file] [log] [blame]
Krzysztof Kozlowskice2f0e02017-12-25 11:40:11 +01001// SPDX-License-Identifier: GPL-2.0
Tomasz Figa4961cfd2013-08-26 02:37:59 +09002/*
3 * Samsung's S3C64xx SoC series common device tree source
4 *
5 * Copyright (c) 2013 Tomasz Figa <tomasz.figa@gmail.com>
6 *
7 * Samsung's S3C64xx SoC series device nodes are listed in this file.
8 * Particular SoCs from S3C64xx series can include this file and provide
9 * values for SoCs specfic bindings.
10 *
11 * Note: This file does not include device nodes for all the controllers in
12 * S3C64xx SoCs. As device tree coverage for S3C64xx increases, additional
13 * nodes can be added to this file.
Tomasz Figa4961cfd2013-08-26 02:37:59 +090014 */
15
Tomasz Figa4961cfd2013-08-26 02:37:59 +090016#include <dt-bindings/clock/samsung,s3c64xx-clock.h>
17
18/ {
Krzysztof Kozlowskid5bb3a82018-05-06 18:03:07 +020019 #address-cells = <1>;
20 #size-cells = <1>;
21
Tomasz Figa4961cfd2013-08-26 02:37:59 +090022 aliases {
23 i2c0 = &i2c0;
24 pinctrl0 = &pinctrl0;
Tomasz Figa1e64f482014-06-26 13:24:35 +020025 serial0 = &uart0;
26 serial1 = &uart1;
27 serial2 = &uart2;
28 serial3 = &uart3;
Tomasz Figa4961cfd2013-08-26 02:37:59 +090029 };
30
31 cpus {
32 #address-cells = <1>;
33 #size-cells = <0>;
34
35 cpu@0 {
36 device_type = "cpu";
Krzysztof Kozlowskia9040232020-09-07 20:33:08 +020037 compatible = "arm,arm1176jzf-s";
Tomasz Figa4961cfd2013-08-26 02:37:59 +090038 reg = <0x0>;
39 };
40 };
41
42 soc: soc {
43 compatible = "simple-bus";
44 #address-cells = <1>;
45 #size-cells = <1>;
46 ranges;
47
48 vic0: interrupt-controller@71200000 {
49 compatible = "arm,pl192-vic";
50 interrupt-controller;
51 reg = <0x71200000 0x1000>;
52 #interrupt-cells = <1>;
53 };
54
55 vic1: interrupt-controller@71300000 {
56 compatible = "arm,pl192-vic";
57 interrupt-controller;
58 reg = <0x71300000 0x1000>;
59 #interrupt-cells = <1>;
60 };
61
62 sdhci0: sdhci@7c200000 {
63 compatible = "samsung,s3c6410-sdhci";
64 reg = <0x7c200000 0x100>;
65 interrupt-parent = <&vic1>;
66 interrupts = <24>;
67 clock-names = "hsmmc", "mmc_busclk.0", "mmc_busclk.2";
68 clocks = <&clocks HCLK_HSMMC0>, <&clocks HCLK_HSMMC0>,
69 <&clocks SCLK_MMC0>;
70 status = "disabled";
71 };
72
73 sdhci1: sdhci@7c300000 {
74 compatible = "samsung,s3c6410-sdhci";
75 reg = <0x7c300000 0x100>;
76 interrupt-parent = <&vic1>;
77 interrupts = <25>;
78 clock-names = "hsmmc", "mmc_busclk.0", "mmc_busclk.2";
79 clocks = <&clocks HCLK_HSMMC1>, <&clocks HCLK_HSMMC1>,
80 <&clocks SCLK_MMC1>;
81 status = "disabled";
82 };
83
84 sdhci2: sdhci@7c400000 {
85 compatible = "samsung,s3c6410-sdhci";
86 reg = <0x7c400000 0x100>;
87 interrupt-parent = <&vic1>;
88 interrupts = <17>;
89 clock-names = "hsmmc", "mmc_busclk.0", "mmc_busclk.2";
90 clocks = <&clocks HCLK_HSMMC2>, <&clocks HCLK_HSMMC2>,
91 <&clocks SCLK_MMC2>;
92 status = "disabled";
93 };
94
95 watchdog: watchdog@7e004000 {
Krzysztof Kozlowski9f553422017-03-11 19:25:26 +020096 compatible = "samsung,s3c6410-wdt";
Tomasz Figa4961cfd2013-08-26 02:37:59 +090097 reg = <0x7e004000 0x1000>;
98 interrupt-parent = <&vic0>;
99 interrupts = <26>;
100 clock-names = "watchdog";
101 clocks = <&clocks PCLK_WDT>;
Tomasz Figa4961cfd2013-08-26 02:37:59 +0900102 };
103
104 i2c0: i2c@7f004000 {
105 compatible = "samsung,s3c2440-i2c";
106 reg = <0x7f004000 0x1000>;
107 interrupt-parent = <&vic1>;
108 interrupts = <18>;
109 clock-names = "i2c";
110 clocks = <&clocks PCLK_IIC0>;
111 status = "disabled";
112 #address-cells = <1>;
113 #size-cells = <0>;
114 };
115
116 uart0: serial@7f005000 {
117 compatible = "samsung,s3c6400-uart";
118 reg = <0x7f005000 0x100>;
119 interrupt-parent = <&vic1>;
120 interrupts = <5>;
121 clock-names = "uart", "clk_uart_baud2",
122 "clk_uart_baud3";
123 clocks = <&clocks PCLK_UART0>, <&clocks PCLK_UART0>,
124 <&clocks SCLK_UART>;
125 status = "disabled";
126 };
127
128 uart1: serial@7f005400 {
129 compatible = "samsung,s3c6400-uart";
130 reg = <0x7f005400 0x100>;
131 interrupt-parent = <&vic1>;
132 interrupts = <6>;
133 clock-names = "uart", "clk_uart_baud2",
134 "clk_uart_baud3";
135 clocks = <&clocks PCLK_UART1>, <&clocks PCLK_UART1>,
136 <&clocks SCLK_UART>;
137 status = "disabled";
138 };
139
140 uart2: serial@7f005800 {
141 compatible = "samsung,s3c6400-uart";
142 reg = <0x7f005800 0x100>;
143 interrupt-parent = <&vic1>;
144 interrupts = <7>;
145 clock-names = "uart", "clk_uart_baud2",
146 "clk_uart_baud3";
147 clocks = <&clocks PCLK_UART2>, <&clocks PCLK_UART2>,
148 <&clocks SCLK_UART>;
149 status = "disabled";
150 };
151
152 uart3: serial@7f005c00 {
153 compatible = "samsung,s3c6400-uart";
154 reg = <0x7f005c00 0x100>;
155 interrupt-parent = <&vic1>;
156 interrupts = <8>;
157 clock-names = "uart", "clk_uart_baud2",
158 "clk_uart_baud3";
159 clocks = <&clocks PCLK_UART3>, <&clocks PCLK_UART3>,
160 <&clocks SCLK_UART>;
161 status = "disabled";
162 };
163
164 pwm: pwm@7f006000 {
165 compatible = "samsung,s3c6400-pwm";
166 reg = <0x7f006000 0x1000>;
167 interrupt-parent = <&vic0>;
168 interrupts = <23>, <24>, <25>, <27>, <28>;
169 clock-names = "timers";
170 clocks = <&clocks PCLK_PWM>;
171 samsung,pwm-outputs = <0>, <1>;
172 #pwm-cells = <3>;
Tomasz Figa4961cfd2013-08-26 02:37:59 +0900173 };
174
175 pinctrl0: pinctrl@7f008000 {
176 compatible = "samsung,s3c64xx-pinctrl";
177 reg = <0x7f008000 0x1000>;
178 interrupt-parent = <&vic1>;
179 interrupts = <21>;
180
181 pctrl_int_map: pinctrl-interrupt-map {
182 interrupt-map = <0 &vic0 0>,
183 <1 &vic0 1>,
184 <2 &vic1 0>,
185 <3 &vic1 1>;
186 #address-cells = <0>;
187 #size-cells = <0>;
188 #interrupt-cells = <1>;
189 };
190
191 wakeup-interrupt-controller {
192 compatible = "samsung,s3c64xx-wakeup-eint";
193 interrupts = <0>, <1>, <2>, <3>;
194 interrupt-parent = <&pctrl_int_map>;
195 };
196 };
197 };
198};
199
200#include "s3c64xx-pinctrl.dtsi"