exynos4.dtsi 26.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * 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.
 */

22
#include <dt-bindings/clock/exynos4.h>
23
#include <dt-bindings/clock/exynos-audss-clk.h>
24
#include <dt-bindings/interrupt-controller/arm-gic.h>
25
#include <dt-bindings/interrupt-controller/irq.h>
26
#include "exynos-syscon-restart.dtsi"
27 28 29

/ {
	interrupt-parent = <&gic>;
30 31
	#address-cells = <1>;
	#size-cells = <1>;
32 33 34 35 36

	aliases {
		spi0 = &spi_0;
		spi1 = &spi_1;
		spi2 = &spi_2;
37 38 39 40 41 42 43 44
		i2c0 = &i2c_0;
		i2c1 = &i2c_1;
		i2c2 = &i2c_2;
		i2c3 = &i2c_3;
		i2c4 = &i2c_4;
		i2c5 = &i2c_5;
		i2c6 = &i2c_6;
		i2c7 = &i2c_7;
45
		i2c8 = &i2c_8;
46 47 48 49 50 51
		csis0 = &csis_0;
		csis1 = &csis_1;
		fimc0 = &fimc_0;
		fimc1 = &fimc_1;
		fimc2 = &fimc_2;
		fimc3 = &fimc_3;
52 53 54 55
		serial0 = &serial_0;
		serial1 = &serial_1;
		serial2 = &serial_2;
		serial3 = &serial_3;
56 57
	};

58
	clock_audss: clock-controller@3810000 {
59 60 61
		compatible = "samsung,exynos4210-audss-clock";
		reg = <0x03810000 0x0C>;
		#clock-cells = <1>;
62 63 64
		clocks = <&clock CLK_FIN_PLL>, <&clock CLK_FOUT_EPLL>,
			 <&clock CLK_SCLK_AUDIO0>, <&clock CLK_SCLK_AUDIO0>;
		clock-names = "pll_ref", "pll_in", "sclk_audio", "sclk_pcm_in";
65 66
	};

67
	i2s0: i2s@3830000 {
68 69
		compatible = "samsung,s5pv210-i2s";
		reg = <0x03830000 0x100>;
70 71 72 73
		clocks = <&clock_audss EXYNOS_I2S_BUS>,
			 <&clock_audss EXYNOS_DOUT_AUD_BUS>,
			 <&clock_audss EXYNOS_SCLK_I2S>;
		clock-names = "iis", "i2s_opclk0", "i2s_opclk1";
74 75
		#clock-cells = <1>;
		clock-output-names = "i2s_cdclk0";
76 77 78
		dmas = <&pdma0 12>, <&pdma0 11>, <&pdma0 10>;
		dma-names = "tx", "rx", "tx-sec";
		samsung,idma-addr = <0x03000000>;
79
		#sound-dai-cells = <1>;
80 81 82
		status = "disabled";
	};

83 84 85 86 87
	chipid@10000000 {
		compatible = "samsung,exynos4210-chipid";
		reg = <0x10000000 0x100>;
	};

88 89 90 91 92
	scu: snoop-control-unit@10500000 {
		compatible = "arm,cortex-a9-scu";
		reg = <0x10500000 0x2000>;
	};

93 94
	memory-controller@12570000 {
		compatible = "samsung,exynos4210-srom";
95 96 97
		reg = <0x12570000 0x14>;
	};

98
	mipi_phy: video-phy {
99 100
		compatible = "samsung,s5pv210-mipi-video-phy";
		#phy-cells = <1>;
101
		syscon = <&pmu_system_controller>;
102 103
	};

104
	pd_mfc: mfc-power-domain@10023c40 {
105 106
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C40 0x20>;
107
		#power-domain-cells = <0>;
108
		label = "MFC";
109 110
	};

111
	pd_g3d: g3d-power-domain@10023c60 {
112 113
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C60 0x20>;
114
		#power-domain-cells = <0>;
115
		label = "G3D";
116 117
	};

118
	pd_lcd0: lcd0-power-domain@10023c80 {
119 120
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C80 0x20>;
121
		#power-domain-cells = <0>;
122
		label = "LCD0";
123 124
	};

125
	pd_tv: tv-power-domain@10023c20 {
126 127
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C20 0x20>;
128
		#power-domain-cells = <0>;
129
		power-domains = <&pd_lcd0>;
130
		label = "TV";
131 132
	};

133
	pd_cam: cam-power-domain@10023c00 {
134 135
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023C00 0x20>;
136
		#power-domain-cells = <0>;
137
		label = "CAM";
138 139
	};

140
	pd_gps: gps-power-domain@10023ce0 {
141 142
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023CE0 0x20>;
143
		#power-domain-cells = <0>;
144
		label = "GPS";
145 146
	};

147
	pd_gps_alive: gps-alive-power-domain@10023d00 {
148 149
		compatible = "samsung,exynos4210-pd";
		reg = <0x10023D00 0x20>;
150
		#power-domain-cells = <0>;
151
		label = "GPS alive";
152 153
	};

154
	gic: interrupt-controller@10490000 {
155 156 157
		compatible = "arm,cortex-a9-gic";
		#interrupt-cells = <3>;
		interrupt-controller;
158
		reg = <0x10490000 0x10000>, <0x10480000 0x10000>;
159 160
	};

161
	combiner: interrupt-controller@10440000 {
162 163 164 165 166 167
		compatible = "samsung,exynos4210-combiner";
		#interrupt-cells = <2>;
		interrupt-controller;
		reg = <0x10440000 0x1000>;
	};

168 169 170 171 172 173
	pmu {
		compatible = "arm,cortex-a9-pmu";
		interrupt-parent = <&combiner>;
		interrupts = <2 2>, <3 2>;
	};

174
	sys_reg: syscon@10010000 {
175 176 177 178
		compatible = "samsung,exynos4-sysreg", "syscon";
		reg = <0x10010000 0x400>;
	};

179 180 181
	pmu_system_controller: system-controller@10020000 {
		compatible = "samsung,exynos4210-pmu", "syscon";
		reg = <0x10020000 0x4000>;
182 183 184
		interrupt-controller;
		#interrupt-cells = <3>;
		interrupt-parent = <&gic>;
185 186
	};

187
	dsi_0: dsi@11c80000 {
188 189
		compatible = "samsung,exynos4210-mipi-dsi";
		reg = <0x11C80000 0x10000>;
190
		interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
191
		power-domains = <&pd_lcd0>;
192 193
		phys = <&mipi_phy 1>;
		phy-names = "dsim";
194
		clocks = <&clock CLK_DSIM0>, <&clock CLK_SCLK_MIPI0>;
195
		clock-names = "bus_clk", "sclk_mipi";
196 197 198 199 200
		status = "disabled";
		#address-cells = <1>;
		#size-cells = <0>;
	};

201 202 203 204 205
	camera {
		compatible = "samsung,fimc", "simple-bus";
		status = "disabled";
		#address-cells = <1>;
		#size-cells = <1>;
206 207
		#clock-cells = <1>;
		clock-output-names = "cam_a_clkout", "cam_b_clkout";
208 209 210 211 212
		ranges;

		fimc_0: fimc@11800000 {
			compatible = "samsung,exynos4210-fimc";
			reg = <0x11800000 0x1000>;
213
			interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
214
			clocks = <&clock CLK_FIMC0>, <&clock CLK_SCLK_FIMC0>;
215
			clock-names = "fimc", "sclk_fimc";
216
			power-domains = <&pd_cam>;
217
			samsung,sysreg = <&sys_reg>;
218
			iommus = <&sysmmu_fimc0>;
219 220 221 222 223 224
			status = "disabled";
		};

		fimc_1: fimc@11810000 {
			compatible = "samsung,exynos4210-fimc";
			reg = <0x11810000 0x1000>;
225
			interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
226
			clocks = <&clock CLK_FIMC1>, <&clock CLK_SCLK_FIMC1>;
227
			clock-names = "fimc", "sclk_fimc";
228
			power-domains = <&pd_cam>;
229
			samsung,sysreg = <&sys_reg>;
230
			iommus = <&sysmmu_fimc1>;
231 232 233 234 235 236
			status = "disabled";
		};

		fimc_2: fimc@11820000 {
			compatible = "samsung,exynos4210-fimc";
			reg = <0x11820000 0x1000>;
237
			interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
238
			clocks = <&clock CLK_FIMC2>, <&clock CLK_SCLK_FIMC2>;
239
			clock-names = "fimc", "sclk_fimc";
240
			power-domains = <&pd_cam>;
241
			samsung,sysreg = <&sys_reg>;
242
			iommus = <&sysmmu_fimc2>;
243 244 245 246 247 248
			status = "disabled";
		};

		fimc_3: fimc@11830000 {
			compatible = "samsung,exynos4210-fimc";
			reg = <0x11830000 0x1000>;
249
			interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
250
			clocks = <&clock CLK_FIMC3>, <&clock CLK_SCLK_FIMC3>;
251
			clock-names = "fimc", "sclk_fimc";
252
			power-domains = <&pd_cam>;
253
			samsung,sysreg = <&sys_reg>;
254
			iommus = <&sysmmu_fimc3>;
255 256 257 258 259 260
			status = "disabled";
		};

		csis_0: csis@11880000 {
			compatible = "samsung,exynos4210-csis";
			reg = <0x11880000 0x4000>;
261
			interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
262
			clocks = <&clock CLK_CSIS0>, <&clock CLK_SCLK_CSIS0>;
263 264
			clock-names = "csis", "sclk_csis";
			bus-width = <4>;
265
			power-domains = <&pd_cam>;
266 267
			phys = <&mipi_phy 0>;
			phy-names = "csis";
268 269 270 271 272 273 274 275
			status = "disabled";
			#address-cells = <1>;
			#size-cells = <0>;
		};

		csis_1: csis@11890000 {
			compatible = "samsung,exynos4210-csis";
			reg = <0x11890000 0x4000>;
276
			interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
277
			clocks = <&clock CLK_CSIS1>, <&clock CLK_SCLK_CSIS1>;
278 279
			clock-names = "csis", "sclk_csis";
			bus-width = <2>;
280
			power-domains = <&pd_cam>;
281 282
			phys = <&mipi_phy 2>;
			phy-names = "csis";
283 284 285 286 287 288
			status = "disabled";
			#address-cells = <1>;
			#size-cells = <0>;
		};
	};

289
	rtc: rtc@10070000 {
290 291
		compatible = "samsung,s3c6410-rtc";
		reg = <0x10070000 0x100>;
292
		interrupt-parent = <&pmu_system_controller>;
293 294
		interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
295
		clocks = <&clock CLK_RTC>;
296
		clock-names = "rtc";
297
		status = "disabled";
298 299
	};

300
	keypad: keypad@100a0000 {
301 302
		compatible = "samsung,s5pv210-keypad";
		reg = <0x100A0000 0x100>;
303
		interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
304
		clocks = <&clock CLK_KEYIF>;
305
		clock-names = "keypad";
306
		status = "disabled";
307 308
	};

309
	sdhci_0: sdhci@12510000 {
310 311
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12510000 0x100>;
312
		interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
313
		clocks = <&clock CLK_SDMMC0>, <&clock CLK_SCLK_MMC0>;
314
		clock-names = "hsmmc", "mmc_busclk.2";
315
		status = "disabled";
316 317
	};

318
	sdhci_1: sdhci@12520000 {
319 320
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12520000 0x100>;
321
		interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
322
		clocks = <&clock CLK_SDMMC1>, <&clock CLK_SCLK_MMC1>;
323
		clock-names = "hsmmc", "mmc_busclk.2";
324
		status = "disabled";
325 326
	};

327
	sdhci_2: sdhci@12530000 {
328 329
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12530000 0x100>;
330
		interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
331
		clocks = <&clock CLK_SDMMC2>, <&clock CLK_SCLK_MMC2>;
332
		clock-names = "hsmmc", "mmc_busclk.2";
333
		status = "disabled";
334 335
	};

336
	sdhci_3: sdhci@12540000 {
337 338
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12540000 0x100>;
339
		interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
340
		clocks = <&clock CLK_SDMMC3>, <&clock CLK_SCLK_MMC3>;
341
		clock-names = "hsmmc", "mmc_busclk.2";
342
		status = "disabled";
343 344
	};

345
	exynos_usbphy: exynos-usbphy@125b0000 {
346 347 348 349 350 351 352
		compatible = "samsung,exynos4210-usb2-phy";
		reg = <0x125B0000 0x100>;
		samsung,pmureg-phandle = <&pmu_system_controller>;
		clocks = <&clock CLK_USB_DEVICE>, <&clock CLK_XUSBXTI>;
		clock-names = "phy", "ref";
		#phy-cells = <1>;
		status = "disabled";
353 354
	};

355
	hsotg: hsotg@12480000 {
356 357
		compatible = "samsung,s3c6400-hsotg";
		reg = <0x12480000 0x20000>;
358
		interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
359 360 361 362 363
		clocks = <&clock CLK_USB_DEVICE>;
		clock-names = "otg";
		phys = <&exynos_usbphy 0>;
		phy-names = "usb2-phy";
		status = "disabled";
364 365
	};

366
	ehci: ehci@12580000 {
367 368
		compatible = "samsung,exynos4210-ehci";
		reg = <0x12580000 0x100>;
369
		interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
370
		clocks = <&clock CLK_USB_HOST>;
371 372
		clock-names = "usbhost";
		status = "disabled";
373 374 375
		#address-cells = <1>;
		#size-cells = <0>;
		port@0 {
376 377 378
			reg = <0>;
			phys = <&exynos_usbphy 1>;
			status = "disabled";
379 380
		};
		port@1 {
381 382 383
			reg = <1>;
			phys = <&exynos_usbphy 2>;
			status = "disabled";
384 385
		};
		port@2 {
386 387 388
			reg = <2>;
			phys = <&exynos_usbphy 3>;
			status = "disabled";
389
		};
390 391
	};

392
	ohci: ohci@12590000 {
393 394
		compatible = "samsung,exynos4210-ohci";
		reg = <0x12590000 0x100>;
395
		interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
396
		clocks = <&clock CLK_USB_HOST>;
397 398
		clock-names = "usbhost";
		status = "disabled";
399 400 401
		#address-cells = <1>;
		#size-cells = <0>;
		port@0 {
402 403 404
			reg = <0>;
			phys = <&exynos_usbphy 1>;
			status = "disabled";
405
		};
406 407
	};

408
	i2s1: i2s@13960000 {
409
		compatible = "samsung,s3c6410-i2s";
410 411 412
		reg = <0x13960000 0x100>;
		clocks = <&clock CLK_I2S1>;
		clock-names = "iis";
413 414
		#clock-cells = <1>;
		clock-output-names = "i2s_cdclk1";
415 416
		dmas = <&pdma1 12>, <&pdma1 11>;
		dma-names = "tx", "rx";
417
		#sound-dai-cells = <1>;
418 419 420 421
		status = "disabled";
	};

	i2s2: i2s@13970000 {
422
		compatible = "samsung,s3c6410-i2s";
423 424 425
		reg = <0x13970000 0x100>;
		clocks = <&clock CLK_I2S2>;
		clock-names = "iis";
426 427
		#clock-cells = <1>;
		clock-output-names = "i2s_cdclk2";
428 429
		dmas = <&pdma0 14>, <&pdma0 13>;
		dma-names = "tx", "rx";
430
		#sound-dai-cells = <1>;
431 432 433
		status = "disabled";
	};

434 435 436
	mfc: codec@13400000 {
		compatible = "samsung,mfc-v5";
		reg = <0x13400000 0x10000>;
437
		interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
438
		power-domains = <&pd_mfc>;
439 440
		clocks = <&clock CLK_MFC>, <&clock CLK_SCLK_MFC>;
		clock-names = "mfc", "sclk_mfc";
441 442
		iommus = <&sysmmu_mfc_l>, <&sysmmu_mfc_r>;
		iommu-names = "left", "right";
443 444
	};

445
	serial_0: serial@13800000 {
446 447
		compatible = "samsung,exynos4210-uart";
		reg = <0x13800000 0x100>;
448
		interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
449
		clocks = <&clock CLK_UART0>, <&clock CLK_SCLK_UART0>;
450
		clock-names = "uart", "clk_uart_baud0";
451 452
		dmas = <&pdma0 15>, <&pdma0 16>;
		dma-names = "rx", "tx";
453
		status = "disabled";
454 455
	};

456
	serial_1: serial@13810000 {
457 458
		compatible = "samsung,exynos4210-uart";
		reg = <0x13810000 0x100>;
459
		interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
460
		clocks = <&clock CLK_UART1>, <&clock CLK_SCLK_UART1>;
461
		clock-names = "uart", "clk_uart_baud0";
462 463
		dmas = <&pdma1 15>, <&pdma1 16>;
		dma-names = "rx", "tx";
464
		status = "disabled";
465 466
	};

467
	serial_2: serial@13820000 {
468 469
		compatible = "samsung,exynos4210-uart";
		reg = <0x13820000 0x100>;
470
		interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
471
		clocks = <&clock CLK_UART2>, <&clock CLK_SCLK_UART2>;
472
		clock-names = "uart", "clk_uart_baud0";
473 474
		dmas = <&pdma0 17>, <&pdma0 18>;
		dma-names = "rx", "tx";
475
		status = "disabled";
476 477
	};

478
	serial_3: serial@13830000 {
479 480
		compatible = "samsung,exynos4210-uart";
		reg = <0x13830000 0x100>;
481
		interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
482
		clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>;
483
		clock-names = "uart", "clk_uart_baud0";
484 485
		dmas = <&pdma1 17>, <&pdma1 18>;
		dma-names = "rx", "tx";
486
		status = "disabled";
487 488
	};

489
	i2c_0: i2c@13860000 {
490 491
		#address-cells = <1>;
		#size-cells = <0>;
492 493
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13860000 0x100>;
494
		interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>;
495
		clocks = <&clock CLK_I2C0>;
496
		clock-names = "i2c";
497 498
		pinctrl-names = "default";
		pinctrl-0 = <&i2c0_bus>;
499
		status = "disabled";
500 501
	};

502
	i2c_1: i2c@13870000 {
503 504
		#address-cells = <1>;
		#size-cells = <0>;
505 506
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13870000 0x100>;
507
		interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
508
		clocks = <&clock CLK_I2C1>;
509
		clock-names = "i2c";
510 511
		pinctrl-names = "default";
		pinctrl-0 = <&i2c1_bus>;
512
		status = "disabled";
513 514
	};

515
	i2c_2: i2c@13880000 {
516 517
		#address-cells = <1>;
		#size-cells = <0>;
518 519
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13880000 0x100>;
520
		interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
521
		clocks = <&clock CLK_I2C2>;
522
		clock-names = "i2c";
523 524
		pinctrl-names = "default";
		pinctrl-0 = <&i2c2_bus>;
525
		status = "disabled";
526 527
	};

528
	i2c_3: i2c@13890000 {
529 530
		#address-cells = <1>;
		#size-cells = <0>;
531 532
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13890000 0x100>;
533
		interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
534
		clocks = <&clock CLK_I2C3>;
535
		clock-names = "i2c";
536 537
		pinctrl-names = "default";
		pinctrl-0 = <&i2c3_bus>;
538
		status = "disabled";
539 540
	};

541
	i2c_4: i2c@138a0000 {
542 543
		#address-cells = <1>;
		#size-cells = <0>;
544 545
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138A0000 0x100>;
546
		interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
547
		clocks = <&clock CLK_I2C4>;
548
		clock-names = "i2c";
549 550
		pinctrl-names = "default";
		pinctrl-0 = <&i2c4_bus>;
551
		status = "disabled";
552 553
	};

554
	i2c_5: i2c@138b0000 {
555 556
		#address-cells = <1>;
		#size-cells = <0>;
557 558
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138B0000 0x100>;
559
		interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
560
		clocks = <&clock CLK_I2C5>;
561
		clock-names = "i2c";
562 563
		pinctrl-names = "default";
		pinctrl-0 = <&i2c5_bus>;
564
		status = "disabled";
565 566
	};

567
	i2c_6: i2c@138c0000 {
568 569
		#address-cells = <1>;
		#size-cells = <0>;
570 571
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138C0000 0x100>;
572
		interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
573
		clocks = <&clock CLK_I2C6>;
574
		clock-names = "i2c";
575 576
		pinctrl-names = "default";
		pinctrl-0 = <&i2c6_bus>;
577
		status = "disabled";
578 579
	};

580
	i2c_7: i2c@138d0000 {
581 582
		#address-cells = <1>;
		#size-cells = <0>;
583 584
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138D0000 0x100>;
585
		interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
586
		clocks = <&clock CLK_I2C7>;
587
		clock-names = "i2c";
588 589
		pinctrl-names = "default";
		pinctrl-0 = <&i2c7_bus>;
590
		status = "disabled";
591 592
	};

593
	i2c_8: i2c@138e0000 {
594 595 596 597
		#address-cells = <1>;
		#size-cells = <0>;
		compatible = "samsung,s3c2440-hdmiphy-i2c";
		reg = <0x138E0000 0x100>;
598
		interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
599 600 601 602 603 604 605 606 607 608
		clocks = <&clock CLK_I2C_HDMI>;
		clock-names = "i2c";
		status = "disabled";

		hdmi_i2c_phy: hdmiphy@38 {
			compatible = "exynos4210-hdmiphy";
			reg = <0x38>;
		};
	};

609 610 611
	spi_0: spi@13920000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13920000 0x100>;
612
		interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
613 614
		dmas = <&pdma0 7>, <&pdma0 6>;
		dma-names = "tx", "rx";
615 616
		#address-cells = <1>;
		#size-cells = <0>;
617
		clocks = <&clock CLK_SPI0>, <&clock CLK_SCLK_SPI0>;
618
		clock-names = "spi", "spi_busclk0";
619 620
		pinctrl-names = "default";
		pinctrl-0 = <&spi0_bus>;
621
		status = "disabled";
622 623 624 625 626
	};

	spi_1: spi@13930000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13930000 0x100>;
627
		interrupts = <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
628 629
		dmas = <&pdma1 7>, <&pdma1 6>;
		dma-names = "tx", "rx";
630 631
		#address-cells = <1>;
		#size-cells = <0>;
632
		clocks = <&clock CLK_SPI1>, <&clock CLK_SCLK_SPI1>;
633
		clock-names = "spi", "spi_busclk0";
634 635
		pinctrl-names = "default";
		pinctrl-0 = <&spi1_bus>;
636
		status = "disabled";
637 638 639 640 641
	};

	spi_2: spi@13940000 {
		compatible = "samsung,exynos4210-spi";
		reg = <0x13940000 0x100>;
642
		interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>;
643 644
		dmas = <&pdma0 9>, <&pdma0 8>;
		dma-names = "tx", "rx";
645 646
		#address-cells = <1>;
		#size-cells = <0>;
647
		clocks = <&clock CLK_SPI2>, <&clock CLK_SCLK_SPI2>;
648
		clock-names = "spi", "spi_busclk0";
649 650
		pinctrl-names = "default";
		pinctrl-0 = <&spi2_bus>;
651
		status = "disabled";
652 653
	};

654
	pwm: pwm@139d0000 {
655 656
		compatible = "samsung,exynos4210-pwm";
		reg = <0x139D0000 0x1000>;
657 658 659 660 661
		interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
662
		clocks = <&clock CLK_PWM>;
663
		clock-names = "timers";
664
		#pwm-cells = <3>;
665 666 667
		status = "disabled";
	};

668 669 670
	amba {
		#address-cells = <1>;
		#size-cells = <1>;
671
		compatible = "simple-bus";
672 673 674 675 676 677
		interrupt-parent = <&gic>;
		ranges;

		pdma0: pdma@12680000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12680000 0x1000>;
678
			interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
679
			clocks = <&clock CLK_PDMA0>;
680
			clock-names = "apb_pclk";
681 682 683
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
684 685 686 687 688
		};

		pdma1: pdma@12690000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12690000 0x1000>;
689
			interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
690
			clocks = <&clock CLK_PDMA1>;
691
			clock-names = "apb_pclk";
692 693 694
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
695
		};
696 697 698 699

		mdma1: mdma@12850000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12850000 0x1000>;
700
			interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
701
			clocks = <&clock CLK_MDMA>;
702
			clock-names = "apb_pclk";
703 704 705
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <1>;
706
		};
707
	};
708 709 710 711 712 713 714

	fimd: fimd@11c00000 {
		compatible = "samsung,exynos4210-fimd";
		interrupt-parent = <&combiner>;
		reg = <0x11c00000 0x20000>;
		interrupt-names = "fifo", "vsync", "lcd_sys";
		interrupts = <11 0>, <11 1>, <11 2>;
715
		clocks = <&clock CLK_SCLK_FIMD0>, <&clock CLK_FIMD0>;
716
		clock-names = "sclk_fimd", "fimd";
717
		power-domains = <&pd_lcd0>;
718
		iommus = <&sysmmu_fimd0>;
719
		samsung,sysreg = <&sys_reg>;
720 721
		status = "disabled";
	};
722

723
	tmu: tmu@100c0000 {
724 725 726
		#include "exynos4412-tmu-sensor-conf.dtsi"
	};

727
	jpeg_codec: jpeg-codec@11840000 {
728 729
		compatible = "samsung,exynos4210-jpeg";
		reg = <0x11840000 0x1000>;
730
		interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
731 732 733
		clocks = <&clock CLK_JPEG>;
		clock-names = "jpeg";
		power-domains = <&pd_cam>;
734
		iommus = <&sysmmu_jpeg>;
735 736
	};

737 738 739
	rotator: rotator@12810000 {
		compatible = "samsung,exynos4210-rotator";
		reg = <0x12810000 0x64>;
740
		interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
741 742 743 744 745
		clocks = <&clock CLK_ROTATOR>;
		clock-names = "rotator";
		iommus = <&sysmmu_rotator>;
	};

746
	hdmi: hdmi@12d00000 {
747 748
		compatible = "samsung,exynos4210-hdmi";
		reg = <0x12D00000 0x70000>;
749
		interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
750 751 752 753 754 755 756 757
		clock-names = "hdmi", "sclk_hdmi", "sclk_pixel", "sclk_hdmiphy",
			"mout_hdmi";
		clocks = <&clock CLK_HDMI>, <&clock CLK_SCLK_HDMI>,
			<&clock CLK_SCLK_PIXEL>, <&clock CLK_SCLK_HDMIPHY>,
			<&clock CLK_MOUT_HDMI>;
		phy = <&hdmi_i2c_phy>;
		power-domains = <&pd_tv>;
		samsung,syscon-phandle = <&pmu_system_controller>;
758
		#sound-dai-cells = <0>;
759
		status = "disabled";
760 761
	};

762
	hdmicec: cec@100b0000 {
763 764
		compatible = "samsung,s5p-cec";
		reg = <0x100B0000 0x200>;
765
		interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
766 767 768
		clocks = <&clock CLK_HDMI_CEC>;
		clock-names = "hdmicec";
		samsung,syscon-phandle = <&pmu_system_controller>;
769
		hdmi-phandle = <&hdmi>;
770 771 772
		pinctrl-names = "default";
		pinctrl-0 = <&hdmi_cec>;
		status = "disabled";
773 774
	};

775
	mixer: mixer@12c10000 {
776
		compatible = "samsung,exynos4210-mixer";
777
		interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
778 779
		reg = <0x12C10000 0x2100>, <0x12c00000 0x300>;
		power-domains = <&pd_tv>;
780
		iommus = <&sysmmu_tv>;
781 782 783
		status = "disabled";
	};

784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890
	ppmu_dmc0: ppmu_dmc0@106a0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x106a0000 0x2000>;
		clocks = <&clock CLK_PPMUDMC0>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_dmc1: ppmu_dmc1@106b0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x106b0000 0x2000>;
		clocks = <&clock CLK_PPMUDMC1>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_cpu: ppmu_cpu@106c0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x106c0000 0x2000>;
		clocks = <&clock CLK_PPMUCPU>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_acp: ppmu_acp@10ae0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x106e0000 0x2000>;
		status = "disabled";
	};

	ppmu_rightbus: ppmu_rightbus@112a0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x112a0000 0x2000>;
		clocks = <&clock CLK_PPMURIGHT>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_leftbus: ppmu_leftbus0@116a0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x116a0000 0x2000>;
		clocks = <&clock CLK_PPMULEFT>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_camif: ppmu_camif@11ac0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x11ac0000 0x2000>;
		clocks = <&clock CLK_PPMUCAMIF>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_lcd0: ppmu_lcd0@11e40000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x11e40000 0x2000>;
		clocks = <&clock CLK_PPMULCD0>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_fsys: ppmu_g3d@12630000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x12630000 0x2000>;
		status = "disabled";
	};

	ppmu_image: ppmu_image@12aa0000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x12aa0000 0x2000>;
		clocks = <&clock CLK_PPMUIMAGE>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_tv: ppmu_tv@12e40000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x12e40000 0x2000>;
		clocks = <&clock CLK_PPMUTV>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_g3d: ppmu_g3d@13220000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x13220000 0x2000>;
		clocks = <&clock CLK_PPMUG3D>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_mfc_left: ppmu_mfc_left@13660000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x13660000 0x2000>;
		clocks = <&clock CLK_PPMUMFC_L>;
		clock-names = "ppmu";
		status = "disabled";
	};

	ppmu_mfc_right: ppmu_mfc_right@13670000 {
		compatible = "samsung,exynos-ppmu";
		reg = <0x13670000 0x2000>;
		clocks = <&clock CLK_PPMUMFC_R>;
		clock-names = "ppmu";
		status = "disabled";
	};
891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913

	sysmmu_mfc_l: sysmmu@13620000 {
		compatible = "samsung,exynos-sysmmu";
		reg = <0x13620000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <5 5>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_MFCL>, <&clock CLK_MFC>;
		power-domains = <&pd_mfc>;
		#iommu-cells = <0>;
	};

	sysmmu_mfc_r: sysmmu@13630000 {
		compatible = "samsung,exynos-sysmmu";
		reg = <0x13630000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <5 6>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_MFCR>, <&clock CLK_MFC>;
		power-domains = <&pd_mfc>;
		#iommu-cells = <0>;
	};

914
	sysmmu_tv: sysmmu@12e20000 {
915 916 917 918 919 920 921 922 923 924
		compatible = "samsung,exynos-sysmmu";
		reg = <0x12E20000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <5 4>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_TV>, <&clock CLK_MIXER>;
		power-domains = <&pd_tv>;
		#iommu-cells = <0>;
	};

925
	sysmmu_fimc0: sysmmu@11a20000 {
926 927 928 929 930 931 932 933 934 935
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11A20000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <4 2>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_FIMC0>, <&clock CLK_FIMC0>;
		power-domains = <&pd_cam>;
		#iommu-cells = <0>;
	};

936
	sysmmu_fimc1: sysmmu@11a30000 {
937 938 939 940 941 942 943 944 945 946
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11A30000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <4 3>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_FIMC1>, <&clock CLK_FIMC1>;
		power-domains = <&pd_cam>;
		#iommu-cells = <0>;
	};

947
	sysmmu_fimc2: sysmmu@11a40000 {
948 949 950 951 952 953 954 955 956 957
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11A40000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <4 4>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_FIMC2>, <&clock CLK_FIMC2>;
		power-domains = <&pd_cam>;
		#iommu-cells = <0>;
	};

958
	sysmmu_fimc3: sysmmu@11a50000 {
959 960 961 962 963 964 965 966 967 968
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11A50000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <4 5>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_FIMC3>, <&clock CLK_FIMC3>;
		power-domains = <&pd_cam>;
		#iommu-cells = <0>;
	};

969
	sysmmu_jpeg: sysmmu@11a60000 {
970 971 972 973 974 975 976 977 978 979
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11A60000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <4 6>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_JPEG>, <&clock CLK_JPEG>;
		power-domains = <&pd_cam>;
		#iommu-cells = <0>;
	};

980
	sysmmu_rotator: sysmmu@12a30000 {
981 982 983 984 985 986 987 988 989
		compatible = "samsung,exynos-sysmmu";
		reg = <0x12A30000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <5 0>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_ROTATOR>, <&clock CLK_ROTATOR>;
		#iommu-cells = <0>;
	};

990
	sysmmu_fimd0: sysmmu@11e20000 {
991 992 993 994 995 996 997 998 999
		compatible = "samsung,exynos-sysmmu";
		reg = <0x11E20000 0x1000>;
		interrupt-parent = <&combiner>;
		interrupts = <5 2>;
		clock-names = "sysmmu", "master";
		clocks = <&clock CLK_SMMU_FIMD0>, <&clock CLK_FIMD0>;
		power-domains = <&pd_lcd0>;
		#iommu-cells = <0>;
	};
1000

1001 1002 1003
	sss: sss@10830000 {
		compatible = "samsung,exynos4210-secss";
		reg = <0x10830000 0x300>;
1004
		interrupts = <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>;
1005 1006 1007 1008
		clocks = <&clock CLK_SSS>;
		clock-names = "secss";
	};

1009 1010 1011 1012 1013 1014
	prng: rng@10830400 {
		compatible = "samsung,exynos4-rng";
		reg = <0x10830400 0x200>;
		clocks = <&clock CLK_SSS>;
		clock-names = "secss";
	};
1015
};