1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (c) 2016 AmLogic, Inc.
7 #include <linux/clk-provider.h>
8 #include <linux/init.h>
9 #include <linux/of_device.h>
10 #include <linux/platform_device.h>
13 #include "clk-input.h"
14 #include "clk-regmap.h"
17 #include "meson-eeclk.h"
18 #include "vid-pll-div.h"
20 #define IN_PREFIX "ee-in-"
22 static DEFINE_SPINLOCK(meson_clk_lock);
24 static const struct pll_params_table gxbb_gp0_pll_params_table[] = {
59 static const struct pll_params_table gxl_gp0_pll_params_table[] = {
88 static struct clk_regmap gxbb_fixed_pll_dco = {
89 .data = &(struct meson_clk_pll_data){
91 .reg_off = HHI_MPLL_CNTL,
96 .reg_off = HHI_MPLL_CNTL,
101 .reg_off = HHI_MPLL_CNTL,
106 .reg_off = HHI_MPLL_CNTL2,
111 .reg_off = HHI_MPLL_CNTL,
116 .reg_off = HHI_MPLL_CNTL,
121 .hw.init = &(struct clk_init_data){
122 .name = "fixed_pll_dco",
123 .ops = &meson_clk_pll_ro_ops,
124 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
129 static struct clk_regmap gxbb_fixed_pll = {
130 .data = &(struct clk_regmap_div_data){
131 .offset = HHI_MPLL_CNTL,
134 .flags = CLK_DIVIDER_POWER_OF_TWO,
136 .hw.init = &(struct clk_init_data){
138 .ops = &clk_regmap_divider_ro_ops,
139 .parent_names = (const char *[]){ "fixed_pll_dco" },
142 * This clock won't ever change at runtime so
143 * CLK_SET_RATE_PARENT is not required
148 static struct clk_fixed_factor gxbb_hdmi_pll_pre_mult = {
151 .hw.init = &(struct clk_init_data){
152 .name = "hdmi_pll_pre_mult",
153 .ops = &clk_fixed_factor_ops,
154 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
159 static struct clk_regmap gxbb_hdmi_pll_dco = {
160 .data = &(struct meson_clk_pll_data){
162 .reg_off = HHI_HDMI_PLL_CNTL,
167 .reg_off = HHI_HDMI_PLL_CNTL,
172 .reg_off = HHI_HDMI_PLL_CNTL,
177 .reg_off = HHI_HDMI_PLL_CNTL2,
182 .reg_off = HHI_HDMI_PLL_CNTL,
187 .reg_off = HHI_HDMI_PLL_CNTL,
192 .hw.init = &(struct clk_init_data){
193 .name = "hdmi_pll_dco",
194 .ops = &meson_clk_pll_ro_ops,
195 .parent_names = (const char *[]){ "hdmi_pll_pre_mult" },
198 * Display directly handle hdmi pll registers ATM, we need
199 * NOCACHE to keep our view of the clock as accurate as possible
201 .flags = CLK_GET_RATE_NOCACHE,
205 static struct clk_regmap gxl_hdmi_pll_dco = {
206 .data = &(struct meson_clk_pll_data){
208 .reg_off = HHI_HDMI_PLL_CNTL,
213 .reg_off = HHI_HDMI_PLL_CNTL,
218 .reg_off = HHI_HDMI_PLL_CNTL,
223 * On gxl, there is a register shift due to
224 * HHI_HDMI_PLL_CNTL1 which does not exist on gxbb,
225 * so we use the HHI_HDMI_PLL_CNTL2 define from GXBB
226 * instead which is defined at the same offset.
229 .reg_off = HHI_HDMI_PLL_CNTL2,
234 .reg_off = HHI_HDMI_PLL_CNTL,
239 .reg_off = HHI_HDMI_PLL_CNTL,
244 .hw.init = &(struct clk_init_data){
245 .name = "hdmi_pll_dco",
246 .ops = &meson_clk_pll_ro_ops,
247 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
250 * Display directly handle hdmi pll registers ATM, we need
251 * NOCACHE to keep our view of the clock as accurate as possible
253 .flags = CLK_GET_RATE_NOCACHE,
257 static struct clk_regmap gxbb_hdmi_pll_od = {
258 .data = &(struct clk_regmap_div_data){
259 .offset = HHI_HDMI_PLL_CNTL2,
262 .flags = CLK_DIVIDER_POWER_OF_TWO,
264 .hw.init = &(struct clk_init_data){
265 .name = "hdmi_pll_od",
266 .ops = &clk_regmap_divider_ro_ops,
267 .parent_names = (const char *[]){ "hdmi_pll_dco" },
269 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
273 static struct clk_regmap gxbb_hdmi_pll_od2 = {
274 .data = &(struct clk_regmap_div_data){
275 .offset = HHI_HDMI_PLL_CNTL2,
278 .flags = CLK_DIVIDER_POWER_OF_TWO,
280 .hw.init = &(struct clk_init_data){
281 .name = "hdmi_pll_od2",
282 .ops = &clk_regmap_divider_ro_ops,
283 .parent_names = (const char *[]){ "hdmi_pll_od" },
285 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
289 static struct clk_regmap gxbb_hdmi_pll = {
290 .data = &(struct clk_regmap_div_data){
291 .offset = HHI_HDMI_PLL_CNTL2,
294 .flags = CLK_DIVIDER_POWER_OF_TWO,
296 .hw.init = &(struct clk_init_data){
298 .ops = &clk_regmap_divider_ro_ops,
299 .parent_names = (const char *[]){ "hdmi_pll_od2" },
301 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
305 static struct clk_regmap gxl_hdmi_pll_od = {
306 .data = &(struct clk_regmap_div_data){
307 .offset = HHI_HDMI_PLL_CNTL + 8,
310 .flags = CLK_DIVIDER_POWER_OF_TWO,
312 .hw.init = &(struct clk_init_data){
313 .name = "hdmi_pll_od",
314 .ops = &clk_regmap_divider_ro_ops,
315 .parent_names = (const char *[]){ "hdmi_pll_dco" },
317 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
321 static struct clk_regmap gxl_hdmi_pll_od2 = {
322 .data = &(struct clk_regmap_div_data){
323 .offset = HHI_HDMI_PLL_CNTL + 8,
326 .flags = CLK_DIVIDER_POWER_OF_TWO,
328 .hw.init = &(struct clk_init_data){
329 .name = "hdmi_pll_od2",
330 .ops = &clk_regmap_divider_ro_ops,
331 .parent_names = (const char *[]){ "hdmi_pll_od" },
333 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
337 static struct clk_regmap gxl_hdmi_pll = {
338 .data = &(struct clk_regmap_div_data){
339 .offset = HHI_HDMI_PLL_CNTL + 8,
342 .flags = CLK_DIVIDER_POWER_OF_TWO,
344 .hw.init = &(struct clk_init_data){
346 .ops = &clk_regmap_divider_ro_ops,
347 .parent_names = (const char *[]){ "hdmi_pll_od2" },
349 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
353 static struct clk_regmap gxbb_sys_pll_dco = {
354 .data = &(struct meson_clk_pll_data){
356 .reg_off = HHI_SYS_PLL_CNTL,
361 .reg_off = HHI_SYS_PLL_CNTL,
366 .reg_off = HHI_SYS_PLL_CNTL,
371 .reg_off = HHI_SYS_PLL_CNTL,
376 .reg_off = HHI_SYS_PLL_CNTL,
381 .hw.init = &(struct clk_init_data){
382 .name = "sys_pll_dco",
383 .ops = &meson_clk_pll_ro_ops,
384 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
389 static struct clk_regmap gxbb_sys_pll = {
390 .data = &(struct clk_regmap_div_data){
391 .offset = HHI_SYS_PLL_CNTL,
394 .flags = CLK_DIVIDER_POWER_OF_TWO,
396 .hw.init = &(struct clk_init_data){
398 .ops = &clk_regmap_divider_ro_ops,
399 .parent_names = (const char *[]){ "sys_pll_dco" },
401 .flags = CLK_SET_RATE_PARENT,
405 static const struct reg_sequence gxbb_gp0_init_regs[] = {
406 { .reg = HHI_GP0_PLL_CNTL2, .def = 0x69c80000 },
407 { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a5590c4 },
408 { .reg = HHI_GP0_PLL_CNTL4, .def = 0x0000500d },
411 static struct clk_regmap gxbb_gp0_pll_dco = {
412 .data = &(struct meson_clk_pll_data){
414 .reg_off = HHI_GP0_PLL_CNTL,
419 .reg_off = HHI_GP0_PLL_CNTL,
424 .reg_off = HHI_GP0_PLL_CNTL,
429 .reg_off = HHI_GP0_PLL_CNTL,
434 .reg_off = HHI_GP0_PLL_CNTL,
438 .table = gxbb_gp0_pll_params_table,
439 .init_regs = gxbb_gp0_init_regs,
440 .init_count = ARRAY_SIZE(gxbb_gp0_init_regs),
442 .hw.init = &(struct clk_init_data){
443 .name = "gp0_pll_dco",
444 .ops = &meson_clk_pll_ops,
445 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
450 static const struct reg_sequence gxl_gp0_init_regs[] = {
451 { .reg = HHI_GP0_PLL_CNTL1, .def = 0xc084b000 },
452 { .reg = HHI_GP0_PLL_CNTL2, .def = 0xb75020be },
453 { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a59a288 },
454 { .reg = HHI_GP0_PLL_CNTL4, .def = 0xc000004d },
455 { .reg = HHI_GP0_PLL_CNTL5, .def = 0x00078000 },
458 static struct clk_regmap gxl_gp0_pll_dco = {
459 .data = &(struct meson_clk_pll_data){
461 .reg_off = HHI_GP0_PLL_CNTL,
466 .reg_off = HHI_GP0_PLL_CNTL,
471 .reg_off = HHI_GP0_PLL_CNTL,
476 .reg_off = HHI_GP0_PLL_CNTL1,
481 .reg_off = HHI_GP0_PLL_CNTL,
486 .reg_off = HHI_GP0_PLL_CNTL,
490 .table = gxl_gp0_pll_params_table,
491 .init_regs = gxl_gp0_init_regs,
492 .init_count = ARRAY_SIZE(gxl_gp0_init_regs),
494 .hw.init = &(struct clk_init_data){
495 .name = "gp0_pll_dco",
496 .ops = &meson_clk_pll_ops,
497 .parent_names = (const char *[]){ IN_PREFIX "xtal" },
502 static struct clk_regmap gxbb_gp0_pll = {
503 .data = &(struct clk_regmap_div_data){
504 .offset = HHI_GP0_PLL_CNTL,
507 .flags = CLK_DIVIDER_POWER_OF_TWO,
509 .hw.init = &(struct clk_init_data){
511 .ops = &clk_regmap_divider_ops,
512 .parent_names = (const char *[]){ "gp0_pll_dco" },
514 .flags = CLK_SET_RATE_PARENT,
518 static struct clk_fixed_factor gxbb_fclk_div2_div = {
521 .hw.init = &(struct clk_init_data){
522 .name = "fclk_div2_div",
523 .ops = &clk_fixed_factor_ops,
524 .parent_names = (const char *[]){ "fixed_pll" },
529 static struct clk_regmap gxbb_fclk_div2 = {
530 .data = &(struct clk_regmap_gate_data){
531 .offset = HHI_MPLL_CNTL6,
534 .hw.init = &(struct clk_init_data){
536 .ops = &clk_regmap_gate_ops,
537 .parent_names = (const char *[]){ "fclk_div2_div" },
539 .flags = CLK_IS_CRITICAL,
543 static struct clk_fixed_factor gxbb_fclk_div3_div = {
546 .hw.init = &(struct clk_init_data){
547 .name = "fclk_div3_div",
548 .ops = &clk_fixed_factor_ops,
549 .parent_names = (const char *[]){ "fixed_pll" },
554 static struct clk_regmap gxbb_fclk_div3 = {
555 .data = &(struct clk_regmap_gate_data){
556 .offset = HHI_MPLL_CNTL6,
559 .hw.init = &(struct clk_init_data){
561 .ops = &clk_regmap_gate_ops,
562 .parent_names = (const char *[]){ "fclk_div3_div" },
566 * This clock, as fdiv2, is used by the SCPI FW and is required
567 * by the platform to operate correctly.
568 * Until the following condition are met, we need this clock to
569 * be marked as critical:
570 * a) The SCPI generic driver claims and enable all the clocks
572 * b) CCF has a clock hand-off mechanism to make the sure the
573 * clock stays on until the proper driver comes along
575 .flags = CLK_IS_CRITICAL,
579 static struct clk_fixed_factor gxbb_fclk_div4_div = {
582 .hw.init = &(struct clk_init_data){
583 .name = "fclk_div4_div",
584 .ops = &clk_fixed_factor_ops,
585 .parent_names = (const char *[]){ "fixed_pll" },
590 static struct clk_regmap gxbb_fclk_div4 = {
591 .data = &(struct clk_regmap_gate_data){
592 .offset = HHI_MPLL_CNTL6,
595 .hw.init = &(struct clk_init_data){
597 .ops = &clk_regmap_gate_ops,
598 .parent_names = (const char *[]){ "fclk_div4_div" },
603 static struct clk_fixed_factor gxbb_fclk_div5_div = {
606 .hw.init = &(struct clk_init_data){
607 .name = "fclk_div5_div",
608 .ops = &clk_fixed_factor_ops,
609 .parent_names = (const char *[]){ "fixed_pll" },
614 static struct clk_regmap gxbb_fclk_div5 = {
615 .data = &(struct clk_regmap_gate_data){
616 .offset = HHI_MPLL_CNTL6,
619 .hw.init = &(struct clk_init_data){
621 .ops = &clk_regmap_gate_ops,
622 .parent_names = (const char *[]){ "fclk_div5_div" },
627 static struct clk_fixed_factor gxbb_fclk_div7_div = {
630 .hw.init = &(struct clk_init_data){
631 .name = "fclk_div7_div",
632 .ops = &clk_fixed_factor_ops,
633 .parent_names = (const char *[]){ "fixed_pll" },
638 static struct clk_regmap gxbb_fclk_div7 = {
639 .data = &(struct clk_regmap_gate_data){
640 .offset = HHI_MPLL_CNTL6,
643 .hw.init = &(struct clk_init_data){
645 .ops = &clk_regmap_gate_ops,
646 .parent_names = (const char *[]){ "fclk_div7_div" },
651 static struct clk_regmap gxbb_mpll_prediv = {
652 .data = &(struct clk_regmap_div_data){
653 .offset = HHI_MPLL_CNTL5,
657 .hw.init = &(struct clk_init_data){
658 .name = "mpll_prediv",
659 .ops = &clk_regmap_divider_ro_ops,
660 .parent_names = (const char *[]){ "fixed_pll" },
665 static struct clk_regmap gxbb_mpll0_div = {
666 .data = &(struct meson_clk_mpll_data){
668 .reg_off = HHI_MPLL_CNTL7,
673 .reg_off = HHI_MPLL_CNTL7,
678 .reg_off = HHI_MPLL_CNTL7,
683 .reg_off = HHI_MPLL_CNTL,
687 .lock = &meson_clk_lock,
689 .hw.init = &(struct clk_init_data){
691 .ops = &meson_clk_mpll_ops,
692 .parent_names = (const char *[]){ "mpll_prediv" },
697 static struct clk_regmap gxbb_mpll0 = {
698 .data = &(struct clk_regmap_gate_data){
699 .offset = HHI_MPLL_CNTL7,
702 .hw.init = &(struct clk_init_data){
704 .ops = &clk_regmap_gate_ops,
705 .parent_names = (const char *[]){ "mpll0_div" },
707 .flags = CLK_SET_RATE_PARENT,
711 static struct clk_regmap gxbb_mpll1_div = {
712 .data = &(struct meson_clk_mpll_data){
714 .reg_off = HHI_MPLL_CNTL8,
719 .reg_off = HHI_MPLL_CNTL8,
724 .reg_off = HHI_MPLL_CNTL8,
728 .lock = &meson_clk_lock,
730 .hw.init = &(struct clk_init_data){
732 .ops = &meson_clk_mpll_ops,
733 .parent_names = (const char *[]){ "mpll_prediv" },
738 static struct clk_regmap gxbb_mpll1 = {
739 .data = &(struct clk_regmap_gate_data){
740 .offset = HHI_MPLL_CNTL8,
743 .hw.init = &(struct clk_init_data){
745 .ops = &clk_regmap_gate_ops,
746 .parent_names = (const char *[]){ "mpll1_div" },
748 .flags = CLK_SET_RATE_PARENT,
752 static struct clk_regmap gxbb_mpll2_div = {
753 .data = &(struct meson_clk_mpll_data){
755 .reg_off = HHI_MPLL_CNTL9,
760 .reg_off = HHI_MPLL_CNTL9,
765 .reg_off = HHI_MPLL_CNTL9,
769 .lock = &meson_clk_lock,
771 .hw.init = &(struct clk_init_data){
773 .ops = &meson_clk_mpll_ops,
774 .parent_names = (const char *[]){ "mpll_prediv" },
779 static struct clk_regmap gxbb_mpll2 = {
780 .data = &(struct clk_regmap_gate_data){
781 .offset = HHI_MPLL_CNTL9,
784 .hw.init = &(struct clk_init_data){
786 .ops = &clk_regmap_gate_ops,
787 .parent_names = (const char *[]){ "mpll2_div" },
789 .flags = CLK_SET_RATE_PARENT,
793 static u32 mux_table_clk81[] = { 0, 2, 3, 4, 5, 6, 7 };
794 static const char * const clk81_parent_names[] = {
795 IN_PREFIX "xtal", "fclk_div7", "mpll1", "mpll2", "fclk_div4",
796 "fclk_div3", "fclk_div5"
799 static struct clk_regmap gxbb_mpeg_clk_sel = {
800 .data = &(struct clk_regmap_mux_data){
801 .offset = HHI_MPEG_CLK_CNTL,
804 .table = mux_table_clk81,
806 .hw.init = &(struct clk_init_data){
807 .name = "mpeg_clk_sel",
808 .ops = &clk_regmap_mux_ro_ops,
810 * bits 14:12 selects from 8 possible parents:
811 * xtal, 1'b0 (wtf), fclk_div7, mpll_clkout1, mpll_clkout2,
812 * fclk_div4, fclk_div3, fclk_div5
814 .parent_names = clk81_parent_names,
815 .num_parents = ARRAY_SIZE(clk81_parent_names),
819 static struct clk_regmap gxbb_mpeg_clk_div = {
820 .data = &(struct clk_regmap_div_data){
821 .offset = HHI_MPEG_CLK_CNTL,
825 .hw.init = &(struct clk_init_data){
826 .name = "mpeg_clk_div",
827 .ops = &clk_regmap_divider_ro_ops,
828 .parent_names = (const char *[]){ "mpeg_clk_sel" },
833 /* the mother of dragons gates */
834 static struct clk_regmap gxbb_clk81 = {
835 .data = &(struct clk_regmap_gate_data){
836 .offset = HHI_MPEG_CLK_CNTL,
839 .hw.init = &(struct clk_init_data){
841 .ops = &clk_regmap_gate_ops,
842 .parent_names = (const char *[]){ "mpeg_clk_div" },
844 .flags = CLK_IS_CRITICAL,
848 static struct clk_regmap gxbb_sar_adc_clk_sel = {
849 .data = &(struct clk_regmap_mux_data){
850 .offset = HHI_SAR_CLK_CNTL,
854 .hw.init = &(struct clk_init_data){
855 .name = "sar_adc_clk_sel",
856 .ops = &clk_regmap_mux_ops,
857 /* NOTE: The datasheet doesn't list the parents for bit 10 */
858 .parent_names = (const char *[]){ IN_PREFIX "xtal", "clk81", },
863 static struct clk_regmap gxbb_sar_adc_clk_div = {
864 .data = &(struct clk_regmap_div_data){
865 .offset = HHI_SAR_CLK_CNTL,
869 .hw.init = &(struct clk_init_data){
870 .name = "sar_adc_clk_div",
871 .ops = &clk_regmap_divider_ops,
872 .parent_names = (const char *[]){ "sar_adc_clk_sel" },
877 static struct clk_regmap gxbb_sar_adc_clk = {
878 .data = &(struct clk_regmap_gate_data){
879 .offset = HHI_SAR_CLK_CNTL,
882 .hw.init = &(struct clk_init_data){
883 .name = "sar_adc_clk",
884 .ops = &clk_regmap_gate_ops,
885 .parent_names = (const char *[]){ "sar_adc_clk_div" },
887 .flags = CLK_SET_RATE_PARENT,
892 * The MALI IP is clocked by two identical clocks (mali_0 and mali_1)
893 * muxed by a glitch-free switch.
896 static const char * const gxbb_mali_0_1_parent_names[] = {
897 IN_PREFIX "xtal", "gp0_pll", "mpll2", "mpll1", "fclk_div7",
898 "fclk_div4", "fclk_div3", "fclk_div5"
901 static struct clk_regmap gxbb_mali_0_sel = {
902 .data = &(struct clk_regmap_mux_data){
903 .offset = HHI_MALI_CLK_CNTL,
907 .hw.init = &(struct clk_init_data){
908 .name = "mali_0_sel",
909 .ops = &clk_regmap_mux_ops,
911 * bits 10:9 selects from 8 possible parents:
912 * xtal, gp0_pll, mpll2, mpll1, fclk_div7,
913 * fclk_div4, fclk_div3, fclk_div5
915 .parent_names = gxbb_mali_0_1_parent_names,
917 .flags = CLK_SET_RATE_NO_REPARENT,
921 static struct clk_regmap gxbb_mali_0_div = {
922 .data = &(struct clk_regmap_div_data){
923 .offset = HHI_MALI_CLK_CNTL,
927 .hw.init = &(struct clk_init_data){
928 .name = "mali_0_div",
929 .ops = &clk_regmap_divider_ops,
930 .parent_names = (const char *[]){ "mali_0_sel" },
932 .flags = CLK_SET_RATE_NO_REPARENT,
936 static struct clk_regmap gxbb_mali_0 = {
937 .data = &(struct clk_regmap_gate_data){
938 .offset = HHI_MALI_CLK_CNTL,
941 .hw.init = &(struct clk_init_data){
943 .ops = &clk_regmap_gate_ops,
944 .parent_names = (const char *[]){ "mali_0_div" },
946 .flags = CLK_SET_RATE_PARENT,
950 static struct clk_regmap gxbb_mali_1_sel = {
951 .data = &(struct clk_regmap_mux_data){
952 .offset = HHI_MALI_CLK_CNTL,
956 .hw.init = &(struct clk_init_data){
957 .name = "mali_1_sel",
958 .ops = &clk_regmap_mux_ops,
960 * bits 10:9 selects from 8 possible parents:
961 * xtal, gp0_pll, mpll2, mpll1, fclk_div7,
962 * fclk_div4, fclk_div3, fclk_div5
964 .parent_names = gxbb_mali_0_1_parent_names,
966 .flags = CLK_SET_RATE_NO_REPARENT,
970 static struct clk_regmap gxbb_mali_1_div = {
971 .data = &(struct clk_regmap_div_data){
972 .offset = HHI_MALI_CLK_CNTL,
976 .hw.init = &(struct clk_init_data){
977 .name = "mali_1_div",
978 .ops = &clk_regmap_divider_ops,
979 .parent_names = (const char *[]){ "mali_1_sel" },
981 .flags = CLK_SET_RATE_NO_REPARENT,
985 static struct clk_regmap gxbb_mali_1 = {
986 .data = &(struct clk_regmap_gate_data){
987 .offset = HHI_MALI_CLK_CNTL,
990 .hw.init = &(struct clk_init_data){
992 .ops = &clk_regmap_gate_ops,
993 .parent_names = (const char *[]){ "mali_1_div" },
995 .flags = CLK_SET_RATE_PARENT,
999 static const char * const gxbb_mali_parent_names[] = {
1003 static struct clk_regmap gxbb_mali = {
1004 .data = &(struct clk_regmap_mux_data){
1005 .offset = HHI_MALI_CLK_CNTL,
1009 .hw.init = &(struct clk_init_data){
1011 .ops = &clk_regmap_mux_ops,
1012 .parent_names = gxbb_mali_parent_names,
1014 .flags = CLK_SET_RATE_NO_REPARENT,
1018 static struct clk_regmap gxbb_cts_amclk_sel = {
1019 .data = &(struct clk_regmap_mux_data){
1020 .offset = HHI_AUD_CLK_CNTL,
1023 .table = (u32[]){ 1, 2, 3 },
1024 .flags = CLK_MUX_ROUND_CLOSEST,
1026 .hw.init = &(struct clk_init_data){
1027 .name = "cts_amclk_sel",
1028 .ops = &clk_regmap_mux_ops,
1029 .parent_names = (const char *[]){ "mpll0", "mpll1", "mpll2" },
1034 static struct clk_regmap gxbb_cts_amclk_div = {
1035 .data = &(struct clk_regmap_div_data) {
1036 .offset = HHI_AUD_CLK_CNTL,
1039 .flags = CLK_DIVIDER_ROUND_CLOSEST,
1041 .hw.init = &(struct clk_init_data){
1042 .name = "cts_amclk_div",
1043 .ops = &clk_regmap_divider_ops,
1044 .parent_names = (const char *[]){ "cts_amclk_sel" },
1046 .flags = CLK_SET_RATE_PARENT,
1050 static struct clk_regmap gxbb_cts_amclk = {
1051 .data = &(struct clk_regmap_gate_data){
1052 .offset = HHI_AUD_CLK_CNTL,
1055 .hw.init = &(struct clk_init_data){
1056 .name = "cts_amclk",
1057 .ops = &clk_regmap_gate_ops,
1058 .parent_names = (const char *[]){ "cts_amclk_div" },
1060 .flags = CLK_SET_RATE_PARENT,
1064 static struct clk_regmap gxbb_cts_mclk_i958_sel = {
1065 .data = &(struct clk_regmap_mux_data){
1066 .offset = HHI_AUD_CLK_CNTL2,
1069 .table = (u32[]){ 1, 2, 3 },
1070 .flags = CLK_MUX_ROUND_CLOSEST,
1072 .hw.init = &(struct clk_init_data) {
1073 .name = "cts_mclk_i958_sel",
1074 .ops = &clk_regmap_mux_ops,
1075 .parent_names = (const char *[]){ "mpll0", "mpll1", "mpll2" },
1080 static struct clk_regmap gxbb_cts_mclk_i958_div = {
1081 .data = &(struct clk_regmap_div_data){
1082 .offset = HHI_AUD_CLK_CNTL2,
1085 .flags = CLK_DIVIDER_ROUND_CLOSEST,
1087 .hw.init = &(struct clk_init_data) {
1088 .name = "cts_mclk_i958_div",
1089 .ops = &clk_regmap_divider_ops,
1090 .parent_names = (const char *[]){ "cts_mclk_i958_sel" },
1092 .flags = CLK_SET_RATE_PARENT,
1096 static struct clk_regmap gxbb_cts_mclk_i958 = {
1097 .data = &(struct clk_regmap_gate_data){
1098 .offset = HHI_AUD_CLK_CNTL2,
1101 .hw.init = &(struct clk_init_data){
1102 .name = "cts_mclk_i958",
1103 .ops = &clk_regmap_gate_ops,
1104 .parent_names = (const char *[]){ "cts_mclk_i958_div" },
1106 .flags = CLK_SET_RATE_PARENT,
1110 static struct clk_regmap gxbb_cts_i958 = {
1111 .data = &(struct clk_regmap_mux_data){
1112 .offset = HHI_AUD_CLK_CNTL2,
1116 .hw.init = &(struct clk_init_data){
1118 .ops = &clk_regmap_mux_ops,
1119 .parent_names = (const char *[]){ "cts_amclk", "cts_mclk_i958" },
1122 *The parent is specific to origin of the audio data. Let the
1123 * consumer choose the appropriate parent
1125 .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
1129 static struct clk_regmap gxbb_32k_clk_div = {
1130 .data = &(struct clk_regmap_div_data){
1131 .offset = HHI_32K_CLK_CNTL,
1135 .hw.init = &(struct clk_init_data){
1136 .name = "32k_clk_div",
1137 .ops = &clk_regmap_divider_ops,
1138 .parent_names = (const char *[]){ "32k_clk_sel" },
1140 .flags = CLK_SET_RATE_PARENT | CLK_DIVIDER_ROUND_CLOSEST,
1144 static struct clk_regmap gxbb_32k_clk = {
1145 .data = &(struct clk_regmap_gate_data){
1146 .offset = HHI_32K_CLK_CNTL,
1149 .hw.init = &(struct clk_init_data){
1151 .ops = &clk_regmap_gate_ops,
1152 .parent_names = (const char *[]){ "32k_clk_div" },
1154 .flags = CLK_SET_RATE_PARENT,
1158 static const char * const gxbb_32k_clk_parent_names[] = {
1159 IN_PREFIX "xtal", "cts_slow_oscin", "fclk_div3", "fclk_div5"
1162 static struct clk_regmap gxbb_32k_clk_sel = {
1163 .data = &(struct clk_regmap_mux_data){
1164 .offset = HHI_32K_CLK_CNTL,
1168 .hw.init = &(struct clk_init_data){
1169 .name = "32k_clk_sel",
1170 .ops = &clk_regmap_mux_ops,
1171 .parent_names = gxbb_32k_clk_parent_names,
1173 .flags = CLK_SET_RATE_PARENT,
1177 static const char * const gxbb_sd_emmc_clk0_parent_names[] = {
1178 IN_PREFIX "xtal", "fclk_div2", "fclk_div3", "fclk_div5", "fclk_div7",
1181 * Following these parent clocks, we should also have had mpll2, mpll3
1182 * and gp0_pll but these clocks are too precious to be used here. All
1183 * the necessary rates for MMC and NAND operation can be acheived using
1184 * xtal or fclk_div clocks
1189 static struct clk_regmap gxbb_sd_emmc_a_clk0_sel = {
1190 .data = &(struct clk_regmap_mux_data){
1191 .offset = HHI_SD_EMMC_CLK_CNTL,
1195 .hw.init = &(struct clk_init_data) {
1196 .name = "sd_emmc_a_clk0_sel",
1197 .ops = &clk_regmap_mux_ops,
1198 .parent_names = gxbb_sd_emmc_clk0_parent_names,
1199 .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
1200 .flags = CLK_SET_RATE_PARENT,
1204 static struct clk_regmap gxbb_sd_emmc_a_clk0_div = {
1205 .data = &(struct clk_regmap_div_data){
1206 .offset = HHI_SD_EMMC_CLK_CNTL,
1209 .flags = CLK_DIVIDER_ROUND_CLOSEST,
1211 .hw.init = &(struct clk_init_data) {
1212 .name = "sd_emmc_a_clk0_div",
1213 .ops = &clk_regmap_divider_ops,
1214 .parent_names = (const char *[]){ "sd_emmc_a_clk0_sel" },
1216 .flags = CLK_SET_RATE_PARENT,
1220 static struct clk_regmap gxbb_sd_emmc_a_clk0 = {
1221 .data = &(struct clk_regmap_gate_data){
1222 .offset = HHI_SD_EMMC_CLK_CNTL,
1225 .hw.init = &(struct clk_init_data){
1226 .name = "sd_emmc_a_clk0",
1227 .ops = &clk_regmap_gate_ops,
1228 .parent_names = (const char *[]){ "sd_emmc_a_clk0_div" },
1230 .flags = CLK_SET_RATE_PARENT,
1235 static struct clk_regmap gxbb_sd_emmc_b_clk0_sel = {
1236 .data = &(struct clk_regmap_mux_data){
1237 .offset = HHI_SD_EMMC_CLK_CNTL,
1241 .hw.init = &(struct clk_init_data) {
1242 .name = "sd_emmc_b_clk0_sel",
1243 .ops = &clk_regmap_mux_ops,
1244 .parent_names = gxbb_sd_emmc_clk0_parent_names,
1245 .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
1246 .flags = CLK_SET_RATE_PARENT,
1250 static struct clk_regmap gxbb_sd_emmc_b_clk0_div = {
1251 .data = &(struct clk_regmap_div_data){
1252 .offset = HHI_SD_EMMC_CLK_CNTL,
1255 .flags = CLK_DIVIDER_ROUND_CLOSEST,
1257 .hw.init = &(struct clk_init_data) {
1258 .name = "sd_emmc_b_clk0_div",
1259 .ops = &clk_regmap_divider_ops,
1260 .parent_names = (const char *[]){ "sd_emmc_b_clk0_sel" },
1262 .flags = CLK_SET_RATE_PARENT,
1266 static struct clk_regmap gxbb_sd_emmc_b_clk0 = {
1267 .data = &(struct clk_regmap_gate_data){
1268 .offset = HHI_SD_EMMC_CLK_CNTL,
1271 .hw.init = &(struct clk_init_data){
1272 .name = "sd_emmc_b_clk0",
1273 .ops = &clk_regmap_gate_ops,
1274 .parent_names = (const char *[]){ "sd_emmc_b_clk0_div" },
1276 .flags = CLK_SET_RATE_PARENT,
1280 /* EMMC/NAND clock */
1281 static struct clk_regmap gxbb_sd_emmc_c_clk0_sel = {
1282 .data = &(struct clk_regmap_mux_data){
1283 .offset = HHI_NAND_CLK_CNTL,
1287 .hw.init = &(struct clk_init_data) {
1288 .name = "sd_emmc_c_clk0_sel",
1289 .ops = &clk_regmap_mux_ops,
1290 .parent_names = gxbb_sd_emmc_clk0_parent_names,
1291 .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
1292 .flags = CLK_SET_RATE_PARENT,
1296 static struct clk_regmap gxbb_sd_emmc_c_clk0_div = {
1297 .data = &(struct clk_regmap_div_data){
1298 .offset = HHI_NAND_CLK_CNTL,
1301 .flags = CLK_DIVIDER_ROUND_CLOSEST,
1303 .hw.init = &(struct clk_init_data) {
1304 .name = "sd_emmc_c_clk0_div",
1305 .ops = &clk_regmap_divider_ops,
1306 .parent_names = (const char *[]){ "sd_emmc_c_clk0_sel" },
1308 .flags = CLK_SET_RATE_PARENT,
1312 static struct clk_regmap gxbb_sd_emmc_c_clk0 = {
1313 .data = &(struct clk_regmap_gate_data){
1314 .offset = HHI_NAND_CLK_CNTL,
1317 .hw.init = &(struct clk_init_data){
1318 .name = "sd_emmc_c_clk0",
1319 .ops = &clk_regmap_gate_ops,
1320 .parent_names = (const char *[]){ "sd_emmc_c_clk0_div" },
1322 .flags = CLK_SET_RATE_PARENT,
1328 static const char * const gxbb_vpu_parent_names[] = {
1329 "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
1332 static struct clk_regmap gxbb_vpu_0_sel = {
1333 .data = &(struct clk_regmap_mux_data){
1334 .offset = HHI_VPU_CLK_CNTL,
1338 .hw.init = &(struct clk_init_data){
1339 .name = "vpu_0_sel",
1340 .ops = &clk_regmap_mux_ops,
1342 * bits 9:10 selects from 4 possible parents:
1343 * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
1345 .parent_names = gxbb_vpu_parent_names,
1346 .num_parents = ARRAY_SIZE(gxbb_vpu_parent_names),
1347 .flags = CLK_SET_RATE_NO_REPARENT,
1351 static struct clk_regmap gxbb_vpu_0_div = {
1352 .data = &(struct clk_regmap_div_data){
1353 .offset = HHI_VPU_CLK_CNTL,
1357 .hw.init = &(struct clk_init_data){
1358 .name = "vpu_0_div",
1359 .ops = &clk_regmap_divider_ops,
1360 .parent_names = (const char *[]){ "vpu_0_sel" },
1362 .flags = CLK_SET_RATE_PARENT,
1366 static struct clk_regmap gxbb_vpu_0 = {
1367 .data = &(struct clk_regmap_gate_data){
1368 .offset = HHI_VPU_CLK_CNTL,
1371 .hw.init = &(struct clk_init_data) {
1373 .ops = &clk_regmap_gate_ops,
1374 .parent_names = (const char *[]){ "vpu_0_div" },
1376 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1380 static struct clk_regmap gxbb_vpu_1_sel = {
1381 .data = &(struct clk_regmap_mux_data){
1382 .offset = HHI_VPU_CLK_CNTL,
1386 .hw.init = &(struct clk_init_data){
1387 .name = "vpu_1_sel",
1388 .ops = &clk_regmap_mux_ops,
1390 * bits 25:26 selects from 4 possible parents:
1391 * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
1393 .parent_names = gxbb_vpu_parent_names,
1394 .num_parents = ARRAY_SIZE(gxbb_vpu_parent_names),
1395 .flags = CLK_SET_RATE_NO_REPARENT,
1399 static struct clk_regmap gxbb_vpu_1_div = {
1400 .data = &(struct clk_regmap_div_data){
1401 .offset = HHI_VPU_CLK_CNTL,
1405 .hw.init = &(struct clk_init_data){
1406 .name = "vpu_1_div",
1407 .ops = &clk_regmap_divider_ops,
1408 .parent_names = (const char *[]){ "vpu_1_sel" },
1410 .flags = CLK_SET_RATE_PARENT,
1414 static struct clk_regmap gxbb_vpu_1 = {
1415 .data = &(struct clk_regmap_gate_data){
1416 .offset = HHI_VPU_CLK_CNTL,
1419 .hw.init = &(struct clk_init_data) {
1421 .ops = &clk_regmap_gate_ops,
1422 .parent_names = (const char *[]){ "vpu_1_div" },
1424 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1428 static struct clk_regmap gxbb_vpu = {
1429 .data = &(struct clk_regmap_mux_data){
1430 .offset = HHI_VPU_CLK_CNTL,
1434 .hw.init = &(struct clk_init_data){
1436 .ops = &clk_regmap_mux_ops,
1438 * bit 31 selects from 2 possible parents:
1441 .parent_names = (const char *[]){ "vpu_0", "vpu_1" },
1443 .flags = CLK_SET_RATE_NO_REPARENT,
1449 static const char * const gxbb_vapb_parent_names[] = {
1450 "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
1453 static struct clk_regmap gxbb_vapb_0_sel = {
1454 .data = &(struct clk_regmap_mux_data){
1455 .offset = HHI_VAPBCLK_CNTL,
1459 .hw.init = &(struct clk_init_data){
1460 .name = "vapb_0_sel",
1461 .ops = &clk_regmap_mux_ops,
1463 * bits 9:10 selects from 4 possible parents:
1464 * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
1466 .parent_names = gxbb_vapb_parent_names,
1467 .num_parents = ARRAY_SIZE(gxbb_vapb_parent_names),
1468 .flags = CLK_SET_RATE_NO_REPARENT,
1472 static struct clk_regmap gxbb_vapb_0_div = {
1473 .data = &(struct clk_regmap_div_data){
1474 .offset = HHI_VAPBCLK_CNTL,
1478 .hw.init = &(struct clk_init_data){
1479 .name = "vapb_0_div",
1480 .ops = &clk_regmap_divider_ops,
1481 .parent_names = (const char *[]){ "vapb_0_sel" },
1483 .flags = CLK_SET_RATE_PARENT,
1487 static struct clk_regmap gxbb_vapb_0 = {
1488 .data = &(struct clk_regmap_gate_data){
1489 .offset = HHI_VAPBCLK_CNTL,
1492 .hw.init = &(struct clk_init_data) {
1494 .ops = &clk_regmap_gate_ops,
1495 .parent_names = (const char *[]){ "vapb_0_div" },
1497 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1501 static struct clk_regmap gxbb_vapb_1_sel = {
1502 .data = &(struct clk_regmap_mux_data){
1503 .offset = HHI_VAPBCLK_CNTL,
1507 .hw.init = &(struct clk_init_data){
1508 .name = "vapb_1_sel",
1509 .ops = &clk_regmap_mux_ops,
1511 * bits 25:26 selects from 4 possible parents:
1512 * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
1514 .parent_names = gxbb_vapb_parent_names,
1515 .num_parents = ARRAY_SIZE(gxbb_vapb_parent_names),
1516 .flags = CLK_SET_RATE_NO_REPARENT,
1520 static struct clk_regmap gxbb_vapb_1_div = {
1521 .data = &(struct clk_regmap_div_data){
1522 .offset = HHI_VAPBCLK_CNTL,
1526 .hw.init = &(struct clk_init_data){
1527 .name = "vapb_1_div",
1528 .ops = &clk_regmap_divider_ops,
1529 .parent_names = (const char *[]){ "vapb_1_sel" },
1531 .flags = CLK_SET_RATE_PARENT,
1535 static struct clk_regmap gxbb_vapb_1 = {
1536 .data = &(struct clk_regmap_gate_data){
1537 .offset = HHI_VAPBCLK_CNTL,
1540 .hw.init = &(struct clk_init_data) {
1542 .ops = &clk_regmap_gate_ops,
1543 .parent_names = (const char *[]){ "vapb_1_div" },
1545 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1549 static struct clk_regmap gxbb_vapb_sel = {
1550 .data = &(struct clk_regmap_mux_data){
1551 .offset = HHI_VAPBCLK_CNTL,
1555 .hw.init = &(struct clk_init_data){
1557 .ops = &clk_regmap_mux_ops,
1559 * bit 31 selects from 2 possible parents:
1562 .parent_names = (const char *[]){ "vapb_0", "vapb_1" },
1564 .flags = CLK_SET_RATE_NO_REPARENT,
1568 static struct clk_regmap gxbb_vapb = {
1569 .data = &(struct clk_regmap_gate_data){
1570 .offset = HHI_VAPBCLK_CNTL,
1573 .hw.init = &(struct clk_init_data) {
1575 .ops = &clk_regmap_gate_ops,
1576 .parent_names = (const char *[]){ "vapb_sel" },
1578 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1584 static struct clk_regmap gxbb_vid_pll_div = {
1585 .data = &(struct meson_vid_pll_div_data){
1587 .reg_off = HHI_VID_PLL_CLK_DIV,
1592 .reg_off = HHI_VID_PLL_CLK_DIV,
1597 .hw.init = &(struct clk_init_data) {
1598 .name = "vid_pll_div",
1599 .ops = &meson_vid_pll_div_ro_ops,
1600 .parent_names = (const char *[]){ "hdmi_pll" },
1602 .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
1606 static const char * const gxbb_vid_pll_parent_names[] = { "vid_pll_div", "hdmi_pll" };
1608 static struct clk_regmap gxbb_vid_pll_sel = {
1609 .data = &(struct clk_regmap_mux_data){
1610 .offset = HHI_VID_PLL_CLK_DIV,
1614 .hw.init = &(struct clk_init_data){
1615 .name = "vid_pll_sel",
1616 .ops = &clk_regmap_mux_ops,
1618 * bit 18 selects from 2 possible parents:
1619 * vid_pll_div or hdmi_pll
1621 .parent_names = gxbb_vid_pll_parent_names,
1622 .num_parents = ARRAY_SIZE(gxbb_vid_pll_parent_names),
1623 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
1627 static struct clk_regmap gxbb_vid_pll = {
1628 .data = &(struct clk_regmap_gate_data){
1629 .offset = HHI_VID_PLL_CLK_DIV,
1632 .hw.init = &(struct clk_init_data) {
1634 .ops = &clk_regmap_gate_ops,
1635 .parent_names = (const char *[]){ "vid_pll_sel" },
1637 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1641 static const char * const gxbb_vclk_parent_names[] = {
1642 "vid_pll", "fclk_div4", "fclk_div3", "fclk_div5", "vid_pll",
1643 "fclk_div7", "mpll1",
1646 static struct clk_regmap gxbb_vclk_sel = {
1647 .data = &(struct clk_regmap_mux_data){
1648 .offset = HHI_VID_CLK_CNTL,
1652 .hw.init = &(struct clk_init_data){
1654 .ops = &clk_regmap_mux_ops,
1656 * bits 16:18 selects from 8 possible parents:
1657 * vid_pll, fclk_div4, fclk_div3, fclk_div5,
1658 * vid_pll, fclk_div7, mp1
1660 .parent_names = gxbb_vclk_parent_names,
1661 .num_parents = ARRAY_SIZE(gxbb_vclk_parent_names),
1662 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
1666 static struct clk_regmap gxbb_vclk2_sel = {
1667 .data = &(struct clk_regmap_mux_data){
1668 .offset = HHI_VIID_CLK_CNTL,
1672 .hw.init = &(struct clk_init_data){
1673 .name = "vclk2_sel",
1674 .ops = &clk_regmap_mux_ops,
1676 * bits 16:18 selects from 8 possible parents:
1677 * vid_pll, fclk_div4, fclk_div3, fclk_div5,
1678 * vid_pll, fclk_div7, mp1
1680 .parent_names = gxbb_vclk_parent_names,
1681 .num_parents = ARRAY_SIZE(gxbb_vclk_parent_names),
1682 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
1686 static struct clk_regmap gxbb_vclk_input = {
1687 .data = &(struct clk_regmap_gate_data){
1688 .offset = HHI_VID_CLK_DIV,
1691 .hw.init = &(struct clk_init_data) {
1692 .name = "vclk_input",
1693 .ops = &clk_regmap_gate_ops,
1694 .parent_names = (const char *[]){ "vclk_sel" },
1696 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1700 static struct clk_regmap gxbb_vclk2_input = {
1701 .data = &(struct clk_regmap_gate_data){
1702 .offset = HHI_VIID_CLK_DIV,
1705 .hw.init = &(struct clk_init_data) {
1706 .name = "vclk2_input",
1707 .ops = &clk_regmap_gate_ops,
1708 .parent_names = (const char *[]){ "vclk2_sel" },
1710 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1714 static struct clk_regmap gxbb_vclk_div = {
1715 .data = &(struct clk_regmap_div_data){
1716 .offset = HHI_VID_CLK_DIV,
1720 .hw.init = &(struct clk_init_data){
1722 .ops = &clk_regmap_divider_ops,
1723 .parent_names = (const char *[]){ "vclk_input" },
1725 .flags = CLK_GET_RATE_NOCACHE,
1729 static struct clk_regmap gxbb_vclk2_div = {
1730 .data = &(struct clk_regmap_div_data){
1731 .offset = HHI_VIID_CLK_DIV,
1735 .hw.init = &(struct clk_init_data){
1736 .name = "vclk2_div",
1737 .ops = &clk_regmap_divider_ops,
1738 .parent_names = (const char *[]){ "vclk2_input" },
1740 .flags = CLK_GET_RATE_NOCACHE,
1744 static struct clk_regmap gxbb_vclk = {
1745 .data = &(struct clk_regmap_gate_data){
1746 .offset = HHI_VID_CLK_CNTL,
1749 .hw.init = &(struct clk_init_data) {
1751 .ops = &clk_regmap_gate_ops,
1752 .parent_names = (const char *[]){ "vclk_div" },
1754 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1758 static struct clk_regmap gxbb_vclk2 = {
1759 .data = &(struct clk_regmap_gate_data){
1760 .offset = HHI_VIID_CLK_CNTL,
1763 .hw.init = &(struct clk_init_data) {
1765 .ops = &clk_regmap_gate_ops,
1766 .parent_names = (const char *[]){ "vclk2_div" },
1768 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1772 static struct clk_regmap gxbb_vclk_div1 = {
1773 .data = &(struct clk_regmap_gate_data){
1774 .offset = HHI_VID_CLK_CNTL,
1777 .hw.init = &(struct clk_init_data) {
1778 .name = "vclk_div1",
1779 .ops = &clk_regmap_gate_ops,
1780 .parent_names = (const char *[]){ "vclk" },
1782 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1786 static struct clk_regmap gxbb_vclk_div2_en = {
1787 .data = &(struct clk_regmap_gate_data){
1788 .offset = HHI_VID_CLK_CNTL,
1791 .hw.init = &(struct clk_init_data) {
1792 .name = "vclk_div2_en",
1793 .ops = &clk_regmap_gate_ops,
1794 .parent_names = (const char *[]){ "vclk" },
1796 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1800 static struct clk_regmap gxbb_vclk_div4_en = {
1801 .data = &(struct clk_regmap_gate_data){
1802 .offset = HHI_VID_CLK_CNTL,
1805 .hw.init = &(struct clk_init_data) {
1806 .name = "vclk_div4_en",
1807 .ops = &clk_regmap_gate_ops,
1808 .parent_names = (const char *[]){ "vclk" },
1810 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1814 static struct clk_regmap gxbb_vclk_div6_en = {
1815 .data = &(struct clk_regmap_gate_data){
1816 .offset = HHI_VID_CLK_CNTL,
1819 .hw.init = &(struct clk_init_data) {
1820 .name = "vclk_div6_en",
1821 .ops = &clk_regmap_gate_ops,
1822 .parent_names = (const char *[]){ "vclk" },
1824 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1828 static struct clk_regmap gxbb_vclk_div12_en = {
1829 .data = &(struct clk_regmap_gate_data){
1830 .offset = HHI_VID_CLK_CNTL,
1833 .hw.init = &(struct clk_init_data) {
1834 .name = "vclk_div12_en",
1835 .ops = &clk_regmap_gate_ops,
1836 .parent_names = (const char *[]){ "vclk" },
1838 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1842 static struct clk_regmap gxbb_vclk2_div1 = {
1843 .data = &(struct clk_regmap_gate_data){
1844 .offset = HHI_VIID_CLK_CNTL,
1847 .hw.init = &(struct clk_init_data) {
1848 .name = "vclk2_div1",
1849 .ops = &clk_regmap_gate_ops,
1850 .parent_names = (const char *[]){ "vclk2" },
1852 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1856 static struct clk_regmap gxbb_vclk2_div2_en = {
1857 .data = &(struct clk_regmap_gate_data){
1858 .offset = HHI_VIID_CLK_CNTL,
1861 .hw.init = &(struct clk_init_data) {
1862 .name = "vclk2_div2_en",
1863 .ops = &clk_regmap_gate_ops,
1864 .parent_names = (const char *[]){ "vclk2" },
1866 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1870 static struct clk_regmap gxbb_vclk2_div4_en = {
1871 .data = &(struct clk_regmap_gate_data){
1872 .offset = HHI_VIID_CLK_CNTL,
1875 .hw.init = &(struct clk_init_data) {
1876 .name = "vclk2_div4_en",
1877 .ops = &clk_regmap_gate_ops,
1878 .parent_names = (const char *[]){ "vclk2" },
1880 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1884 static struct clk_regmap gxbb_vclk2_div6_en = {
1885 .data = &(struct clk_regmap_gate_data){
1886 .offset = HHI_VIID_CLK_CNTL,
1889 .hw.init = &(struct clk_init_data) {
1890 .name = "vclk2_div6_en",
1891 .ops = &clk_regmap_gate_ops,
1892 .parent_names = (const char *[]){ "vclk2" },
1894 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1898 static struct clk_regmap gxbb_vclk2_div12_en = {
1899 .data = &(struct clk_regmap_gate_data){
1900 .offset = HHI_VIID_CLK_CNTL,
1903 .hw.init = &(struct clk_init_data) {
1904 .name = "vclk2_div12_en",
1905 .ops = &clk_regmap_gate_ops,
1906 .parent_names = (const char *[]){ "vclk2" },
1908 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
1912 static struct clk_fixed_factor gxbb_vclk_div2 = {
1915 .hw.init = &(struct clk_init_data){
1916 .name = "vclk_div2",
1917 .ops = &clk_fixed_factor_ops,
1918 .parent_names = (const char *[]){ "vclk_div2_en" },
1923 static struct clk_fixed_factor gxbb_vclk_div4 = {
1926 .hw.init = &(struct clk_init_data){
1927 .name = "vclk_div4",
1928 .ops = &clk_fixed_factor_ops,
1929 .parent_names = (const char *[]){ "vclk_div4_en" },
1934 static struct clk_fixed_factor gxbb_vclk_div6 = {
1937 .hw.init = &(struct clk_init_data){
1938 .name = "vclk_div6",
1939 .ops = &clk_fixed_factor_ops,
1940 .parent_names = (const char *[]){ "vclk_div6_en" },
1945 static struct clk_fixed_factor gxbb_vclk_div12 = {
1948 .hw.init = &(struct clk_init_data){
1949 .name = "vclk_div12",
1950 .ops = &clk_fixed_factor_ops,
1951 .parent_names = (const char *[]){ "vclk_div12_en" },
1956 static struct clk_fixed_factor gxbb_vclk2_div2 = {
1959 .hw.init = &(struct clk_init_data){
1960 .name = "vclk2_div2",
1961 .ops = &clk_fixed_factor_ops,
1962 .parent_names = (const char *[]){ "vclk2_div2_en" },
1967 static struct clk_fixed_factor gxbb_vclk2_div4 = {
1970 .hw.init = &(struct clk_init_data){
1971 .name = "vclk2_div4",
1972 .ops = &clk_fixed_factor_ops,
1973 .parent_names = (const char *[]){ "vclk2_div4_en" },
1978 static struct clk_fixed_factor gxbb_vclk2_div6 = {
1981 .hw.init = &(struct clk_init_data){
1982 .name = "vclk2_div6",
1983 .ops = &clk_fixed_factor_ops,
1984 .parent_names = (const char *[]){ "vclk2_div6_en" },
1989 static struct clk_fixed_factor gxbb_vclk2_div12 = {
1992 .hw.init = &(struct clk_init_data){
1993 .name = "vclk2_div12",
1994 .ops = &clk_fixed_factor_ops,
1995 .parent_names = (const char *[]){ "vclk2_div12_en" },
2000 static u32 mux_table_cts_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
2001 static const char * const gxbb_cts_parent_names[] = {
2002 "vclk_div1", "vclk_div2", "vclk_div4", "vclk_div6",
2003 "vclk_div12", "vclk2_div1", "vclk2_div2", "vclk2_div4",
2004 "vclk2_div6", "vclk2_div12"
2007 static struct clk_regmap gxbb_cts_enci_sel = {
2008 .data = &(struct clk_regmap_mux_data){
2009 .offset = HHI_VID_CLK_DIV,
2012 .table = mux_table_cts_sel,
2014 .hw.init = &(struct clk_init_data){
2015 .name = "cts_enci_sel",
2016 .ops = &clk_regmap_mux_ops,
2017 .parent_names = gxbb_cts_parent_names,
2018 .num_parents = ARRAY_SIZE(gxbb_cts_parent_names),
2019 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
2023 static struct clk_regmap gxbb_cts_encp_sel = {
2024 .data = &(struct clk_regmap_mux_data){
2025 .offset = HHI_VID_CLK_DIV,
2028 .table = mux_table_cts_sel,
2030 .hw.init = &(struct clk_init_data){
2031 .name = "cts_encp_sel",
2032 .ops = &clk_regmap_mux_ops,
2033 .parent_names = gxbb_cts_parent_names,
2034 .num_parents = ARRAY_SIZE(gxbb_cts_parent_names),
2035 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
2039 static struct clk_regmap gxbb_cts_vdac_sel = {
2040 .data = &(struct clk_regmap_mux_data){
2041 .offset = HHI_VIID_CLK_DIV,
2044 .table = mux_table_cts_sel,
2046 .hw.init = &(struct clk_init_data){
2047 .name = "cts_vdac_sel",
2048 .ops = &clk_regmap_mux_ops,
2049 .parent_names = gxbb_cts_parent_names,
2050 .num_parents = ARRAY_SIZE(gxbb_cts_parent_names),
2051 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
2055 /* TOFIX: add support for cts_tcon */
2056 static u32 mux_table_hdmi_tx_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
2057 static const char * const gxbb_cts_hdmi_tx_parent_names[] = {
2058 "vclk_div1", "vclk_div2", "vclk_div4", "vclk_div6",
2059 "vclk_div12", "vclk2_div1", "vclk2_div2", "vclk2_div4",
2060 "vclk2_div6", "vclk2_div12"
2063 static struct clk_regmap gxbb_hdmi_tx_sel = {
2064 .data = &(struct clk_regmap_mux_data){
2065 .offset = HHI_HDMI_CLK_CNTL,
2068 .table = mux_table_hdmi_tx_sel,
2070 .hw.init = &(struct clk_init_data){
2071 .name = "hdmi_tx_sel",
2072 .ops = &clk_regmap_mux_ops,
2074 * bits 31:28 selects from 12 possible parents:
2075 * vclk_div1, vclk_div2, vclk_div4, vclk_div6, vclk_div12
2076 * vclk2_div1, vclk2_div2, vclk2_div4, vclk2_div6, vclk2_div12,
2079 .parent_names = gxbb_cts_hdmi_tx_parent_names,
2080 .num_parents = ARRAY_SIZE(gxbb_cts_hdmi_tx_parent_names),
2081 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
2085 static struct clk_regmap gxbb_cts_enci = {
2086 .data = &(struct clk_regmap_gate_data){
2087 .offset = HHI_VID_CLK_CNTL2,
2090 .hw.init = &(struct clk_init_data) {
2092 .ops = &clk_regmap_gate_ops,
2093 .parent_names = (const char *[]){ "cts_enci_sel" },
2095 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2099 static struct clk_regmap gxbb_cts_encp = {
2100 .data = &(struct clk_regmap_gate_data){
2101 .offset = HHI_VID_CLK_CNTL2,
2104 .hw.init = &(struct clk_init_data) {
2106 .ops = &clk_regmap_gate_ops,
2107 .parent_names = (const char *[]){ "cts_encp_sel" },
2109 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2113 static struct clk_regmap gxbb_cts_vdac = {
2114 .data = &(struct clk_regmap_gate_data){
2115 .offset = HHI_VID_CLK_CNTL2,
2118 .hw.init = &(struct clk_init_data) {
2120 .ops = &clk_regmap_gate_ops,
2121 .parent_names = (const char *[]){ "cts_vdac_sel" },
2123 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2127 static struct clk_regmap gxbb_hdmi_tx = {
2128 .data = &(struct clk_regmap_gate_data){
2129 .offset = HHI_VID_CLK_CNTL2,
2132 .hw.init = &(struct clk_init_data) {
2134 .ops = &clk_regmap_gate_ops,
2135 .parent_names = (const char *[]){ "hdmi_tx_sel" },
2137 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2143 static const char * const gxbb_hdmi_parent_names[] = {
2144 IN_PREFIX "xtal", "fclk_div4", "fclk_div3", "fclk_div5"
2147 static struct clk_regmap gxbb_hdmi_sel = {
2148 .data = &(struct clk_regmap_mux_data){
2149 .offset = HHI_HDMI_CLK_CNTL,
2152 .flags = CLK_MUX_ROUND_CLOSEST,
2154 .hw.init = &(struct clk_init_data){
2156 .ops = &clk_regmap_mux_ops,
2157 .parent_names = gxbb_hdmi_parent_names,
2158 .num_parents = ARRAY_SIZE(gxbb_hdmi_parent_names),
2159 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
2163 static struct clk_regmap gxbb_hdmi_div = {
2164 .data = &(struct clk_regmap_div_data){
2165 .offset = HHI_HDMI_CLK_CNTL,
2169 .hw.init = &(struct clk_init_data){
2171 .ops = &clk_regmap_divider_ops,
2172 .parent_names = (const char *[]){ "hdmi_sel" },
2174 .flags = CLK_GET_RATE_NOCACHE,
2178 static struct clk_regmap gxbb_hdmi = {
2179 .data = &(struct clk_regmap_gate_data){
2180 .offset = HHI_HDMI_CLK_CNTL,
2183 .hw.init = &(struct clk_init_data) {
2185 .ops = &clk_regmap_gate_ops,
2186 .parent_names = (const char *[]){ "hdmi_div" },
2188 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
2194 static const char * const gxbb_vdec_parent_names[] = {
2195 "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
2198 static struct clk_regmap gxbb_vdec_1_sel = {
2199 .data = &(struct clk_regmap_mux_data){
2200 .offset = HHI_VDEC_CLK_CNTL,
2203 .flags = CLK_MUX_ROUND_CLOSEST,
2205 .hw.init = &(struct clk_init_data){
2206 .name = "vdec_1_sel",
2207 .ops = &clk_regmap_mux_ops,
2208 .parent_names = gxbb_vdec_parent_names,
2209 .num_parents = ARRAY_SIZE(gxbb_vdec_parent_names),
2210 .flags = CLK_SET_RATE_PARENT,
2214 static struct clk_regmap gxbb_vdec_1_div = {
2215 .data = &(struct clk_regmap_div_data){
2216 .offset = HHI_VDEC_CLK_CNTL,
2219 .flags = CLK_DIVIDER_ROUND_CLOSEST,
2221 .hw.init = &(struct clk_init_data){
2222 .name = "vdec_1_div",
2223 .ops = &clk_regmap_divider_ops,
2224 .parent_names = (const char *[]){ "vdec_1_sel" },
2226 .flags = CLK_SET_RATE_PARENT,
2230 static struct clk_regmap gxbb_vdec_1 = {
2231 .data = &(struct clk_regmap_gate_data){
2232 .offset = HHI_VDEC_CLK_CNTL,
2235 .hw.init = &(struct clk_init_data) {
2237 .ops = &clk_regmap_gate_ops,
2238 .parent_names = (const char *[]){ "vdec_1_div" },
2240 .flags = CLK_SET_RATE_PARENT,
2244 static struct clk_regmap gxbb_vdec_hevc_sel = {
2245 .data = &(struct clk_regmap_mux_data){
2246 .offset = HHI_VDEC2_CLK_CNTL,
2249 .flags = CLK_MUX_ROUND_CLOSEST,
2251 .hw.init = &(struct clk_init_data){
2252 .name = "vdec_hevc_sel",
2253 .ops = &clk_regmap_mux_ops,
2254 .parent_names = gxbb_vdec_parent_names,
2255 .num_parents = ARRAY_SIZE(gxbb_vdec_parent_names),
2256 .flags = CLK_SET_RATE_PARENT,
2260 static struct clk_regmap gxbb_vdec_hevc_div = {
2261 .data = &(struct clk_regmap_div_data){
2262 .offset = HHI_VDEC2_CLK_CNTL,
2265 .flags = CLK_DIVIDER_ROUND_CLOSEST,
2267 .hw.init = &(struct clk_init_data){
2268 .name = "vdec_hevc_div",
2269 .ops = &clk_regmap_divider_ops,
2270 .parent_names = (const char *[]){ "vdec_hevc_sel" },
2272 .flags = CLK_SET_RATE_PARENT,
2276 static struct clk_regmap gxbb_vdec_hevc = {
2277 .data = &(struct clk_regmap_gate_data){
2278 .offset = HHI_VDEC2_CLK_CNTL,
2281 .hw.init = &(struct clk_init_data) {
2282 .name = "vdec_hevc",
2283 .ops = &clk_regmap_gate_ops,
2284 .parent_names = (const char *[]){ "vdec_hevc_div" },
2286 .flags = CLK_SET_RATE_PARENT,
2290 static u32 mux_table_gen_clk[] = { 0, 4, 5, 6, 7, 8,
2291 9, 10, 11, 13, 14, };
2292 static const char * const gen_clk_parent_names[] = {
2293 IN_PREFIX "xtal", "vdec_1", "vdec_hevc", "mpll0", "mpll1", "mpll2",
2294 "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7", "gp0_pll",
2297 static struct clk_regmap gxbb_gen_clk_sel = {
2298 .data = &(struct clk_regmap_mux_data){
2299 .offset = HHI_GEN_CLK_CNTL,
2302 .table = mux_table_gen_clk,
2304 .hw.init = &(struct clk_init_data){
2305 .name = "gen_clk_sel",
2306 .ops = &clk_regmap_mux_ops,
2308 * bits 15:12 selects from 14 possible parents:
2309 * xtal, [rtc_oscin_i], [sys_cpu_div16], [ddr_dpll_pt],
2310 * vid_pll, vid2_pll (hevc), mpll0, mpll1, mpll2, fdiv4,
2311 * fdiv3, fdiv5, [cts_msr_clk], fdiv7, gp0_pll
2313 .parent_names = gen_clk_parent_names,
2314 .num_parents = ARRAY_SIZE(gen_clk_parent_names),
2318 static struct clk_regmap gxbb_gen_clk_div = {
2319 .data = &(struct clk_regmap_div_data){
2320 .offset = HHI_GEN_CLK_CNTL,
2324 .hw.init = &(struct clk_init_data){
2325 .name = "gen_clk_div",
2326 .ops = &clk_regmap_divider_ops,
2327 .parent_names = (const char *[]){ "gen_clk_sel" },
2329 .flags = CLK_SET_RATE_PARENT,
2333 static struct clk_regmap gxbb_gen_clk = {
2334 .data = &(struct clk_regmap_gate_data){
2335 .offset = HHI_GEN_CLK_CNTL,
2338 .hw.init = &(struct clk_init_data){
2340 .ops = &clk_regmap_gate_ops,
2341 .parent_names = (const char *[]){ "gen_clk_div" },
2343 .flags = CLK_SET_RATE_PARENT,
2347 /* Everything Else (EE) domain gates */
2348 static MESON_GATE(gxbb_ddr, HHI_GCLK_MPEG0, 0);
2349 static MESON_GATE(gxbb_dos, HHI_GCLK_MPEG0, 1);
2350 static MESON_GATE(gxbb_isa, HHI_GCLK_MPEG0, 5);
2351 static MESON_GATE(gxbb_pl301, HHI_GCLK_MPEG0, 6);
2352 static MESON_GATE(gxbb_periphs, HHI_GCLK_MPEG0, 7);
2353 static MESON_GATE(gxbb_spicc, HHI_GCLK_MPEG0, 8);
2354 static MESON_GATE(gxbb_i2c, HHI_GCLK_MPEG0, 9);
2355 static MESON_GATE(gxbb_sana, HHI_GCLK_MPEG0, 10);
2356 static MESON_GATE(gxbb_smart_card, HHI_GCLK_MPEG0, 11);
2357 static MESON_GATE(gxbb_rng0, HHI_GCLK_MPEG0, 12);
2358 static MESON_GATE(gxbb_uart0, HHI_GCLK_MPEG0, 13);
2359 static MESON_GATE(gxbb_sdhc, HHI_GCLK_MPEG0, 14);
2360 static MESON_GATE(gxbb_stream, HHI_GCLK_MPEG0, 15);
2361 static MESON_GATE(gxbb_async_fifo, HHI_GCLK_MPEG0, 16);
2362 static MESON_GATE(gxbb_sdio, HHI_GCLK_MPEG0, 17);
2363 static MESON_GATE(gxbb_abuf, HHI_GCLK_MPEG0, 18);
2364 static MESON_GATE(gxbb_hiu_iface, HHI_GCLK_MPEG0, 19);
2365 static MESON_GATE(gxbb_assist_misc, HHI_GCLK_MPEG0, 23);
2366 static MESON_GATE(gxbb_emmc_a, HHI_GCLK_MPEG0, 24);
2367 static MESON_GATE(gxbb_emmc_b, HHI_GCLK_MPEG0, 25);
2368 static MESON_GATE(gxbb_emmc_c, HHI_GCLK_MPEG0, 26);
2369 static MESON_GATE(gxbb_spi, HHI_GCLK_MPEG0, 30);
2371 static MESON_GATE(gxbb_i2s_spdif, HHI_GCLK_MPEG1, 2);
2372 static MESON_GATE(gxbb_eth, HHI_GCLK_MPEG1, 3);
2373 static MESON_GATE(gxbb_demux, HHI_GCLK_MPEG1, 4);
2374 static MESON_GATE(gxbb_aiu_glue, HHI_GCLK_MPEG1, 6);
2375 static MESON_GATE(gxbb_iec958, HHI_GCLK_MPEG1, 7);
2376 static MESON_GATE(gxbb_i2s_out, HHI_GCLK_MPEG1, 8);
2377 static MESON_GATE(gxbb_amclk, HHI_GCLK_MPEG1, 9);
2378 static MESON_GATE(gxbb_aififo2, HHI_GCLK_MPEG1, 10);
2379 static MESON_GATE(gxbb_mixer, HHI_GCLK_MPEG1, 11);
2380 static MESON_GATE(gxbb_mixer_iface, HHI_GCLK_MPEG1, 12);
2381 static MESON_GATE(gxbb_adc, HHI_GCLK_MPEG1, 13);
2382 static MESON_GATE(gxbb_blkmv, HHI_GCLK_MPEG1, 14);
2383 static MESON_GATE(gxbb_aiu, HHI_GCLK_MPEG1, 15);
2384 static MESON_GATE(gxbb_uart1, HHI_GCLK_MPEG1, 16);
2385 static MESON_GATE(gxbb_g2d, HHI_GCLK_MPEG1, 20);
2386 static MESON_GATE(gxbb_usb0, HHI_GCLK_MPEG1, 21);
2387 static MESON_GATE(gxbb_usb1, HHI_GCLK_MPEG1, 22);
2388 static MESON_GATE(gxbb_reset, HHI_GCLK_MPEG1, 23);
2389 static MESON_GATE(gxbb_nand, HHI_GCLK_MPEG1, 24);
2390 static MESON_GATE(gxbb_dos_parser, HHI_GCLK_MPEG1, 25);
2391 static MESON_GATE(gxbb_usb, HHI_GCLK_MPEG1, 26);
2392 static MESON_GATE(gxbb_vdin1, HHI_GCLK_MPEG1, 28);
2393 static MESON_GATE(gxbb_ahb_arb0, HHI_GCLK_MPEG1, 29);
2394 static MESON_GATE(gxbb_efuse, HHI_GCLK_MPEG1, 30);
2395 static MESON_GATE(gxbb_boot_rom, HHI_GCLK_MPEG1, 31);
2397 static MESON_GATE(gxbb_ahb_data_bus, HHI_GCLK_MPEG2, 1);
2398 static MESON_GATE(gxbb_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2);
2399 static MESON_GATE(gxbb_hdmi_intr_sync, HHI_GCLK_MPEG2, 3);
2400 static MESON_GATE(gxbb_hdmi_pclk, HHI_GCLK_MPEG2, 4);
2401 static MESON_GATE(gxbb_usb1_ddr_bridge, HHI_GCLK_MPEG2, 8);
2402 static MESON_GATE(gxbb_usb0_ddr_bridge, HHI_GCLK_MPEG2, 9);
2403 static MESON_GATE(gxbb_mmc_pclk, HHI_GCLK_MPEG2, 11);
2404 static MESON_GATE(gxbb_dvin, HHI_GCLK_MPEG2, 12);
2405 static MESON_GATE(gxbb_uart2, HHI_GCLK_MPEG2, 15);
2406 static MESON_GATE(gxbb_sar_adc, HHI_GCLK_MPEG2, 22);
2407 static MESON_GATE(gxbb_vpu_intr, HHI_GCLK_MPEG2, 25);
2408 static MESON_GATE(gxbb_sec_ahb_ahb3_bridge, HHI_GCLK_MPEG2, 26);
2409 static MESON_GATE(gxbb_clk81_a53, HHI_GCLK_MPEG2, 29);
2411 static MESON_GATE(gxbb_vclk2_venci0, HHI_GCLK_OTHER, 1);
2412 static MESON_GATE(gxbb_vclk2_venci1, HHI_GCLK_OTHER, 2);
2413 static MESON_GATE(gxbb_vclk2_vencp0, HHI_GCLK_OTHER, 3);
2414 static MESON_GATE(gxbb_vclk2_vencp1, HHI_GCLK_OTHER, 4);
2415 static MESON_GATE(gxbb_gclk_venci_int0, HHI_GCLK_OTHER, 8);
2416 static MESON_GATE(gxbb_gclk_vencp_int, HHI_GCLK_OTHER, 9);
2417 static MESON_GATE(gxbb_dac_clk, HHI_GCLK_OTHER, 10);
2418 static MESON_GATE(gxbb_aoclk_gate, HHI_GCLK_OTHER, 14);
2419 static MESON_GATE(gxbb_iec958_gate, HHI_GCLK_OTHER, 16);
2420 static MESON_GATE(gxbb_enc480p, HHI_GCLK_OTHER, 20);
2421 static MESON_GATE(gxbb_rng1, HHI_GCLK_OTHER, 21);
2422 static MESON_GATE(gxbb_gclk_venci_int1, HHI_GCLK_OTHER, 22);
2423 static MESON_GATE(gxbb_vclk2_venclmcc, HHI_GCLK_OTHER, 24);
2424 static MESON_GATE(gxbb_vclk2_vencl, HHI_GCLK_OTHER, 25);
2425 static MESON_GATE(gxbb_vclk_other, HHI_GCLK_OTHER, 26);
2426 static MESON_GATE(gxbb_edp, HHI_GCLK_OTHER, 31);
2428 /* Always On (AO) domain gates */
2430 static MESON_GATE(gxbb_ao_media_cpu, HHI_GCLK_AO, 0);
2431 static MESON_GATE(gxbb_ao_ahb_sram, HHI_GCLK_AO, 1);
2432 static MESON_GATE(gxbb_ao_ahb_bus, HHI_GCLK_AO, 2);
2433 static MESON_GATE(gxbb_ao_iface, HHI_GCLK_AO, 3);
2434 static MESON_GATE(gxbb_ao_i2c, HHI_GCLK_AO, 4);
2436 /* Array of all clocks provided by this provider */
2438 static struct clk_hw_onecell_data gxbb_hw_onecell_data = {
2440 [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
2441 [CLKID_HDMI_PLL] = &gxbb_hdmi_pll.hw,
2442 [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
2443 [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
2444 [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
2445 [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
2446 [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
2447 [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
2448 [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
2449 [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
2450 [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
2451 [CLKID_CLK81] = &gxbb_clk81.hw,
2452 [CLKID_MPLL0] = &gxbb_mpll0.hw,
2453 [CLKID_MPLL1] = &gxbb_mpll1.hw,
2454 [CLKID_MPLL2] = &gxbb_mpll2.hw,
2455 [CLKID_DDR] = &gxbb_ddr.hw,
2456 [CLKID_DOS] = &gxbb_dos.hw,
2457 [CLKID_ISA] = &gxbb_isa.hw,
2458 [CLKID_PL301] = &gxbb_pl301.hw,
2459 [CLKID_PERIPHS] = &gxbb_periphs.hw,
2460 [CLKID_SPICC] = &gxbb_spicc.hw,
2461 [CLKID_I2C] = &gxbb_i2c.hw,
2462 [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
2463 [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
2464 [CLKID_RNG0] = &gxbb_rng0.hw,
2465 [CLKID_UART0] = &gxbb_uart0.hw,
2466 [CLKID_SDHC] = &gxbb_sdhc.hw,
2467 [CLKID_STREAM] = &gxbb_stream.hw,
2468 [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
2469 [CLKID_SDIO] = &gxbb_sdio.hw,
2470 [CLKID_ABUF] = &gxbb_abuf.hw,
2471 [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
2472 [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
2473 [CLKID_SPI] = &gxbb_spi.hw,
2474 [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
2475 [CLKID_ETH] = &gxbb_eth.hw,
2476 [CLKID_DEMUX] = &gxbb_demux.hw,
2477 [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
2478 [CLKID_IEC958] = &gxbb_iec958.hw,
2479 [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
2480 [CLKID_AMCLK] = &gxbb_amclk.hw,
2481 [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
2482 [CLKID_MIXER] = &gxbb_mixer.hw,
2483 [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
2484 [CLKID_ADC] = &gxbb_adc.hw,
2485 [CLKID_BLKMV] = &gxbb_blkmv.hw,
2486 [CLKID_AIU] = &gxbb_aiu.hw,
2487 [CLKID_UART1] = &gxbb_uart1.hw,
2488 [CLKID_G2D] = &gxbb_g2d.hw,
2489 [CLKID_USB0] = &gxbb_usb0.hw,
2490 [CLKID_USB1] = &gxbb_usb1.hw,
2491 [CLKID_RESET] = &gxbb_reset.hw,
2492 [CLKID_NAND] = &gxbb_nand.hw,
2493 [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
2494 [CLKID_USB] = &gxbb_usb.hw,
2495 [CLKID_VDIN1] = &gxbb_vdin1.hw,
2496 [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
2497 [CLKID_EFUSE] = &gxbb_efuse.hw,
2498 [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
2499 [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
2500 [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
2501 [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
2502 [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
2503 [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
2504 [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
2505 [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
2506 [CLKID_DVIN] = &gxbb_dvin.hw,
2507 [CLKID_UART2] = &gxbb_uart2.hw,
2508 [CLKID_SANA] = &gxbb_sana.hw,
2509 [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
2510 [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
2511 [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
2512 [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
2513 [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
2514 [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
2515 [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
2516 [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
2517 [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
2518 [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
2519 [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
2520 [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
2521 [CLKID_ENC480P] = &gxbb_enc480p.hw,
2522 [CLKID_RNG1] = &gxbb_rng1.hw,
2523 [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
2524 [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
2525 [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
2526 [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
2527 [CLKID_EDP] = &gxbb_edp.hw,
2528 [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
2529 [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
2530 [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
2531 [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
2532 [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
2533 [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
2534 [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
2535 [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
2536 [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
2537 [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
2538 [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
2539 [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
2540 [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
2541 [CLKID_MALI_0] = &gxbb_mali_0.hw,
2542 [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
2543 [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
2544 [CLKID_MALI_1] = &gxbb_mali_1.hw,
2545 [CLKID_MALI] = &gxbb_mali.hw,
2546 [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
2547 [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
2548 [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
2549 [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
2550 [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
2551 [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
2552 [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
2553 [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
2554 [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
2555 [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
2556 [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
2557 [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
2558 [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
2559 [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
2560 [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
2561 [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
2562 [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
2563 [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
2564 [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
2565 [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
2566 [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
2567 [CLKID_VPU_0] = &gxbb_vpu_0.hw,
2568 [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
2569 [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
2570 [CLKID_VPU_1] = &gxbb_vpu_1.hw,
2571 [CLKID_VPU] = &gxbb_vpu.hw,
2572 [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
2573 [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
2574 [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
2575 [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
2576 [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
2577 [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
2578 [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
2579 [CLKID_VAPB] = &gxbb_vapb.hw,
2580 [CLKID_HDMI_PLL_PRE_MULT] = &gxbb_hdmi_pll_pre_mult.hw,
2581 [CLKID_MPLL0_DIV] = &gxbb_mpll0_div.hw,
2582 [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
2583 [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
2584 [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
2585 [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
2586 [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
2587 [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
2588 [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
2589 [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
2590 [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
2591 [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
2592 [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
2593 [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
2594 [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
2595 [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
2596 [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
2597 [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
2598 [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
2599 [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
2600 [CLKID_HDMI_PLL_DCO] = &gxbb_hdmi_pll_dco.hw,
2601 [CLKID_HDMI_PLL_OD] = &gxbb_hdmi_pll_od.hw,
2602 [CLKID_HDMI_PLL_OD2] = &gxbb_hdmi_pll_od2.hw,
2603 [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
2604 [CLKID_GP0_PLL_DCO] = &gxbb_gp0_pll_dco.hw,
2605 [CLKID_VID_PLL_DIV] = &gxbb_vid_pll_div.hw,
2606 [CLKID_VID_PLL_SEL] = &gxbb_vid_pll_sel.hw,
2607 [CLKID_VID_PLL] = &gxbb_vid_pll.hw,
2608 [CLKID_VCLK_SEL] = &gxbb_vclk_sel.hw,
2609 [CLKID_VCLK2_SEL] = &gxbb_vclk2_sel.hw,
2610 [CLKID_VCLK_INPUT] = &gxbb_vclk_input.hw,
2611 [CLKID_VCLK2_INPUT] = &gxbb_vclk2_input.hw,
2612 [CLKID_VCLK_DIV] = &gxbb_vclk_div.hw,
2613 [CLKID_VCLK2_DIV] = &gxbb_vclk2_div.hw,
2614 [CLKID_VCLK] = &gxbb_vclk.hw,
2615 [CLKID_VCLK2] = &gxbb_vclk2.hw,
2616 [CLKID_VCLK_DIV1] = &gxbb_vclk_div1.hw,
2617 [CLKID_VCLK_DIV2_EN] = &gxbb_vclk_div2_en.hw,
2618 [CLKID_VCLK_DIV2] = &gxbb_vclk_div2.hw,
2619 [CLKID_VCLK_DIV4_EN] = &gxbb_vclk_div4_en.hw,
2620 [CLKID_VCLK_DIV4] = &gxbb_vclk_div4.hw,
2621 [CLKID_VCLK_DIV6_EN] = &gxbb_vclk_div6_en.hw,
2622 [CLKID_VCLK_DIV6] = &gxbb_vclk_div6.hw,
2623 [CLKID_VCLK_DIV12_EN] = &gxbb_vclk_div12_en.hw,
2624 [CLKID_VCLK_DIV12] = &gxbb_vclk_div12.hw,
2625 [CLKID_VCLK2_DIV1] = &gxbb_vclk2_div1.hw,
2626 [CLKID_VCLK2_DIV2_EN] = &gxbb_vclk2_div2_en.hw,
2627 [CLKID_VCLK2_DIV2] = &gxbb_vclk2_div2.hw,
2628 [CLKID_VCLK2_DIV4_EN] = &gxbb_vclk2_div4_en.hw,
2629 [CLKID_VCLK2_DIV4] = &gxbb_vclk2_div4.hw,
2630 [CLKID_VCLK2_DIV6_EN] = &gxbb_vclk2_div6_en.hw,
2631 [CLKID_VCLK2_DIV6] = &gxbb_vclk2_div6.hw,
2632 [CLKID_VCLK2_DIV12_EN] = &gxbb_vclk2_div12_en.hw,
2633 [CLKID_VCLK2_DIV12] = &gxbb_vclk2_div12.hw,
2634 [CLKID_CTS_ENCI_SEL] = &gxbb_cts_enci_sel.hw,
2635 [CLKID_CTS_ENCP_SEL] = &gxbb_cts_encp_sel.hw,
2636 [CLKID_CTS_VDAC_SEL] = &gxbb_cts_vdac_sel.hw,
2637 [CLKID_HDMI_TX_SEL] = &gxbb_hdmi_tx_sel.hw,
2638 [CLKID_CTS_ENCI] = &gxbb_cts_enci.hw,
2639 [CLKID_CTS_ENCP] = &gxbb_cts_encp.hw,
2640 [CLKID_CTS_VDAC] = &gxbb_cts_vdac.hw,
2641 [CLKID_HDMI_TX] = &gxbb_hdmi_tx.hw,
2642 [CLKID_HDMI_SEL] = &gxbb_hdmi_sel.hw,
2643 [CLKID_HDMI_DIV] = &gxbb_hdmi_div.hw,
2644 [CLKID_HDMI] = &gxbb_hdmi.hw,
2650 static struct clk_hw_onecell_data gxl_hw_onecell_data = {
2652 [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
2653 [CLKID_HDMI_PLL] = &gxl_hdmi_pll.hw,
2654 [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
2655 [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
2656 [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
2657 [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
2658 [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
2659 [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
2660 [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
2661 [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
2662 [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
2663 [CLKID_CLK81] = &gxbb_clk81.hw,
2664 [CLKID_MPLL0] = &gxbb_mpll0.hw,
2665 [CLKID_MPLL1] = &gxbb_mpll1.hw,
2666 [CLKID_MPLL2] = &gxbb_mpll2.hw,
2667 [CLKID_DDR] = &gxbb_ddr.hw,
2668 [CLKID_DOS] = &gxbb_dos.hw,
2669 [CLKID_ISA] = &gxbb_isa.hw,
2670 [CLKID_PL301] = &gxbb_pl301.hw,
2671 [CLKID_PERIPHS] = &gxbb_periphs.hw,
2672 [CLKID_SPICC] = &gxbb_spicc.hw,
2673 [CLKID_I2C] = &gxbb_i2c.hw,
2674 [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
2675 [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
2676 [CLKID_RNG0] = &gxbb_rng0.hw,
2677 [CLKID_UART0] = &gxbb_uart0.hw,
2678 [CLKID_SDHC] = &gxbb_sdhc.hw,
2679 [CLKID_STREAM] = &gxbb_stream.hw,
2680 [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
2681 [CLKID_SDIO] = &gxbb_sdio.hw,
2682 [CLKID_ABUF] = &gxbb_abuf.hw,
2683 [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
2684 [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
2685 [CLKID_SPI] = &gxbb_spi.hw,
2686 [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
2687 [CLKID_ETH] = &gxbb_eth.hw,
2688 [CLKID_DEMUX] = &gxbb_demux.hw,
2689 [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
2690 [CLKID_IEC958] = &gxbb_iec958.hw,
2691 [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
2692 [CLKID_AMCLK] = &gxbb_amclk.hw,
2693 [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
2694 [CLKID_MIXER] = &gxbb_mixer.hw,
2695 [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
2696 [CLKID_ADC] = &gxbb_adc.hw,
2697 [CLKID_BLKMV] = &gxbb_blkmv.hw,
2698 [CLKID_AIU] = &gxbb_aiu.hw,
2699 [CLKID_UART1] = &gxbb_uart1.hw,
2700 [CLKID_G2D] = &gxbb_g2d.hw,
2701 [CLKID_USB0] = &gxbb_usb0.hw,
2702 [CLKID_USB1] = &gxbb_usb1.hw,
2703 [CLKID_RESET] = &gxbb_reset.hw,
2704 [CLKID_NAND] = &gxbb_nand.hw,
2705 [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
2706 [CLKID_USB] = &gxbb_usb.hw,
2707 [CLKID_VDIN1] = &gxbb_vdin1.hw,
2708 [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
2709 [CLKID_EFUSE] = &gxbb_efuse.hw,
2710 [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
2711 [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
2712 [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
2713 [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
2714 [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
2715 [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
2716 [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
2717 [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
2718 [CLKID_DVIN] = &gxbb_dvin.hw,
2719 [CLKID_UART2] = &gxbb_uart2.hw,
2720 [CLKID_SANA] = &gxbb_sana.hw,
2721 [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
2722 [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
2723 [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
2724 [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
2725 [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
2726 [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
2727 [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
2728 [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
2729 [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
2730 [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
2731 [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
2732 [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
2733 [CLKID_ENC480P] = &gxbb_enc480p.hw,
2734 [CLKID_RNG1] = &gxbb_rng1.hw,
2735 [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
2736 [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
2737 [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
2738 [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
2739 [CLKID_EDP] = &gxbb_edp.hw,
2740 [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
2741 [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
2742 [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
2743 [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
2744 [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
2745 [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
2746 [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
2747 [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
2748 [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
2749 [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
2750 [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
2751 [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
2752 [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
2753 [CLKID_MALI_0] = &gxbb_mali_0.hw,
2754 [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
2755 [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
2756 [CLKID_MALI_1] = &gxbb_mali_1.hw,
2757 [CLKID_MALI] = &gxbb_mali.hw,
2758 [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
2759 [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
2760 [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
2761 [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
2762 [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
2763 [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
2764 [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
2765 [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
2766 [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
2767 [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
2768 [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
2769 [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
2770 [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
2771 [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
2772 [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
2773 [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
2774 [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
2775 [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
2776 [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
2777 [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
2778 [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
2779 [CLKID_VPU_0] = &gxbb_vpu_0.hw,
2780 [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
2781 [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
2782 [CLKID_VPU_1] = &gxbb_vpu_1.hw,
2783 [CLKID_VPU] = &gxbb_vpu.hw,
2784 [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
2785 [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
2786 [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
2787 [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
2788 [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
2789 [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
2790 [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
2791 [CLKID_VAPB] = &gxbb_vapb.hw,
2792 [CLKID_MPLL0_DIV] = &gxbb_mpll0_div.hw,
2793 [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
2794 [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
2795 [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
2796 [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
2797 [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
2798 [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
2799 [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
2800 [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
2801 [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
2802 [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
2803 [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
2804 [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
2805 [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
2806 [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
2807 [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
2808 [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
2809 [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
2810 [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
2811 [CLKID_HDMI_PLL_DCO] = &gxl_hdmi_pll_dco.hw,
2812 [CLKID_HDMI_PLL_OD] = &gxl_hdmi_pll_od.hw,
2813 [CLKID_HDMI_PLL_OD2] = &gxl_hdmi_pll_od2.hw,
2814 [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
2815 [CLKID_GP0_PLL_DCO] = &gxl_gp0_pll_dco.hw,
2816 [CLKID_VID_PLL_DIV] = &gxbb_vid_pll_div.hw,
2817 [CLKID_VID_PLL_SEL] = &gxbb_vid_pll_sel.hw,
2818 [CLKID_VID_PLL] = &gxbb_vid_pll.hw,
2819 [CLKID_VCLK_SEL] = &gxbb_vclk_sel.hw,
2820 [CLKID_VCLK2_SEL] = &gxbb_vclk2_sel.hw,
2821 [CLKID_VCLK_INPUT] = &gxbb_vclk_input.hw,
2822 [CLKID_VCLK2_INPUT] = &gxbb_vclk2_input.hw,
2823 [CLKID_VCLK_DIV] = &gxbb_vclk_div.hw,
2824 [CLKID_VCLK2_DIV] = &gxbb_vclk2_div.hw,
2825 [CLKID_VCLK] = &gxbb_vclk.hw,
2826 [CLKID_VCLK2] = &gxbb_vclk2.hw,
2827 [CLKID_VCLK_DIV1] = &gxbb_vclk_div1.hw,
2828 [CLKID_VCLK_DIV2_EN] = &gxbb_vclk_div2_en.hw,
2829 [CLKID_VCLK_DIV2] = &gxbb_vclk_div2.hw,
2830 [CLKID_VCLK_DIV4_EN] = &gxbb_vclk_div4_en.hw,
2831 [CLKID_VCLK_DIV4] = &gxbb_vclk_div4.hw,
2832 [CLKID_VCLK_DIV6_EN] = &gxbb_vclk_div6_en.hw,
2833 [CLKID_VCLK_DIV6] = &gxbb_vclk_div6.hw,
2834 [CLKID_VCLK_DIV12_EN] = &gxbb_vclk_div12_en.hw,
2835 [CLKID_VCLK_DIV12] = &gxbb_vclk_div12.hw,
2836 [CLKID_VCLK2_DIV1] = &gxbb_vclk2_div1.hw,
2837 [CLKID_VCLK2_DIV2_EN] = &gxbb_vclk2_div2_en.hw,
2838 [CLKID_VCLK2_DIV2] = &gxbb_vclk2_div2.hw,
2839 [CLKID_VCLK2_DIV4_EN] = &gxbb_vclk2_div4_en.hw,
2840 [CLKID_VCLK2_DIV4] = &gxbb_vclk2_div4.hw,
2841 [CLKID_VCLK2_DIV6_EN] = &gxbb_vclk2_div6_en.hw,
2842 [CLKID_VCLK2_DIV6] = &gxbb_vclk2_div6.hw,
2843 [CLKID_VCLK2_DIV12_EN] = &gxbb_vclk2_div12_en.hw,
2844 [CLKID_VCLK2_DIV12] = &gxbb_vclk2_div12.hw,
2845 [CLKID_CTS_ENCI_SEL] = &gxbb_cts_enci_sel.hw,
2846 [CLKID_CTS_ENCP_SEL] = &gxbb_cts_encp_sel.hw,
2847 [CLKID_CTS_VDAC_SEL] = &gxbb_cts_vdac_sel.hw,
2848 [CLKID_HDMI_TX_SEL] = &gxbb_hdmi_tx_sel.hw,
2849 [CLKID_CTS_ENCI] = &gxbb_cts_enci.hw,
2850 [CLKID_CTS_ENCP] = &gxbb_cts_encp.hw,
2851 [CLKID_CTS_VDAC] = &gxbb_cts_vdac.hw,
2852 [CLKID_HDMI_TX] = &gxbb_hdmi_tx.hw,
2853 [CLKID_HDMI_SEL] = &gxbb_hdmi_sel.hw,
2854 [CLKID_HDMI_DIV] = &gxbb_hdmi_div.hw,
2855 [CLKID_HDMI] = &gxbb_hdmi.hw,
2861 static struct clk_regmap *const gxbb_clk_regmaps[] = {
2909 &gxbb_hdmi_intr_sync,
2911 &gxbb_usb1_ddr_bridge,
2912 &gxbb_usb0_ddr_bridge,
2918 &gxbb_sec_ahb_ahb3_bridge,
2924 &gxbb_gclk_venci_int0,
2925 &gxbb_gclk_vencp_int,
2931 &gxbb_gclk_venci_int1,
2932 &gxbb_vclk2_venclmcc,
2948 &gxbb_cts_mclk_i958,
2950 &gxbb_sd_emmc_a_clk0,
2951 &gxbb_sd_emmc_b_clk0,
2952 &gxbb_sd_emmc_c_clk0,
2959 &gxbb_sar_adc_clk_div,
2962 &gxbb_cts_mclk_i958_div,
2964 &gxbb_sd_emmc_a_clk0_div,
2965 &gxbb_sd_emmc_b_clk0_div,
2966 &gxbb_sd_emmc_c_clk0_div,
2972 &gxbb_sar_adc_clk_sel,
2976 &gxbb_cts_amclk_sel,
2977 &gxbb_cts_mclk_i958_sel,
2980 &gxbb_sd_emmc_a_clk0_sel,
2981 &gxbb_sd_emmc_b_clk0_sel,
2982 &gxbb_sd_emmc_c_clk0_sel,
2995 &gxbb_cts_amclk_div,
3007 &gxbb_vdec_hevc_sel,
3008 &gxbb_vdec_hevc_div,
3013 &gxbb_fixed_pll_dco,
3027 &gxbb_vclk_div12_en,
3033 &gxbb_vclk2_div2_en,
3034 &gxbb_vclk2_div4_en,
3035 &gxbb_vclk2_div6_en,
3036 &gxbb_vclk2_div12_en,
3055 static struct clk_regmap *const gxl_clk_regmaps[] = {
3103 &gxbb_hdmi_intr_sync,
3105 &gxbb_usb1_ddr_bridge,
3106 &gxbb_usb0_ddr_bridge,
3112 &gxbb_sec_ahb_ahb3_bridge,
3118 &gxbb_gclk_venci_int0,
3119 &gxbb_gclk_vencp_int,
3125 &gxbb_gclk_venci_int1,
3126 &gxbb_vclk2_venclmcc,
3142 &gxbb_cts_mclk_i958,
3144 &gxbb_sd_emmc_a_clk0,
3145 &gxbb_sd_emmc_b_clk0,
3146 &gxbb_sd_emmc_c_clk0,
3153 &gxbb_sar_adc_clk_div,
3156 &gxbb_cts_mclk_i958_div,
3158 &gxbb_sd_emmc_a_clk0_div,
3159 &gxbb_sd_emmc_b_clk0_div,
3160 &gxbb_sd_emmc_c_clk0_div,
3166 &gxbb_sar_adc_clk_sel,
3170 &gxbb_cts_amclk_sel,
3171 &gxbb_cts_mclk_i958_sel,
3174 &gxbb_sd_emmc_a_clk0_sel,
3175 &gxbb_sd_emmc_b_clk0_sel,
3176 &gxbb_sd_emmc_c_clk0_sel,
3189 &gxbb_cts_amclk_div,
3201 &gxbb_vdec_hevc_sel,
3202 &gxbb_vdec_hevc_div,
3207 &gxbb_fixed_pll_dco,
3221 &gxbb_vclk_div12_en,
3227 &gxbb_vclk2_div2_en,
3228 &gxbb_vclk2_div4_en,
3229 &gxbb_vclk2_div6_en,
3230 &gxbb_vclk2_div12_en,
3249 static const struct meson_eeclkc_data gxbb_clkc_data = {
3250 .regmap_clks = gxbb_clk_regmaps,
3251 .regmap_clk_num = ARRAY_SIZE(gxbb_clk_regmaps),
3252 .hw_onecell_data = &gxbb_hw_onecell_data,
3255 static const struct meson_eeclkc_data gxl_clkc_data = {
3256 .regmap_clks = gxl_clk_regmaps,
3257 .regmap_clk_num = ARRAY_SIZE(gxl_clk_regmaps),
3258 .hw_onecell_data = &gxl_hw_onecell_data,
3261 static const struct of_device_id clkc_match_table[] = {
3262 { .compatible = "amlogic,gxbb-clkc", .data = &gxbb_clkc_data },
3263 { .compatible = "amlogic,gxl-clkc", .data = &gxl_clkc_data },
3267 static struct platform_driver gxbb_driver = {
3268 .probe = meson_eeclkc_probe,
3270 .name = "gxbb-clkc",
3271 .of_match_table = clkc_match_table,
3275 builtin_platform_driver(gxbb_driver);