exynos4.dtsi 8.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
/*
 * Samsung's Exynos4 SoC series common device tree source
 *
 * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd.
 *		http://www.samsung.com
 * Copyright (c) 2010-2011 Linaro Ltd.
 *		www.linaro.org
 *
 * Samsung's Exynos4 SoC series device nodes are listed in this file.  Particular
 * SoCs from Exynos4 series can include this file and provide values for SoCs
 * specfic bindings.
 *
 * Note: This file does not include device nodes for all the controllers in
 * Exynos4 SoCs. As device tree coverage for Exynos4 increases, additional
 * nodes can be added to this file.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

/include/ "skeleton.dtsi"

/ {
	interrupt-parent = <&gic>;

	aliases {
		spi0 = &spi_0;
		spi1 = &spi_1;
		spi2 = &spi_2;
31 32 33 34 35 36 37 38
		i2c0 = &i2c_0;
		i2c1 = &i2c_1;
		i2c2 = &i2c_2;
		i2c3 = &i2c_3;
		i2c4 = &i2c_4;
		i2c5 = &i2c_5;
		i2c6 = &i2c_6;
		i2c7 = &i2c_7;
39 40
	};

41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
	pd_mfc: mfc-power-domain@10023C40 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C40 0x20>;
	};

	pd_g3d: g3d-power-domain@10023C60 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C60 0x20>;
	};

	pd_lcd0: lcd0-power-domain@10023C80 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C80 0x20>;
	};

	pd_tv: tv-power-domain@10023C20 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C20 0x20>;
	};

	pd_cam: cam-power-domain@10023C00 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C00 0x20>;
	};

	pd_gps: gps-power-domain@10023CE0 {
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023CE0 0x20>;
69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
	};

	gic:interrupt-controller@10490000 {
		compatible = "arm,cortex-a9-gic";
		#interrupt-cells = <3>;
		interrupt-controller;
		reg = <0x10490000 0x1000>, <0x10480000 0x100>;
	};

	combiner:interrupt-controller@10440000 {
		compatible = "samsung,exynos4210-combiner";
		#interrupt-cells = <2>;
		interrupt-controller;
		reg = <0x10440000 0x1000>;
	};

	watchdog@10060000 {
		compatible = "samsung,s3c2410-wdt";
		reg = <0x10060000 0x100>;
		interrupts = <0 43 0>;
89 90
		clocks = <&clock 345>;
		clock-names = "watchdog";
91
		status = "disabled";
92 93 94 95 96 97
	};

	rtc@10070000 {
		compatible = "samsung,s3c6410-rtc";
		reg = <0x10070000 0x100>;
		interrupts = <0 44 0>, <0 45 0>;
98 99
		clocks = <&clock 346>;
		clock-names = "rtc";
100
		status = "disabled";
101 102 103 104 105 106
	};

	keypad@100A0000 {
		compatible = "samsung,s5pv210-keypad";
		reg = <0x100A0000 0x100>;
		interrupts = <0 109 0>;
107 108
		clocks = <&clock 347>;
		clock-names = "keypad";
109
		status = "disabled";
110 111 112 113 114 115
	};

	sdhci@12510000 {
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12510000 0x100>;
		interrupts = <0 73 0>;
116 117
		clocks = <&clock 297>, <&clock 145>;
		clock-names = "hsmmc", "mmc_busclk.2";
118
		status = "disabled";
119 120 121 122 123 124
	};

	sdhci@12520000 {
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12520000 0x100>;
		interrupts = <0 74 0>;
125 126
		clocks = <&clock 298>, <&clock 146>;
		clock-names = "hsmmc", "mmc_busclk.2";
127
		status = "disabled";
128 129 130 131 132 133
	};

	sdhci@12530000 {
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12530000 0x100>;
		interrupts = <0 75 0>;
134 135
		clocks = <&clock 299>, <&clock 147>;
		clock-names = "hsmmc", "mmc_busclk.2";
136
		status = "disabled";
137 138 139 140 141 142
	};

	sdhci@12540000 {
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12540000 0x100>;
		interrupts = <0 76 0>;
143 144
		clocks = <&clock 300>, <&clock 148>;
		clock-names = "hsmmc", "mmc_busclk.2";
145
		status = "disabled";
146 147
	};

148 149 150 151 152 153 154 155
	mfc: codec@13400000 {
		compatible = "samsung,mfc-v5";
		reg = <0x13400000 0x10000>;
		interrupts = <0 94 0>;
		samsung,power-domain = <&pd_mfc>;
		status = "disabled";
	};

156 157 158 159
	serial@13800000 {
		compatible = "samsung,exynos4210-uart";
		reg = <0x13800000 0x100>;
		interrupts = <0 52 0>;
160 161
		clocks = <&clock 312>, <&clock 151>;
		clock-names = "uart", "clk_uart_baud0";
162
		status = "disabled";
163 164 165 166 167 168
	};

	serial@13810000 {
		compatible = "samsung,exynos4210-uart";
		reg = <0x13810000 0x100>;
		interrupts = <0 53 0>;
169 170
		clocks = <&clock 313>, <&clock 152>;
		clock-names = "uart", "clk_uart_baud0";
171
		status = "disabled";
172 173 174 175 176 177
	};

	serial@13820000 {
		compatible = "samsung,exynos4210-uart";
		reg = <0x13820000 0x100>;
		interrupts = <0 54 0>;
178 179
		clocks = <&clock 314>, <&clock 153>;
		clock-names = "uart", "clk_uart_baud0";
180
		status = "disabled";
181 182 183 184 185 186
	};

	serial@13830000 {
		compatible = "samsung,exynos4210-uart";
		reg = <0x13830000 0x100>;
		interrupts = <0 55 0>;
187 188
		clocks = <&clock 315>, <&clock 154>;
		clock-names = "uart", "clk_uart_baud0";
189
		status = "disabled";
190 191
	};

192
	i2c_0: i2c@13860000 {
193 194
		#address-cells = <1>;
		#size-cells = <0>;
195 196 197
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13860000 0x100>;
		interrupts = <0 58 0>;
198 199
		clocks = <&clock 317>;
		clock-names = "i2c";
200 201
		pinctrl-names = "default";
		pinctrl-0 = <&i2c0_bus>;
202
		status = "disabled";
203 204
	};

205
	i2c_1: i2c@13870000 {
206 207
		#address-cells = <1>;
		#size-cells = <0>;
208 209 210
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13870000 0x100>;
		interrupts = <0 59 0>;
211 212
		clocks = <&clock 318>;
		clock-names = "i2c";
213 214
		pinctrl-names = "default";
		pinctrl-0 = <&i2c1_bus>;
215
		status = "disabled";
216 217
	};

218
	i2c_2: i2c@13880000 {
219 220
		#address-cells = <1>;
		#size-cells = <0>;
221 222 223
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13880000 0x100>;
		interrupts = <0 60 0>;
224 225
		clocks = <&clock 319>;
		clock-names = "i2c";
226
		status = "disabled";
227 228
	};

229
	i2c_3: i2c@13890000 {
230 231
		#address-cells = <1>;
		#size-cells = <0>;
232 233 234
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13890000 0x100>;
		interrupts = <0 61 0>;
235 236
		clocks = <&clock 320>;
		clock-names = "i2c";
237
		status = "disabled";
238 239
	};

240
	i2c_4: i2c@138A0000 {
241 242
		#address-cells = <1>;
		#size-cells = <0>;
243 244 245
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138A0000 0x100>;
		interrupts = <0 62 0>;
246 247
		clocks = <&clock 321>;
		clock-names = "i2c";
248
		status = "disabled";
249 250
	};

251
	i2c_5: i2c@138B0000 {
252 253
		#address-cells = <1>;
		#size-cells = <0>;
254 255 256
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138B0000 0x100>;
		interrupts = <0 63 0>;
257 258
		clocks = <&clock 322>;
		clock-names = "i2c";
259
		status = "disabled";
260 261
	};

262
	i2c_6: i2c@138C0000 {
263 264
		#address-cells = <1>;
		#size-cells = <0>;
265 266 267
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138C0000 0x100>;
		interrupts = <0 64 0>;
268 269
		clocks = <&clock 323>;
		clock-names = "i2c";
270
		status = "disabled";
271 272
	};

273
	i2c_7: i2c@138D0000 {
274 275
		#address-cells = <1>;
		#size-cells = <0>;
276 277 278
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138D0000 0x100>;
		interrupts = <0 65 0>;
279 280
		clocks = <&clock 324>;
		clock-names = "i2c";
281
		status = "disabled";
282 283 284 285 286 287 288 289 290 291
	};

	spi_0: spi@13920000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13920000 0x100>;
		interrupts = <0 66 0>;
		tx-dma-channel = <&pdma0 7>; /* preliminary */
		rx-dma-channel = <&pdma0 6>; /* preliminary */
		#address-cells = <1>;
		#size-cells = <0>;
292 293
		clocks = <&clock 327>, <&clock 159>;
		clock-names = "spi", "spi_busclk0";
294 295
		pinctrl-names = "default";
		pinctrl-0 = <&spi0_bus>;
296
		status = "disabled";
297 298 299 300 301 302 303 304 305 306
	};

	spi_1: spi@13930000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13930000 0x100>;
		interrupts = <0 67 0>;
		tx-dma-channel = <&pdma1 7>; /* preliminary */
		rx-dma-channel = <&pdma1 6>; /* preliminary */
		#address-cells = <1>;
		#size-cells = <0>;
307 308
		clocks = <&clock 328>, <&clock 160>;
		clock-names = "spi", "spi_busclk0";
309 310
		pinctrl-names = "default";
		pinctrl-0 = <&spi1_bus>;
311
		status = "disabled";
312 313 314 315 316 317 318 319 320 321
	};

	spi_2: spi@13940000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13940000 0x100>;
		interrupts = <0 68 0>;
		tx-dma-channel = <&pdma0 9>; /* preliminary */
		rx-dma-channel = <&pdma0 8>; /* preliminary */
		#address-cells = <1>;
		#size-cells = <0>;
322 323
		clocks = <&clock 329>, <&clock 161>;
		clock-names = "spi", "spi_busclk0";
324 325
		pinctrl-names = "default";
		pinctrl-0 = <&spi2_bus>;
326
		status = "disabled";
327 328 329 330 331 332 333 334 335 336 337 338 339
	};

	amba {
		#address-cells = <1>;
		#size-cells = <1>;
		compatible = "arm,amba-bus";
		interrupt-parent = <&gic>;
		ranges;

		pdma0: pdma@12680000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12680000 0x1000>;
			interrupts = <0 35 0>;
340 341
			clocks = <&clock 292>;
			clock-names = "apb_pclk";
342 343 344
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
345 346 347 348 349 350
		};

		pdma1: pdma@12690000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12690000 0x1000>;
			interrupts = <0 36 0>;
351 352
			clocks = <&clock 293>;
			clock-names = "apb_pclk";
353 354 355
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
356
		};
357 358 359 360 361

		mdma1: mdma@12850000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12850000 0x1000>;
			interrupts = <0 34 0>;
362 363
			clocks = <&clock 279>;
			clock-names = "apb_pclk";
364 365 366
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <1>;
367
		};
368 369
	};
};