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 59 60 61 62 63 64 65 66
	clock_audss: clock-controller@03810000 {
		compatible = "samsung,exynos4210-audss-clock";
		reg = <0x03810000 0x0C>;
		#clock-cells = <1>;
	};

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

80 81 82 83 84
	chipid@10000000 {
		compatible = "samsung,exynos4210-chipid";
		reg = <0x10000000 0x100>;
	};

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

90 91
	memory-controller@12570000 {
		compatible = "samsung,exynos4210-srom";
92 93 94
		reg = <0x12570000 0x14>;
	};

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

286
	watchdog: watchdog@10060000 {
287 288
		compatible = "samsung,s3c2410-wdt";
		reg = <0x10060000 0x100>;
289
		interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
290
		clocks = <&clock CLK_WDT>;
291
		clock-names = "watchdog";
292
		status = "disabled";
293 294
	};

295
	rtc: rtc@10070000 {
296 297
		compatible = "samsung,s3c6410-rtc";
		reg = <0x10070000 0x100>;
298
		interrupt-parent = <&pmu_system_controller>;
299 300
		interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
			     <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
301
		clocks = <&clock CLK_RTC>;
302
		clock-names = "rtc";
303
		status = "disabled";
304 305
	};

306
	keypad: keypad@100A0000 {
307 308
		compatible = "samsung,s5pv210-keypad";
		reg = <0x100A0000 0x100>;
309
		interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
310
		clocks = <&clock CLK_KEYIF>;
311
		clock-names = "keypad";
312
		status = "disabled";
313 314
	};

315
	sdhci_0: sdhci@12510000 {
316 317
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12510000 0x100>;
318
		interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
319
		clocks = <&clock CLK_SDMMC0>, <&clock CLK_SCLK_MMC0>;
320
		clock-names = "hsmmc", "mmc_busclk.2";
321
		status = "disabled";
322 323
	};

324
	sdhci_1: sdhci@12520000 {
325 326
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12520000 0x100>;
327
		interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
328
		clocks = <&clock CLK_SDMMC1>, <&clock CLK_SCLK_MMC1>;
329
		clock-names = "hsmmc", "mmc_busclk.2";
330
		status = "disabled";
331 332
	};

333
	sdhci_2: sdhci@12530000 {
334 335
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12530000 0x100>;
336
		interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
337
		clocks = <&clock CLK_SDMMC2>, <&clock CLK_SCLK_MMC2>;
338
		clock-names = "hsmmc", "mmc_busclk.2";
339
		status = "disabled";
340 341
	};

342
	sdhci_3: sdhci@12540000 {
343 344
		compatible = "samsung,exynos4210-sdhci";
		reg = <0x12540000 0x100>;
345
		interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
346
		clocks = <&clock CLK_SDMMC3>, <&clock CLK_SCLK_MMC3>;
347
		clock-names = "hsmmc", "mmc_busclk.2";
348
		status = "disabled";
349 350 351 352 353 354 355 356 357 358
	};

	exynos_usbphy: exynos-usbphy@125B0000 {
		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";
359 360
	};

361
	hsotg: hsotg@12480000 {
362 363
		compatible = "samsung,s3c6400-hsotg";
		reg = <0x12480000 0x20000>;
364
		interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
365 366 367 368 369
		clocks = <&clock CLK_USB_DEVICE>;
		clock-names = "otg";
		phys = <&exynos_usbphy 0>;
		phy-names = "usb2-phy";
		status = "disabled";
370 371
	};

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

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

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

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

440 441 442
	mfc: codec@13400000 {
		compatible = "samsung,mfc-v5";
		reg = <0x13400000 0x10000>;
443
		interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
444
		power-domains = <&pd_mfc>;
445 446
		clocks = <&clock CLK_MFC>, <&clock CLK_SCLK_MFC>;
		clock-names = "mfc", "sclk_mfc";
447 448
		iommus = <&sysmmu_mfc_l>, <&sysmmu_mfc_r>;
		iommu-names = "left", "right";
449 450
	};

451
	serial_0: serial@13800000 {
452 453
		compatible = "samsung,exynos4210-uart";
		reg = <0x13800000 0x100>;
454
		interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
455
		clocks = <&clock CLK_UART0>, <&clock CLK_SCLK_UART0>;
456
		clock-names = "uart", "clk_uart_baud0";
457 458
		dmas = <&pdma0 15>, <&pdma0 16>;
		dma-names = "rx", "tx";
459
		status = "disabled";
460 461
	};

462
	serial_1: serial@13810000 {
463 464
		compatible = "samsung,exynos4210-uart";
		reg = <0x13810000 0x100>;
465
		interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
466
		clocks = <&clock CLK_UART1>, <&clock CLK_SCLK_UART1>;
467
		clock-names = "uart", "clk_uart_baud0";
468 469
		dmas = <&pdma1 15>, <&pdma1 16>;
		dma-names = "rx", "tx";
470
		status = "disabled";
471 472
	};

473
	serial_2: serial@13820000 {
474 475
		compatible = "samsung,exynos4210-uart";
		reg = <0x13820000 0x100>;
476
		interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
477
		clocks = <&clock CLK_UART2>, <&clock CLK_SCLK_UART2>;
478
		clock-names = "uart", "clk_uart_baud0";
479 480
		dmas = <&pdma0 17>, <&pdma0 18>;
		dma-names = "rx", "tx";
481
		status = "disabled";
482 483
	};

484
	serial_3: serial@13830000 {
485 486
		compatible = "samsung,exynos4210-uart";
		reg = <0x13830000 0x100>;
487
		interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
488
		clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>;
489
		clock-names = "uart", "clk_uart_baud0";
490 491
		dmas = <&pdma1 17>, <&pdma1 18>;
		dma-names = "rx", "tx";
492
		status = "disabled";
493 494
	};

495
	i2c_0: i2c@13860000 {
496 497
		#address-cells = <1>;
		#size-cells = <0>;
498 499
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13860000 0x100>;
500
		interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>;
501
		clocks = <&clock CLK_I2C0>;
502
		clock-names = "i2c";
503 504
		pinctrl-names = "default";
		pinctrl-0 = <&i2c0_bus>;
505
		status = "disabled";
506 507
	};

508
	i2c_1: i2c@13870000 {
509 510
		#address-cells = <1>;
		#size-cells = <0>;
511 512
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13870000 0x100>;
513
		interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
514
		clocks = <&clock CLK_I2C1>;
515
		clock-names = "i2c";
516 517
		pinctrl-names = "default";
		pinctrl-0 = <&i2c1_bus>;
518
		status = "disabled";
519 520
	};

521
	i2c_2: i2c@13880000 {
522 523
		#address-cells = <1>;
		#size-cells = <0>;
524 525
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13880000 0x100>;
526
		interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
527
		clocks = <&clock CLK_I2C2>;
528
		clock-names = "i2c";
529 530
		pinctrl-names = "default";
		pinctrl-0 = <&i2c2_bus>;
531
		status = "disabled";
532 533
	};

534
	i2c_3: i2c@13890000 {
535 536
		#address-cells = <1>;
		#size-cells = <0>;
537 538
		compatible = "samsung,s3c2440-i2c";
		reg = <0x13890000 0x100>;
539
		interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
540
		clocks = <&clock CLK_I2C3>;
541
		clock-names = "i2c";
542 543
		pinctrl-names = "default";
		pinctrl-0 = <&i2c3_bus>;
544
		status = "disabled";
545 546
	};

547
	i2c_4: i2c@138A0000 {
548 549
		#address-cells = <1>;
		#size-cells = <0>;
550 551
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138A0000 0x100>;
552
		interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
553
		clocks = <&clock CLK_I2C4>;
554
		clock-names = "i2c";
555 556
		pinctrl-names = "default";
		pinctrl-0 = <&i2c4_bus>;
557
		status = "disabled";
558 559
	};

560
	i2c_5: i2c@138B0000 {
561 562
		#address-cells = <1>;
		#size-cells = <0>;
563 564
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138B0000 0x100>;
565
		interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
566
		clocks = <&clock CLK_I2C5>;
567
		clock-names = "i2c";
568 569
		pinctrl-names = "default";
		pinctrl-0 = <&i2c5_bus>;
570
		status = "disabled";
571 572
	};

573
	i2c_6: i2c@138C0000 {
574 575
		#address-cells = <1>;
		#size-cells = <0>;
576 577
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138C0000 0x100>;
578
		interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
579
		clocks = <&clock CLK_I2C6>;
580
		clock-names = "i2c";
581 582
		pinctrl-names = "default";
		pinctrl-0 = <&i2c6_bus>;
583
		status = "disabled";
584 585
	};

586
	i2c_7: i2c@138D0000 {
587 588
		#address-cells = <1>;
		#size-cells = <0>;
589 590
		compatible = "samsung,s3c2440-i2c";
		reg = <0x138D0000 0x100>;
591
		interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
592
		clocks = <&clock CLK_I2C7>;
593
		clock-names = "i2c";
594 595
		pinctrl-names = "default";
		pinctrl-0 = <&i2c7_bus>;
596
		status = "disabled";
597 598
	};

599 600 601 602 603
	i2c_8: i2c@138E0000 {
		#address-cells = <1>;
		#size-cells = <0>;
		compatible = "samsung,s3c2440-hdmiphy-i2c";
		reg = <0x138E0000 0x100>;
604
		interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
605 606 607 608 609 610 611 612 613 614
		clocks = <&clock CLK_I2C_HDMI>;
		clock-names = "i2c";
		status = "disabled";

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

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

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

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

660
	pwm: pwm@139D0000 {
661 662
		compatible = "samsung,exynos4210-pwm";
		reg = <0x139D0000 0x1000>;
663 664 665 666 667
		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>;
668
		clocks = <&clock CLK_PWM>;
669
		clock-names = "timers";
670
		#pwm-cells = <3>;
671 672 673
		status = "disabled";
	};

674 675 676
	amba {
		#address-cells = <1>;
		#size-cells = <1>;
677
		compatible = "simple-bus";
678 679 680 681 682 683
		interrupt-parent = <&gic>;
		ranges;

		pdma0: pdma@12680000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12680000 0x1000>;
684
			interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
685
			clocks = <&clock CLK_PDMA0>;
686
			clock-names = "apb_pclk";
687 688 689
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
690 691 692 693 694
		};

		pdma1: pdma@12690000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0x12690000 0x1000>;
695
			interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
696
			clocks = <&clock CLK_PDMA1>;
697
			clock-names = "apb_pclk";
698 699 700
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <32>;
701
		};
702 703 704 705

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

	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>;
721
		clocks = <&clock CLK_SCLK_FIMD0>, <&clock CLK_FIMD0>;
722
		clock-names = "sclk_fimd", "fimd";
723
		power-domains = <&pd_lcd0>;
724
		iommus = <&sysmmu_fimd0>;
725
		samsung,sysreg = <&sys_reg>;
726 727
		status = "disabled";
	};
728

729 730 731 732
	tmu: tmu@100C0000 {
		#include "exynos4412-tmu-sensor-conf.dtsi"
	};

733
	jpeg_codec: jpeg-codec@11840000 {
734 735
		compatible = "samsung,exynos4210-jpeg";
		reg = <0x11840000 0x1000>;
736
		interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
737 738 739
		clocks = <&clock CLK_JPEG>;
		clock-names = "jpeg";
		power-domains = <&pd_cam>;
740
		iommus = <&sysmmu_jpeg>;
741 742
	};

743 744 745
	rotator: rotator@12810000 {
		compatible = "samsung,exynos4210-rotator";
		reg = <0x12810000 0x64>;
746
		interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
747 748 749 750 751
		clocks = <&clock CLK_ROTATOR>;
		clock-names = "rotator";
		iommus = <&sysmmu_rotator>;
	};

752 753 754
	hdmi: hdmi@12D00000 {
		compatible = "samsung,exynos4210-hdmi";
		reg = <0x12D00000 0x70000>;
755
		interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
756 757 758 759 760 761 762 763 764
		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>;
		status = "disabled";
765 766 767 768 769
	};

	hdmicec: cec@100B0000 {
		compatible = "samsung,s5p-cec";
		reg = <0x100B0000 0x200>;
770
		interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
771 772 773 774 775 776
		clocks = <&clock CLK_HDMI_CEC>;
		clock-names = "hdmicec";
		samsung,syscon-phandle = <&pmu_system_controller>;
		pinctrl-names = "default";
		pinctrl-0 = <&hdmi_cec>;
		status = "disabled";
777 778 779 780
	};

	mixer: mixer@12C10000 {
		compatible = "samsung,exynos4210-mixer";
781
		interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
782 783
		reg = <0x12C10000 0x2100>, <0x12c00000 0x300>;
		power-domains = <&pd_tv>;
784
		iommus = <&sysmmu_tv>;
785 786 787
		status = "disabled";
	};

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 891 892 893 894
	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";
	};
895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003

	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>;
	};

	sysmmu_tv: sysmmu@12E20000 {
		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>;
	};

	sysmmu_fimc0: sysmmu@11A20000 {
		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>;
	};

	sysmmu_fimc1: sysmmu@11A30000 {
		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>;
	};

	sysmmu_fimc2: sysmmu@11A40000 {
		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>;
	};

	sysmmu_fimc3: sysmmu@11A50000 {
		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>;
	};

	sysmmu_jpeg: sysmmu@11A60000 {
		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>;
	};

	sysmmu_rotator: sysmmu@12A30000 {
		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>;
	};

	sysmmu_fimd0: sysmmu@11E20000 {
		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>;
	};
1004

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

1013 1014 1015 1016 1017 1018
	prng: rng@10830400 {
		compatible = "samsung,exynos4-rng";
		reg = <0x10830400 0x200>;
		clocks = <&clock CLK_SSS>;
		clock-names = "secss";
	};
1019
};