blob: 07f4cc159ad3103e79a955d26e085b596e34756c [file] [log] [blame]
Stephen Boydd8b21202014-01-15 10:47:31 -08001/*
2 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
3 *
4 * This software is licensed under the terms of the GNU General Public
5 * License version 2, as published by the Free Software Foundation, and
6 * may be copied, distributed, and modified under those terms.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13
14#include <linux/kernel.h>
15#include <linux/bitops.h>
16#include <linux/err.h>
17#include <linux/platform_device.h>
18#include <linux/module.h>
19#include <linux/of.h>
20#include <linux/of_device.h>
21#include <linux/clk-provider.h>
22#include <linux/regmap.h>
23#include <linux/reset-controller.h>
24
25#include <dt-bindings/clock/qcom,mmcc-msm8974.h>
26#include <dt-bindings/reset/qcom,mmcc-msm8974.h>
27
Stephen Boyd49fc8252014-03-21 17:59:37 -070028#include "common.h"
Stephen Boydd8b21202014-01-15 10:47:31 -080029#include "clk-regmap.h"
30#include "clk-pll.h"
31#include "clk-rcg.h"
32#include "clk-branch.h"
33#include "reset.h"
34
Georgi Djakov293d2e972015-03-20 18:30:26 +020035enum {
36 P_XO,
37 P_MMPLL0,
38 P_EDPLINK,
39 P_MMPLL1,
40 P_HDMIPLL,
41 P_GPLL0,
42 P_EDPVCO,
43 P_GPLL1,
44 P_DSI0PLL,
45 P_DSI0PLL_BYTE,
46 P_MMPLL2,
47 P_MMPLL3,
48 P_DSI1PLL,
49 P_DSI1PLL_BYTE,
50};
Stephen Boydd8b21202014-01-15 10:47:31 -080051
Georgi Djakov293d2e972015-03-20 18:30:26 +020052static const struct parent_map mmcc_xo_mmpll0_mmpll1_gpll0_map[] = {
53 { P_XO, 0 },
54 { P_MMPLL0, 1 },
55 { P_MMPLL1, 2 },
56 { P_GPLL0, 5 }
Stephen Boydd8b21202014-01-15 10:47:31 -080057};
58
59static const char *mmcc_xo_mmpll0_mmpll1_gpll0[] = {
60 "xo",
61 "mmpll0_vote",
62 "mmpll1_vote",
63 "mmss_gpll0_vote",
64};
65
Georgi Djakov293d2e972015-03-20 18:30:26 +020066static const struct parent_map mmcc_xo_mmpll0_dsi_hdmi_gpll0_map[] = {
67 { P_XO, 0 },
68 { P_MMPLL0, 1 },
69 { P_HDMIPLL, 4 },
70 { P_GPLL0, 5 },
71 { P_DSI0PLL, 2 },
72 { P_DSI1PLL, 3 }
Stephen Boydd8b21202014-01-15 10:47:31 -080073};
74
75static const char *mmcc_xo_mmpll0_dsi_hdmi_gpll0[] = {
76 "xo",
77 "mmpll0_vote",
78 "hdmipll",
79 "mmss_gpll0_vote",
80 "dsi0pll",
81 "dsi1pll",
82};
83
Georgi Djakov293d2e972015-03-20 18:30:26 +020084static const struct parent_map mmcc_xo_mmpll0_1_2_gpll0_map[] = {
85 { P_XO, 0 },
86 { P_MMPLL0, 1 },
87 { P_MMPLL1, 2 },
88 { P_GPLL0, 5 },
89 { P_MMPLL2, 3 }
Stephen Boydd8b21202014-01-15 10:47:31 -080090};
91
92static const char *mmcc_xo_mmpll0_1_2_gpll0[] = {
93 "xo",
94 "mmpll0_vote",
95 "mmpll1_vote",
96 "mmss_gpll0_vote",
97 "mmpll2",
98};
99
Georgi Djakov293d2e972015-03-20 18:30:26 +0200100static const struct parent_map mmcc_xo_mmpll0_1_3_gpll0_map[] = {
101 { P_XO, 0 },
102 { P_MMPLL0, 1 },
103 { P_MMPLL1, 2 },
104 { P_GPLL0, 5 },
105 { P_MMPLL3, 3 }
Stephen Boydd8b21202014-01-15 10:47:31 -0800106};
107
108static const char *mmcc_xo_mmpll0_1_3_gpll0[] = {
109 "xo",
110 "mmpll0_vote",
111 "mmpll1_vote",
112 "mmss_gpll0_vote",
113 "mmpll3",
114};
115
Georgi Djakov293d2e972015-03-20 18:30:26 +0200116static const struct parent_map mmcc_xo_mmpll0_1_gpll1_0_map[] = {
117 { P_XO, 0 },
118 { P_MMPLL0, 1 },
119 { P_MMPLL1, 2 },
120 { P_GPLL0, 5 },
121 { P_GPLL1, 4 }
Stephen Boydd8b21202014-01-15 10:47:31 -0800122};
123
124static const char *mmcc_xo_mmpll0_1_gpll1_0[] = {
125 "xo",
126 "mmpll0_vote",
127 "mmpll1_vote",
128 "mmss_gpll0_vote",
129 "gpll1_vote",
130};
131
Georgi Djakov293d2e972015-03-20 18:30:26 +0200132static const struct parent_map mmcc_xo_dsi_hdmi_edp_map[] = {
133 { P_XO, 0 },
134 { P_EDPLINK, 4 },
135 { P_HDMIPLL, 3 },
136 { P_EDPVCO, 5 },
137 { P_DSI0PLL, 1 },
138 { P_DSI1PLL, 2 }
Stephen Boydd8b21202014-01-15 10:47:31 -0800139};
140
141static const char *mmcc_xo_dsi_hdmi_edp[] = {
142 "xo",
143 "edp_link_clk",
144 "hdmipll",
145 "edp_vco_div",
146 "dsi0pll",
147 "dsi1pll",
148};
149
Georgi Djakov293d2e972015-03-20 18:30:26 +0200150static const struct parent_map mmcc_xo_dsi_hdmi_edp_gpll0_map[] = {
151 { P_XO, 0 },
152 { P_EDPLINK, 4 },
153 { P_HDMIPLL, 3 },
154 { P_GPLL0, 5 },
155 { P_DSI0PLL, 1 },
156 { P_DSI1PLL, 2 }
Stephen Boydd8b21202014-01-15 10:47:31 -0800157};
158
159static const char *mmcc_xo_dsi_hdmi_edp_gpll0[] = {
160 "xo",
161 "edp_link_clk",
162 "hdmipll",
163 "gpll0_vote",
164 "dsi0pll",
165 "dsi1pll",
166};
167
Georgi Djakov293d2e972015-03-20 18:30:26 +0200168static const struct parent_map mmcc_xo_dsibyte_hdmi_edp_gpll0_map[] = {
169 { P_XO, 0 },
170 { P_EDPLINK, 4 },
171 { P_HDMIPLL, 3 },
172 { P_GPLL0, 5 },
173 { P_DSI0PLL_BYTE, 1 },
174 { P_DSI1PLL_BYTE, 2 }
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700175};
176
177static const char *mmcc_xo_dsibyte_hdmi_edp_gpll0[] = {
178 "xo",
179 "edp_link_clk",
180 "hdmipll",
181 "gpll0_vote",
182 "dsi0pllbyte",
183 "dsi1pllbyte",
184};
185
Stephen Boydd8b21202014-01-15 10:47:31 -0800186#define F(f, s, h, m, n) { (f), (s), (2 * (h) - 1), (m), (n) }
187
188static struct clk_pll mmpll0 = {
189 .l_reg = 0x0004,
190 .m_reg = 0x0008,
191 .n_reg = 0x000c,
192 .config_reg = 0x0014,
193 .mode_reg = 0x0000,
194 .status_reg = 0x001c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700195 .status_bit = 17,
Stephen Boydd8b21202014-01-15 10:47:31 -0800196 .clkr.hw.init = &(struct clk_init_data){
197 .name = "mmpll0",
198 .parent_names = (const char *[]){ "xo" },
199 .num_parents = 1,
200 .ops = &clk_pll_ops,
201 },
202};
203
204static struct clk_regmap mmpll0_vote = {
205 .enable_reg = 0x0100,
206 .enable_mask = BIT(0),
207 .hw.init = &(struct clk_init_data){
208 .name = "mmpll0_vote",
209 .parent_names = (const char *[]){ "mmpll0" },
210 .num_parents = 1,
211 .ops = &clk_pll_vote_ops,
212 },
213};
214
215static struct clk_pll mmpll1 = {
216 .l_reg = 0x0044,
217 .m_reg = 0x0048,
218 .n_reg = 0x004c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700219 .config_reg = 0x0050,
Stephen Boydd8b21202014-01-15 10:47:31 -0800220 .mode_reg = 0x0040,
221 .status_reg = 0x005c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700222 .status_bit = 17,
Stephen Boydd8b21202014-01-15 10:47:31 -0800223 .clkr.hw.init = &(struct clk_init_data){
224 .name = "mmpll1",
225 .parent_names = (const char *[]){ "xo" },
226 .num_parents = 1,
227 .ops = &clk_pll_ops,
228 },
229};
230
231static struct clk_regmap mmpll1_vote = {
232 .enable_reg = 0x0100,
233 .enable_mask = BIT(1),
234 .hw.init = &(struct clk_init_data){
235 .name = "mmpll1_vote",
236 .parent_names = (const char *[]){ "mmpll1" },
237 .num_parents = 1,
238 .ops = &clk_pll_vote_ops,
239 },
240};
241
242static struct clk_pll mmpll2 = {
243 .l_reg = 0x4104,
244 .m_reg = 0x4108,
245 .n_reg = 0x410c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700246 .config_reg = 0x4110,
Stephen Boydd8b21202014-01-15 10:47:31 -0800247 .mode_reg = 0x4100,
248 .status_reg = 0x411c,
249 .clkr.hw.init = &(struct clk_init_data){
250 .name = "mmpll2",
251 .parent_names = (const char *[]){ "xo" },
252 .num_parents = 1,
253 .ops = &clk_pll_ops,
254 },
255};
256
257static struct clk_pll mmpll3 = {
258 .l_reg = 0x0084,
259 .m_reg = 0x0088,
260 .n_reg = 0x008c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700261 .config_reg = 0x0090,
Stephen Boydd8b21202014-01-15 10:47:31 -0800262 .mode_reg = 0x0080,
263 .status_reg = 0x009c,
Stephen Boyd437ae6a2014-05-16 16:07:09 -0700264 .status_bit = 17,
Stephen Boydd8b21202014-01-15 10:47:31 -0800265 .clkr.hw.init = &(struct clk_init_data){
266 .name = "mmpll3",
267 .parent_names = (const char *[]){ "xo" },
268 .num_parents = 1,
269 .ops = &clk_pll_ops,
270 },
271};
272
273static struct clk_rcg2 mmss_ahb_clk_src = {
274 .cmd_rcgr = 0x5000,
275 .hid_width = 5,
276 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
277 .clkr.hw.init = &(struct clk_init_data){
278 .name = "mmss_ahb_clk_src",
279 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
280 .num_parents = 4,
281 .ops = &clk_rcg2_ops,
282 },
283};
284
285static struct freq_tbl ftbl_mmss_axi_clk[] = {
286 F( 19200000, P_XO, 1, 0, 0),
287 F( 37500000, P_GPLL0, 16, 0, 0),
288 F( 50000000, P_GPLL0, 12, 0, 0),
289 F( 75000000, P_GPLL0, 8, 0, 0),
290 F(100000000, P_GPLL0, 6, 0, 0),
291 F(150000000, P_GPLL0, 4, 0, 0),
292 F(291750000, P_MMPLL1, 4, 0, 0),
293 F(400000000, P_MMPLL0, 2, 0, 0),
294 F(466800000, P_MMPLL1, 2.5, 0, 0),
295};
296
297static struct clk_rcg2 mmss_axi_clk_src = {
298 .cmd_rcgr = 0x5040,
299 .hid_width = 5,
300 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
301 .freq_tbl = ftbl_mmss_axi_clk,
302 .clkr.hw.init = &(struct clk_init_data){
303 .name = "mmss_axi_clk_src",
304 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
305 .num_parents = 4,
306 .ops = &clk_rcg2_ops,
307 },
308};
309
310static struct freq_tbl ftbl_ocmemnoc_clk[] = {
311 F( 19200000, P_XO, 1, 0, 0),
312 F( 37500000, P_GPLL0, 16, 0, 0),
313 F( 50000000, P_GPLL0, 12, 0, 0),
314 F( 75000000, P_GPLL0, 8, 0, 0),
315 F(100000000, P_GPLL0, 6, 0, 0),
316 F(150000000, P_GPLL0, 4, 0, 0),
317 F(291750000, P_MMPLL1, 4, 0, 0),
318 F(400000000, P_MMPLL0, 2, 0, 0),
319};
320
321static struct clk_rcg2 ocmemnoc_clk_src = {
322 .cmd_rcgr = 0x5090,
323 .hid_width = 5,
324 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
325 .freq_tbl = ftbl_ocmemnoc_clk,
326 .clkr.hw.init = &(struct clk_init_data){
327 .name = "ocmemnoc_clk_src",
328 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
329 .num_parents = 4,
330 .ops = &clk_rcg2_ops,
331 },
332};
333
334static struct freq_tbl ftbl_camss_csi0_3_clk[] = {
335 F(100000000, P_GPLL0, 6, 0, 0),
336 F(200000000, P_MMPLL0, 4, 0, 0),
337 { }
338};
339
340static struct clk_rcg2 csi0_clk_src = {
341 .cmd_rcgr = 0x3090,
342 .hid_width = 5,
343 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
344 .freq_tbl = ftbl_camss_csi0_3_clk,
345 .clkr.hw.init = &(struct clk_init_data){
346 .name = "csi0_clk_src",
347 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
348 .num_parents = 4,
349 .ops = &clk_rcg2_ops,
350 },
351};
352
353static struct clk_rcg2 csi1_clk_src = {
354 .cmd_rcgr = 0x3100,
355 .hid_width = 5,
356 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
357 .freq_tbl = ftbl_camss_csi0_3_clk,
358 .clkr.hw.init = &(struct clk_init_data){
359 .name = "csi1_clk_src",
360 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
361 .num_parents = 4,
362 .ops = &clk_rcg2_ops,
363 },
364};
365
366static struct clk_rcg2 csi2_clk_src = {
367 .cmd_rcgr = 0x3160,
368 .hid_width = 5,
369 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
370 .freq_tbl = ftbl_camss_csi0_3_clk,
371 .clkr.hw.init = &(struct clk_init_data){
372 .name = "csi2_clk_src",
373 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
374 .num_parents = 4,
375 .ops = &clk_rcg2_ops,
376 },
377};
378
379static struct clk_rcg2 csi3_clk_src = {
380 .cmd_rcgr = 0x31c0,
381 .hid_width = 5,
382 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
383 .freq_tbl = ftbl_camss_csi0_3_clk,
384 .clkr.hw.init = &(struct clk_init_data){
385 .name = "csi3_clk_src",
386 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
387 .num_parents = 4,
388 .ops = &clk_rcg2_ops,
389 },
390};
391
392static struct freq_tbl ftbl_camss_vfe_vfe0_1_clk[] = {
393 F(37500000, P_GPLL0, 16, 0, 0),
394 F(50000000, P_GPLL0, 12, 0, 0),
395 F(60000000, P_GPLL0, 10, 0, 0),
396 F(80000000, P_GPLL0, 7.5, 0, 0),
397 F(100000000, P_GPLL0, 6, 0, 0),
398 F(109090000, P_GPLL0, 5.5, 0, 0),
399 F(133330000, P_GPLL0, 4.5, 0, 0),
400 F(200000000, P_GPLL0, 3, 0, 0),
401 F(228570000, P_MMPLL0, 3.5, 0, 0),
402 F(266670000, P_MMPLL0, 3, 0, 0),
403 F(320000000, P_MMPLL0, 2.5, 0, 0),
404 F(400000000, P_MMPLL0, 2, 0, 0),
405 F(465000000, P_MMPLL3, 2, 0, 0),
406 { }
407};
408
409static struct clk_rcg2 vfe0_clk_src = {
410 .cmd_rcgr = 0x3600,
411 .hid_width = 5,
412 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
413 .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
414 .clkr.hw.init = &(struct clk_init_data){
415 .name = "vfe0_clk_src",
416 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
417 .num_parents = 4,
418 .ops = &clk_rcg2_ops,
419 },
420};
421
422static struct clk_rcg2 vfe1_clk_src = {
423 .cmd_rcgr = 0x3620,
424 .hid_width = 5,
425 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
426 .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
427 .clkr.hw.init = &(struct clk_init_data){
428 .name = "vfe1_clk_src",
429 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
430 .num_parents = 4,
431 .ops = &clk_rcg2_ops,
432 },
433};
434
435static struct freq_tbl ftbl_mdss_mdp_clk[] = {
436 F(37500000, P_GPLL0, 16, 0, 0),
437 F(60000000, P_GPLL0, 10, 0, 0),
438 F(75000000, P_GPLL0, 8, 0, 0),
439 F(85710000, P_GPLL0, 7, 0, 0),
440 F(100000000, P_GPLL0, 6, 0, 0),
441 F(133330000, P_MMPLL0, 6, 0, 0),
442 F(160000000, P_MMPLL0, 5, 0, 0),
443 F(200000000, P_MMPLL0, 4, 0, 0),
444 F(228570000, P_MMPLL0, 3.5, 0, 0),
445 F(240000000, P_GPLL0, 2.5, 0, 0),
446 F(266670000, P_MMPLL0, 3, 0, 0),
447 F(320000000, P_MMPLL0, 2.5, 0, 0),
448 { }
449};
450
451static struct clk_rcg2 mdp_clk_src = {
452 .cmd_rcgr = 0x2040,
453 .hid_width = 5,
454 .parent_map = mmcc_xo_mmpll0_dsi_hdmi_gpll0_map,
455 .freq_tbl = ftbl_mdss_mdp_clk,
456 .clkr.hw.init = &(struct clk_init_data){
457 .name = "mdp_clk_src",
458 .parent_names = mmcc_xo_mmpll0_dsi_hdmi_gpll0,
459 .num_parents = 6,
460 .ops = &clk_rcg2_ops,
461 },
462};
463
464static struct clk_rcg2 gfx3d_clk_src = {
465 .cmd_rcgr = 0x4000,
466 .hid_width = 5,
467 .parent_map = mmcc_xo_mmpll0_1_2_gpll0_map,
468 .clkr.hw.init = &(struct clk_init_data){
469 .name = "gfx3d_clk_src",
470 .parent_names = mmcc_xo_mmpll0_1_2_gpll0,
471 .num_parents = 5,
472 .ops = &clk_rcg2_ops,
473 },
474};
475
476static struct freq_tbl ftbl_camss_jpeg_jpeg0_2_clk[] = {
477 F(75000000, P_GPLL0, 8, 0, 0),
478 F(133330000, P_GPLL0, 4.5, 0, 0),
479 F(200000000, P_GPLL0, 3, 0, 0),
480 F(228570000, P_MMPLL0, 3.5, 0, 0),
481 F(266670000, P_MMPLL0, 3, 0, 0),
482 F(320000000, P_MMPLL0, 2.5, 0, 0),
483 { }
484};
485
486static struct clk_rcg2 jpeg0_clk_src = {
487 .cmd_rcgr = 0x3500,
488 .hid_width = 5,
489 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
490 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
491 .clkr.hw.init = &(struct clk_init_data){
492 .name = "jpeg0_clk_src",
493 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
494 .num_parents = 4,
495 .ops = &clk_rcg2_ops,
496 },
497};
498
499static struct clk_rcg2 jpeg1_clk_src = {
500 .cmd_rcgr = 0x3520,
501 .hid_width = 5,
502 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
503 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
504 .clkr.hw.init = &(struct clk_init_data){
505 .name = "jpeg1_clk_src",
506 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
507 .num_parents = 4,
508 .ops = &clk_rcg2_ops,
509 },
510};
511
512static struct clk_rcg2 jpeg2_clk_src = {
513 .cmd_rcgr = 0x3540,
514 .hid_width = 5,
515 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
516 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
517 .clkr.hw.init = &(struct clk_init_data){
518 .name = "jpeg2_clk_src",
519 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
520 .num_parents = 4,
521 .ops = &clk_rcg2_ops,
522 },
523};
524
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700525static struct freq_tbl pixel_freq_tbl[] = {
526 { .src = P_DSI0PLL },
Stephen Boydd8b21202014-01-15 10:47:31 -0800527 { }
528};
529
530static struct clk_rcg2 pclk0_clk_src = {
531 .cmd_rcgr = 0x2000,
532 .mnd_width = 8,
533 .hid_width = 5,
534 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700535 .freq_tbl = pixel_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800536 .clkr.hw.init = &(struct clk_init_data){
537 .name = "pclk0_clk_src",
538 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
539 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700540 .ops = &clk_pixel_ops,
541 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800542 },
543};
544
545static struct clk_rcg2 pclk1_clk_src = {
546 .cmd_rcgr = 0x2020,
547 .mnd_width = 8,
548 .hid_width = 5,
549 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700550 .freq_tbl = pixel_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800551 .clkr.hw.init = &(struct clk_init_data){
552 .name = "pclk1_clk_src",
553 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
554 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700555 .ops = &clk_pixel_ops,
556 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800557 },
558};
559
560static struct freq_tbl ftbl_venus0_vcodec0_clk[] = {
561 F(50000000, P_GPLL0, 12, 0, 0),
562 F(100000000, P_GPLL0, 6, 0, 0),
563 F(133330000, P_MMPLL0, 6, 0, 0),
564 F(200000000, P_MMPLL0, 4, 0, 0),
565 F(266670000, P_MMPLL0, 3, 0, 0),
566 F(465000000, P_MMPLL3, 2, 0, 0),
567 { }
568};
569
570static struct clk_rcg2 vcodec0_clk_src = {
571 .cmd_rcgr = 0x1000,
572 .mnd_width = 8,
573 .hid_width = 5,
574 .parent_map = mmcc_xo_mmpll0_1_3_gpll0_map,
575 .freq_tbl = ftbl_venus0_vcodec0_clk,
576 .clkr.hw.init = &(struct clk_init_data){
577 .name = "vcodec0_clk_src",
578 .parent_names = mmcc_xo_mmpll0_1_3_gpll0,
579 .num_parents = 5,
580 .ops = &clk_rcg2_ops,
581 },
582};
583
584static struct freq_tbl ftbl_camss_cci_cci_clk[] = {
585 F(19200000, P_XO, 1, 0, 0),
586 { }
587};
588
589static struct clk_rcg2 cci_clk_src = {
590 .cmd_rcgr = 0x3300,
591 .hid_width = 5,
592 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
593 .freq_tbl = ftbl_camss_cci_cci_clk,
594 .clkr.hw.init = &(struct clk_init_data){
595 .name = "cci_clk_src",
596 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
597 .num_parents = 4,
598 .ops = &clk_rcg2_ops,
599 },
600};
601
602static struct freq_tbl ftbl_camss_gp0_1_clk[] = {
603 F(10000, P_XO, 16, 1, 120),
604 F(24000, P_XO, 16, 1, 50),
605 F(6000000, P_GPLL0, 10, 1, 10),
606 F(12000000, P_GPLL0, 10, 1, 5),
607 F(13000000, P_GPLL0, 4, 13, 150),
608 F(24000000, P_GPLL0, 5, 1, 5),
609 { }
610};
611
612static struct clk_rcg2 camss_gp0_clk_src = {
613 .cmd_rcgr = 0x3420,
614 .mnd_width = 8,
615 .hid_width = 5,
616 .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
617 .freq_tbl = ftbl_camss_gp0_1_clk,
618 .clkr.hw.init = &(struct clk_init_data){
619 .name = "camss_gp0_clk_src",
620 .parent_names = mmcc_xo_mmpll0_1_gpll1_0,
621 .num_parents = 5,
622 .ops = &clk_rcg2_ops,
623 },
624};
625
626static struct clk_rcg2 camss_gp1_clk_src = {
627 .cmd_rcgr = 0x3450,
628 .mnd_width = 8,
629 .hid_width = 5,
630 .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
631 .freq_tbl = ftbl_camss_gp0_1_clk,
632 .clkr.hw.init = &(struct clk_init_data){
633 .name = "camss_gp1_clk_src",
634 .parent_names = mmcc_xo_mmpll0_1_gpll1_0,
635 .num_parents = 5,
636 .ops = &clk_rcg2_ops,
637 },
638};
639
640static struct freq_tbl ftbl_camss_mclk0_3_clk[] = {
641 F(4800000, P_XO, 4, 0, 0),
642 F(6000000, P_GPLL0, 10, 1, 10),
643 F(8000000, P_GPLL0, 15, 1, 5),
644 F(9600000, P_XO, 2, 0, 0),
645 F(16000000, P_GPLL0, 12.5, 1, 3),
646 F(19200000, P_XO, 1, 0, 0),
647 F(24000000, P_GPLL0, 5, 1, 5),
648 F(32000000, P_MMPLL0, 5, 1, 5),
649 F(48000000, P_GPLL0, 12.5, 0, 0),
650 F(64000000, P_MMPLL0, 12.5, 0, 0),
651 F(66670000, P_GPLL0, 9, 0, 0),
652 { }
653};
654
655static struct clk_rcg2 mclk0_clk_src = {
656 .cmd_rcgr = 0x3360,
657 .hid_width = 5,
658 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
659 .freq_tbl = ftbl_camss_mclk0_3_clk,
660 .clkr.hw.init = &(struct clk_init_data){
661 .name = "mclk0_clk_src",
662 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
663 .num_parents = 4,
664 .ops = &clk_rcg2_ops,
665 },
666};
667
668static struct clk_rcg2 mclk1_clk_src = {
669 .cmd_rcgr = 0x3390,
670 .hid_width = 5,
671 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
672 .freq_tbl = ftbl_camss_mclk0_3_clk,
673 .clkr.hw.init = &(struct clk_init_data){
674 .name = "mclk1_clk_src",
675 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
676 .num_parents = 4,
677 .ops = &clk_rcg2_ops,
678 },
679};
680
681static struct clk_rcg2 mclk2_clk_src = {
682 .cmd_rcgr = 0x33c0,
683 .hid_width = 5,
684 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
685 .freq_tbl = ftbl_camss_mclk0_3_clk,
686 .clkr.hw.init = &(struct clk_init_data){
687 .name = "mclk2_clk_src",
688 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
689 .num_parents = 4,
690 .ops = &clk_rcg2_ops,
691 },
692};
693
694static struct clk_rcg2 mclk3_clk_src = {
695 .cmd_rcgr = 0x33f0,
696 .hid_width = 5,
697 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
698 .freq_tbl = ftbl_camss_mclk0_3_clk,
699 .clkr.hw.init = &(struct clk_init_data){
700 .name = "mclk3_clk_src",
701 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
702 .num_parents = 4,
703 .ops = &clk_rcg2_ops,
704 },
705};
706
707static struct freq_tbl ftbl_camss_phy0_2_csi0_2phytimer_clk[] = {
708 F(100000000, P_GPLL0, 6, 0, 0),
709 F(200000000, P_MMPLL0, 4, 0, 0),
710 { }
711};
712
713static struct clk_rcg2 csi0phytimer_clk_src = {
714 .cmd_rcgr = 0x3000,
715 .hid_width = 5,
716 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
717 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
718 .clkr.hw.init = &(struct clk_init_data){
719 .name = "csi0phytimer_clk_src",
720 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
721 .num_parents = 4,
722 .ops = &clk_rcg2_ops,
723 },
724};
725
726static struct clk_rcg2 csi1phytimer_clk_src = {
727 .cmd_rcgr = 0x3030,
728 .hid_width = 5,
729 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
730 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
731 .clkr.hw.init = &(struct clk_init_data){
732 .name = "csi1phytimer_clk_src",
733 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
734 .num_parents = 4,
735 .ops = &clk_rcg2_ops,
736 },
737};
738
739static struct clk_rcg2 csi2phytimer_clk_src = {
740 .cmd_rcgr = 0x3060,
741 .hid_width = 5,
742 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
743 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
744 .clkr.hw.init = &(struct clk_init_data){
745 .name = "csi2phytimer_clk_src",
746 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
747 .num_parents = 4,
748 .ops = &clk_rcg2_ops,
749 },
750};
751
752static struct freq_tbl ftbl_camss_vfe_cpp_clk[] = {
753 F(133330000, P_GPLL0, 4.5, 0, 0),
754 F(266670000, P_MMPLL0, 3, 0, 0),
755 F(320000000, P_MMPLL0, 2.5, 0, 0),
756 F(400000000, P_MMPLL0, 2, 0, 0),
757 F(465000000, P_MMPLL3, 2, 0, 0),
758 { }
759};
760
761static struct clk_rcg2 cpp_clk_src = {
762 .cmd_rcgr = 0x3640,
763 .hid_width = 5,
764 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
765 .freq_tbl = ftbl_camss_vfe_cpp_clk,
766 .clkr.hw.init = &(struct clk_init_data){
767 .name = "cpp_clk_src",
768 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
769 .num_parents = 4,
770 .ops = &clk_rcg2_ops,
771 },
772};
773
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700774static struct freq_tbl byte_freq_tbl[] = {
775 { .src = P_DSI0PLL_BYTE },
Stephen Boydd8b21202014-01-15 10:47:31 -0800776 { }
777};
778
779static struct clk_rcg2 byte0_clk_src = {
780 .cmd_rcgr = 0x2120,
781 .hid_width = 5,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700782 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
783 .freq_tbl = byte_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800784 .clkr.hw.init = &(struct clk_init_data){
785 .name = "byte0_clk_src",
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700786 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
Stephen Boydd8b21202014-01-15 10:47:31 -0800787 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700788 .ops = &clk_byte_ops,
789 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800790 },
791};
792
793static struct clk_rcg2 byte1_clk_src = {
794 .cmd_rcgr = 0x2140,
795 .hid_width = 5,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700796 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
797 .freq_tbl = byte_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800798 .clkr.hw.init = &(struct clk_init_data){
799 .name = "byte1_clk_src",
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700800 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
Stephen Boydd8b21202014-01-15 10:47:31 -0800801 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700802 .ops = &clk_byte_ops,
803 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800804 },
805};
806
807static struct freq_tbl ftbl_mdss_edpaux_clk[] = {
808 F(19200000, P_XO, 1, 0, 0),
809 { }
810};
811
812static struct clk_rcg2 edpaux_clk_src = {
813 .cmd_rcgr = 0x20e0,
814 .hid_width = 5,
815 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
816 .freq_tbl = ftbl_mdss_edpaux_clk,
817 .clkr.hw.init = &(struct clk_init_data){
818 .name = "edpaux_clk_src",
819 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
820 .num_parents = 4,
821 .ops = &clk_rcg2_ops,
822 },
823};
824
825static struct freq_tbl ftbl_mdss_edplink_clk[] = {
826 F(135000000, P_EDPLINK, 2, 0, 0),
827 F(270000000, P_EDPLINK, 11, 0, 0),
828 { }
829};
830
831static struct clk_rcg2 edplink_clk_src = {
832 .cmd_rcgr = 0x20c0,
833 .hid_width = 5,
834 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
835 .freq_tbl = ftbl_mdss_edplink_clk,
836 .clkr.hw.init = &(struct clk_init_data){
837 .name = "edplink_clk_src",
838 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
839 .num_parents = 6,
840 .ops = &clk_rcg2_ops,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700841 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800842 },
843};
844
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700845static struct freq_tbl edp_pixel_freq_tbl[] = {
846 { .src = P_EDPVCO },
Stephen Boydd8b21202014-01-15 10:47:31 -0800847 { }
848};
849
850static struct clk_rcg2 edppixel_clk_src = {
851 .cmd_rcgr = 0x20a0,
852 .mnd_width = 8,
853 .hid_width = 5,
854 .parent_map = mmcc_xo_dsi_hdmi_edp_map,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700855 .freq_tbl = edp_pixel_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800856 .clkr.hw.init = &(struct clk_init_data){
857 .name = "edppixel_clk_src",
858 .parent_names = mmcc_xo_dsi_hdmi_edp,
859 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700860 .ops = &clk_edp_pixel_ops,
Stephen Boydd8b21202014-01-15 10:47:31 -0800861 },
862};
863
864static struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
865 F(19200000, P_XO, 1, 0, 0),
866 { }
867};
868
869static struct clk_rcg2 esc0_clk_src = {
870 .cmd_rcgr = 0x2160,
871 .hid_width = 5,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700872 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
Stephen Boydd8b21202014-01-15 10:47:31 -0800873 .freq_tbl = ftbl_mdss_esc0_1_clk,
874 .clkr.hw.init = &(struct clk_init_data){
875 .name = "esc0_clk_src",
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700876 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
Stephen Boydd8b21202014-01-15 10:47:31 -0800877 .num_parents = 6,
878 .ops = &clk_rcg2_ops,
879 },
880};
881
882static struct clk_rcg2 esc1_clk_src = {
883 .cmd_rcgr = 0x2180,
884 .hid_width = 5,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700885 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
Stephen Boydd8b21202014-01-15 10:47:31 -0800886 .freq_tbl = ftbl_mdss_esc0_1_clk,
887 .clkr.hw.init = &(struct clk_init_data){
888 .name = "esc1_clk_src",
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700889 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
Stephen Boydd8b21202014-01-15 10:47:31 -0800890 .num_parents = 6,
891 .ops = &clk_rcg2_ops,
892 },
893};
894
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700895static struct freq_tbl extpclk_freq_tbl[] = {
896 { .src = P_HDMIPLL },
Stephen Boydd8b21202014-01-15 10:47:31 -0800897 { }
898};
899
900static struct clk_rcg2 extpclk_clk_src = {
901 .cmd_rcgr = 0x2060,
902 .hid_width = 5,
903 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700904 .freq_tbl = extpclk_freq_tbl,
Stephen Boydd8b21202014-01-15 10:47:31 -0800905 .clkr.hw.init = &(struct clk_init_data){
906 .name = "extpclk_clk_src",
907 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
908 .num_parents = 6,
Stephen Boydb7b7cc72014-05-16 16:07:12 -0700909 .ops = &clk_byte_ops,
910 .flags = CLK_SET_RATE_PARENT,
Stephen Boydd8b21202014-01-15 10:47:31 -0800911 },
912};
913
914static struct freq_tbl ftbl_mdss_hdmi_clk[] = {
915 F(19200000, P_XO, 1, 0, 0),
916 { }
917};
918
919static struct clk_rcg2 hdmi_clk_src = {
920 .cmd_rcgr = 0x2100,
921 .hid_width = 5,
922 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
923 .freq_tbl = ftbl_mdss_hdmi_clk,
924 .clkr.hw.init = &(struct clk_init_data){
925 .name = "hdmi_clk_src",
926 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
927 .num_parents = 4,
928 .ops = &clk_rcg2_ops,
929 },
930};
931
932static struct freq_tbl ftbl_mdss_vsync_clk[] = {
933 F(19200000, P_XO, 1, 0, 0),
934 { }
935};
936
937static struct clk_rcg2 vsync_clk_src = {
938 .cmd_rcgr = 0x2080,
939 .hid_width = 5,
940 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
941 .freq_tbl = ftbl_mdss_vsync_clk,
942 .clkr.hw.init = &(struct clk_init_data){
943 .name = "vsync_clk_src",
944 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
945 .num_parents = 4,
946 .ops = &clk_rcg2_ops,
947 },
948};
949
950static struct clk_branch camss_cci_cci_ahb_clk = {
951 .halt_reg = 0x3348,
952 .clkr = {
953 .enable_reg = 0x3348,
954 .enable_mask = BIT(0),
955 .hw.init = &(struct clk_init_data){
956 .name = "camss_cci_cci_ahb_clk",
957 .parent_names = (const char *[]){
958 "mmss_ahb_clk_src",
959 },
960 .num_parents = 1,
961 .ops = &clk_branch2_ops,
962 },
963 },
964};
965
966static struct clk_branch camss_cci_cci_clk = {
967 .halt_reg = 0x3344,
968 .clkr = {
969 .enable_reg = 0x3344,
970 .enable_mask = BIT(0),
971 .hw.init = &(struct clk_init_data){
972 .name = "camss_cci_cci_clk",
973 .parent_names = (const char *[]){
974 "cci_clk_src",
975 },
976 .num_parents = 1,
977 .flags = CLK_SET_RATE_PARENT,
978 .ops = &clk_branch2_ops,
979 },
980 },
981};
982
983static struct clk_branch camss_csi0_ahb_clk = {
984 .halt_reg = 0x30bc,
985 .clkr = {
986 .enable_reg = 0x30bc,
987 .enable_mask = BIT(0),
988 .hw.init = &(struct clk_init_data){
989 .name = "camss_csi0_ahb_clk",
990 .parent_names = (const char *[]){
991 "mmss_ahb_clk_src",
992 },
993 .num_parents = 1,
994 .ops = &clk_branch2_ops,
995 },
996 },
997};
998
999static struct clk_branch camss_csi0_clk = {
1000 .halt_reg = 0x30b4,
1001 .clkr = {
1002 .enable_reg = 0x30b4,
1003 .enable_mask = BIT(0),
1004 .hw.init = &(struct clk_init_data){
1005 .name = "camss_csi0_clk",
1006 .parent_names = (const char *[]){
1007 "csi0_clk_src",
1008 },
1009 .num_parents = 1,
1010 .flags = CLK_SET_RATE_PARENT,
1011 .ops = &clk_branch2_ops,
1012 },
1013 },
1014};
1015
1016static struct clk_branch camss_csi0phy_clk = {
1017 .halt_reg = 0x30c4,
1018 .clkr = {
1019 .enable_reg = 0x30c4,
1020 .enable_mask = BIT(0),
1021 .hw.init = &(struct clk_init_data){
1022 .name = "camss_csi0phy_clk",
1023 .parent_names = (const char *[]){
1024 "csi0_clk_src",
1025 },
1026 .num_parents = 1,
1027 .flags = CLK_SET_RATE_PARENT,
1028 .ops = &clk_branch2_ops,
1029 },
1030 },
1031};
1032
1033static struct clk_branch camss_csi0pix_clk = {
1034 .halt_reg = 0x30e4,
1035 .clkr = {
1036 .enable_reg = 0x30e4,
1037 .enable_mask = BIT(0),
1038 .hw.init = &(struct clk_init_data){
1039 .name = "camss_csi0pix_clk",
1040 .parent_names = (const char *[]){
1041 "csi0_clk_src",
1042 },
1043 .num_parents = 1,
1044 .flags = CLK_SET_RATE_PARENT,
1045 .ops = &clk_branch2_ops,
1046 },
1047 },
1048};
1049
1050static struct clk_branch camss_csi0rdi_clk = {
1051 .halt_reg = 0x30d4,
1052 .clkr = {
1053 .enable_reg = 0x30d4,
1054 .enable_mask = BIT(0),
1055 .hw.init = &(struct clk_init_data){
1056 .name = "camss_csi0rdi_clk",
1057 .parent_names = (const char *[]){
1058 "csi0_clk_src",
1059 },
1060 .num_parents = 1,
1061 .flags = CLK_SET_RATE_PARENT,
1062 .ops = &clk_branch2_ops,
1063 },
1064 },
1065};
1066
1067static struct clk_branch camss_csi1_ahb_clk = {
1068 .halt_reg = 0x3128,
1069 .clkr = {
1070 .enable_reg = 0x3128,
1071 .enable_mask = BIT(0),
1072 .hw.init = &(struct clk_init_data){
1073 .name = "camss_csi1_ahb_clk",
1074 .parent_names = (const char *[]){
1075 "mmss_ahb_clk_src",
1076 },
1077 .num_parents = 1,
1078 .ops = &clk_branch2_ops,
1079 },
1080 },
1081};
1082
1083static struct clk_branch camss_csi1_clk = {
1084 .halt_reg = 0x3124,
1085 .clkr = {
1086 .enable_reg = 0x3124,
1087 .enable_mask = BIT(0),
1088 .hw.init = &(struct clk_init_data){
1089 .name = "camss_csi1_clk",
1090 .parent_names = (const char *[]){
1091 "csi1_clk_src",
1092 },
1093 .num_parents = 1,
1094 .flags = CLK_SET_RATE_PARENT,
1095 .ops = &clk_branch2_ops,
1096 },
1097 },
1098};
1099
1100static struct clk_branch camss_csi1phy_clk = {
1101 .halt_reg = 0x3134,
1102 .clkr = {
1103 .enable_reg = 0x3134,
1104 .enable_mask = BIT(0),
1105 .hw.init = &(struct clk_init_data){
1106 .name = "camss_csi1phy_clk",
1107 .parent_names = (const char *[]){
1108 "csi1_clk_src",
1109 },
1110 .num_parents = 1,
1111 .flags = CLK_SET_RATE_PARENT,
1112 .ops = &clk_branch2_ops,
1113 },
1114 },
1115};
1116
1117static struct clk_branch camss_csi1pix_clk = {
1118 .halt_reg = 0x3154,
1119 .clkr = {
1120 .enable_reg = 0x3154,
1121 .enable_mask = BIT(0),
1122 .hw.init = &(struct clk_init_data){
1123 .name = "camss_csi1pix_clk",
1124 .parent_names = (const char *[]){
1125 "csi1_clk_src",
1126 },
1127 .num_parents = 1,
1128 .flags = CLK_SET_RATE_PARENT,
1129 .ops = &clk_branch2_ops,
1130 },
1131 },
1132};
1133
1134static struct clk_branch camss_csi1rdi_clk = {
1135 .halt_reg = 0x3144,
1136 .clkr = {
1137 .enable_reg = 0x3144,
1138 .enable_mask = BIT(0),
1139 .hw.init = &(struct clk_init_data){
1140 .name = "camss_csi1rdi_clk",
1141 .parent_names = (const char *[]){
1142 "csi1_clk_src",
1143 },
1144 .num_parents = 1,
1145 .flags = CLK_SET_RATE_PARENT,
1146 .ops = &clk_branch2_ops,
1147 },
1148 },
1149};
1150
1151static struct clk_branch camss_csi2_ahb_clk = {
1152 .halt_reg = 0x3188,
1153 .clkr = {
1154 .enable_reg = 0x3188,
1155 .enable_mask = BIT(0),
1156 .hw.init = &(struct clk_init_data){
1157 .name = "camss_csi2_ahb_clk",
1158 .parent_names = (const char *[]){
1159 "mmss_ahb_clk_src",
1160 },
1161 .num_parents = 1,
1162 .ops = &clk_branch2_ops,
1163 },
1164 },
1165};
1166
1167static struct clk_branch camss_csi2_clk = {
1168 .halt_reg = 0x3184,
1169 .clkr = {
1170 .enable_reg = 0x3184,
1171 .enable_mask = BIT(0),
1172 .hw.init = &(struct clk_init_data){
1173 .name = "camss_csi2_clk",
1174 .parent_names = (const char *[]){
1175 "csi2_clk_src",
1176 },
1177 .num_parents = 1,
1178 .flags = CLK_SET_RATE_PARENT,
1179 .ops = &clk_branch2_ops,
1180 },
1181 },
1182};
1183
1184static struct clk_branch camss_csi2phy_clk = {
1185 .halt_reg = 0x3194,
1186 .clkr = {
1187 .enable_reg = 0x3194,
1188 .enable_mask = BIT(0),
1189 .hw.init = &(struct clk_init_data){
1190 .name = "camss_csi2phy_clk",
1191 .parent_names = (const char *[]){
1192 "csi2_clk_src",
1193 },
1194 .num_parents = 1,
1195 .flags = CLK_SET_RATE_PARENT,
1196 .ops = &clk_branch2_ops,
1197 },
1198 },
1199};
1200
1201static struct clk_branch camss_csi2pix_clk = {
1202 .halt_reg = 0x31b4,
1203 .clkr = {
1204 .enable_reg = 0x31b4,
1205 .enable_mask = BIT(0),
1206 .hw.init = &(struct clk_init_data){
1207 .name = "camss_csi2pix_clk",
1208 .parent_names = (const char *[]){
1209 "csi2_clk_src",
1210 },
1211 .num_parents = 1,
1212 .flags = CLK_SET_RATE_PARENT,
1213 .ops = &clk_branch2_ops,
1214 },
1215 },
1216};
1217
1218static struct clk_branch camss_csi2rdi_clk = {
1219 .halt_reg = 0x31a4,
1220 .clkr = {
1221 .enable_reg = 0x31a4,
1222 .enable_mask = BIT(0),
1223 .hw.init = &(struct clk_init_data){
1224 .name = "camss_csi2rdi_clk",
1225 .parent_names = (const char *[]){
1226 "csi2_clk_src",
1227 },
1228 .num_parents = 1,
1229 .flags = CLK_SET_RATE_PARENT,
1230 .ops = &clk_branch2_ops,
1231 },
1232 },
1233};
1234
1235static struct clk_branch camss_csi3_ahb_clk = {
1236 .halt_reg = 0x31e8,
1237 .clkr = {
1238 .enable_reg = 0x31e8,
1239 .enable_mask = BIT(0),
1240 .hw.init = &(struct clk_init_data){
1241 .name = "camss_csi3_ahb_clk",
1242 .parent_names = (const char *[]){
1243 "mmss_ahb_clk_src",
1244 },
1245 .num_parents = 1,
1246 .ops = &clk_branch2_ops,
1247 },
1248 },
1249};
1250
1251static struct clk_branch camss_csi3_clk = {
1252 .halt_reg = 0x31e4,
1253 .clkr = {
1254 .enable_reg = 0x31e4,
1255 .enable_mask = BIT(0),
1256 .hw.init = &(struct clk_init_data){
1257 .name = "camss_csi3_clk",
1258 .parent_names = (const char *[]){
1259 "csi3_clk_src",
1260 },
1261 .num_parents = 1,
1262 .flags = CLK_SET_RATE_PARENT,
1263 .ops = &clk_branch2_ops,
1264 },
1265 },
1266};
1267
1268static struct clk_branch camss_csi3phy_clk = {
1269 .halt_reg = 0x31f4,
1270 .clkr = {
1271 .enable_reg = 0x31f4,
1272 .enable_mask = BIT(0),
1273 .hw.init = &(struct clk_init_data){
1274 .name = "camss_csi3phy_clk",
1275 .parent_names = (const char *[]){
1276 "csi3_clk_src",
1277 },
1278 .num_parents = 1,
1279 .flags = CLK_SET_RATE_PARENT,
1280 .ops = &clk_branch2_ops,
1281 },
1282 },
1283};
1284
1285static struct clk_branch camss_csi3pix_clk = {
1286 .halt_reg = 0x3214,
1287 .clkr = {
1288 .enable_reg = 0x3214,
1289 .enable_mask = BIT(0),
1290 .hw.init = &(struct clk_init_data){
1291 .name = "camss_csi3pix_clk",
1292 .parent_names = (const char *[]){
1293 "csi3_clk_src",
1294 },
1295 .num_parents = 1,
1296 .flags = CLK_SET_RATE_PARENT,
1297 .ops = &clk_branch2_ops,
1298 },
1299 },
1300};
1301
1302static struct clk_branch camss_csi3rdi_clk = {
1303 .halt_reg = 0x3204,
1304 .clkr = {
1305 .enable_reg = 0x3204,
1306 .enable_mask = BIT(0),
1307 .hw.init = &(struct clk_init_data){
1308 .name = "camss_csi3rdi_clk",
1309 .parent_names = (const char *[]){
1310 "csi3_clk_src",
1311 },
1312 .num_parents = 1,
1313 .flags = CLK_SET_RATE_PARENT,
1314 .ops = &clk_branch2_ops,
1315 },
1316 },
1317};
1318
1319static struct clk_branch camss_csi_vfe0_clk = {
1320 .halt_reg = 0x3704,
1321 .clkr = {
1322 .enable_reg = 0x3704,
1323 .enable_mask = BIT(0),
1324 .hw.init = &(struct clk_init_data){
1325 .name = "camss_csi_vfe0_clk",
1326 .parent_names = (const char *[]){
1327 "vfe0_clk_src",
1328 },
1329 .num_parents = 1,
1330 .flags = CLK_SET_RATE_PARENT,
1331 .ops = &clk_branch2_ops,
1332 },
1333 },
1334};
1335
1336static struct clk_branch camss_csi_vfe1_clk = {
1337 .halt_reg = 0x3714,
1338 .clkr = {
1339 .enable_reg = 0x3714,
1340 .enable_mask = BIT(0),
1341 .hw.init = &(struct clk_init_data){
1342 .name = "camss_csi_vfe1_clk",
1343 .parent_names = (const char *[]){
1344 "vfe1_clk_src",
1345 },
1346 .num_parents = 1,
1347 .flags = CLK_SET_RATE_PARENT,
1348 .ops = &clk_branch2_ops,
1349 },
1350 },
1351};
1352
1353static struct clk_branch camss_gp0_clk = {
1354 .halt_reg = 0x3444,
1355 .clkr = {
1356 .enable_reg = 0x3444,
1357 .enable_mask = BIT(0),
1358 .hw.init = &(struct clk_init_data){
1359 .name = "camss_gp0_clk",
1360 .parent_names = (const char *[]){
1361 "camss_gp0_clk_src",
1362 },
1363 .num_parents = 1,
1364 .flags = CLK_SET_RATE_PARENT,
1365 .ops = &clk_branch2_ops,
1366 },
1367 },
1368};
1369
1370static struct clk_branch camss_gp1_clk = {
1371 .halt_reg = 0x3474,
1372 .clkr = {
1373 .enable_reg = 0x3474,
1374 .enable_mask = BIT(0),
1375 .hw.init = &(struct clk_init_data){
1376 .name = "camss_gp1_clk",
1377 .parent_names = (const char *[]){
1378 "camss_gp1_clk_src",
1379 },
1380 .num_parents = 1,
1381 .flags = CLK_SET_RATE_PARENT,
1382 .ops = &clk_branch2_ops,
1383 },
1384 },
1385};
1386
1387static struct clk_branch camss_ispif_ahb_clk = {
1388 .halt_reg = 0x3224,
1389 .clkr = {
1390 .enable_reg = 0x3224,
1391 .enable_mask = BIT(0),
1392 .hw.init = &(struct clk_init_data){
1393 .name = "camss_ispif_ahb_clk",
1394 .parent_names = (const char *[]){
1395 "mmss_ahb_clk_src",
1396 },
1397 .num_parents = 1,
1398 .ops = &clk_branch2_ops,
1399 },
1400 },
1401};
1402
1403static struct clk_branch camss_jpeg_jpeg0_clk = {
1404 .halt_reg = 0x35a8,
1405 .clkr = {
1406 .enable_reg = 0x35a8,
1407 .enable_mask = BIT(0),
1408 .hw.init = &(struct clk_init_data){
1409 .name = "camss_jpeg_jpeg0_clk",
1410 .parent_names = (const char *[]){
1411 "jpeg0_clk_src",
1412 },
1413 .num_parents = 1,
1414 .flags = CLK_SET_RATE_PARENT,
1415 .ops = &clk_branch2_ops,
1416 },
1417 },
1418};
1419
1420static struct clk_branch camss_jpeg_jpeg1_clk = {
1421 .halt_reg = 0x35ac,
1422 .clkr = {
1423 .enable_reg = 0x35ac,
1424 .enable_mask = BIT(0),
1425 .hw.init = &(struct clk_init_data){
1426 .name = "camss_jpeg_jpeg1_clk",
1427 .parent_names = (const char *[]){
1428 "jpeg1_clk_src",
1429 },
1430 .num_parents = 1,
1431 .flags = CLK_SET_RATE_PARENT,
1432 .ops = &clk_branch2_ops,
1433 },
1434 },
1435};
1436
1437static struct clk_branch camss_jpeg_jpeg2_clk = {
1438 .halt_reg = 0x35b0,
1439 .clkr = {
1440 .enable_reg = 0x35b0,
1441 .enable_mask = BIT(0),
1442 .hw.init = &(struct clk_init_data){
1443 .name = "camss_jpeg_jpeg2_clk",
1444 .parent_names = (const char *[]){
1445 "jpeg2_clk_src",
1446 },
1447 .num_parents = 1,
1448 .flags = CLK_SET_RATE_PARENT,
1449 .ops = &clk_branch2_ops,
1450 },
1451 },
1452};
1453
1454static struct clk_branch camss_jpeg_jpeg_ahb_clk = {
1455 .halt_reg = 0x35b4,
1456 .clkr = {
1457 .enable_reg = 0x35b4,
1458 .enable_mask = BIT(0),
1459 .hw.init = &(struct clk_init_data){
1460 .name = "camss_jpeg_jpeg_ahb_clk",
1461 .parent_names = (const char *[]){
1462 "mmss_ahb_clk_src",
1463 },
1464 .num_parents = 1,
1465 .ops = &clk_branch2_ops,
1466 },
1467 },
1468};
1469
1470static struct clk_branch camss_jpeg_jpeg_axi_clk = {
1471 .halt_reg = 0x35b8,
1472 .clkr = {
1473 .enable_reg = 0x35b8,
1474 .enable_mask = BIT(0),
1475 .hw.init = &(struct clk_init_data){
1476 .name = "camss_jpeg_jpeg_axi_clk",
1477 .parent_names = (const char *[]){
1478 "mmss_axi_clk_src",
1479 },
1480 .num_parents = 1,
1481 .ops = &clk_branch2_ops,
1482 },
1483 },
1484};
1485
1486static struct clk_branch camss_jpeg_jpeg_ocmemnoc_clk = {
1487 .halt_reg = 0x35bc,
1488 .clkr = {
1489 .enable_reg = 0x35bc,
1490 .enable_mask = BIT(0),
1491 .hw.init = &(struct clk_init_data){
1492 .name = "camss_jpeg_jpeg_ocmemnoc_clk",
1493 .parent_names = (const char *[]){
1494 "ocmemnoc_clk_src",
1495 },
1496 .num_parents = 1,
1497 .flags = CLK_SET_RATE_PARENT,
1498 .ops = &clk_branch2_ops,
1499 },
1500 },
1501};
1502
1503static struct clk_branch camss_mclk0_clk = {
1504 .halt_reg = 0x3384,
1505 .clkr = {
1506 .enable_reg = 0x3384,
1507 .enable_mask = BIT(0),
1508 .hw.init = &(struct clk_init_data){
1509 .name = "camss_mclk0_clk",
1510 .parent_names = (const char *[]){
1511 "mclk0_clk_src",
1512 },
1513 .num_parents = 1,
1514 .flags = CLK_SET_RATE_PARENT,
1515 .ops = &clk_branch2_ops,
1516 },
1517 },
1518};
1519
1520static struct clk_branch camss_mclk1_clk = {
1521 .halt_reg = 0x33b4,
1522 .clkr = {
1523 .enable_reg = 0x33b4,
1524 .enable_mask = BIT(0),
1525 .hw.init = &(struct clk_init_data){
1526 .name = "camss_mclk1_clk",
1527 .parent_names = (const char *[]){
1528 "mclk1_clk_src",
1529 },
1530 .num_parents = 1,
1531 .flags = CLK_SET_RATE_PARENT,
1532 .ops = &clk_branch2_ops,
1533 },
1534 },
1535};
1536
1537static struct clk_branch camss_mclk2_clk = {
1538 .halt_reg = 0x33e4,
1539 .clkr = {
1540 .enable_reg = 0x33e4,
1541 .enable_mask = BIT(0),
1542 .hw.init = &(struct clk_init_data){
1543 .name = "camss_mclk2_clk",
1544 .parent_names = (const char *[]){
1545 "mclk2_clk_src",
1546 },
1547 .num_parents = 1,
1548 .flags = CLK_SET_RATE_PARENT,
1549 .ops = &clk_branch2_ops,
1550 },
1551 },
1552};
1553
1554static struct clk_branch camss_mclk3_clk = {
1555 .halt_reg = 0x3414,
1556 .clkr = {
1557 .enable_reg = 0x3414,
1558 .enable_mask = BIT(0),
1559 .hw.init = &(struct clk_init_data){
1560 .name = "camss_mclk3_clk",
1561 .parent_names = (const char *[]){
1562 "mclk3_clk_src",
1563 },
1564 .num_parents = 1,
1565 .flags = CLK_SET_RATE_PARENT,
1566 .ops = &clk_branch2_ops,
1567 },
1568 },
1569};
1570
1571static struct clk_branch camss_micro_ahb_clk = {
1572 .halt_reg = 0x3494,
1573 .clkr = {
1574 .enable_reg = 0x3494,
1575 .enable_mask = BIT(0),
1576 .hw.init = &(struct clk_init_data){
1577 .name = "camss_micro_ahb_clk",
1578 .parent_names = (const char *[]){
1579 "mmss_ahb_clk_src",
1580 },
1581 .num_parents = 1,
1582 .ops = &clk_branch2_ops,
1583 },
1584 },
1585};
1586
1587static struct clk_branch camss_phy0_csi0phytimer_clk = {
1588 .halt_reg = 0x3024,
1589 .clkr = {
1590 .enable_reg = 0x3024,
1591 .enable_mask = BIT(0),
1592 .hw.init = &(struct clk_init_data){
1593 .name = "camss_phy0_csi0phytimer_clk",
1594 .parent_names = (const char *[]){
1595 "csi0phytimer_clk_src",
1596 },
1597 .num_parents = 1,
1598 .flags = CLK_SET_RATE_PARENT,
1599 .ops = &clk_branch2_ops,
1600 },
1601 },
1602};
1603
1604static struct clk_branch camss_phy1_csi1phytimer_clk = {
1605 .halt_reg = 0x3054,
1606 .clkr = {
1607 .enable_reg = 0x3054,
1608 .enable_mask = BIT(0),
1609 .hw.init = &(struct clk_init_data){
1610 .name = "camss_phy1_csi1phytimer_clk",
1611 .parent_names = (const char *[]){
1612 "csi1phytimer_clk_src",
1613 },
1614 .num_parents = 1,
1615 .flags = CLK_SET_RATE_PARENT,
1616 .ops = &clk_branch2_ops,
1617 },
1618 },
1619};
1620
1621static struct clk_branch camss_phy2_csi2phytimer_clk = {
1622 .halt_reg = 0x3084,
1623 .clkr = {
1624 .enable_reg = 0x3084,
1625 .enable_mask = BIT(0),
1626 .hw.init = &(struct clk_init_data){
1627 .name = "camss_phy2_csi2phytimer_clk",
1628 .parent_names = (const char *[]){
1629 "csi2phytimer_clk_src",
1630 },
1631 .num_parents = 1,
1632 .flags = CLK_SET_RATE_PARENT,
1633 .ops = &clk_branch2_ops,
1634 },
1635 },
1636};
1637
1638static struct clk_branch camss_top_ahb_clk = {
1639 .halt_reg = 0x3484,
1640 .clkr = {
1641 .enable_reg = 0x3484,
1642 .enable_mask = BIT(0),
1643 .hw.init = &(struct clk_init_data){
1644 .name = "camss_top_ahb_clk",
1645 .parent_names = (const char *[]){
1646 "mmss_ahb_clk_src",
1647 },
1648 .num_parents = 1,
1649 .ops = &clk_branch2_ops,
1650 },
1651 },
1652};
1653
1654static struct clk_branch camss_vfe_cpp_ahb_clk = {
1655 .halt_reg = 0x36b4,
1656 .clkr = {
1657 .enable_reg = 0x36b4,
1658 .enable_mask = BIT(0),
1659 .hw.init = &(struct clk_init_data){
1660 .name = "camss_vfe_cpp_ahb_clk",
1661 .parent_names = (const char *[]){
1662 "mmss_ahb_clk_src",
1663 },
1664 .num_parents = 1,
1665 .ops = &clk_branch2_ops,
1666 },
1667 },
1668};
1669
1670static struct clk_branch camss_vfe_cpp_clk = {
1671 .halt_reg = 0x36b0,
1672 .clkr = {
1673 .enable_reg = 0x36b0,
1674 .enable_mask = BIT(0),
1675 .hw.init = &(struct clk_init_data){
1676 .name = "camss_vfe_cpp_clk",
1677 .parent_names = (const char *[]){
1678 "cpp_clk_src",
1679 },
1680 .num_parents = 1,
1681 .flags = CLK_SET_RATE_PARENT,
1682 .ops = &clk_branch2_ops,
1683 },
1684 },
1685};
1686
1687static struct clk_branch camss_vfe_vfe0_clk = {
1688 .halt_reg = 0x36a8,
1689 .clkr = {
1690 .enable_reg = 0x36a8,
1691 .enable_mask = BIT(0),
1692 .hw.init = &(struct clk_init_data){
1693 .name = "camss_vfe_vfe0_clk",
1694 .parent_names = (const char *[]){
1695 "vfe0_clk_src",
1696 },
1697 .num_parents = 1,
1698 .flags = CLK_SET_RATE_PARENT,
1699 .ops = &clk_branch2_ops,
1700 },
1701 },
1702};
1703
1704static struct clk_branch camss_vfe_vfe1_clk = {
1705 .halt_reg = 0x36ac,
1706 .clkr = {
1707 .enable_reg = 0x36ac,
1708 .enable_mask = BIT(0),
1709 .hw.init = &(struct clk_init_data){
1710 .name = "camss_vfe_vfe1_clk",
1711 .parent_names = (const char *[]){
1712 "vfe1_clk_src",
1713 },
1714 .num_parents = 1,
1715 .flags = CLK_SET_RATE_PARENT,
1716 .ops = &clk_branch2_ops,
1717 },
1718 },
1719};
1720
1721static struct clk_branch camss_vfe_vfe_ahb_clk = {
1722 .halt_reg = 0x36b8,
1723 .clkr = {
1724 .enable_reg = 0x36b8,
1725 .enable_mask = BIT(0),
1726 .hw.init = &(struct clk_init_data){
1727 .name = "camss_vfe_vfe_ahb_clk",
1728 .parent_names = (const char *[]){
1729 "mmss_ahb_clk_src",
1730 },
1731 .num_parents = 1,
1732 .ops = &clk_branch2_ops,
1733 },
1734 },
1735};
1736
1737static struct clk_branch camss_vfe_vfe_axi_clk = {
1738 .halt_reg = 0x36bc,
1739 .clkr = {
1740 .enable_reg = 0x36bc,
1741 .enable_mask = BIT(0),
1742 .hw.init = &(struct clk_init_data){
1743 .name = "camss_vfe_vfe_axi_clk",
1744 .parent_names = (const char *[]){
1745 "mmss_axi_clk_src",
1746 },
1747 .num_parents = 1,
1748 .ops = &clk_branch2_ops,
1749 },
1750 },
1751};
1752
1753static struct clk_branch camss_vfe_vfe_ocmemnoc_clk = {
1754 .halt_reg = 0x36c0,
1755 .clkr = {
1756 .enable_reg = 0x36c0,
1757 .enable_mask = BIT(0),
1758 .hw.init = &(struct clk_init_data){
1759 .name = "camss_vfe_vfe_ocmemnoc_clk",
1760 .parent_names = (const char *[]){
1761 "ocmemnoc_clk_src",
1762 },
1763 .num_parents = 1,
1764 .flags = CLK_SET_RATE_PARENT,
1765 .ops = &clk_branch2_ops,
1766 },
1767 },
1768};
1769
1770static struct clk_branch mdss_ahb_clk = {
1771 .halt_reg = 0x2308,
1772 .clkr = {
1773 .enable_reg = 0x2308,
1774 .enable_mask = BIT(0),
1775 .hw.init = &(struct clk_init_data){
1776 .name = "mdss_ahb_clk",
1777 .parent_names = (const char *[]){
1778 "mmss_ahb_clk_src",
1779 },
1780 .num_parents = 1,
1781 .ops = &clk_branch2_ops,
1782 },
1783 },
1784};
1785
1786static struct clk_branch mdss_axi_clk = {
1787 .halt_reg = 0x2310,
1788 .clkr = {
1789 .enable_reg = 0x2310,
1790 .enable_mask = BIT(0),
1791 .hw.init = &(struct clk_init_data){
1792 .name = "mdss_axi_clk",
1793 .parent_names = (const char *[]){
1794 "mmss_axi_clk_src",
1795 },
1796 .num_parents = 1,
1797 .flags = CLK_SET_RATE_PARENT,
1798 .ops = &clk_branch2_ops,
1799 },
1800 },
1801};
1802
1803static struct clk_branch mdss_byte0_clk = {
1804 .halt_reg = 0x233c,
1805 .clkr = {
1806 .enable_reg = 0x233c,
1807 .enable_mask = BIT(0),
1808 .hw.init = &(struct clk_init_data){
1809 .name = "mdss_byte0_clk",
1810 .parent_names = (const char *[]){
1811 "byte0_clk_src",
1812 },
1813 .num_parents = 1,
1814 .flags = CLK_SET_RATE_PARENT,
1815 .ops = &clk_branch2_ops,
1816 },
1817 },
1818};
1819
1820static struct clk_branch mdss_byte1_clk = {
1821 .halt_reg = 0x2340,
1822 .clkr = {
1823 .enable_reg = 0x2340,
1824 .enable_mask = BIT(0),
1825 .hw.init = &(struct clk_init_data){
1826 .name = "mdss_byte1_clk",
1827 .parent_names = (const char *[]){
1828 "byte1_clk_src",
1829 },
1830 .num_parents = 1,
1831 .flags = CLK_SET_RATE_PARENT,
1832 .ops = &clk_branch2_ops,
1833 },
1834 },
1835};
1836
1837static struct clk_branch mdss_edpaux_clk = {
1838 .halt_reg = 0x2334,
1839 .clkr = {
1840 .enable_reg = 0x2334,
1841 .enable_mask = BIT(0),
1842 .hw.init = &(struct clk_init_data){
1843 .name = "mdss_edpaux_clk",
1844 .parent_names = (const char *[]){
1845 "edpaux_clk_src",
1846 },
1847 .num_parents = 1,
1848 .flags = CLK_SET_RATE_PARENT,
1849 .ops = &clk_branch2_ops,
1850 },
1851 },
1852};
1853
1854static struct clk_branch mdss_edplink_clk = {
1855 .halt_reg = 0x2330,
1856 .clkr = {
1857 .enable_reg = 0x2330,
1858 .enable_mask = BIT(0),
1859 .hw.init = &(struct clk_init_data){
1860 .name = "mdss_edplink_clk",
1861 .parent_names = (const char *[]){
1862 "edplink_clk_src",
1863 },
1864 .num_parents = 1,
1865 .flags = CLK_SET_RATE_PARENT,
1866 .ops = &clk_branch2_ops,
1867 },
1868 },
1869};
1870
1871static struct clk_branch mdss_edppixel_clk = {
1872 .halt_reg = 0x232c,
1873 .clkr = {
1874 .enable_reg = 0x232c,
1875 .enable_mask = BIT(0),
1876 .hw.init = &(struct clk_init_data){
1877 .name = "mdss_edppixel_clk",
1878 .parent_names = (const char *[]){
1879 "edppixel_clk_src",
1880 },
1881 .num_parents = 1,
1882 .flags = CLK_SET_RATE_PARENT,
1883 .ops = &clk_branch2_ops,
1884 },
1885 },
1886};
1887
1888static struct clk_branch mdss_esc0_clk = {
1889 .halt_reg = 0x2344,
1890 .clkr = {
1891 .enable_reg = 0x2344,
1892 .enable_mask = BIT(0),
1893 .hw.init = &(struct clk_init_data){
1894 .name = "mdss_esc0_clk",
1895 .parent_names = (const char *[]){
1896 "esc0_clk_src",
1897 },
1898 .num_parents = 1,
1899 .flags = CLK_SET_RATE_PARENT,
1900 .ops = &clk_branch2_ops,
1901 },
1902 },
1903};
1904
1905static struct clk_branch mdss_esc1_clk = {
1906 .halt_reg = 0x2348,
1907 .clkr = {
1908 .enable_reg = 0x2348,
1909 .enable_mask = BIT(0),
1910 .hw.init = &(struct clk_init_data){
1911 .name = "mdss_esc1_clk",
1912 .parent_names = (const char *[]){
1913 "esc1_clk_src",
1914 },
1915 .num_parents = 1,
1916 .flags = CLK_SET_RATE_PARENT,
1917 .ops = &clk_branch2_ops,
1918 },
1919 },
1920};
1921
1922static struct clk_branch mdss_extpclk_clk = {
1923 .halt_reg = 0x2324,
1924 .clkr = {
1925 .enable_reg = 0x2324,
1926 .enable_mask = BIT(0),
1927 .hw.init = &(struct clk_init_data){
1928 .name = "mdss_extpclk_clk",
1929 .parent_names = (const char *[]){
1930 "extpclk_clk_src",
1931 },
1932 .num_parents = 1,
1933 .flags = CLK_SET_RATE_PARENT,
1934 .ops = &clk_branch2_ops,
1935 },
1936 },
1937};
1938
1939static struct clk_branch mdss_hdmi_ahb_clk = {
1940 .halt_reg = 0x230c,
1941 .clkr = {
1942 .enable_reg = 0x230c,
1943 .enable_mask = BIT(0),
1944 .hw.init = &(struct clk_init_data){
1945 .name = "mdss_hdmi_ahb_clk",
1946 .parent_names = (const char *[]){
1947 "mmss_ahb_clk_src",
1948 },
1949 .num_parents = 1,
1950 .ops = &clk_branch2_ops,
1951 },
1952 },
1953};
1954
1955static struct clk_branch mdss_hdmi_clk = {
1956 .halt_reg = 0x2338,
1957 .clkr = {
1958 .enable_reg = 0x2338,
1959 .enable_mask = BIT(0),
1960 .hw.init = &(struct clk_init_data){
1961 .name = "mdss_hdmi_clk",
1962 .parent_names = (const char *[]){
1963 "hdmi_clk_src",
1964 },
1965 .num_parents = 1,
1966 .flags = CLK_SET_RATE_PARENT,
1967 .ops = &clk_branch2_ops,
1968 },
1969 },
1970};
1971
1972static struct clk_branch mdss_mdp_clk = {
1973 .halt_reg = 0x231c,
1974 .clkr = {
1975 .enable_reg = 0x231c,
1976 .enable_mask = BIT(0),
1977 .hw.init = &(struct clk_init_data){
1978 .name = "mdss_mdp_clk",
1979 .parent_names = (const char *[]){
1980 "mdp_clk_src",
1981 },
1982 .num_parents = 1,
1983 .flags = CLK_SET_RATE_PARENT,
1984 .ops = &clk_branch2_ops,
1985 },
1986 },
1987};
1988
1989static struct clk_branch mdss_mdp_lut_clk = {
1990 .halt_reg = 0x2320,
1991 .clkr = {
1992 .enable_reg = 0x2320,
1993 .enable_mask = BIT(0),
1994 .hw.init = &(struct clk_init_data){
1995 .name = "mdss_mdp_lut_clk",
1996 .parent_names = (const char *[]){
1997 "mdp_clk_src",
1998 },
1999 .num_parents = 1,
2000 .flags = CLK_SET_RATE_PARENT,
2001 .ops = &clk_branch2_ops,
2002 },
2003 },
2004};
2005
2006static struct clk_branch mdss_pclk0_clk = {
2007 .halt_reg = 0x2314,
2008 .clkr = {
2009 .enable_reg = 0x2314,
2010 .enable_mask = BIT(0),
2011 .hw.init = &(struct clk_init_data){
2012 .name = "mdss_pclk0_clk",
2013 .parent_names = (const char *[]){
2014 "pclk0_clk_src",
2015 },
2016 .num_parents = 1,
2017 .flags = CLK_SET_RATE_PARENT,
2018 .ops = &clk_branch2_ops,
2019 },
2020 },
2021};
2022
2023static struct clk_branch mdss_pclk1_clk = {
2024 .halt_reg = 0x2318,
2025 .clkr = {
2026 .enable_reg = 0x2318,
2027 .enable_mask = BIT(0),
2028 .hw.init = &(struct clk_init_data){
2029 .name = "mdss_pclk1_clk",
2030 .parent_names = (const char *[]){
2031 "pclk1_clk_src",
2032 },
2033 .num_parents = 1,
2034 .flags = CLK_SET_RATE_PARENT,
2035 .ops = &clk_branch2_ops,
2036 },
2037 },
2038};
2039
2040static struct clk_branch mdss_vsync_clk = {
2041 .halt_reg = 0x2328,
2042 .clkr = {
2043 .enable_reg = 0x2328,
2044 .enable_mask = BIT(0),
2045 .hw.init = &(struct clk_init_data){
2046 .name = "mdss_vsync_clk",
2047 .parent_names = (const char *[]){
2048 "vsync_clk_src",
2049 },
2050 .num_parents = 1,
2051 .flags = CLK_SET_RATE_PARENT,
2052 .ops = &clk_branch2_ops,
2053 },
2054 },
2055};
2056
2057static struct clk_branch mmss_misc_ahb_clk = {
2058 .halt_reg = 0x502c,
2059 .clkr = {
2060 .enable_reg = 0x502c,
2061 .enable_mask = BIT(0),
2062 .hw.init = &(struct clk_init_data){
2063 .name = "mmss_misc_ahb_clk",
2064 .parent_names = (const char *[]){
2065 "mmss_ahb_clk_src",
2066 },
2067 .num_parents = 1,
2068 .ops = &clk_branch2_ops,
2069 },
2070 },
2071};
2072
2073static struct clk_branch mmss_mmssnoc_ahb_clk = {
2074 .halt_reg = 0x5024,
2075 .clkr = {
2076 .enable_reg = 0x5024,
2077 .enable_mask = BIT(0),
2078 .hw.init = &(struct clk_init_data){
2079 .name = "mmss_mmssnoc_ahb_clk",
2080 .parent_names = (const char *[]){
2081 "mmss_ahb_clk_src",
2082 },
2083 .num_parents = 1,
2084 .ops = &clk_branch2_ops,
2085 .flags = CLK_IGNORE_UNUSED,
2086 },
2087 },
2088};
2089
2090static struct clk_branch mmss_mmssnoc_bto_ahb_clk = {
2091 .halt_reg = 0x5028,
2092 .clkr = {
2093 .enable_reg = 0x5028,
2094 .enable_mask = BIT(0),
2095 .hw.init = &(struct clk_init_data){
2096 .name = "mmss_mmssnoc_bto_ahb_clk",
2097 .parent_names = (const char *[]){
2098 "mmss_ahb_clk_src",
2099 },
2100 .num_parents = 1,
2101 .ops = &clk_branch2_ops,
2102 .flags = CLK_IGNORE_UNUSED,
2103 },
2104 },
2105};
2106
2107static struct clk_branch mmss_mmssnoc_axi_clk = {
2108 .halt_reg = 0x506c,
2109 .clkr = {
2110 .enable_reg = 0x506c,
2111 .enable_mask = BIT(0),
2112 .hw.init = &(struct clk_init_data){
2113 .name = "mmss_mmssnoc_axi_clk",
2114 .parent_names = (const char *[]){
2115 "mmss_axi_clk_src",
2116 },
2117 .num_parents = 1,
2118 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2119 .ops = &clk_branch2_ops,
2120 },
2121 },
2122};
2123
2124static struct clk_branch mmss_s0_axi_clk = {
2125 .halt_reg = 0x5064,
2126 .clkr = {
2127 .enable_reg = 0x5064,
2128 .enable_mask = BIT(0),
2129 .hw.init = &(struct clk_init_data){
2130 .name = "mmss_s0_axi_clk",
2131 .parent_names = (const char *[]){
2132 "mmss_axi_clk_src",
2133 },
2134 .num_parents = 1,
2135 .ops = &clk_branch2_ops,
2136 .flags = CLK_IGNORE_UNUSED,
2137 },
2138 },
2139};
2140
2141static struct clk_branch ocmemcx_ahb_clk = {
2142 .halt_reg = 0x405c,
2143 .clkr = {
2144 .enable_reg = 0x405c,
2145 .enable_mask = BIT(0),
2146 .hw.init = &(struct clk_init_data){
2147 .name = "ocmemcx_ahb_clk",
2148 .parent_names = (const char *[]){
2149 "mmss_ahb_clk_src",
2150 },
2151 .num_parents = 1,
2152 .ops = &clk_branch2_ops,
2153 },
2154 },
2155};
2156
2157static struct clk_branch ocmemcx_ocmemnoc_clk = {
2158 .halt_reg = 0x4058,
2159 .clkr = {
2160 .enable_reg = 0x4058,
2161 .enable_mask = BIT(0),
2162 .hw.init = &(struct clk_init_data){
2163 .name = "ocmemcx_ocmemnoc_clk",
2164 .parent_names = (const char *[]){
2165 "ocmemnoc_clk_src",
2166 },
2167 .num_parents = 1,
2168 .flags = CLK_SET_RATE_PARENT,
2169 .ops = &clk_branch2_ops,
2170 },
2171 },
2172};
2173
2174static struct clk_branch oxili_ocmemgx_clk = {
2175 .halt_reg = 0x402c,
2176 .clkr = {
2177 .enable_reg = 0x402c,
2178 .enable_mask = BIT(0),
2179 .hw.init = &(struct clk_init_data){
2180 .name = "oxili_ocmemgx_clk",
2181 .parent_names = (const char *[]){
2182 "gfx3d_clk_src",
2183 },
2184 .num_parents = 1,
2185 .flags = CLK_SET_RATE_PARENT,
2186 .ops = &clk_branch2_ops,
2187 },
2188 },
2189};
2190
2191static struct clk_branch ocmemnoc_clk = {
2192 .halt_reg = 0x50b4,
2193 .clkr = {
2194 .enable_reg = 0x50b4,
2195 .enable_mask = BIT(0),
2196 .hw.init = &(struct clk_init_data){
2197 .name = "ocmemnoc_clk",
2198 .parent_names = (const char *[]){
2199 "ocmemnoc_clk_src",
2200 },
2201 .num_parents = 1,
2202 .flags = CLK_SET_RATE_PARENT,
2203 .ops = &clk_branch2_ops,
2204 },
2205 },
2206};
2207
2208static struct clk_branch oxili_gfx3d_clk = {
2209 .halt_reg = 0x4028,
2210 .clkr = {
2211 .enable_reg = 0x4028,
2212 .enable_mask = BIT(0),
2213 .hw.init = &(struct clk_init_data){
2214 .name = "oxili_gfx3d_clk",
2215 .parent_names = (const char *[]){
2216 "gfx3d_clk_src",
2217 },
2218 .num_parents = 1,
2219 .flags = CLK_SET_RATE_PARENT,
2220 .ops = &clk_branch2_ops,
2221 },
2222 },
2223};
2224
2225static struct clk_branch oxilicx_ahb_clk = {
2226 .halt_reg = 0x403c,
2227 .clkr = {
2228 .enable_reg = 0x403c,
2229 .enable_mask = BIT(0),
2230 .hw.init = &(struct clk_init_data){
2231 .name = "oxilicx_ahb_clk",
2232 .parent_names = (const char *[]){
2233 "mmss_ahb_clk_src",
2234 },
2235 .num_parents = 1,
2236 .ops = &clk_branch2_ops,
2237 },
2238 },
2239};
2240
2241static struct clk_branch oxilicx_axi_clk = {
2242 .halt_reg = 0x4038,
2243 .clkr = {
2244 .enable_reg = 0x4038,
2245 .enable_mask = BIT(0),
2246 .hw.init = &(struct clk_init_data){
2247 .name = "oxilicx_axi_clk",
2248 .parent_names = (const char *[]){
2249 "mmss_axi_clk_src",
2250 },
2251 .num_parents = 1,
2252 .ops = &clk_branch2_ops,
2253 },
2254 },
2255};
2256
2257static struct clk_branch venus0_ahb_clk = {
2258 .halt_reg = 0x1030,
2259 .clkr = {
2260 .enable_reg = 0x1030,
2261 .enable_mask = BIT(0),
2262 .hw.init = &(struct clk_init_data){
2263 .name = "venus0_ahb_clk",
2264 .parent_names = (const char *[]){
2265 "mmss_ahb_clk_src",
2266 },
2267 .num_parents = 1,
2268 .ops = &clk_branch2_ops,
2269 },
2270 },
2271};
2272
2273static struct clk_branch venus0_axi_clk = {
2274 .halt_reg = 0x1034,
2275 .clkr = {
2276 .enable_reg = 0x1034,
2277 .enable_mask = BIT(0),
2278 .hw.init = &(struct clk_init_data){
2279 .name = "venus0_axi_clk",
2280 .parent_names = (const char *[]){
2281 "mmss_axi_clk_src",
2282 },
2283 .num_parents = 1,
2284 .ops = &clk_branch2_ops,
2285 },
2286 },
2287};
2288
2289static struct clk_branch venus0_ocmemnoc_clk = {
2290 .halt_reg = 0x1038,
2291 .clkr = {
2292 .enable_reg = 0x1038,
2293 .enable_mask = BIT(0),
2294 .hw.init = &(struct clk_init_data){
2295 .name = "venus0_ocmemnoc_clk",
2296 .parent_names = (const char *[]){
2297 "ocmemnoc_clk_src",
2298 },
2299 .num_parents = 1,
2300 .flags = CLK_SET_RATE_PARENT,
2301 .ops = &clk_branch2_ops,
2302 },
2303 },
2304};
2305
2306static struct clk_branch venus0_vcodec0_clk = {
2307 .halt_reg = 0x1028,
2308 .clkr = {
2309 .enable_reg = 0x1028,
2310 .enable_mask = BIT(0),
2311 .hw.init = &(struct clk_init_data){
2312 .name = "venus0_vcodec0_clk",
2313 .parent_names = (const char *[]){
2314 "vcodec0_clk_src",
2315 },
2316 .num_parents = 1,
2317 .flags = CLK_SET_RATE_PARENT,
2318 .ops = &clk_branch2_ops,
2319 },
2320 },
2321};
2322
2323static const struct pll_config mmpll1_config = {
2324 .l = 60,
2325 .m = 25,
2326 .n = 32,
2327 .vco_val = 0x0,
2328 .vco_mask = 0x3 << 20,
2329 .pre_div_val = 0x0,
Stephen Boyd437ae6a2014-05-16 16:07:09 -07002330 .pre_div_mask = 0x7 << 12,
Stephen Boydd8b21202014-01-15 10:47:31 -08002331 .post_div_val = 0x0,
2332 .post_div_mask = 0x3 << 8,
2333 .mn_ena_mask = BIT(24),
2334 .main_output_mask = BIT(0),
2335};
2336
2337static struct pll_config mmpll3_config = {
2338 .l = 48,
2339 .m = 7,
2340 .n = 16,
2341 .vco_val = 0x0,
2342 .vco_mask = 0x3 << 20,
2343 .pre_div_val = 0x0,
Stephen Boyd437ae6a2014-05-16 16:07:09 -07002344 .pre_div_mask = 0x7 << 12,
Stephen Boydd8b21202014-01-15 10:47:31 -08002345 .post_div_val = 0x0,
2346 .post_div_mask = 0x3 << 8,
2347 .mn_ena_mask = BIT(24),
2348 .main_output_mask = BIT(0),
2349 .aux_output_mask = BIT(1),
2350};
2351
2352static struct clk_regmap *mmcc_msm8974_clocks[] = {
2353 [MMSS_AHB_CLK_SRC] = &mmss_ahb_clk_src.clkr,
2354 [MMSS_AXI_CLK_SRC] = &mmss_axi_clk_src.clkr,
2355 [OCMEMNOC_CLK_SRC] = &ocmemnoc_clk_src.clkr,
2356 [MMPLL0] = &mmpll0.clkr,
2357 [MMPLL0_VOTE] = &mmpll0_vote,
2358 [MMPLL1] = &mmpll1.clkr,
2359 [MMPLL1_VOTE] = &mmpll1_vote,
2360 [MMPLL2] = &mmpll2.clkr,
2361 [MMPLL3] = &mmpll3.clkr,
2362 [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
2363 [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
2364 [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
2365 [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
2366 [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
2367 [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
2368 [MDP_CLK_SRC] = &mdp_clk_src.clkr,
2369 [GFX3D_CLK_SRC] = &gfx3d_clk_src.clkr,
2370 [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
2371 [JPEG1_CLK_SRC] = &jpeg1_clk_src.clkr,
2372 [JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
2373 [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
2374 [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
2375 [VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr,
2376 [CCI_CLK_SRC] = &cci_clk_src.clkr,
2377 [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
2378 [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
2379 [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
2380 [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
2381 [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
2382 [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
2383 [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
2384 [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
2385 [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
2386 [CPP_CLK_SRC] = &cpp_clk_src.clkr,
2387 [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
2388 [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
2389 [EDPAUX_CLK_SRC] = &edpaux_clk_src.clkr,
2390 [EDPLINK_CLK_SRC] = &edplink_clk_src.clkr,
2391 [EDPPIXEL_CLK_SRC] = &edppixel_clk_src.clkr,
2392 [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
2393 [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
2394 [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
2395 [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
2396 [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
2397 [CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
2398 [CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
2399 [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
2400 [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
2401 [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
2402 [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
2403 [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
2404 [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
2405 [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
2406 [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
2407 [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
2408 [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
2409 [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
2410 [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
2411 [CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
2412 [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
2413 [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
2414 [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
2415 [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
2416 [CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
2417 [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
2418 [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
2419 [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
2420 [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
2421 [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
2422 [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
2423 [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
2424 [CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
2425 [CAMSS_JPEG_JPEG1_CLK] = &camss_jpeg_jpeg1_clk.clkr,
2426 [CAMSS_JPEG_JPEG2_CLK] = &camss_jpeg_jpeg2_clk.clkr,
2427 [CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
2428 [CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
2429 [CAMSS_JPEG_JPEG_OCMEMNOC_CLK] = &camss_jpeg_jpeg_ocmemnoc_clk.clkr,
2430 [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
2431 [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
2432 [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
2433 [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
2434 [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
2435 [CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
2436 [CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
2437 [CAMSS_PHY2_CSI2PHYTIMER_CLK] = &camss_phy2_csi2phytimer_clk.clkr,
2438 [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
2439 [CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
2440 [CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
2441 [CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
2442 [CAMSS_VFE_VFE1_CLK] = &camss_vfe_vfe1_clk.clkr,
2443 [CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
2444 [CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
2445 [CAMSS_VFE_VFE_OCMEMNOC_CLK] = &camss_vfe_vfe_ocmemnoc_clk.clkr,
2446 [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
2447 [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
2448 [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
2449 [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
2450 [MDSS_EDPAUX_CLK] = &mdss_edpaux_clk.clkr,
2451 [MDSS_EDPLINK_CLK] = &mdss_edplink_clk.clkr,
2452 [MDSS_EDPPIXEL_CLK] = &mdss_edppixel_clk.clkr,
2453 [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
2454 [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
2455 [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
2456 [MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
2457 [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
2458 [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
2459 [MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
2460 [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
2461 [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
2462 [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
2463 [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
2464 [MMSS_MMSSNOC_AHB_CLK] = &mmss_mmssnoc_ahb_clk.clkr,
2465 [MMSS_MMSSNOC_BTO_AHB_CLK] = &mmss_mmssnoc_bto_ahb_clk.clkr,
2466 [MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
2467 [MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
2468 [OCMEMCX_AHB_CLK] = &ocmemcx_ahb_clk.clkr,
2469 [OCMEMCX_OCMEMNOC_CLK] = &ocmemcx_ocmemnoc_clk.clkr,
2470 [OXILI_OCMEMGX_CLK] = &oxili_ocmemgx_clk.clkr,
2471 [OCMEMNOC_CLK] = &ocmemnoc_clk.clkr,
2472 [OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
2473 [OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
2474 [OXILICX_AXI_CLK] = &oxilicx_axi_clk.clkr,
2475 [VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
2476 [VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
2477 [VENUS0_OCMEMNOC_CLK] = &venus0_ocmemnoc_clk.clkr,
2478 [VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
2479};
2480
2481static const struct qcom_reset_map mmcc_msm8974_resets[] = {
2482 [SPDM_RESET] = { 0x0200 },
2483 [SPDM_RM_RESET] = { 0x0300 },
2484 [VENUS0_RESET] = { 0x1020 },
2485 [MDSS_RESET] = { 0x2300 },
2486 [CAMSS_PHY0_RESET] = { 0x3020 },
2487 [CAMSS_PHY1_RESET] = { 0x3050 },
2488 [CAMSS_PHY2_RESET] = { 0x3080 },
2489 [CAMSS_CSI0_RESET] = { 0x30b0 },
2490 [CAMSS_CSI0PHY_RESET] = { 0x30c0 },
2491 [CAMSS_CSI0RDI_RESET] = { 0x30d0 },
2492 [CAMSS_CSI0PIX_RESET] = { 0x30e0 },
2493 [CAMSS_CSI1_RESET] = { 0x3120 },
2494 [CAMSS_CSI1PHY_RESET] = { 0x3130 },
2495 [CAMSS_CSI1RDI_RESET] = { 0x3140 },
2496 [CAMSS_CSI1PIX_RESET] = { 0x3150 },
2497 [CAMSS_CSI2_RESET] = { 0x3180 },
2498 [CAMSS_CSI2PHY_RESET] = { 0x3190 },
2499 [CAMSS_CSI2RDI_RESET] = { 0x31a0 },
2500 [CAMSS_CSI2PIX_RESET] = { 0x31b0 },
2501 [CAMSS_CSI3_RESET] = { 0x31e0 },
2502 [CAMSS_CSI3PHY_RESET] = { 0x31f0 },
2503 [CAMSS_CSI3RDI_RESET] = { 0x3200 },
2504 [CAMSS_CSI3PIX_RESET] = { 0x3210 },
2505 [CAMSS_ISPIF_RESET] = { 0x3220 },
2506 [CAMSS_CCI_RESET] = { 0x3340 },
2507 [CAMSS_MCLK0_RESET] = { 0x3380 },
2508 [CAMSS_MCLK1_RESET] = { 0x33b0 },
2509 [CAMSS_MCLK2_RESET] = { 0x33e0 },
2510 [CAMSS_MCLK3_RESET] = { 0x3410 },
2511 [CAMSS_GP0_RESET] = { 0x3440 },
2512 [CAMSS_GP1_RESET] = { 0x3470 },
2513 [CAMSS_TOP_RESET] = { 0x3480 },
2514 [CAMSS_MICRO_RESET] = { 0x3490 },
2515 [CAMSS_JPEG_RESET] = { 0x35a0 },
2516 [CAMSS_VFE_RESET] = { 0x36a0 },
2517 [CAMSS_CSI_VFE0_RESET] = { 0x3700 },
2518 [CAMSS_CSI_VFE1_RESET] = { 0x3710 },
2519 [OXILI_RESET] = { 0x4020 },
2520 [OXILICX_RESET] = { 0x4030 },
2521 [OCMEMCX_RESET] = { 0x4050 },
2522 [MMSS_RBCRP_RESET] = { 0x4080 },
2523 [MMSSNOCAHB_RESET] = { 0x5020 },
2524 [MMSSNOCAXI_RESET] = { 0x5060 },
2525 [OCMEMNOC_RESET] = { 0x50b0 },
2526};
2527
2528static const struct regmap_config mmcc_msm8974_regmap_config = {
2529 .reg_bits = 32,
2530 .reg_stride = 4,
2531 .val_bits = 32,
2532 .max_register = 0x5104,
2533 .fast_io = true,
2534};
2535
Stephen Boyd49fc8252014-03-21 17:59:37 -07002536static const struct qcom_cc_desc mmcc_msm8974_desc = {
2537 .config = &mmcc_msm8974_regmap_config,
2538 .clks = mmcc_msm8974_clocks,
2539 .num_clks = ARRAY_SIZE(mmcc_msm8974_clocks),
2540 .resets = mmcc_msm8974_resets,
2541 .num_resets = ARRAY_SIZE(mmcc_msm8974_resets),
2542};
2543
Stephen Boydd8b21202014-01-15 10:47:31 -08002544static const struct of_device_id mmcc_msm8974_match_table[] = {
2545 { .compatible = "qcom,mmcc-msm8974" },
2546 { }
2547};
2548MODULE_DEVICE_TABLE(of, mmcc_msm8974_match_table);
2549
Stephen Boydd8b21202014-01-15 10:47:31 -08002550static int mmcc_msm8974_probe(struct platform_device *pdev)
2551{
Stephen Boydd8b21202014-01-15 10:47:31 -08002552 struct regmap *regmap;
Stephen Boydd8b21202014-01-15 10:47:31 -08002553
Stephen Boyd5b6b7492014-07-15 14:59:21 -07002554 regmap = qcom_cc_map(pdev, &mmcc_msm8974_desc);
2555 if (IS_ERR(regmap))
2556 return PTR_ERR(regmap);
Stephen Boydd8b21202014-01-15 10:47:31 -08002557
Stephen Boyd49fc8252014-03-21 17:59:37 -07002558 clk_pll_configure_sr_hpm_lp(&mmpll1, regmap, &mmpll1_config, true);
2559 clk_pll_configure_sr_hpm_lp(&mmpll3, regmap, &mmpll3_config, false);
Stephen Boydd8b21202014-01-15 10:47:31 -08002560
Stephen Boyd5b6b7492014-07-15 14:59:21 -07002561 return qcom_cc_really_probe(pdev, &mmcc_msm8974_desc, regmap);
Stephen Boydd8b21202014-01-15 10:47:31 -08002562}
2563
2564static int mmcc_msm8974_remove(struct platform_device *pdev)
2565{
Stephen Boyd49fc8252014-03-21 17:59:37 -07002566 qcom_cc_remove(pdev);
Stephen Boydd8b21202014-01-15 10:47:31 -08002567 return 0;
2568}
2569
2570static struct platform_driver mmcc_msm8974_driver = {
2571 .probe = mmcc_msm8974_probe,
2572 .remove = mmcc_msm8974_remove,
2573 .driver = {
2574 .name = "mmcc-msm8974",
Stephen Boydd8b21202014-01-15 10:47:31 -08002575 .of_match_table = mmcc_msm8974_match_table,
2576 },
2577};
2578module_platform_driver(mmcc_msm8974_driver);
2579
2580MODULE_DESCRIPTION("QCOM MMCC MSM8974 Driver");
2581MODULE_LICENSE("GPL v2");
2582MODULE_ALIAS("platform:mmcc-msm8974");