1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
6 #include <linux/kernel.h>
7 #include <linux/bitops.h>
9 #include <linux/platform_device.h>
10 #include <linux/module.h>
12 #include <linux/of_device.h>
13 #include <linux/clk-provider.h>
14 #include <linux/regmap.h>
15 #include <linux/reset-controller.h>
17 #include <dt-bindings/clock/qcom,mmcc-msm8974.h>
18 #include <dt-bindings/reset/qcom,mmcc-msm8974.h>
21 #include "clk-regmap.h"
24 #include "clk-branch.h"
45 static const struct parent_map mmcc_xo_mmpll0_mmpll1_gpll0_map[] = {
52 static const char * const mmcc_xo_mmpll0_mmpll1_gpll0[] = {
59 static const struct parent_map mmcc_xo_mmpll0_dsi_hdmi_gpll0_map[] = {
68 static const char * const mmcc_xo_mmpll0_dsi_hdmi_gpll0[] = {
77 static const struct parent_map mmcc_xo_mmpll0_1_3_gpll0_map[] = {
85 static const char * const mmcc_xo_mmpll0_1_3_gpll0[] = {
93 static const struct parent_map mmcc_xo_mmpll0_1_gpll1_0_map[] = {
101 static const char * const mmcc_xo_mmpll0_1_gpll1_0[] = {
109 static const struct parent_map mmcc_xo_dsi_hdmi_edp_map[] = {
118 static const char * const mmcc_xo_dsi_hdmi_edp[] = {
127 static const struct parent_map mmcc_xo_dsi_hdmi_edp_gpll0_map[] = {
136 static const char * const mmcc_xo_dsi_hdmi_edp_gpll0[] = {
145 static const struct parent_map mmcc_xo_dsibyte_hdmi_edp_gpll0_map[] = {
150 { P_DSI0PLL_BYTE, 1 },
151 { P_DSI1PLL_BYTE, 2 }
154 static const char * const mmcc_xo_dsibyte_hdmi_edp_gpll0[] = {
163 static struct clk_pll mmpll0 = {
167 .config_reg = 0x0014,
169 .status_reg = 0x001c,
171 .clkr.hw.init = &(struct clk_init_data){
173 .parent_names = (const char *[]){ "xo" },
179 static struct clk_regmap mmpll0_vote = {
180 .enable_reg = 0x0100,
181 .enable_mask = BIT(0),
182 .hw.init = &(struct clk_init_data){
183 .name = "mmpll0_vote",
184 .parent_names = (const char *[]){ "mmpll0" },
186 .ops = &clk_pll_vote_ops,
190 static struct clk_pll mmpll1 = {
194 .config_reg = 0x0050,
196 .status_reg = 0x005c,
198 .clkr.hw.init = &(struct clk_init_data){
200 .parent_names = (const char *[]){ "xo" },
206 static struct clk_regmap mmpll1_vote = {
207 .enable_reg = 0x0100,
208 .enable_mask = BIT(1),
209 .hw.init = &(struct clk_init_data){
210 .name = "mmpll1_vote",
211 .parent_names = (const char *[]){ "mmpll1" },
213 .ops = &clk_pll_vote_ops,
217 static struct clk_pll mmpll2 = {
221 .config_reg = 0x4110,
223 .status_reg = 0x411c,
224 .clkr.hw.init = &(struct clk_init_data){
226 .parent_names = (const char *[]){ "xo" },
232 static struct clk_pll mmpll3 = {
236 .config_reg = 0x0090,
238 .status_reg = 0x009c,
240 .clkr.hw.init = &(struct clk_init_data){
242 .parent_names = (const char *[]){ "xo" },
248 static struct clk_rcg2 mmss_ahb_clk_src = {
251 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
252 .clkr.hw.init = &(struct clk_init_data){
253 .name = "mmss_ahb_clk_src",
254 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
256 .ops = &clk_rcg2_ops,
260 static struct freq_tbl ftbl_mmss_axi_clk[] = {
261 F( 19200000, P_XO, 1, 0, 0),
262 F( 37500000, P_GPLL0, 16, 0, 0),
263 F( 50000000, P_GPLL0, 12, 0, 0),
264 F( 75000000, P_GPLL0, 8, 0, 0),
265 F(100000000, P_GPLL0, 6, 0, 0),
266 F(150000000, P_GPLL0, 4, 0, 0),
267 F(291750000, P_MMPLL1, 4, 0, 0),
268 F(400000000, P_MMPLL0, 2, 0, 0),
269 F(466800000, P_MMPLL1, 2.5, 0, 0),
272 static struct clk_rcg2 mmss_axi_clk_src = {
275 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
276 .freq_tbl = ftbl_mmss_axi_clk,
277 .clkr.hw.init = &(struct clk_init_data){
278 .name = "mmss_axi_clk_src",
279 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
281 .ops = &clk_rcg2_ops,
285 static struct freq_tbl ftbl_ocmemnoc_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),
296 static struct clk_rcg2 ocmemnoc_clk_src = {
299 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
300 .freq_tbl = ftbl_ocmemnoc_clk,
301 .clkr.hw.init = &(struct clk_init_data){
302 .name = "ocmemnoc_clk_src",
303 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
305 .ops = &clk_rcg2_ops,
309 static struct freq_tbl ftbl_camss_csi0_3_clk[] = {
310 F(100000000, P_GPLL0, 6, 0, 0),
311 F(200000000, P_MMPLL0, 4, 0, 0),
315 static struct clk_rcg2 csi0_clk_src = {
318 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
319 .freq_tbl = ftbl_camss_csi0_3_clk,
320 .clkr.hw.init = &(struct clk_init_data){
321 .name = "csi0_clk_src",
322 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
324 .ops = &clk_rcg2_ops,
328 static struct clk_rcg2 csi1_clk_src = {
331 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
332 .freq_tbl = ftbl_camss_csi0_3_clk,
333 .clkr.hw.init = &(struct clk_init_data){
334 .name = "csi1_clk_src",
335 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
337 .ops = &clk_rcg2_ops,
341 static struct clk_rcg2 csi2_clk_src = {
344 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
345 .freq_tbl = ftbl_camss_csi0_3_clk,
346 .clkr.hw.init = &(struct clk_init_data){
347 .name = "csi2_clk_src",
348 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
350 .ops = &clk_rcg2_ops,
354 static struct clk_rcg2 csi3_clk_src = {
357 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
358 .freq_tbl = ftbl_camss_csi0_3_clk,
359 .clkr.hw.init = &(struct clk_init_data){
360 .name = "csi3_clk_src",
361 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
363 .ops = &clk_rcg2_ops,
367 static struct freq_tbl ftbl_camss_vfe_vfe0_1_clk[] = {
368 F(37500000, P_GPLL0, 16, 0, 0),
369 F(50000000, P_GPLL0, 12, 0, 0),
370 F(60000000, P_GPLL0, 10, 0, 0),
371 F(80000000, P_GPLL0, 7.5, 0, 0),
372 F(100000000, P_GPLL0, 6, 0, 0),
373 F(109090000, P_GPLL0, 5.5, 0, 0),
374 F(133330000, P_GPLL0, 4.5, 0, 0),
375 F(200000000, P_GPLL0, 3, 0, 0),
376 F(228570000, P_MMPLL0, 3.5, 0, 0),
377 F(266670000, P_MMPLL0, 3, 0, 0),
378 F(320000000, P_MMPLL0, 2.5, 0, 0),
379 F(400000000, P_MMPLL0, 2, 0, 0),
380 F(465000000, P_MMPLL3, 2, 0, 0),
384 static struct clk_rcg2 vfe0_clk_src = {
387 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
388 .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
389 .clkr.hw.init = &(struct clk_init_data){
390 .name = "vfe0_clk_src",
391 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
393 .ops = &clk_rcg2_ops,
397 static struct clk_rcg2 vfe1_clk_src = {
400 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
401 .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
402 .clkr.hw.init = &(struct clk_init_data){
403 .name = "vfe1_clk_src",
404 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
406 .ops = &clk_rcg2_ops,
410 static struct freq_tbl ftbl_mdss_mdp_clk[] = {
411 F(37500000, P_GPLL0, 16, 0, 0),
412 F(60000000, P_GPLL0, 10, 0, 0),
413 F(75000000, P_GPLL0, 8, 0, 0),
414 F(85710000, P_GPLL0, 7, 0, 0),
415 F(100000000, P_GPLL0, 6, 0, 0),
416 F(133330000, P_MMPLL0, 6, 0, 0),
417 F(160000000, P_MMPLL0, 5, 0, 0),
418 F(200000000, P_MMPLL0, 4, 0, 0),
419 F(228570000, P_MMPLL0, 3.5, 0, 0),
420 F(240000000, P_GPLL0, 2.5, 0, 0),
421 F(266670000, P_MMPLL0, 3, 0, 0),
422 F(320000000, P_MMPLL0, 2.5, 0, 0),
426 static struct clk_rcg2 mdp_clk_src = {
429 .parent_map = mmcc_xo_mmpll0_dsi_hdmi_gpll0_map,
430 .freq_tbl = ftbl_mdss_mdp_clk,
431 .clkr.hw.init = &(struct clk_init_data){
432 .name = "mdp_clk_src",
433 .parent_names = mmcc_xo_mmpll0_dsi_hdmi_gpll0,
435 .ops = &clk_rcg2_ops,
439 static struct freq_tbl ftbl_camss_jpeg_jpeg0_2_clk[] = {
440 F(75000000, P_GPLL0, 8, 0, 0),
441 F(133330000, P_GPLL0, 4.5, 0, 0),
442 F(200000000, P_GPLL0, 3, 0, 0),
443 F(228570000, P_MMPLL0, 3.5, 0, 0),
444 F(266670000, P_MMPLL0, 3, 0, 0),
445 F(320000000, P_MMPLL0, 2.5, 0, 0),
449 static struct clk_rcg2 jpeg0_clk_src = {
452 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
453 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
454 .clkr.hw.init = &(struct clk_init_data){
455 .name = "jpeg0_clk_src",
456 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
458 .ops = &clk_rcg2_ops,
462 static struct clk_rcg2 jpeg1_clk_src = {
465 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
466 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
467 .clkr.hw.init = &(struct clk_init_data){
468 .name = "jpeg1_clk_src",
469 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
471 .ops = &clk_rcg2_ops,
475 static struct clk_rcg2 jpeg2_clk_src = {
478 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
479 .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
480 .clkr.hw.init = &(struct clk_init_data){
481 .name = "jpeg2_clk_src",
482 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
484 .ops = &clk_rcg2_ops,
488 static struct clk_rcg2 pclk0_clk_src = {
492 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
493 .clkr.hw.init = &(struct clk_init_data){
494 .name = "pclk0_clk_src",
495 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
497 .ops = &clk_pixel_ops,
498 .flags = CLK_SET_RATE_PARENT,
502 static struct clk_rcg2 pclk1_clk_src = {
506 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
507 .clkr.hw.init = &(struct clk_init_data){
508 .name = "pclk1_clk_src",
509 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
511 .ops = &clk_pixel_ops,
512 .flags = CLK_SET_RATE_PARENT,
516 static struct freq_tbl ftbl_venus0_vcodec0_clk[] = {
517 F(50000000, P_GPLL0, 12, 0, 0),
518 F(100000000, P_GPLL0, 6, 0, 0),
519 F(133330000, P_MMPLL0, 6, 0, 0),
520 F(200000000, P_MMPLL0, 4, 0, 0),
521 F(266670000, P_MMPLL0, 3, 0, 0),
522 F(465000000, P_MMPLL3, 2, 0, 0),
526 static struct clk_rcg2 vcodec0_clk_src = {
530 .parent_map = mmcc_xo_mmpll0_1_3_gpll0_map,
531 .freq_tbl = ftbl_venus0_vcodec0_clk,
532 .clkr.hw.init = &(struct clk_init_data){
533 .name = "vcodec0_clk_src",
534 .parent_names = mmcc_xo_mmpll0_1_3_gpll0,
536 .ops = &clk_rcg2_ops,
540 static struct freq_tbl ftbl_camss_cci_cci_clk[] = {
541 F(19200000, P_XO, 1, 0, 0),
545 static struct clk_rcg2 cci_clk_src = {
548 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
549 .freq_tbl = ftbl_camss_cci_cci_clk,
550 .clkr.hw.init = &(struct clk_init_data){
551 .name = "cci_clk_src",
552 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
554 .ops = &clk_rcg2_ops,
558 static struct freq_tbl ftbl_camss_gp0_1_clk[] = {
559 F(10000, P_XO, 16, 1, 120),
560 F(24000, P_XO, 16, 1, 50),
561 F(6000000, P_GPLL0, 10, 1, 10),
562 F(12000000, P_GPLL0, 10, 1, 5),
563 F(13000000, P_GPLL0, 4, 13, 150),
564 F(24000000, P_GPLL0, 5, 1, 5),
568 static struct clk_rcg2 camss_gp0_clk_src = {
572 .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
573 .freq_tbl = ftbl_camss_gp0_1_clk,
574 .clkr.hw.init = &(struct clk_init_data){
575 .name = "camss_gp0_clk_src",
576 .parent_names = mmcc_xo_mmpll0_1_gpll1_0,
578 .ops = &clk_rcg2_ops,
582 static struct clk_rcg2 camss_gp1_clk_src = {
586 .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
587 .freq_tbl = ftbl_camss_gp0_1_clk,
588 .clkr.hw.init = &(struct clk_init_data){
589 .name = "camss_gp1_clk_src",
590 .parent_names = mmcc_xo_mmpll0_1_gpll1_0,
592 .ops = &clk_rcg2_ops,
596 static struct freq_tbl ftbl_camss_mclk0_3_clk[] = {
597 F(4800000, P_XO, 4, 0, 0),
598 F(6000000, P_GPLL0, 10, 1, 10),
599 F(8000000, P_GPLL0, 15, 1, 5),
600 F(9600000, P_XO, 2, 0, 0),
601 F(16000000, P_GPLL0, 12.5, 1, 3),
602 F(19200000, P_XO, 1, 0, 0),
603 F(24000000, P_GPLL0, 5, 1, 5),
604 F(32000000, P_MMPLL0, 5, 1, 5),
605 F(48000000, P_GPLL0, 12.5, 0, 0),
606 F(64000000, P_MMPLL0, 12.5, 0, 0),
607 F(66670000, P_GPLL0, 9, 0, 0),
611 static struct clk_rcg2 mclk0_clk_src = {
614 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
615 .freq_tbl = ftbl_camss_mclk0_3_clk,
616 .clkr.hw.init = &(struct clk_init_data){
617 .name = "mclk0_clk_src",
618 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
620 .ops = &clk_rcg2_ops,
624 static struct clk_rcg2 mclk1_clk_src = {
627 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
628 .freq_tbl = ftbl_camss_mclk0_3_clk,
629 .clkr.hw.init = &(struct clk_init_data){
630 .name = "mclk1_clk_src",
631 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
633 .ops = &clk_rcg2_ops,
637 static struct clk_rcg2 mclk2_clk_src = {
640 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
641 .freq_tbl = ftbl_camss_mclk0_3_clk,
642 .clkr.hw.init = &(struct clk_init_data){
643 .name = "mclk2_clk_src",
644 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
646 .ops = &clk_rcg2_ops,
650 static struct clk_rcg2 mclk3_clk_src = {
653 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
654 .freq_tbl = ftbl_camss_mclk0_3_clk,
655 .clkr.hw.init = &(struct clk_init_data){
656 .name = "mclk3_clk_src",
657 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
659 .ops = &clk_rcg2_ops,
663 static struct freq_tbl ftbl_camss_phy0_2_csi0_2phytimer_clk[] = {
664 F(100000000, P_GPLL0, 6, 0, 0),
665 F(200000000, P_MMPLL0, 4, 0, 0),
669 static struct clk_rcg2 csi0phytimer_clk_src = {
672 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
673 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
674 .clkr.hw.init = &(struct clk_init_data){
675 .name = "csi0phytimer_clk_src",
676 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
678 .ops = &clk_rcg2_ops,
682 static struct clk_rcg2 csi1phytimer_clk_src = {
685 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
686 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
687 .clkr.hw.init = &(struct clk_init_data){
688 .name = "csi1phytimer_clk_src",
689 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
691 .ops = &clk_rcg2_ops,
695 static struct clk_rcg2 csi2phytimer_clk_src = {
698 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
699 .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
700 .clkr.hw.init = &(struct clk_init_data){
701 .name = "csi2phytimer_clk_src",
702 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
704 .ops = &clk_rcg2_ops,
708 static struct freq_tbl ftbl_camss_vfe_cpp_clk[] = {
709 F(133330000, P_GPLL0, 4.5, 0, 0),
710 F(266670000, P_MMPLL0, 3, 0, 0),
711 F(320000000, P_MMPLL0, 2.5, 0, 0),
712 F(400000000, P_MMPLL0, 2, 0, 0),
713 F(465000000, P_MMPLL3, 2, 0, 0),
717 static struct clk_rcg2 cpp_clk_src = {
720 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
721 .freq_tbl = ftbl_camss_vfe_cpp_clk,
722 .clkr.hw.init = &(struct clk_init_data){
723 .name = "cpp_clk_src",
724 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
726 .ops = &clk_rcg2_ops,
730 static struct freq_tbl byte_freq_tbl[] = {
731 { .src = P_DSI0PLL_BYTE },
735 static struct clk_rcg2 byte0_clk_src = {
738 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
739 .freq_tbl = byte_freq_tbl,
740 .clkr.hw.init = &(struct clk_init_data){
741 .name = "byte0_clk_src",
742 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
744 .ops = &clk_byte2_ops,
745 .flags = CLK_SET_RATE_PARENT,
749 static struct clk_rcg2 byte1_clk_src = {
752 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
753 .freq_tbl = byte_freq_tbl,
754 .clkr.hw.init = &(struct clk_init_data){
755 .name = "byte1_clk_src",
756 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
758 .ops = &clk_byte2_ops,
759 .flags = CLK_SET_RATE_PARENT,
763 static struct freq_tbl ftbl_mdss_edpaux_clk[] = {
764 F(19200000, P_XO, 1, 0, 0),
768 static struct clk_rcg2 edpaux_clk_src = {
771 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
772 .freq_tbl = ftbl_mdss_edpaux_clk,
773 .clkr.hw.init = &(struct clk_init_data){
774 .name = "edpaux_clk_src",
775 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
777 .ops = &clk_rcg2_ops,
781 static struct freq_tbl ftbl_mdss_edplink_clk[] = {
782 F(135000000, P_EDPLINK, 2, 0, 0),
783 F(270000000, P_EDPLINK, 11, 0, 0),
787 static struct clk_rcg2 edplink_clk_src = {
790 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
791 .freq_tbl = ftbl_mdss_edplink_clk,
792 .clkr.hw.init = &(struct clk_init_data){
793 .name = "edplink_clk_src",
794 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
796 .ops = &clk_rcg2_ops,
797 .flags = CLK_SET_RATE_PARENT,
801 static struct freq_tbl edp_pixel_freq_tbl[] = {
806 static struct clk_rcg2 edppixel_clk_src = {
810 .parent_map = mmcc_xo_dsi_hdmi_edp_map,
811 .freq_tbl = edp_pixel_freq_tbl,
812 .clkr.hw.init = &(struct clk_init_data){
813 .name = "edppixel_clk_src",
814 .parent_names = mmcc_xo_dsi_hdmi_edp,
816 .ops = &clk_edp_pixel_ops,
820 static struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
821 F(19200000, P_XO, 1, 0, 0),
825 static struct clk_rcg2 esc0_clk_src = {
828 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
829 .freq_tbl = ftbl_mdss_esc0_1_clk,
830 .clkr.hw.init = &(struct clk_init_data){
831 .name = "esc0_clk_src",
832 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
834 .ops = &clk_rcg2_ops,
838 static struct clk_rcg2 esc1_clk_src = {
841 .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
842 .freq_tbl = ftbl_mdss_esc0_1_clk,
843 .clkr.hw.init = &(struct clk_init_data){
844 .name = "esc1_clk_src",
845 .parent_names = mmcc_xo_dsibyte_hdmi_edp_gpll0,
847 .ops = &clk_rcg2_ops,
851 static struct freq_tbl extpclk_freq_tbl[] = {
852 { .src = P_HDMIPLL },
856 static struct clk_rcg2 extpclk_clk_src = {
859 .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
860 .freq_tbl = extpclk_freq_tbl,
861 .clkr.hw.init = &(struct clk_init_data){
862 .name = "extpclk_clk_src",
863 .parent_names = mmcc_xo_dsi_hdmi_edp_gpll0,
865 .ops = &clk_byte_ops,
866 .flags = CLK_SET_RATE_PARENT,
870 static struct freq_tbl ftbl_mdss_hdmi_clk[] = {
871 F(19200000, P_XO, 1, 0, 0),
875 static struct clk_rcg2 hdmi_clk_src = {
878 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
879 .freq_tbl = ftbl_mdss_hdmi_clk,
880 .clkr.hw.init = &(struct clk_init_data){
881 .name = "hdmi_clk_src",
882 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
884 .ops = &clk_rcg2_ops,
888 static struct freq_tbl ftbl_mdss_vsync_clk[] = {
889 F(19200000, P_XO, 1, 0, 0),
893 static struct clk_rcg2 vsync_clk_src = {
896 .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
897 .freq_tbl = ftbl_mdss_vsync_clk,
898 .clkr.hw.init = &(struct clk_init_data){
899 .name = "vsync_clk_src",
900 .parent_names = mmcc_xo_mmpll0_mmpll1_gpll0,
902 .ops = &clk_rcg2_ops,
906 static struct clk_branch camss_cci_cci_ahb_clk = {
909 .enable_reg = 0x3348,
910 .enable_mask = BIT(0),
911 .hw.init = &(struct clk_init_data){
912 .name = "camss_cci_cci_ahb_clk",
913 .parent_names = (const char *[]){
917 .ops = &clk_branch2_ops,
922 static struct clk_branch camss_cci_cci_clk = {
925 .enable_reg = 0x3344,
926 .enable_mask = BIT(0),
927 .hw.init = &(struct clk_init_data){
928 .name = "camss_cci_cci_clk",
929 .parent_names = (const char *[]){
933 .flags = CLK_SET_RATE_PARENT,
934 .ops = &clk_branch2_ops,
939 static struct clk_branch camss_csi0_ahb_clk = {
942 .enable_reg = 0x30bc,
943 .enable_mask = BIT(0),
944 .hw.init = &(struct clk_init_data){
945 .name = "camss_csi0_ahb_clk",
946 .parent_names = (const char *[]){
950 .ops = &clk_branch2_ops,
955 static struct clk_branch camss_csi0_clk = {
958 .enable_reg = 0x30b4,
959 .enable_mask = BIT(0),
960 .hw.init = &(struct clk_init_data){
961 .name = "camss_csi0_clk",
962 .parent_names = (const char *[]){
966 .flags = CLK_SET_RATE_PARENT,
967 .ops = &clk_branch2_ops,
972 static struct clk_branch camss_csi0phy_clk = {
975 .enable_reg = 0x30c4,
976 .enable_mask = BIT(0),
977 .hw.init = &(struct clk_init_data){
978 .name = "camss_csi0phy_clk",
979 .parent_names = (const char *[]){
983 .flags = CLK_SET_RATE_PARENT,
984 .ops = &clk_branch2_ops,
989 static struct clk_branch camss_csi0pix_clk = {
992 .enable_reg = 0x30e4,
993 .enable_mask = BIT(0),
994 .hw.init = &(struct clk_init_data){
995 .name = "camss_csi0pix_clk",
996 .parent_names = (const char *[]){
1000 .flags = CLK_SET_RATE_PARENT,
1001 .ops = &clk_branch2_ops,
1006 static struct clk_branch camss_csi0rdi_clk = {
1009 .enable_reg = 0x30d4,
1010 .enable_mask = BIT(0),
1011 .hw.init = &(struct clk_init_data){
1012 .name = "camss_csi0rdi_clk",
1013 .parent_names = (const char *[]){
1017 .flags = CLK_SET_RATE_PARENT,
1018 .ops = &clk_branch2_ops,
1023 static struct clk_branch camss_csi1_ahb_clk = {
1026 .enable_reg = 0x3128,
1027 .enable_mask = BIT(0),
1028 .hw.init = &(struct clk_init_data){
1029 .name = "camss_csi1_ahb_clk",
1030 .parent_names = (const char *[]){
1034 .ops = &clk_branch2_ops,
1039 static struct clk_branch camss_csi1_clk = {
1042 .enable_reg = 0x3124,
1043 .enable_mask = BIT(0),
1044 .hw.init = &(struct clk_init_data){
1045 .name = "camss_csi1_clk",
1046 .parent_names = (const char *[]){
1050 .flags = CLK_SET_RATE_PARENT,
1051 .ops = &clk_branch2_ops,
1056 static struct clk_branch camss_csi1phy_clk = {
1059 .enable_reg = 0x3134,
1060 .enable_mask = BIT(0),
1061 .hw.init = &(struct clk_init_data){
1062 .name = "camss_csi1phy_clk",
1063 .parent_names = (const char *[]){
1067 .flags = CLK_SET_RATE_PARENT,
1068 .ops = &clk_branch2_ops,
1073 static struct clk_branch camss_csi1pix_clk = {
1076 .enable_reg = 0x3154,
1077 .enable_mask = BIT(0),
1078 .hw.init = &(struct clk_init_data){
1079 .name = "camss_csi1pix_clk",
1080 .parent_names = (const char *[]){
1084 .flags = CLK_SET_RATE_PARENT,
1085 .ops = &clk_branch2_ops,
1090 static struct clk_branch camss_csi1rdi_clk = {
1093 .enable_reg = 0x3144,
1094 .enable_mask = BIT(0),
1095 .hw.init = &(struct clk_init_data){
1096 .name = "camss_csi1rdi_clk",
1097 .parent_names = (const char *[]){
1101 .flags = CLK_SET_RATE_PARENT,
1102 .ops = &clk_branch2_ops,
1107 static struct clk_branch camss_csi2_ahb_clk = {
1110 .enable_reg = 0x3188,
1111 .enable_mask = BIT(0),
1112 .hw.init = &(struct clk_init_data){
1113 .name = "camss_csi2_ahb_clk",
1114 .parent_names = (const char *[]){
1118 .ops = &clk_branch2_ops,
1123 static struct clk_branch camss_csi2_clk = {
1126 .enable_reg = 0x3184,
1127 .enable_mask = BIT(0),
1128 .hw.init = &(struct clk_init_data){
1129 .name = "camss_csi2_clk",
1130 .parent_names = (const char *[]){
1134 .flags = CLK_SET_RATE_PARENT,
1135 .ops = &clk_branch2_ops,
1140 static struct clk_branch camss_csi2phy_clk = {
1143 .enable_reg = 0x3194,
1144 .enable_mask = BIT(0),
1145 .hw.init = &(struct clk_init_data){
1146 .name = "camss_csi2phy_clk",
1147 .parent_names = (const char *[]){
1151 .flags = CLK_SET_RATE_PARENT,
1152 .ops = &clk_branch2_ops,
1157 static struct clk_branch camss_csi2pix_clk = {
1160 .enable_reg = 0x31b4,
1161 .enable_mask = BIT(0),
1162 .hw.init = &(struct clk_init_data){
1163 .name = "camss_csi2pix_clk",
1164 .parent_names = (const char *[]){
1168 .flags = CLK_SET_RATE_PARENT,
1169 .ops = &clk_branch2_ops,
1174 static struct clk_branch camss_csi2rdi_clk = {
1177 .enable_reg = 0x31a4,
1178 .enable_mask = BIT(0),
1179 .hw.init = &(struct clk_init_data){
1180 .name = "camss_csi2rdi_clk",
1181 .parent_names = (const char *[]){
1185 .flags = CLK_SET_RATE_PARENT,
1186 .ops = &clk_branch2_ops,
1191 static struct clk_branch camss_csi3_ahb_clk = {
1194 .enable_reg = 0x31e8,
1195 .enable_mask = BIT(0),
1196 .hw.init = &(struct clk_init_data){
1197 .name = "camss_csi3_ahb_clk",
1198 .parent_names = (const char *[]){
1202 .ops = &clk_branch2_ops,
1207 static struct clk_branch camss_csi3_clk = {
1210 .enable_reg = 0x31e4,
1211 .enable_mask = BIT(0),
1212 .hw.init = &(struct clk_init_data){
1213 .name = "camss_csi3_clk",
1214 .parent_names = (const char *[]){
1218 .flags = CLK_SET_RATE_PARENT,
1219 .ops = &clk_branch2_ops,
1224 static struct clk_branch camss_csi3phy_clk = {
1227 .enable_reg = 0x31f4,
1228 .enable_mask = BIT(0),
1229 .hw.init = &(struct clk_init_data){
1230 .name = "camss_csi3phy_clk",
1231 .parent_names = (const char *[]){
1235 .flags = CLK_SET_RATE_PARENT,
1236 .ops = &clk_branch2_ops,
1241 static struct clk_branch camss_csi3pix_clk = {
1244 .enable_reg = 0x3214,
1245 .enable_mask = BIT(0),
1246 .hw.init = &(struct clk_init_data){
1247 .name = "camss_csi3pix_clk",
1248 .parent_names = (const char *[]){
1252 .flags = CLK_SET_RATE_PARENT,
1253 .ops = &clk_branch2_ops,
1258 static struct clk_branch camss_csi3rdi_clk = {
1261 .enable_reg = 0x3204,
1262 .enable_mask = BIT(0),
1263 .hw.init = &(struct clk_init_data){
1264 .name = "camss_csi3rdi_clk",
1265 .parent_names = (const char *[]){
1269 .flags = CLK_SET_RATE_PARENT,
1270 .ops = &clk_branch2_ops,
1275 static struct clk_branch camss_csi_vfe0_clk = {
1278 .enable_reg = 0x3704,
1279 .enable_mask = BIT(0),
1280 .hw.init = &(struct clk_init_data){
1281 .name = "camss_csi_vfe0_clk",
1282 .parent_names = (const char *[]){
1286 .flags = CLK_SET_RATE_PARENT,
1287 .ops = &clk_branch2_ops,
1292 static struct clk_branch camss_csi_vfe1_clk = {
1295 .enable_reg = 0x3714,
1296 .enable_mask = BIT(0),
1297 .hw.init = &(struct clk_init_data){
1298 .name = "camss_csi_vfe1_clk",
1299 .parent_names = (const char *[]){
1303 .flags = CLK_SET_RATE_PARENT,
1304 .ops = &clk_branch2_ops,
1309 static struct clk_branch camss_gp0_clk = {
1312 .enable_reg = 0x3444,
1313 .enable_mask = BIT(0),
1314 .hw.init = &(struct clk_init_data){
1315 .name = "camss_gp0_clk",
1316 .parent_names = (const char *[]){
1317 "camss_gp0_clk_src",
1320 .flags = CLK_SET_RATE_PARENT,
1321 .ops = &clk_branch2_ops,
1326 static struct clk_branch camss_gp1_clk = {
1329 .enable_reg = 0x3474,
1330 .enable_mask = BIT(0),
1331 .hw.init = &(struct clk_init_data){
1332 .name = "camss_gp1_clk",
1333 .parent_names = (const char *[]){
1334 "camss_gp1_clk_src",
1337 .flags = CLK_SET_RATE_PARENT,
1338 .ops = &clk_branch2_ops,
1343 static struct clk_branch camss_ispif_ahb_clk = {
1346 .enable_reg = 0x3224,
1347 .enable_mask = BIT(0),
1348 .hw.init = &(struct clk_init_data){
1349 .name = "camss_ispif_ahb_clk",
1350 .parent_names = (const char *[]){
1354 .ops = &clk_branch2_ops,
1359 static struct clk_branch camss_jpeg_jpeg0_clk = {
1362 .enable_reg = 0x35a8,
1363 .enable_mask = BIT(0),
1364 .hw.init = &(struct clk_init_data){
1365 .name = "camss_jpeg_jpeg0_clk",
1366 .parent_names = (const char *[]){
1370 .flags = CLK_SET_RATE_PARENT,
1371 .ops = &clk_branch2_ops,
1376 static struct clk_branch camss_jpeg_jpeg1_clk = {
1379 .enable_reg = 0x35ac,
1380 .enable_mask = BIT(0),
1381 .hw.init = &(struct clk_init_data){
1382 .name = "camss_jpeg_jpeg1_clk",
1383 .parent_names = (const char *[]){
1387 .flags = CLK_SET_RATE_PARENT,
1388 .ops = &clk_branch2_ops,
1393 static struct clk_branch camss_jpeg_jpeg2_clk = {
1396 .enable_reg = 0x35b0,
1397 .enable_mask = BIT(0),
1398 .hw.init = &(struct clk_init_data){
1399 .name = "camss_jpeg_jpeg2_clk",
1400 .parent_names = (const char *[]){
1404 .flags = CLK_SET_RATE_PARENT,
1405 .ops = &clk_branch2_ops,
1410 static struct clk_branch camss_jpeg_jpeg_ahb_clk = {
1413 .enable_reg = 0x35b4,
1414 .enable_mask = BIT(0),
1415 .hw.init = &(struct clk_init_data){
1416 .name = "camss_jpeg_jpeg_ahb_clk",
1417 .parent_names = (const char *[]){
1421 .ops = &clk_branch2_ops,
1426 static struct clk_branch camss_jpeg_jpeg_axi_clk = {
1429 .enable_reg = 0x35b8,
1430 .enable_mask = BIT(0),
1431 .hw.init = &(struct clk_init_data){
1432 .name = "camss_jpeg_jpeg_axi_clk",
1433 .parent_names = (const char *[]){
1437 .ops = &clk_branch2_ops,
1442 static struct clk_branch camss_jpeg_jpeg_ocmemnoc_clk = {
1445 .enable_reg = 0x35bc,
1446 .enable_mask = BIT(0),
1447 .hw.init = &(struct clk_init_data){
1448 .name = "camss_jpeg_jpeg_ocmemnoc_clk",
1449 .parent_names = (const char *[]){
1453 .flags = CLK_SET_RATE_PARENT,
1454 .ops = &clk_branch2_ops,
1459 static struct clk_branch camss_mclk0_clk = {
1462 .enable_reg = 0x3384,
1463 .enable_mask = BIT(0),
1464 .hw.init = &(struct clk_init_data){
1465 .name = "camss_mclk0_clk",
1466 .parent_names = (const char *[]){
1470 .flags = CLK_SET_RATE_PARENT,
1471 .ops = &clk_branch2_ops,
1476 static struct clk_branch camss_mclk1_clk = {
1479 .enable_reg = 0x33b4,
1480 .enable_mask = BIT(0),
1481 .hw.init = &(struct clk_init_data){
1482 .name = "camss_mclk1_clk",
1483 .parent_names = (const char *[]){
1487 .flags = CLK_SET_RATE_PARENT,
1488 .ops = &clk_branch2_ops,
1493 static struct clk_branch camss_mclk2_clk = {
1496 .enable_reg = 0x33e4,
1497 .enable_mask = BIT(0),
1498 .hw.init = &(struct clk_init_data){
1499 .name = "camss_mclk2_clk",
1500 .parent_names = (const char *[]){
1504 .flags = CLK_SET_RATE_PARENT,
1505 .ops = &clk_branch2_ops,
1510 static struct clk_branch camss_mclk3_clk = {
1513 .enable_reg = 0x3414,
1514 .enable_mask = BIT(0),
1515 .hw.init = &(struct clk_init_data){
1516 .name = "camss_mclk3_clk",
1517 .parent_names = (const char *[]){
1521 .flags = CLK_SET_RATE_PARENT,
1522 .ops = &clk_branch2_ops,
1527 static struct clk_branch camss_micro_ahb_clk = {
1530 .enable_reg = 0x3494,
1531 .enable_mask = BIT(0),
1532 .hw.init = &(struct clk_init_data){
1533 .name = "camss_micro_ahb_clk",
1534 .parent_names = (const char *[]){
1538 .ops = &clk_branch2_ops,
1543 static struct clk_branch camss_phy0_csi0phytimer_clk = {
1546 .enable_reg = 0x3024,
1547 .enable_mask = BIT(0),
1548 .hw.init = &(struct clk_init_data){
1549 .name = "camss_phy0_csi0phytimer_clk",
1550 .parent_names = (const char *[]){
1551 "csi0phytimer_clk_src",
1554 .flags = CLK_SET_RATE_PARENT,
1555 .ops = &clk_branch2_ops,
1560 static struct clk_branch camss_phy1_csi1phytimer_clk = {
1563 .enable_reg = 0x3054,
1564 .enable_mask = BIT(0),
1565 .hw.init = &(struct clk_init_data){
1566 .name = "camss_phy1_csi1phytimer_clk",
1567 .parent_names = (const char *[]){
1568 "csi1phytimer_clk_src",
1571 .flags = CLK_SET_RATE_PARENT,
1572 .ops = &clk_branch2_ops,
1577 static struct clk_branch camss_phy2_csi2phytimer_clk = {
1580 .enable_reg = 0x3084,
1581 .enable_mask = BIT(0),
1582 .hw.init = &(struct clk_init_data){
1583 .name = "camss_phy2_csi2phytimer_clk",
1584 .parent_names = (const char *[]){
1585 "csi2phytimer_clk_src",
1588 .flags = CLK_SET_RATE_PARENT,
1589 .ops = &clk_branch2_ops,
1594 static struct clk_branch camss_top_ahb_clk = {
1597 .enable_reg = 0x3484,
1598 .enable_mask = BIT(0),
1599 .hw.init = &(struct clk_init_data){
1600 .name = "camss_top_ahb_clk",
1601 .parent_names = (const char *[]){
1605 .ops = &clk_branch2_ops,
1610 static struct clk_branch camss_vfe_cpp_ahb_clk = {
1613 .enable_reg = 0x36b4,
1614 .enable_mask = BIT(0),
1615 .hw.init = &(struct clk_init_data){
1616 .name = "camss_vfe_cpp_ahb_clk",
1617 .parent_names = (const char *[]){
1621 .ops = &clk_branch2_ops,
1626 static struct clk_branch camss_vfe_cpp_clk = {
1629 .enable_reg = 0x36b0,
1630 .enable_mask = BIT(0),
1631 .hw.init = &(struct clk_init_data){
1632 .name = "camss_vfe_cpp_clk",
1633 .parent_names = (const char *[]){
1637 .flags = CLK_SET_RATE_PARENT,
1638 .ops = &clk_branch2_ops,
1643 static struct clk_branch camss_vfe_vfe0_clk = {
1646 .enable_reg = 0x36a8,
1647 .enable_mask = BIT(0),
1648 .hw.init = &(struct clk_init_data){
1649 .name = "camss_vfe_vfe0_clk",
1650 .parent_names = (const char *[]){
1654 .flags = CLK_SET_RATE_PARENT,
1655 .ops = &clk_branch2_ops,
1660 static struct clk_branch camss_vfe_vfe1_clk = {
1663 .enable_reg = 0x36ac,
1664 .enable_mask = BIT(0),
1665 .hw.init = &(struct clk_init_data){
1666 .name = "camss_vfe_vfe1_clk",
1667 .parent_names = (const char *[]){
1671 .flags = CLK_SET_RATE_PARENT,
1672 .ops = &clk_branch2_ops,
1677 static struct clk_branch camss_vfe_vfe_ahb_clk = {
1680 .enable_reg = 0x36b8,
1681 .enable_mask = BIT(0),
1682 .hw.init = &(struct clk_init_data){
1683 .name = "camss_vfe_vfe_ahb_clk",
1684 .parent_names = (const char *[]){
1688 .ops = &clk_branch2_ops,
1693 static struct clk_branch camss_vfe_vfe_axi_clk = {
1696 .enable_reg = 0x36bc,
1697 .enable_mask = BIT(0),
1698 .hw.init = &(struct clk_init_data){
1699 .name = "camss_vfe_vfe_axi_clk",
1700 .parent_names = (const char *[]){
1704 .ops = &clk_branch2_ops,
1709 static struct clk_branch camss_vfe_vfe_ocmemnoc_clk = {
1712 .enable_reg = 0x36c0,
1713 .enable_mask = BIT(0),
1714 .hw.init = &(struct clk_init_data){
1715 .name = "camss_vfe_vfe_ocmemnoc_clk",
1716 .parent_names = (const char *[]){
1720 .flags = CLK_SET_RATE_PARENT,
1721 .ops = &clk_branch2_ops,
1726 static struct clk_branch mdss_ahb_clk = {
1729 .enable_reg = 0x2308,
1730 .enable_mask = BIT(0),
1731 .hw.init = &(struct clk_init_data){
1732 .name = "mdss_ahb_clk",
1733 .parent_names = (const char *[]){
1737 .ops = &clk_branch2_ops,
1742 static struct clk_branch mdss_axi_clk = {
1745 .enable_reg = 0x2310,
1746 .enable_mask = BIT(0),
1747 .hw.init = &(struct clk_init_data){
1748 .name = "mdss_axi_clk",
1749 .parent_names = (const char *[]){
1753 .flags = CLK_SET_RATE_PARENT,
1754 .ops = &clk_branch2_ops,
1759 static struct clk_branch mdss_byte0_clk = {
1762 .enable_reg = 0x233c,
1763 .enable_mask = BIT(0),
1764 .hw.init = &(struct clk_init_data){
1765 .name = "mdss_byte0_clk",
1766 .parent_names = (const char *[]){
1770 .flags = CLK_SET_RATE_PARENT,
1771 .ops = &clk_branch2_ops,
1776 static struct clk_branch mdss_byte1_clk = {
1779 .enable_reg = 0x2340,
1780 .enable_mask = BIT(0),
1781 .hw.init = &(struct clk_init_data){
1782 .name = "mdss_byte1_clk",
1783 .parent_names = (const char *[]){
1787 .flags = CLK_SET_RATE_PARENT,
1788 .ops = &clk_branch2_ops,
1793 static struct clk_branch mdss_edpaux_clk = {
1796 .enable_reg = 0x2334,
1797 .enable_mask = BIT(0),
1798 .hw.init = &(struct clk_init_data){
1799 .name = "mdss_edpaux_clk",
1800 .parent_names = (const char *[]){
1804 .flags = CLK_SET_RATE_PARENT,
1805 .ops = &clk_branch2_ops,
1810 static struct clk_branch mdss_edplink_clk = {
1813 .enable_reg = 0x2330,
1814 .enable_mask = BIT(0),
1815 .hw.init = &(struct clk_init_data){
1816 .name = "mdss_edplink_clk",
1817 .parent_names = (const char *[]){
1821 .flags = CLK_SET_RATE_PARENT,
1822 .ops = &clk_branch2_ops,
1827 static struct clk_branch mdss_edppixel_clk = {
1830 .enable_reg = 0x232c,
1831 .enable_mask = BIT(0),
1832 .hw.init = &(struct clk_init_data){
1833 .name = "mdss_edppixel_clk",
1834 .parent_names = (const char *[]){
1838 .flags = CLK_SET_RATE_PARENT,
1839 .ops = &clk_branch2_ops,
1844 static struct clk_branch mdss_esc0_clk = {
1847 .enable_reg = 0x2344,
1848 .enable_mask = BIT(0),
1849 .hw.init = &(struct clk_init_data){
1850 .name = "mdss_esc0_clk",
1851 .parent_names = (const char *[]){
1855 .flags = CLK_SET_RATE_PARENT,
1856 .ops = &clk_branch2_ops,
1861 static struct clk_branch mdss_esc1_clk = {
1864 .enable_reg = 0x2348,
1865 .enable_mask = BIT(0),
1866 .hw.init = &(struct clk_init_data){
1867 .name = "mdss_esc1_clk",
1868 .parent_names = (const char *[]){
1872 .flags = CLK_SET_RATE_PARENT,
1873 .ops = &clk_branch2_ops,
1878 static struct clk_branch mdss_extpclk_clk = {
1881 .enable_reg = 0x2324,
1882 .enable_mask = BIT(0),
1883 .hw.init = &(struct clk_init_data){
1884 .name = "mdss_extpclk_clk",
1885 .parent_names = (const char *[]){
1889 .flags = CLK_SET_RATE_PARENT,
1890 .ops = &clk_branch2_ops,
1895 static struct clk_branch mdss_hdmi_ahb_clk = {
1898 .enable_reg = 0x230c,
1899 .enable_mask = BIT(0),
1900 .hw.init = &(struct clk_init_data){
1901 .name = "mdss_hdmi_ahb_clk",
1902 .parent_names = (const char *[]){
1906 .ops = &clk_branch2_ops,
1911 static struct clk_branch mdss_hdmi_clk = {
1914 .enable_reg = 0x2338,
1915 .enable_mask = BIT(0),
1916 .hw.init = &(struct clk_init_data){
1917 .name = "mdss_hdmi_clk",
1918 .parent_names = (const char *[]){
1922 .flags = CLK_SET_RATE_PARENT,
1923 .ops = &clk_branch2_ops,
1928 static struct clk_branch mdss_mdp_clk = {
1931 .enable_reg = 0x231c,
1932 .enable_mask = BIT(0),
1933 .hw.init = &(struct clk_init_data){
1934 .name = "mdss_mdp_clk",
1935 .parent_names = (const char *[]){
1939 .flags = CLK_SET_RATE_PARENT,
1940 .ops = &clk_branch2_ops,
1945 static struct clk_branch mdss_mdp_lut_clk = {
1948 .enable_reg = 0x2320,
1949 .enable_mask = BIT(0),
1950 .hw.init = &(struct clk_init_data){
1951 .name = "mdss_mdp_lut_clk",
1952 .parent_names = (const char *[]){
1956 .flags = CLK_SET_RATE_PARENT,
1957 .ops = &clk_branch2_ops,
1962 static struct clk_branch mdss_pclk0_clk = {
1965 .enable_reg = 0x2314,
1966 .enable_mask = BIT(0),
1967 .hw.init = &(struct clk_init_data){
1968 .name = "mdss_pclk0_clk",
1969 .parent_names = (const char *[]){
1973 .flags = CLK_SET_RATE_PARENT,
1974 .ops = &clk_branch2_ops,
1979 static struct clk_branch mdss_pclk1_clk = {
1982 .enable_reg = 0x2318,
1983 .enable_mask = BIT(0),
1984 .hw.init = &(struct clk_init_data){
1985 .name = "mdss_pclk1_clk",
1986 .parent_names = (const char *[]){
1990 .flags = CLK_SET_RATE_PARENT,
1991 .ops = &clk_branch2_ops,
1996 static struct clk_branch mdss_vsync_clk = {
1999 .enable_reg = 0x2328,
2000 .enable_mask = BIT(0),
2001 .hw.init = &(struct clk_init_data){
2002 .name = "mdss_vsync_clk",
2003 .parent_names = (const char *[]){
2007 .flags = CLK_SET_RATE_PARENT,
2008 .ops = &clk_branch2_ops,
2013 static struct clk_branch mmss_misc_ahb_clk = {
2016 .enable_reg = 0x502c,
2017 .enable_mask = BIT(0),
2018 .hw.init = &(struct clk_init_data){
2019 .name = "mmss_misc_ahb_clk",
2020 .parent_names = (const char *[]){
2024 .ops = &clk_branch2_ops,
2029 static struct clk_branch mmss_mmssnoc_ahb_clk = {
2032 .enable_reg = 0x5024,
2033 .enable_mask = BIT(0),
2034 .hw.init = &(struct clk_init_data){
2035 .name = "mmss_mmssnoc_ahb_clk",
2036 .parent_names = (const char *[]){
2040 .ops = &clk_branch2_ops,
2041 .flags = CLK_IGNORE_UNUSED,
2046 static struct clk_branch mmss_mmssnoc_bto_ahb_clk = {
2049 .enable_reg = 0x5028,
2050 .enable_mask = BIT(0),
2051 .hw.init = &(struct clk_init_data){
2052 .name = "mmss_mmssnoc_bto_ahb_clk",
2053 .parent_names = (const char *[]){
2057 .ops = &clk_branch2_ops,
2058 .flags = CLK_IGNORE_UNUSED,
2063 static struct clk_branch mmss_mmssnoc_axi_clk = {
2066 .enable_reg = 0x506c,
2067 .enable_mask = BIT(0),
2068 .hw.init = &(struct clk_init_data){
2069 .name = "mmss_mmssnoc_axi_clk",
2070 .parent_names = (const char *[]){
2074 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2075 .ops = &clk_branch2_ops,
2080 static struct clk_branch mmss_s0_axi_clk = {
2083 .enable_reg = 0x5064,
2084 .enable_mask = BIT(0),
2085 .hw.init = &(struct clk_init_data){
2086 .name = "mmss_s0_axi_clk",
2087 .parent_names = (const char *[]){
2091 .ops = &clk_branch2_ops,
2092 .flags = CLK_IGNORE_UNUSED,
2097 static struct clk_branch ocmemcx_ahb_clk = {
2100 .enable_reg = 0x405c,
2101 .enable_mask = BIT(0),
2102 .hw.init = &(struct clk_init_data){
2103 .name = "ocmemcx_ahb_clk",
2104 .parent_names = (const char *[]){
2108 .ops = &clk_branch2_ops,
2113 static struct clk_branch ocmemcx_ocmemnoc_clk = {
2116 .enable_reg = 0x4058,
2117 .enable_mask = BIT(0),
2118 .hw.init = &(struct clk_init_data){
2119 .name = "ocmemcx_ocmemnoc_clk",
2120 .parent_names = (const char *[]){
2124 .flags = CLK_SET_RATE_PARENT,
2125 .ops = &clk_branch2_ops,
2130 static struct clk_branch oxili_ocmemgx_clk = {
2133 .enable_reg = 0x402c,
2134 .enable_mask = BIT(0),
2135 .hw.init = &(struct clk_init_data){
2136 .name = "oxili_ocmemgx_clk",
2137 .parent_names = (const char *[]){
2141 .flags = CLK_SET_RATE_PARENT,
2142 .ops = &clk_branch2_ops,
2147 static struct clk_branch ocmemnoc_clk = {
2150 .enable_reg = 0x50b4,
2151 .enable_mask = BIT(0),
2152 .hw.init = &(struct clk_init_data){
2153 .name = "ocmemnoc_clk",
2154 .parent_names = (const char *[]){
2158 .flags = CLK_SET_RATE_PARENT,
2159 .ops = &clk_branch2_ops,
2164 static struct clk_branch oxili_gfx3d_clk = {
2167 .enable_reg = 0x4028,
2168 .enable_mask = BIT(0),
2169 .hw.init = &(struct clk_init_data){
2170 .name = "oxili_gfx3d_clk",
2171 .parent_names = (const char *[]){
2175 .flags = CLK_SET_RATE_PARENT,
2176 .ops = &clk_branch2_ops,
2181 static struct clk_branch oxilicx_ahb_clk = {
2184 .enable_reg = 0x403c,
2185 .enable_mask = BIT(0),
2186 .hw.init = &(struct clk_init_data){
2187 .name = "oxilicx_ahb_clk",
2188 .parent_names = (const char *[]){
2192 .ops = &clk_branch2_ops,
2197 static struct clk_branch oxilicx_axi_clk = {
2200 .enable_reg = 0x4038,
2201 .enable_mask = BIT(0),
2202 .hw.init = &(struct clk_init_data){
2203 .name = "oxilicx_axi_clk",
2204 .parent_names = (const char *[]){
2208 .ops = &clk_branch2_ops,
2213 static struct clk_branch venus0_ahb_clk = {
2216 .enable_reg = 0x1030,
2217 .enable_mask = BIT(0),
2218 .hw.init = &(struct clk_init_data){
2219 .name = "venus0_ahb_clk",
2220 .parent_names = (const char *[]){
2224 .ops = &clk_branch2_ops,
2229 static struct clk_branch venus0_axi_clk = {
2232 .enable_reg = 0x1034,
2233 .enable_mask = BIT(0),
2234 .hw.init = &(struct clk_init_data){
2235 .name = "venus0_axi_clk",
2236 .parent_names = (const char *[]){
2240 .ops = &clk_branch2_ops,
2245 static struct clk_branch venus0_ocmemnoc_clk = {
2248 .enable_reg = 0x1038,
2249 .enable_mask = BIT(0),
2250 .hw.init = &(struct clk_init_data){
2251 .name = "venus0_ocmemnoc_clk",
2252 .parent_names = (const char *[]){
2256 .flags = CLK_SET_RATE_PARENT,
2257 .ops = &clk_branch2_ops,
2262 static struct clk_branch venus0_vcodec0_clk = {
2265 .enable_reg = 0x1028,
2266 .enable_mask = BIT(0),
2267 .hw.init = &(struct clk_init_data){
2268 .name = "venus0_vcodec0_clk",
2269 .parent_names = (const char *[]){
2273 .flags = CLK_SET_RATE_PARENT,
2274 .ops = &clk_branch2_ops,
2279 static const struct pll_config mmpll1_config = {
2284 .vco_mask = 0x3 << 20,
2286 .pre_div_mask = 0x7 << 12,
2287 .post_div_val = 0x0,
2288 .post_div_mask = 0x3 << 8,
2289 .mn_ena_mask = BIT(24),
2290 .main_output_mask = BIT(0),
2293 static struct pll_config mmpll3_config = {
2298 .vco_mask = 0x3 << 20,
2300 .pre_div_mask = 0x7 << 12,
2301 .post_div_val = 0x0,
2302 .post_div_mask = 0x3 << 8,
2303 .mn_ena_mask = BIT(24),
2304 .main_output_mask = BIT(0),
2305 .aux_output_mask = BIT(1),
2308 static struct gdsc venus0_gdsc = {
2310 .cxcs = (unsigned int []){ 0x1028 },
2312 .resets = (unsigned int []){ VENUS0_RESET },
2317 .pwrsts = PWRSTS_ON,
2320 static struct gdsc mdss_gdsc = {
2322 .cxcs = (unsigned int []){ 0x231c, 0x2320 },
2327 .pwrsts = PWRSTS_RET_ON,
2330 static struct gdsc camss_jpeg_gdsc = {
2332 .cxcs = (unsigned int []){ 0x35a8, 0x35ac, 0x35b0 },
2335 .name = "camss_jpeg",
2337 .pwrsts = PWRSTS_OFF_ON,
2340 static struct gdsc camss_vfe_gdsc = {
2342 .cxcs = (unsigned int []){ 0x36a8, 0x36ac, 0x3704, 0x3714, 0x36b0 },
2345 .name = "camss_vfe",
2347 .pwrsts = PWRSTS_OFF_ON,
2350 static struct gdsc oxili_gdsc = {
2352 .cxcs = (unsigned int []){ 0x4028 },
2357 .pwrsts = PWRSTS_OFF_ON,
2360 static struct gdsc oxilicx_gdsc = {
2365 .parent = &oxili_gdsc.pd,
2366 .pwrsts = PWRSTS_OFF_ON,
2369 static struct clk_regmap *mmcc_msm8974_clocks[] = {
2370 [MMSS_AHB_CLK_SRC] = &mmss_ahb_clk_src.clkr,
2371 [MMSS_AXI_CLK_SRC] = &mmss_axi_clk_src.clkr,
2372 [OCMEMNOC_CLK_SRC] = &ocmemnoc_clk_src.clkr,
2373 [MMPLL0] = &mmpll0.clkr,
2374 [MMPLL0_VOTE] = &mmpll0_vote,
2375 [MMPLL1] = &mmpll1.clkr,
2376 [MMPLL1_VOTE] = &mmpll1_vote,
2377 [MMPLL2] = &mmpll2.clkr,
2378 [MMPLL3] = &mmpll3.clkr,
2379 [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
2380 [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
2381 [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
2382 [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
2383 [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
2384 [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
2385 [MDP_CLK_SRC] = &mdp_clk_src.clkr,
2386 [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
2387 [JPEG1_CLK_SRC] = &jpeg1_clk_src.clkr,
2388 [JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
2389 [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
2390 [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
2391 [VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr,
2392 [CCI_CLK_SRC] = &cci_clk_src.clkr,
2393 [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
2394 [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
2395 [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
2396 [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
2397 [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
2398 [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
2399 [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
2400 [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
2401 [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
2402 [CPP_CLK_SRC] = &cpp_clk_src.clkr,
2403 [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
2404 [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
2405 [EDPAUX_CLK_SRC] = &edpaux_clk_src.clkr,
2406 [EDPLINK_CLK_SRC] = &edplink_clk_src.clkr,
2407 [EDPPIXEL_CLK_SRC] = &edppixel_clk_src.clkr,
2408 [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
2409 [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
2410 [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
2411 [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
2412 [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
2413 [CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
2414 [CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
2415 [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
2416 [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
2417 [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
2418 [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
2419 [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
2420 [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
2421 [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
2422 [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
2423 [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
2424 [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
2425 [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
2426 [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
2427 [CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
2428 [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
2429 [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
2430 [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
2431 [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
2432 [CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
2433 [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
2434 [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
2435 [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
2436 [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
2437 [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
2438 [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
2439 [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
2440 [CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
2441 [CAMSS_JPEG_JPEG1_CLK] = &camss_jpeg_jpeg1_clk.clkr,
2442 [CAMSS_JPEG_JPEG2_CLK] = &camss_jpeg_jpeg2_clk.clkr,
2443 [CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
2444 [CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
2445 [CAMSS_JPEG_JPEG_OCMEMNOC_CLK] = &camss_jpeg_jpeg_ocmemnoc_clk.clkr,
2446 [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
2447 [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
2448 [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
2449 [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
2450 [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
2451 [CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
2452 [CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
2453 [CAMSS_PHY2_CSI2PHYTIMER_CLK] = &camss_phy2_csi2phytimer_clk.clkr,
2454 [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
2455 [CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
2456 [CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
2457 [CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
2458 [CAMSS_VFE_VFE1_CLK] = &camss_vfe_vfe1_clk.clkr,
2459 [CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
2460 [CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
2461 [CAMSS_VFE_VFE_OCMEMNOC_CLK] = &camss_vfe_vfe_ocmemnoc_clk.clkr,
2462 [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
2463 [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
2464 [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
2465 [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
2466 [MDSS_EDPAUX_CLK] = &mdss_edpaux_clk.clkr,
2467 [MDSS_EDPLINK_CLK] = &mdss_edplink_clk.clkr,
2468 [MDSS_EDPPIXEL_CLK] = &mdss_edppixel_clk.clkr,
2469 [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
2470 [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
2471 [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
2472 [MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
2473 [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
2474 [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
2475 [MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
2476 [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
2477 [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
2478 [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
2479 [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
2480 [MMSS_MMSSNOC_AHB_CLK] = &mmss_mmssnoc_ahb_clk.clkr,
2481 [MMSS_MMSSNOC_BTO_AHB_CLK] = &mmss_mmssnoc_bto_ahb_clk.clkr,
2482 [MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
2483 [MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
2484 [OCMEMCX_AHB_CLK] = &ocmemcx_ahb_clk.clkr,
2485 [OCMEMCX_OCMEMNOC_CLK] = &ocmemcx_ocmemnoc_clk.clkr,
2486 [OXILI_OCMEMGX_CLK] = &oxili_ocmemgx_clk.clkr,
2487 [OCMEMNOC_CLK] = &ocmemnoc_clk.clkr,
2488 [OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
2489 [OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
2490 [OXILICX_AXI_CLK] = &oxilicx_axi_clk.clkr,
2491 [VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
2492 [VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
2493 [VENUS0_OCMEMNOC_CLK] = &venus0_ocmemnoc_clk.clkr,
2494 [VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
2497 static const struct qcom_reset_map mmcc_msm8974_resets[] = {
2498 [SPDM_RESET] = { 0x0200 },
2499 [SPDM_RM_RESET] = { 0x0300 },
2500 [VENUS0_RESET] = { 0x1020 },
2501 [MDSS_RESET] = { 0x2300 },
2502 [CAMSS_PHY0_RESET] = { 0x3020 },
2503 [CAMSS_PHY1_RESET] = { 0x3050 },
2504 [CAMSS_PHY2_RESET] = { 0x3080 },
2505 [CAMSS_CSI0_RESET] = { 0x30b0 },
2506 [CAMSS_CSI0PHY_RESET] = { 0x30c0 },
2507 [CAMSS_CSI0RDI_RESET] = { 0x30d0 },
2508 [CAMSS_CSI0PIX_RESET] = { 0x30e0 },
2509 [CAMSS_CSI1_RESET] = { 0x3120 },
2510 [CAMSS_CSI1PHY_RESET] = { 0x3130 },
2511 [CAMSS_CSI1RDI_RESET] = { 0x3140 },
2512 [CAMSS_CSI1PIX_RESET] = { 0x3150 },
2513 [CAMSS_CSI2_RESET] = { 0x3180 },
2514 [CAMSS_CSI2PHY_RESET] = { 0x3190 },
2515 [CAMSS_CSI2RDI_RESET] = { 0x31a0 },
2516 [CAMSS_CSI2PIX_RESET] = { 0x31b0 },
2517 [CAMSS_CSI3_RESET] = { 0x31e0 },
2518 [CAMSS_CSI3PHY_RESET] = { 0x31f0 },
2519 [CAMSS_CSI3RDI_RESET] = { 0x3200 },
2520 [CAMSS_CSI3PIX_RESET] = { 0x3210 },
2521 [CAMSS_ISPIF_RESET] = { 0x3220 },
2522 [CAMSS_CCI_RESET] = { 0x3340 },
2523 [CAMSS_MCLK0_RESET] = { 0x3380 },
2524 [CAMSS_MCLK1_RESET] = { 0x33b0 },
2525 [CAMSS_MCLK2_RESET] = { 0x33e0 },
2526 [CAMSS_MCLK3_RESET] = { 0x3410 },
2527 [CAMSS_GP0_RESET] = { 0x3440 },
2528 [CAMSS_GP1_RESET] = { 0x3470 },
2529 [CAMSS_TOP_RESET] = { 0x3480 },
2530 [CAMSS_MICRO_RESET] = { 0x3490 },
2531 [CAMSS_JPEG_RESET] = { 0x35a0 },
2532 [CAMSS_VFE_RESET] = { 0x36a0 },
2533 [CAMSS_CSI_VFE0_RESET] = { 0x3700 },
2534 [CAMSS_CSI_VFE1_RESET] = { 0x3710 },
2535 [OXILI_RESET] = { 0x4020 },
2536 [OXILICX_RESET] = { 0x4030 },
2537 [OCMEMCX_RESET] = { 0x4050 },
2538 [MMSS_RBCRP_RESET] = { 0x4080 },
2539 [MMSSNOCAHB_RESET] = { 0x5020 },
2540 [MMSSNOCAXI_RESET] = { 0x5060 },
2541 [OCMEMNOC_RESET] = { 0x50b0 },
2544 static struct gdsc *mmcc_msm8974_gdscs[] = {
2545 [VENUS0_GDSC] = &venus0_gdsc,
2546 [MDSS_GDSC] = &mdss_gdsc,
2547 [CAMSS_JPEG_GDSC] = &camss_jpeg_gdsc,
2548 [CAMSS_VFE_GDSC] = &camss_vfe_gdsc,
2549 [OXILI_GDSC] = &oxili_gdsc,
2550 [OXILICX_GDSC] = &oxilicx_gdsc,
2553 static const struct regmap_config mmcc_msm8974_regmap_config = {
2557 .max_register = 0x5104,
2561 static const struct qcom_cc_desc mmcc_msm8974_desc = {
2562 .config = &mmcc_msm8974_regmap_config,
2563 .clks = mmcc_msm8974_clocks,
2564 .num_clks = ARRAY_SIZE(mmcc_msm8974_clocks),
2565 .resets = mmcc_msm8974_resets,
2566 .num_resets = ARRAY_SIZE(mmcc_msm8974_resets),
2567 .gdscs = mmcc_msm8974_gdscs,
2568 .num_gdscs = ARRAY_SIZE(mmcc_msm8974_gdscs),
2571 static const struct of_device_id mmcc_msm8974_match_table[] = {
2572 { .compatible = "qcom,mmcc-msm8974" },
2575 MODULE_DEVICE_TABLE(of, mmcc_msm8974_match_table);
2577 static int mmcc_msm8974_probe(struct platform_device *pdev)
2579 struct regmap *regmap;
2581 regmap = qcom_cc_map(pdev, &mmcc_msm8974_desc);
2583 return PTR_ERR(regmap);
2585 clk_pll_configure_sr_hpm_lp(&mmpll1, regmap, &mmpll1_config, true);
2586 clk_pll_configure_sr_hpm_lp(&mmpll3, regmap, &mmpll3_config, false);
2588 return qcom_cc_really_probe(pdev, &mmcc_msm8974_desc, regmap);
2591 static struct platform_driver mmcc_msm8974_driver = {
2592 .probe = mmcc_msm8974_probe,
2594 .name = "mmcc-msm8974",
2595 .of_match_table = mmcc_msm8974_match_table,
2598 module_platform_driver(mmcc_msm8974_driver);
2600 MODULE_DESCRIPTION("QCOM MMCC MSM8974 Driver");
2601 MODULE_LICENSE("GPL v2");
2602 MODULE_ALIAS("platform:mmcc-msm8974");