xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/dm816x-clocks.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0-only
2*4882a593Smuzhiyun
3*4882a593Smuzhiyun&scrm {
4*4882a593Smuzhiyun	main_fapll: main_fapll {
5*4882a593Smuzhiyun		#clock-cells = <1>;
6*4882a593Smuzhiyun		compatible = "ti,dm816-fapll-clock";
7*4882a593Smuzhiyun		reg = <0x400 0x40>;
8*4882a593Smuzhiyun		clocks = <&sys_clkin_ck &sys_clkin_ck>;
9*4882a593Smuzhiyun		clock-indices = <1>, <2>, <3>, <4>, <5>,
10*4882a593Smuzhiyun				<6>, <7>;
11*4882a593Smuzhiyun		clock-output-names = "main_pll_clk1",
12*4882a593Smuzhiyun				     "main_pll_clk2",
13*4882a593Smuzhiyun				     "main_pll_clk3",
14*4882a593Smuzhiyun				     "main_pll_clk4",
15*4882a593Smuzhiyun				     "main_pll_clk5",
16*4882a593Smuzhiyun				     "main_pll_clk6",
17*4882a593Smuzhiyun				     "main_pll_clk7";
18*4882a593Smuzhiyun	};
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun	ddr_fapll: ddr_fapll {
21*4882a593Smuzhiyun		#clock-cells = <1>;
22*4882a593Smuzhiyun		compatible = "ti,dm816-fapll-clock";
23*4882a593Smuzhiyun		reg = <0x440 0x30>;
24*4882a593Smuzhiyun		clocks = <&sys_clkin_ck &sys_clkin_ck>;
25*4882a593Smuzhiyun		clock-indices = <1>, <2>, <3>, <4>;
26*4882a593Smuzhiyun		clock-output-names = "ddr_pll_clk1",
27*4882a593Smuzhiyun				     "ddr_pll_clk2",
28*4882a593Smuzhiyun				     "ddr_pll_clk3",
29*4882a593Smuzhiyun				     "ddr_pll_clk4";
30*4882a593Smuzhiyun	};
31*4882a593Smuzhiyun
32*4882a593Smuzhiyun	video_fapll: video_fapll {
33*4882a593Smuzhiyun		#clock-cells = <1>;
34*4882a593Smuzhiyun		compatible = "ti,dm816-fapll-clock";
35*4882a593Smuzhiyun		reg = <0x470 0x30>;
36*4882a593Smuzhiyun		clocks = <&sys_clkin_ck &sys_clkin_ck>;
37*4882a593Smuzhiyun		clock-indices = <1>, <2>, <3>;
38*4882a593Smuzhiyun		clock-output-names = "video_pll_clk1",
39*4882a593Smuzhiyun				     "video_pll_clk2",
40*4882a593Smuzhiyun				     "video_pll_clk3";
41*4882a593Smuzhiyun	};
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun	audio_fapll: audio_fapll {
44*4882a593Smuzhiyun		#clock-cells = <1>;
45*4882a593Smuzhiyun		compatible = "ti,dm816-fapll-clock";
46*4882a593Smuzhiyun		reg = <0x4a0 0x30>;
47*4882a593Smuzhiyun		clocks = <&main_fapll 7>, < &sys_clkin_ck>;
48*4882a593Smuzhiyun		clock-indices = <1>, <2>, <3>, <4>, <5>;
49*4882a593Smuzhiyun		clock-output-names = "audio_pll_clk1",
50*4882a593Smuzhiyun				     "audio_pll_clk2",
51*4882a593Smuzhiyun				     "audio_pll_clk3",
52*4882a593Smuzhiyun				     "audio_pll_clk4",
53*4882a593Smuzhiyun				     "audio_pll_clk5";
54*4882a593Smuzhiyun	};
55*4882a593Smuzhiyun};
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun&scrm_clocks {
58*4882a593Smuzhiyun	secure_32k_ck: secure_32k_ck {
59*4882a593Smuzhiyun		#clock-cells = <0>;
60*4882a593Smuzhiyun		compatible = "fixed-clock";
61*4882a593Smuzhiyun		clock-frequency = <32768>;
62*4882a593Smuzhiyun	};
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun	sys_32k_ck: sys_32k_ck {
65*4882a593Smuzhiyun		#clock-cells = <0>;
66*4882a593Smuzhiyun		compatible = "fixed-clock";
67*4882a593Smuzhiyun		clock-frequency = <32768>;
68*4882a593Smuzhiyun	};
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun	tclkin_ck: tclkin_ck {
71*4882a593Smuzhiyun		#clock-cells = <0>;
72*4882a593Smuzhiyun		compatible = "fixed-clock";
73*4882a593Smuzhiyun		clock-frequency = <32768>;
74*4882a593Smuzhiyun	};
75*4882a593Smuzhiyun
76*4882a593Smuzhiyun	sys_clkin_ck: sys_clkin_ck {
77*4882a593Smuzhiyun		#clock-cells = <0>;
78*4882a593Smuzhiyun		compatible = "fixed-clock";
79*4882a593Smuzhiyun		clock-frequency = <27000000>;
80*4882a593Smuzhiyun	};
81*4882a593Smuzhiyun};
82*4882a593Smuzhiyun
83*4882a593Smuzhiyun/* 0x48180000 */
84*4882a593Smuzhiyun&prcm_clocks {
85*4882a593Smuzhiyun	clkout_pre_ck: clkout_pre_ck@100 {
86*4882a593Smuzhiyun		#clock-cells = <0>;
87*4882a593Smuzhiyun		compatible = "ti,mux-clock";
88*4882a593Smuzhiyun		clocks = <&main_fapll 5 &ddr_fapll 1 &video_fapll 1
89*4882a593Smuzhiyun			  &audio_fapll 1>;
90*4882a593Smuzhiyun		reg = <0x100>;
91*4882a593Smuzhiyun	};
92*4882a593Smuzhiyun
93*4882a593Smuzhiyun	clkout_div_ck: clkout_div_ck@100 {
94*4882a593Smuzhiyun		#clock-cells = <0>;
95*4882a593Smuzhiyun		compatible = "ti,divider-clock";
96*4882a593Smuzhiyun		clocks = <&clkout_pre_ck>;
97*4882a593Smuzhiyun		ti,bit-shift = <3>;
98*4882a593Smuzhiyun		ti,max-div = <8>;
99*4882a593Smuzhiyun		reg = <0x100>;
100*4882a593Smuzhiyun	};
101*4882a593Smuzhiyun
102*4882a593Smuzhiyun	clkout_ck: clkout_ck@100 {
103*4882a593Smuzhiyun		#clock-cells = <0>;
104*4882a593Smuzhiyun		compatible = "ti,gate-clock";
105*4882a593Smuzhiyun		clocks = <&clkout_div_ck>;
106*4882a593Smuzhiyun		ti,bit-shift = <7>;
107*4882a593Smuzhiyun		reg = <0x100>;
108*4882a593Smuzhiyun	};
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun	/* CM_DPLL clocks p1795 */
111*4882a593Smuzhiyun	sysclk1_ck: sysclk1_ck@300 {
112*4882a593Smuzhiyun		#clock-cells = <0>;
113*4882a593Smuzhiyun		compatible = "ti,divider-clock";
114*4882a593Smuzhiyun		clocks = <&main_fapll 1>;
115*4882a593Smuzhiyun		ti,max-div = <7>;
116*4882a593Smuzhiyun		reg = <0x0300>;
117*4882a593Smuzhiyun	};
118*4882a593Smuzhiyun
119*4882a593Smuzhiyun	sysclk2_ck: sysclk2_ck@304 {
120*4882a593Smuzhiyun		#clock-cells = <0>;
121*4882a593Smuzhiyun		compatible = "ti,divider-clock";
122*4882a593Smuzhiyun		clocks = <&main_fapll 2>;
123*4882a593Smuzhiyun		ti,max-div = <7>;
124*4882a593Smuzhiyun		reg = <0x0304>;
125*4882a593Smuzhiyun	};
126*4882a593Smuzhiyun
127*4882a593Smuzhiyun	sysclk3_ck: sysclk3_ck@308 {
128*4882a593Smuzhiyun		#clock-cells = <0>;
129*4882a593Smuzhiyun		compatible = "ti,divider-clock";
130*4882a593Smuzhiyun		clocks = <&main_fapll 3>;
131*4882a593Smuzhiyun		ti,max-div = <7>;
132*4882a593Smuzhiyun		reg = <0x0308>;
133*4882a593Smuzhiyun	};
134*4882a593Smuzhiyun
135*4882a593Smuzhiyun	sysclk4_ck: sysclk4_ck@30c {
136*4882a593Smuzhiyun		#clock-cells = <0>;
137*4882a593Smuzhiyun		compatible = "ti,divider-clock";
138*4882a593Smuzhiyun		clocks = <&main_fapll 4>;
139*4882a593Smuzhiyun		ti,max-div = <1>;
140*4882a593Smuzhiyun		reg = <0x030c>;
141*4882a593Smuzhiyun	};
142*4882a593Smuzhiyun
143*4882a593Smuzhiyun	sysclk5_ck: sysclk5_ck@310 {
144*4882a593Smuzhiyun		#clock-cells = <0>;
145*4882a593Smuzhiyun		compatible = "ti,divider-clock";
146*4882a593Smuzhiyun		clocks = <&sysclk4_ck>;
147*4882a593Smuzhiyun		ti,max-div = <1>;
148*4882a593Smuzhiyun		reg = <0x0310>;
149*4882a593Smuzhiyun	};
150*4882a593Smuzhiyun
151*4882a593Smuzhiyun	sysclk6_ck: sysclk6_ck@314 {
152*4882a593Smuzhiyun		#clock-cells = <0>;
153*4882a593Smuzhiyun		compatible = "ti,divider-clock";
154*4882a593Smuzhiyun		clocks = <&main_fapll 4>;
155*4882a593Smuzhiyun		ti,dividers = <2>, <4>;
156*4882a593Smuzhiyun		reg = <0x0314>;
157*4882a593Smuzhiyun	};
158*4882a593Smuzhiyun
159*4882a593Smuzhiyun	sysclk10_ck: sysclk10_ck@324 {
160*4882a593Smuzhiyun		#clock-cells = <0>;
161*4882a593Smuzhiyun		compatible = "ti,divider-clock";
162*4882a593Smuzhiyun		clocks = <&ddr_fapll 2>;
163*4882a593Smuzhiyun		ti,max-div = <7>;
164*4882a593Smuzhiyun		reg = <0x0324>;
165*4882a593Smuzhiyun	};
166*4882a593Smuzhiyun
167*4882a593Smuzhiyun	sysclk24_ck: sysclk24_ck@3b4 {
168*4882a593Smuzhiyun		#clock-cells = <0>;
169*4882a593Smuzhiyun		compatible = "ti,divider-clock";
170*4882a593Smuzhiyun		clocks = <&main_fapll 5>;
171*4882a593Smuzhiyun		ti,max-div = <7>;
172*4882a593Smuzhiyun		reg = <0x03b4>;
173*4882a593Smuzhiyun	};
174*4882a593Smuzhiyun
175*4882a593Smuzhiyun	mpu_ck: mpu_ck@15dc {
176*4882a593Smuzhiyun		#clock-cells = <0>;
177*4882a593Smuzhiyun		compatible = "ti,gate-clock";
178*4882a593Smuzhiyun		clocks = <&sysclk2_ck>;
179*4882a593Smuzhiyun		ti,bit-shift = <1>;
180*4882a593Smuzhiyun                reg = <0x15dc>;
181*4882a593Smuzhiyun	};
182*4882a593Smuzhiyun
183*4882a593Smuzhiyun	audio_pll_a_ck: audio_pll_a_ck@35c {
184*4882a593Smuzhiyun		#clock-cells = <0>;
185*4882a593Smuzhiyun		compatible = "ti,divider-clock";
186*4882a593Smuzhiyun		clocks = <&audio_fapll 1>;
187*4882a593Smuzhiyun		ti,max-div = <7>;
188*4882a593Smuzhiyun		reg = <0x035c>;
189*4882a593Smuzhiyun	};
190*4882a593Smuzhiyun
191*4882a593Smuzhiyun	sysclk18_ck: sysclk18_ck@378 {
192*4882a593Smuzhiyun		#clock-cells = <0>;
193*4882a593Smuzhiyun		compatible = "ti,mux-clock";
194*4882a593Smuzhiyun		clocks = <&sys_32k_ck>, <&audio_pll_a_ck>;
195*4882a593Smuzhiyun		reg = <0x0378>;
196*4882a593Smuzhiyun	};
197*4882a593Smuzhiyun
198*4882a593Smuzhiyun	timer1_fck: timer1_fck@390 {
199*4882a593Smuzhiyun		#clock-cells = <0>;
200*4882a593Smuzhiyun		compatible = "ti,mux-clock";
201*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
202*4882a593Smuzhiyun		reg = <0x0390>;
203*4882a593Smuzhiyun	};
204*4882a593Smuzhiyun
205*4882a593Smuzhiyun	timer2_fck: timer2_fck@394 {
206*4882a593Smuzhiyun		#clock-cells = <0>;
207*4882a593Smuzhiyun		compatible = "ti,mux-clock";
208*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
209*4882a593Smuzhiyun		reg = <0x0394>;
210*4882a593Smuzhiyun	};
211*4882a593Smuzhiyun
212*4882a593Smuzhiyun	timer3_fck: timer3_fck@398 {
213*4882a593Smuzhiyun		#clock-cells = <0>;
214*4882a593Smuzhiyun		compatible = "ti,mux-clock";
215*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
216*4882a593Smuzhiyun		reg = <0x0398>;
217*4882a593Smuzhiyun	};
218*4882a593Smuzhiyun
219*4882a593Smuzhiyun	timer4_fck: timer4_fck@39c {
220*4882a593Smuzhiyun		#clock-cells = <0>;
221*4882a593Smuzhiyun		compatible = "ti,mux-clock";
222*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
223*4882a593Smuzhiyun		reg = <0x039c>;
224*4882a593Smuzhiyun	};
225*4882a593Smuzhiyun
226*4882a593Smuzhiyun	timer5_fck: timer5_fck@3a0 {
227*4882a593Smuzhiyun		#clock-cells = <0>;
228*4882a593Smuzhiyun		compatible = "ti,mux-clock";
229*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
230*4882a593Smuzhiyun		reg = <0x03a0>;
231*4882a593Smuzhiyun	};
232*4882a593Smuzhiyun
233*4882a593Smuzhiyun	timer6_fck: timer6_fck@3a4 {
234*4882a593Smuzhiyun		#clock-cells = <0>;
235*4882a593Smuzhiyun		compatible = "ti,mux-clock";
236*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
237*4882a593Smuzhiyun		reg = <0x03a4>;
238*4882a593Smuzhiyun	};
239*4882a593Smuzhiyun
240*4882a593Smuzhiyun	timer7_fck: timer7_fck@3a8 {
241*4882a593Smuzhiyun		#clock-cells = <0>;
242*4882a593Smuzhiyun		compatible = "ti,mux-clock";
243*4882a593Smuzhiyun		clocks = <&tclkin_ck>, <&sysclk18_ck>, <&sys_clkin_ck>;
244*4882a593Smuzhiyun		reg = <0x03a8>;
245*4882a593Smuzhiyun	};
246*4882a593Smuzhiyun};
247*4882a593Smuzhiyun
248*4882a593Smuzhiyun&prcm {
249*4882a593Smuzhiyun	default_cm: default_cm@500 {
250*4882a593Smuzhiyun		compatible = "ti,omap4-cm";
251*4882a593Smuzhiyun		reg = <0x500 0x100>;
252*4882a593Smuzhiyun		#address-cells = <1>;
253*4882a593Smuzhiyun		#size-cells = <1>;
254*4882a593Smuzhiyun		ranges = <0 0x500 0x100>;
255*4882a593Smuzhiyun
256*4882a593Smuzhiyun		default_clkctrl: clk@0 {
257*4882a593Smuzhiyun			compatible = "ti,clkctrl";
258*4882a593Smuzhiyun			reg = <0x0 0x5c>;
259*4882a593Smuzhiyun			#clock-cells = <2>;
260*4882a593Smuzhiyun		};
261*4882a593Smuzhiyun	};
262*4882a593Smuzhiyun
263*4882a593Smuzhiyun	alwon_cm: alwon_cm@1400 {
264*4882a593Smuzhiyun		compatible = "ti,omap4-cm";
265*4882a593Smuzhiyun		reg = <0x1400 0x300>;
266*4882a593Smuzhiyun		#address-cells = <1>;
267*4882a593Smuzhiyun		#size-cells = <1>;
268*4882a593Smuzhiyun		ranges = <0 0x1400 0x300>;
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun		alwon_clkctrl: clk@0 {
271*4882a593Smuzhiyun			compatible = "ti,clkctrl";
272*4882a593Smuzhiyun			reg = <0x0 0x208>;
273*4882a593Smuzhiyun			#clock-cells = <2>;
274*4882a593Smuzhiyun		};
275*4882a593Smuzhiyun	};
276*4882a593Smuzhiyun};
277