xref: /OK3568_Linux_fs/kernel/scripts/dtc/include-prefixes/arm/exynos4412-smdk4412.dts (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0
2*4882a593Smuzhiyun/*
3*4882a593Smuzhiyun * Samsung's Exynos4412 based SMDK board device tree source
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (c) 2012-2013 Samsung Electronics Co., Ltd.
6*4882a593Smuzhiyun *		http://www.samsung.com
7*4882a593Smuzhiyun *
8*4882a593Smuzhiyun * Device tree source file for Samsung's SMDK4412 board which is based on
9*4882a593Smuzhiyun * Samsung's Exynos4412 SoC.
10*4882a593Smuzhiyun */
11*4882a593Smuzhiyun
12*4882a593Smuzhiyun/dts-v1/;
13*4882a593Smuzhiyun#include "exynos4412.dtsi"
14*4882a593Smuzhiyun#include "exynos-mfc-reserved-memory.dtsi"
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun/ {
17*4882a593Smuzhiyun	model = "Samsung SMDK evaluation board based on Exynos4412";
18*4882a593Smuzhiyun	compatible = "samsung,smdk4412", "samsung,exynos4412", "samsung,exynos4";
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun	memory@40000000 {
21*4882a593Smuzhiyun		device_type = "memory";
22*4882a593Smuzhiyun		reg = <0x40000000 0x40000000>;
23*4882a593Smuzhiyun	};
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun	chosen {
26*4882a593Smuzhiyun		bootargs = "root=/dev/ram0 rw ramdisk=8192 initrd=0x41000000,8M init=/linuxrc";
27*4882a593Smuzhiyun		stdout-path = "serial1:115200n8";
28*4882a593Smuzhiyun	};
29*4882a593Smuzhiyun
30*4882a593Smuzhiyun	fixed-rate-clocks {
31*4882a593Smuzhiyun		xxti {
32*4882a593Smuzhiyun			compatible = "samsung,clock-xxti";
33*4882a593Smuzhiyun			clock-frequency = <0>;
34*4882a593Smuzhiyun		};
35*4882a593Smuzhiyun
36*4882a593Smuzhiyun		xusbxti {
37*4882a593Smuzhiyun			compatible = "samsung,clock-xusbxti";
38*4882a593Smuzhiyun			clock-frequency = <24000000>;
39*4882a593Smuzhiyun		};
40*4882a593Smuzhiyun
41*4882a593Smuzhiyun		pmic_ap_clk: pmic-ap-clk {
42*4882a593Smuzhiyun			/* Workaround for missing clock on PMIC */
43*4882a593Smuzhiyun			compatible = "fixed-clock";
44*4882a593Smuzhiyun			#clock-cells = <0>;
45*4882a593Smuzhiyun			clock-frequency = <32768>;
46*4882a593Smuzhiyun		};
47*4882a593Smuzhiyun	};
48*4882a593Smuzhiyun};
49*4882a593Smuzhiyun
50*4882a593Smuzhiyun&cpu_thermal {
51*4882a593Smuzhiyun	cooling-maps {
52*4882a593Smuzhiyun		cooling_map0: map0 {
53*4882a593Smuzhiyun			/* Corresponds to 800MHz at freq_table */
54*4882a593Smuzhiyun			cooling-device = <&cpu0 7 7>, <&cpu1 7 7>,
55*4882a593Smuzhiyun					 <&cpu2 7 7>, <&cpu3 7 7>;
56*4882a593Smuzhiyun		};
57*4882a593Smuzhiyun		cooling_map1: map1 {
58*4882a593Smuzhiyun			/* Corresponds to 200MHz at freq_table */
59*4882a593Smuzhiyun			cooling-device = <&cpu0 13 13>, <&cpu1 13 13>,
60*4882a593Smuzhiyun					 <&cpu2 13 13>, <&cpu3 13 13>;
61*4882a593Smuzhiyun		};
62*4882a593Smuzhiyun	};
63*4882a593Smuzhiyun};
64*4882a593Smuzhiyun
65*4882a593Smuzhiyun&keypad {
66*4882a593Smuzhiyun	samsung,keypad-num-rows = <3>;
67*4882a593Smuzhiyun	samsung,keypad-num-columns = <8>;
68*4882a593Smuzhiyun	linux,keypad-no-autorepeat;
69*4882a593Smuzhiyun	wakeup-source;
70*4882a593Smuzhiyun	pinctrl-0 = <&keypad_rows &keypad_cols>;
71*4882a593Smuzhiyun	pinctrl-names = "default";
72*4882a593Smuzhiyun	status = "okay";
73*4882a593Smuzhiyun
74*4882a593Smuzhiyun	key_1 {
75*4882a593Smuzhiyun		keypad,row = <1>;
76*4882a593Smuzhiyun		keypad,column = <3>;
77*4882a593Smuzhiyun		linux,code = <2>;
78*4882a593Smuzhiyun	};
79*4882a593Smuzhiyun
80*4882a593Smuzhiyun	key_2 {
81*4882a593Smuzhiyun		keypad,row = <1>;
82*4882a593Smuzhiyun		keypad,column = <4>;
83*4882a593Smuzhiyun		linux,code = <3>;
84*4882a593Smuzhiyun	};
85*4882a593Smuzhiyun
86*4882a593Smuzhiyun	key_3 {
87*4882a593Smuzhiyun		keypad,row = <1>;
88*4882a593Smuzhiyun		keypad,column = <5>;
89*4882a593Smuzhiyun		linux,code = <4>;
90*4882a593Smuzhiyun	};
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun	key_4 {
93*4882a593Smuzhiyun		keypad,row = <1>;
94*4882a593Smuzhiyun		keypad,column = <6>;
95*4882a593Smuzhiyun		linux,code = <5>;
96*4882a593Smuzhiyun	};
97*4882a593Smuzhiyun
98*4882a593Smuzhiyun	key_5 {
99*4882a593Smuzhiyun		keypad,row = <1>;
100*4882a593Smuzhiyun		keypad,column = <7>;
101*4882a593Smuzhiyun		linux,code = <6>;
102*4882a593Smuzhiyun	};
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun	key_A {
105*4882a593Smuzhiyun		keypad,row = <2>;
106*4882a593Smuzhiyun		keypad,column = <6>;
107*4882a593Smuzhiyun		linux,code = <30>;
108*4882a593Smuzhiyun	};
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun	key_B {
111*4882a593Smuzhiyun		keypad,row = <2>;
112*4882a593Smuzhiyun		keypad,column = <7>;
113*4882a593Smuzhiyun		linux,code = <48>;
114*4882a593Smuzhiyun	};
115*4882a593Smuzhiyun
116*4882a593Smuzhiyun	key_C {
117*4882a593Smuzhiyun		keypad,row = <0>;
118*4882a593Smuzhiyun		keypad,column = <5>;
119*4882a593Smuzhiyun		linux,code = <46>;
120*4882a593Smuzhiyun	};
121*4882a593Smuzhiyun
122*4882a593Smuzhiyun	key_D {
123*4882a593Smuzhiyun		keypad,row = <2>;
124*4882a593Smuzhiyun		keypad,column = <5>;
125*4882a593Smuzhiyun		linux,code = <32>;
126*4882a593Smuzhiyun	};
127*4882a593Smuzhiyun
128*4882a593Smuzhiyun	key_E {
129*4882a593Smuzhiyun		keypad,row = <0>;
130*4882a593Smuzhiyun		keypad,column = <7>;
131*4882a593Smuzhiyun		linux,code = <18>;
132*4882a593Smuzhiyun	};
133*4882a593Smuzhiyun};
134*4882a593Smuzhiyun
135*4882a593Smuzhiyun&pinctrl_1 {
136*4882a593Smuzhiyun	keypad_rows: keypad-rows {
137*4882a593Smuzhiyun		samsung,pins = "gpx2-0", "gpx2-1", "gpx2-2";
138*4882a593Smuzhiyun		samsung,pin-function = <EXYNOS_PIN_FUNC_3>;
139*4882a593Smuzhiyun		samsung,pin-pud = <EXYNOS_PIN_PULL_UP>;
140*4882a593Smuzhiyun		samsung,pin-drv = <EXYNOS4_PIN_DRV_LV1>;
141*4882a593Smuzhiyun	};
142*4882a593Smuzhiyun
143*4882a593Smuzhiyun	keypad_cols: keypad-cols {
144*4882a593Smuzhiyun		samsung,pins = "gpx1-0", "gpx1-1", "gpx1-2", "gpx1-3",
145*4882a593Smuzhiyun			       "gpx1-4", "gpx1-5", "gpx1-6", "gpx1-7";
146*4882a593Smuzhiyun		samsung,pin-function = <EXYNOS_PIN_FUNC_3>;
147*4882a593Smuzhiyun		samsung,pin-pud = <EXYNOS_PIN_PULL_NONE>;
148*4882a593Smuzhiyun		samsung,pin-drv = <EXYNOS4_PIN_DRV_LV1>;
149*4882a593Smuzhiyun	};
150*4882a593Smuzhiyun};
151*4882a593Smuzhiyun
152*4882a593Smuzhiyun&rtc {
153*4882a593Smuzhiyun	clocks = <&clock CLK_RTC>, <&pmic_ap_clk>;
154*4882a593Smuzhiyun	clock-names = "rtc", "rtc_src";
155*4882a593Smuzhiyun};
156*4882a593Smuzhiyun
157*4882a593Smuzhiyun&sdhci_2 {
158*4882a593Smuzhiyun	bus-width = <4>;
159*4882a593Smuzhiyun	pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4 &sd2_cd>;
160*4882a593Smuzhiyun	pinctrl-names = "default";
161*4882a593Smuzhiyun	status = "okay";
162*4882a593Smuzhiyun};
163*4882a593Smuzhiyun
164*4882a593Smuzhiyun&serial_0 {
165*4882a593Smuzhiyun	status = "okay";
166*4882a593Smuzhiyun};
167*4882a593Smuzhiyun
168*4882a593Smuzhiyun&serial_1 {
169*4882a593Smuzhiyun	status = "okay";
170*4882a593Smuzhiyun};
171*4882a593Smuzhiyun
172*4882a593Smuzhiyun&serial_2 {
173*4882a593Smuzhiyun	status = "okay";
174*4882a593Smuzhiyun};
175*4882a593Smuzhiyun
176*4882a593Smuzhiyun&serial_3 {
177*4882a593Smuzhiyun	status = "okay";
178*4882a593Smuzhiyun};
179