162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2021, The Linux Foundation. All rights reserved. 462306a36Sopenharmony_ci * Copyright (c) 2022, Linaro Ltd. 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#include <linux/clk-provider.h> 862306a36Sopenharmony_ci#include <linux/module.h> 962306a36Sopenharmony_ci#include <linux/platform_device.h> 1062306a36Sopenharmony_ci#include <linux/property.h> 1162306a36Sopenharmony_ci#include <linux/pm_clock.h> 1262306a36Sopenharmony_ci#include <linux/pm_runtime.h> 1362306a36Sopenharmony_ci#include <linux/regmap.h> 1462306a36Sopenharmony_ci#include <linux/reset-controller.h> 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#include <dt-bindings/clock/qcom,dispcc-sc8280xp.h> 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#include "clk-alpha-pll.h" 1962306a36Sopenharmony_ci#include "clk-branch.h" 2062306a36Sopenharmony_ci#include "clk-rcg.h" 2162306a36Sopenharmony_ci#include "clk-regmap-divider.h" 2262306a36Sopenharmony_ci#include "common.h" 2362306a36Sopenharmony_ci#include "gdsc.h" 2462306a36Sopenharmony_ci#include "reset.h" 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci/* Need to match the order of clocks in DT binding */ 2762306a36Sopenharmony_cienum { 2862306a36Sopenharmony_ci DT_IFACE, 2962306a36Sopenharmony_ci DT_BI_TCXO, 3062306a36Sopenharmony_ci DT_SLEEP_CLK, 3162306a36Sopenharmony_ci DT_DP0_PHY_PLL_LINK_CLK, 3262306a36Sopenharmony_ci DT_DP0_PHY_PLL_VCO_DIV_CLK, 3362306a36Sopenharmony_ci DT_DP1_PHY_PLL_LINK_CLK, 3462306a36Sopenharmony_ci DT_DP1_PHY_PLL_VCO_DIV_CLK, 3562306a36Sopenharmony_ci DT_DP2_PHY_PLL_LINK_CLK, 3662306a36Sopenharmony_ci DT_DP2_PHY_PLL_VCO_DIV_CLK, 3762306a36Sopenharmony_ci DT_DP3_PHY_PLL_LINK_CLK, 3862306a36Sopenharmony_ci DT_DP3_PHY_PLL_VCO_DIV_CLK, 3962306a36Sopenharmony_ci DT_DSI0_PHY_PLL_OUT_BYTECLK, 4062306a36Sopenharmony_ci DT_DSI0_PHY_PLL_OUT_DSICLK, 4162306a36Sopenharmony_ci DT_DSI1_PHY_PLL_OUT_BYTECLK, 4262306a36Sopenharmony_ci DT_DSI1_PHY_PLL_OUT_DSICLK, 4362306a36Sopenharmony_ci}; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cienum { 4662306a36Sopenharmony_ci P_BI_TCXO, 4762306a36Sopenharmony_ci P_DP0_PHY_PLL_LINK_CLK, 4862306a36Sopenharmony_ci P_DP0_PHY_PLL_VCO_DIV_CLK, 4962306a36Sopenharmony_ci P_DP1_PHY_PLL_LINK_CLK, 5062306a36Sopenharmony_ci P_DP1_PHY_PLL_VCO_DIV_CLK, 5162306a36Sopenharmony_ci P_DP2_PHY_PLL_LINK_CLK, 5262306a36Sopenharmony_ci P_DP2_PHY_PLL_VCO_DIV_CLK, 5362306a36Sopenharmony_ci P_DP3_PHY_PLL_LINK_CLK, 5462306a36Sopenharmony_ci P_DP3_PHY_PLL_VCO_DIV_CLK, 5562306a36Sopenharmony_ci P_DSI0_PHY_PLL_OUT_BYTECLK, 5662306a36Sopenharmony_ci P_DSI0_PHY_PLL_OUT_DSICLK, 5762306a36Sopenharmony_ci P_DSI1_PHY_PLL_OUT_BYTECLK, 5862306a36Sopenharmony_ci P_DSI1_PHY_PLL_OUT_DSICLK, 5962306a36Sopenharmony_ci P_DISPn_CC_PLL0_OUT_MAIN, 6062306a36Sopenharmony_ci P_DISPn_CC_PLL1_OUT_EVEN, 6162306a36Sopenharmony_ci P_DISPn_CC_PLL1_OUT_MAIN, 6262306a36Sopenharmony_ci P_DISPn_CC_PLL2_OUT_MAIN, 6362306a36Sopenharmony_ci P_SLEEP_CLK, 6462306a36Sopenharmony_ci}; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_cistatic const struct clk_parent_data parent_data_tcxo = { .index = DT_BI_TCXO }; 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_cistatic const struct pll_vco lucid_5lpe_vco[] = { 6962306a36Sopenharmony_ci { 249600000, 1800000000, 0 }, 7062306a36Sopenharmony_ci}; 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_cistatic const struct alpha_pll_config disp_cc_pll0_config = { 7362306a36Sopenharmony_ci .l = 0x4e, 7462306a36Sopenharmony_ci .alpha = 0x2000, 7562306a36Sopenharmony_ci .config_ctl_val = 0x20485699, 7662306a36Sopenharmony_ci .config_ctl_hi_val = 0x00002261, 7762306a36Sopenharmony_ci .config_ctl_hi1_val = 0x2a9a699c, 7862306a36Sopenharmony_ci .test_ctl_val = 0x00000000, 7962306a36Sopenharmony_ci .test_ctl_hi_val = 0x00000000, 8062306a36Sopenharmony_ci .test_ctl_hi1_val = 0x01800000, 8162306a36Sopenharmony_ci .user_ctl_val = 0x00000000, 8262306a36Sopenharmony_ci .user_ctl_hi_val = 0x00000805, 8362306a36Sopenharmony_ci .user_ctl_hi1_val = 0x00000000, 8462306a36Sopenharmony_ci}; 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_cistatic struct clk_alpha_pll disp0_cc_pll0 = { 8762306a36Sopenharmony_ci .offset = 0x0, 8862306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 8962306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 9062306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 9162306a36Sopenharmony_ci .clkr = { 9262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 9362306a36Sopenharmony_ci .name = "disp0_cc_pll0", 9462306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 9562306a36Sopenharmony_ci .num_parents = 1, 9662306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 9762306a36Sopenharmony_ci }, 9862306a36Sopenharmony_ci }, 9962306a36Sopenharmony_ci}; 10062306a36Sopenharmony_ci 10162306a36Sopenharmony_cistatic struct clk_alpha_pll disp1_cc_pll0 = { 10262306a36Sopenharmony_ci .offset = 0x0, 10362306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 10462306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 10562306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 10662306a36Sopenharmony_ci .clkr = { 10762306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 10862306a36Sopenharmony_ci .name = "disp1_cc_pll0", 10962306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 11062306a36Sopenharmony_ci .num_parents = 1, 11162306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 11262306a36Sopenharmony_ci }, 11362306a36Sopenharmony_ci }, 11462306a36Sopenharmony_ci}; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_cistatic const struct alpha_pll_config disp_cc_pll1_config = { 11762306a36Sopenharmony_ci .l = 0x1f, 11862306a36Sopenharmony_ci .alpha = 0x4000, 11962306a36Sopenharmony_ci .config_ctl_val = 0x20485699, 12062306a36Sopenharmony_ci .config_ctl_hi_val = 0x00002261, 12162306a36Sopenharmony_ci .config_ctl_hi1_val = 0x2a9a699c, 12262306a36Sopenharmony_ci .test_ctl_val = 0x00000000, 12362306a36Sopenharmony_ci .test_ctl_hi_val = 0x00000000, 12462306a36Sopenharmony_ci .test_ctl_hi1_val = 0x01800000, 12562306a36Sopenharmony_ci .user_ctl_val = 0x00000100, 12662306a36Sopenharmony_ci .user_ctl_hi_val = 0x00000805, 12762306a36Sopenharmony_ci .user_ctl_hi1_val = 0x00000000, 12862306a36Sopenharmony_ci}; 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_cistatic struct clk_alpha_pll disp0_cc_pll1 = { 13162306a36Sopenharmony_ci .offset = 0x1000, 13262306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 13362306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 13462306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 13562306a36Sopenharmony_ci .clkr = { 13662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 13762306a36Sopenharmony_ci .name = "disp0_cc_pll1", 13862306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 13962306a36Sopenharmony_ci .num_parents = 1, 14062306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 14162306a36Sopenharmony_ci }, 14262306a36Sopenharmony_ci }, 14362306a36Sopenharmony_ci}; 14462306a36Sopenharmony_ci 14562306a36Sopenharmony_cistatic struct clk_alpha_pll disp1_cc_pll1 = { 14662306a36Sopenharmony_ci .offset = 0x1000, 14762306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 14862306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 14962306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 15062306a36Sopenharmony_ci .clkr = { 15162306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 15262306a36Sopenharmony_ci .name = "disp1_cc_pll1", 15362306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 15462306a36Sopenharmony_ci .num_parents = 1, 15562306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 15662306a36Sopenharmony_ci }, 15762306a36Sopenharmony_ci }, 15862306a36Sopenharmony_ci}; 15962306a36Sopenharmony_ci 16062306a36Sopenharmony_cistatic const struct clk_div_table post_div_table_disp_cc_pll1_out_even[] = { 16162306a36Sopenharmony_ci { 0x1, 2 }, 16262306a36Sopenharmony_ci { } 16362306a36Sopenharmony_ci}; 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_cistatic struct clk_alpha_pll_postdiv disp0_cc_pll1_out_even = { 16662306a36Sopenharmony_ci .offset = 0x1000, 16762306a36Sopenharmony_ci .post_div_shift = 8, 16862306a36Sopenharmony_ci .post_div_table = post_div_table_disp_cc_pll1_out_even, 16962306a36Sopenharmony_ci .num_post_div = ARRAY_SIZE(post_div_table_disp_cc_pll1_out_even), 17062306a36Sopenharmony_ci .width = 4, 17162306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 17262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 17362306a36Sopenharmony_ci .name = "disp0_cc_pll1_out_even", 17462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 17562306a36Sopenharmony_ci &disp0_cc_pll1.clkr.hw, 17662306a36Sopenharmony_ci }, 17762306a36Sopenharmony_ci .num_parents = 1, 17862306a36Sopenharmony_ci .ops = &clk_alpha_pll_postdiv_lucid_5lpe_ops, 17962306a36Sopenharmony_ci }, 18062306a36Sopenharmony_ci}; 18162306a36Sopenharmony_ci 18262306a36Sopenharmony_cistatic struct clk_alpha_pll_postdiv disp1_cc_pll1_out_even = { 18362306a36Sopenharmony_ci .offset = 0x1000, 18462306a36Sopenharmony_ci .post_div_shift = 8, 18562306a36Sopenharmony_ci .post_div_table = post_div_table_disp_cc_pll1_out_even, 18662306a36Sopenharmony_ci .num_post_div = ARRAY_SIZE(post_div_table_disp_cc_pll1_out_even), 18762306a36Sopenharmony_ci .width = 4, 18862306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 18962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 19062306a36Sopenharmony_ci .name = "disp1_cc_pll1_out_even", 19162306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 19262306a36Sopenharmony_ci &disp1_cc_pll1.clkr.hw, 19362306a36Sopenharmony_ci }, 19462306a36Sopenharmony_ci .num_parents = 1, 19562306a36Sopenharmony_ci .ops = &clk_alpha_pll_postdiv_lucid_5lpe_ops, 19662306a36Sopenharmony_ci }, 19762306a36Sopenharmony_ci}; 19862306a36Sopenharmony_ci 19962306a36Sopenharmony_cistatic const struct alpha_pll_config disp_cc_pll2_config = { 20062306a36Sopenharmony_ci .l = 0x46, 20162306a36Sopenharmony_ci .alpha = 0x5000, 20262306a36Sopenharmony_ci .config_ctl_val = 0x20485699, 20362306a36Sopenharmony_ci .config_ctl_hi_val = 0x00002261, 20462306a36Sopenharmony_ci .config_ctl_hi1_val = 0x2a9a699c, 20562306a36Sopenharmony_ci .test_ctl_val = 0x00000000, 20662306a36Sopenharmony_ci .test_ctl_hi_val = 0x00000000, 20762306a36Sopenharmony_ci .test_ctl_hi1_val = 0x01800000, 20862306a36Sopenharmony_ci .user_ctl_val = 0x00000000, 20962306a36Sopenharmony_ci .user_ctl_hi_val = 0x00000805, 21062306a36Sopenharmony_ci .user_ctl_hi1_val = 0x00000000, 21162306a36Sopenharmony_ci}; 21262306a36Sopenharmony_ci 21362306a36Sopenharmony_cistatic struct clk_alpha_pll disp0_cc_pll2 = { 21462306a36Sopenharmony_ci .offset = 0x9000, 21562306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 21662306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 21762306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 21862306a36Sopenharmony_ci .clkr = { 21962306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 22062306a36Sopenharmony_ci .name = "disp0_cc_pll2", 22162306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 22262306a36Sopenharmony_ci .num_parents = 1, 22362306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 22462306a36Sopenharmony_ci }, 22562306a36Sopenharmony_ci }, 22662306a36Sopenharmony_ci}; 22762306a36Sopenharmony_ci 22862306a36Sopenharmony_cistatic struct clk_alpha_pll disp1_cc_pll2 = { 22962306a36Sopenharmony_ci .offset = 0x9000, 23062306a36Sopenharmony_ci .vco_table = lucid_5lpe_vco, 23162306a36Sopenharmony_ci .num_vco = ARRAY_SIZE(lucid_5lpe_vco), 23262306a36Sopenharmony_ci .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID], 23362306a36Sopenharmony_ci .clkr = { 23462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 23562306a36Sopenharmony_ci .name = "disp1_cc_pll2", 23662306a36Sopenharmony_ci .parent_data = &parent_data_tcxo, 23762306a36Sopenharmony_ci .num_parents = 1, 23862306a36Sopenharmony_ci .ops = &clk_alpha_pll_lucid_5lpe_ops, 23962306a36Sopenharmony_ci }, 24062306a36Sopenharmony_ci }, 24162306a36Sopenharmony_ci}; 24262306a36Sopenharmony_ci 24362306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_0[] = { 24462306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 24562306a36Sopenharmony_ci { P_DP0_PHY_PLL_LINK_CLK, 1 }, 24662306a36Sopenharmony_ci { P_DP1_PHY_PLL_LINK_CLK, 2 }, 24762306a36Sopenharmony_ci { P_DP2_PHY_PLL_LINK_CLK, 3 }, 24862306a36Sopenharmony_ci { P_DP3_PHY_PLL_LINK_CLK, 4 }, 24962306a36Sopenharmony_ci { P_DISPn_CC_PLL2_OUT_MAIN, 5 }, 25062306a36Sopenharmony_ci}; 25162306a36Sopenharmony_ci 25262306a36Sopenharmony_cistatic const struct clk_parent_data disp0_cc_parent_data_0[] = { 25362306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 25462306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_LINK_CLK }, 25562306a36Sopenharmony_ci { .index = DT_DP1_PHY_PLL_LINK_CLK }, 25662306a36Sopenharmony_ci { .index = DT_DP2_PHY_PLL_LINK_CLK }, 25762306a36Sopenharmony_ci { .index = DT_DP3_PHY_PLL_LINK_CLK }, 25862306a36Sopenharmony_ci { .hw = &disp0_cc_pll2.clkr.hw }, 25962306a36Sopenharmony_ci}; 26062306a36Sopenharmony_ci 26162306a36Sopenharmony_cistatic const struct clk_parent_data disp1_cc_parent_data_0[] = { 26262306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 26362306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_LINK_CLK }, 26462306a36Sopenharmony_ci { .index = DT_DP1_PHY_PLL_LINK_CLK }, 26562306a36Sopenharmony_ci { .index = DT_DP2_PHY_PLL_LINK_CLK }, 26662306a36Sopenharmony_ci { .index = DT_DP3_PHY_PLL_LINK_CLK }, 26762306a36Sopenharmony_ci { .hw = &disp1_cc_pll2.clkr.hw }, 26862306a36Sopenharmony_ci}; 26962306a36Sopenharmony_ci 27062306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_1[] = { 27162306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 27262306a36Sopenharmony_ci { P_DP0_PHY_PLL_LINK_CLK, 1 }, 27362306a36Sopenharmony_ci { P_DP0_PHY_PLL_VCO_DIV_CLK, 2 }, 27462306a36Sopenharmony_ci { P_DP3_PHY_PLL_VCO_DIV_CLK, 3 }, 27562306a36Sopenharmony_ci { P_DP1_PHY_PLL_VCO_DIV_CLK, 4 }, 27662306a36Sopenharmony_ci { P_DISPn_CC_PLL2_OUT_MAIN, 5 }, 27762306a36Sopenharmony_ci { P_DP2_PHY_PLL_VCO_DIV_CLK, 6 }, 27862306a36Sopenharmony_ci}; 27962306a36Sopenharmony_ci 28062306a36Sopenharmony_cistatic const struct clk_parent_data disp0_cc_parent_data_1[] = { 28162306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 28262306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_LINK_CLK }, 28362306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_VCO_DIV_CLK }, 28462306a36Sopenharmony_ci { .index = DT_DP3_PHY_PLL_VCO_DIV_CLK }, 28562306a36Sopenharmony_ci { .index = DT_DP1_PHY_PLL_VCO_DIV_CLK }, 28662306a36Sopenharmony_ci { .hw = &disp0_cc_pll2.clkr.hw }, 28762306a36Sopenharmony_ci { .index = DT_DP2_PHY_PLL_VCO_DIV_CLK }, 28862306a36Sopenharmony_ci}; 28962306a36Sopenharmony_ci 29062306a36Sopenharmony_cistatic const struct clk_parent_data disp1_cc_parent_data_1[] = { 29162306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 29262306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_LINK_CLK }, 29362306a36Sopenharmony_ci { .index = DT_DP0_PHY_PLL_VCO_DIV_CLK }, 29462306a36Sopenharmony_ci { .index = DT_DP3_PHY_PLL_VCO_DIV_CLK }, 29562306a36Sopenharmony_ci { .index = DT_DP1_PHY_PLL_VCO_DIV_CLK }, 29662306a36Sopenharmony_ci { .hw = &disp1_cc_pll2.clkr.hw }, 29762306a36Sopenharmony_ci { .index = DT_DP2_PHY_PLL_VCO_DIV_CLK }, 29862306a36Sopenharmony_ci}; 29962306a36Sopenharmony_ci 30062306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_2[] = { 30162306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 30262306a36Sopenharmony_ci}; 30362306a36Sopenharmony_ci 30462306a36Sopenharmony_cistatic const struct clk_parent_data disp_cc_parent_data_2[] = { 30562306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 30662306a36Sopenharmony_ci}; 30762306a36Sopenharmony_ci 30862306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_3[] = { 30962306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 31062306a36Sopenharmony_ci { P_DSI0_PHY_PLL_OUT_DSICLK, 1 }, 31162306a36Sopenharmony_ci { P_DSI0_PHY_PLL_OUT_BYTECLK, 2 }, 31262306a36Sopenharmony_ci { P_DSI1_PHY_PLL_OUT_DSICLK, 3 }, 31362306a36Sopenharmony_ci { P_DSI1_PHY_PLL_OUT_BYTECLK, 4 }, 31462306a36Sopenharmony_ci}; 31562306a36Sopenharmony_ci 31662306a36Sopenharmony_cistatic const struct clk_parent_data disp_cc_parent_data_3[] = { 31762306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 31862306a36Sopenharmony_ci { .index = DT_DSI0_PHY_PLL_OUT_DSICLK }, 31962306a36Sopenharmony_ci { .index = DT_DSI0_PHY_PLL_OUT_BYTECLK }, 32062306a36Sopenharmony_ci { .index = DT_DSI1_PHY_PLL_OUT_DSICLK }, 32162306a36Sopenharmony_ci { .index = DT_DSI1_PHY_PLL_OUT_BYTECLK }, 32262306a36Sopenharmony_ci}; 32362306a36Sopenharmony_ci 32462306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_4[] = { 32562306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 32662306a36Sopenharmony_ci { P_DSI0_PHY_PLL_OUT_BYTECLK, 2 }, 32762306a36Sopenharmony_ci { P_DSI1_PHY_PLL_OUT_BYTECLK, 4 }, 32862306a36Sopenharmony_ci}; 32962306a36Sopenharmony_ci 33062306a36Sopenharmony_cistatic const struct clk_parent_data disp_cc_parent_data_4[] = { 33162306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 33262306a36Sopenharmony_ci { .index = DT_DSI0_PHY_PLL_OUT_BYTECLK }, 33362306a36Sopenharmony_ci { .index = DT_DSI1_PHY_PLL_OUT_BYTECLK }, 33462306a36Sopenharmony_ci}; 33562306a36Sopenharmony_ci 33662306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_5[] = { 33762306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 33862306a36Sopenharmony_ci { P_DISPn_CC_PLL0_OUT_MAIN, 1 }, 33962306a36Sopenharmony_ci { P_DISPn_CC_PLL1_OUT_MAIN, 4 }, 34062306a36Sopenharmony_ci { P_DISPn_CC_PLL2_OUT_MAIN, 5 }, 34162306a36Sopenharmony_ci { P_DISPn_CC_PLL1_OUT_EVEN, 6 }, 34262306a36Sopenharmony_ci}; 34362306a36Sopenharmony_ci 34462306a36Sopenharmony_cistatic const struct clk_parent_data disp0_cc_parent_data_5[] = { 34562306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 34662306a36Sopenharmony_ci { .hw = &disp0_cc_pll0.clkr.hw }, 34762306a36Sopenharmony_ci { .hw = &disp0_cc_pll1.clkr.hw }, 34862306a36Sopenharmony_ci { .hw = &disp0_cc_pll2.clkr.hw }, 34962306a36Sopenharmony_ci { .hw = &disp0_cc_pll1_out_even.clkr.hw }, 35062306a36Sopenharmony_ci}; 35162306a36Sopenharmony_ci 35262306a36Sopenharmony_cistatic const struct clk_parent_data disp1_cc_parent_data_5[] = { 35362306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 35462306a36Sopenharmony_ci { .hw = &disp1_cc_pll0.clkr.hw }, 35562306a36Sopenharmony_ci { .hw = &disp1_cc_pll1.clkr.hw }, 35662306a36Sopenharmony_ci { .hw = &disp1_cc_pll2.clkr.hw }, 35762306a36Sopenharmony_ci { .hw = &disp1_cc_pll1_out_even.clkr.hw }, 35862306a36Sopenharmony_ci}; 35962306a36Sopenharmony_ci 36062306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_6[] = { 36162306a36Sopenharmony_ci { P_BI_TCXO, 0 }, 36262306a36Sopenharmony_ci { P_DISPn_CC_PLL1_OUT_MAIN, 4 }, 36362306a36Sopenharmony_ci { P_DISPn_CC_PLL1_OUT_EVEN, 6 }, 36462306a36Sopenharmony_ci}; 36562306a36Sopenharmony_ci 36662306a36Sopenharmony_cistatic const struct clk_parent_data disp0_cc_parent_data_6[] = { 36762306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 36862306a36Sopenharmony_ci { .hw = &disp0_cc_pll1.clkr.hw }, 36962306a36Sopenharmony_ci { .hw = &disp0_cc_pll1_out_even.clkr.hw }, 37062306a36Sopenharmony_ci}; 37162306a36Sopenharmony_ci 37262306a36Sopenharmony_cistatic const struct clk_parent_data disp1_cc_parent_data_6[] = { 37362306a36Sopenharmony_ci { .index = DT_BI_TCXO }, 37462306a36Sopenharmony_ci { .hw = &disp1_cc_pll1.clkr.hw }, 37562306a36Sopenharmony_ci { .hw = &disp1_cc_pll1_out_even.clkr.hw }, 37662306a36Sopenharmony_ci}; 37762306a36Sopenharmony_ci 37862306a36Sopenharmony_cistatic const struct parent_map disp_cc_parent_map_7[] = { 37962306a36Sopenharmony_ci { P_SLEEP_CLK, 0 }, 38062306a36Sopenharmony_ci}; 38162306a36Sopenharmony_ci 38262306a36Sopenharmony_cistatic const struct clk_parent_data disp_cc_parent_data_7[] = { 38362306a36Sopenharmony_ci { .index = DT_SLEEP_CLK }, 38462306a36Sopenharmony_ci}; 38562306a36Sopenharmony_ci 38662306a36Sopenharmony_cistatic const struct freq_tbl ftbl_disp_cc_mdss_ahb_clk_src[] = { 38762306a36Sopenharmony_ci F(19200000, P_BI_TCXO, 1, 0, 0), 38862306a36Sopenharmony_ci F(37500000, P_DISPn_CC_PLL1_OUT_EVEN, 8, 0, 0), 38962306a36Sopenharmony_ci F(75000000, P_DISPn_CC_PLL1_OUT_MAIN, 8, 0, 0), 39062306a36Sopenharmony_ci { } 39162306a36Sopenharmony_ci}; 39262306a36Sopenharmony_ci 39362306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_ahb_clk_src = { 39462306a36Sopenharmony_ci .cmd_rcgr = 0x2364, 39562306a36Sopenharmony_ci .mnd_width = 0, 39662306a36Sopenharmony_ci .hid_width = 5, 39762306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_6, 39862306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_ahb_clk_src, 39962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 40062306a36Sopenharmony_ci .name = "disp0_cc_mdss_ahb_clk_src", 40162306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_6, 40262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_6), 40362306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 40462306a36Sopenharmony_ci }, 40562306a36Sopenharmony_ci}; 40662306a36Sopenharmony_ci 40762306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_ahb_clk_src = { 40862306a36Sopenharmony_ci .cmd_rcgr = 0x2364, 40962306a36Sopenharmony_ci .mnd_width = 0, 41062306a36Sopenharmony_ci .hid_width = 5, 41162306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_6, 41262306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_ahb_clk_src, 41362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 41462306a36Sopenharmony_ci .name = "disp1_cc_mdss_ahb_clk_src", 41562306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_6, 41662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_6), 41762306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 41862306a36Sopenharmony_ci }, 41962306a36Sopenharmony_ci}; 42062306a36Sopenharmony_ci 42162306a36Sopenharmony_cistatic const struct freq_tbl ftbl_disp_cc_mdss_byte0_clk_src[] = { 42262306a36Sopenharmony_ci F(19200000, P_BI_TCXO, 1, 0, 0), 42362306a36Sopenharmony_ci { } 42462306a36Sopenharmony_ci}; 42562306a36Sopenharmony_ci 42662306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_byte0_clk_src = { 42762306a36Sopenharmony_ci .cmd_rcgr = 0x213c, 42862306a36Sopenharmony_ci .mnd_width = 0, 42962306a36Sopenharmony_ci .hid_width = 5, 43062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 43162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 43262306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte0_clk_src", 43362306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 43462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 43562306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 43662306a36Sopenharmony_ci .ops = &clk_byte2_ops, 43762306a36Sopenharmony_ci }, 43862306a36Sopenharmony_ci}; 43962306a36Sopenharmony_ci 44062306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_byte0_clk_src = { 44162306a36Sopenharmony_ci .cmd_rcgr = 0x213c, 44262306a36Sopenharmony_ci .mnd_width = 0, 44362306a36Sopenharmony_ci .hid_width = 5, 44462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 44562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 44662306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte0_clk_src", 44762306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 44862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 44962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 45062306a36Sopenharmony_ci .ops = &clk_byte2_ops, 45162306a36Sopenharmony_ci }, 45262306a36Sopenharmony_ci}; 45362306a36Sopenharmony_ci 45462306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_byte1_clk_src = { 45562306a36Sopenharmony_ci .cmd_rcgr = 0x2158, 45662306a36Sopenharmony_ci .mnd_width = 0, 45762306a36Sopenharmony_ci .hid_width = 5, 45862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 45962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 46062306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte1_clk_src", 46162306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 46262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 46362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 46462306a36Sopenharmony_ci .ops = &clk_byte2_ops, 46562306a36Sopenharmony_ci }, 46662306a36Sopenharmony_ci}; 46762306a36Sopenharmony_ci 46862306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_byte1_clk_src = { 46962306a36Sopenharmony_ci .cmd_rcgr = 0x2158, 47062306a36Sopenharmony_ci .mnd_width = 0, 47162306a36Sopenharmony_ci .hid_width = 5, 47262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 47362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 47462306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte1_clk_src", 47562306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 47662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 47762306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 47862306a36Sopenharmony_ci .ops = &clk_byte2_ops, 47962306a36Sopenharmony_ci }, 48062306a36Sopenharmony_ci}; 48162306a36Sopenharmony_ci 48262306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx0_aux_clk_src = { 48362306a36Sopenharmony_ci .cmd_rcgr = 0x2238, 48462306a36Sopenharmony_ci .mnd_width = 0, 48562306a36Sopenharmony_ci .hid_width = 5, 48662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 48762306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 48862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 48962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_aux_clk_src", 49062306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 49162306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 49262306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 49362306a36Sopenharmony_ci }, 49462306a36Sopenharmony_ci}; 49562306a36Sopenharmony_ci 49662306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx0_aux_clk_src = { 49762306a36Sopenharmony_ci .cmd_rcgr = 0x2238, 49862306a36Sopenharmony_ci .mnd_width = 0, 49962306a36Sopenharmony_ci .hid_width = 5, 50062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 50162306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 50262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 50362306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_aux_clk_src", 50462306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 50562306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 50662306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 50762306a36Sopenharmony_ci }, 50862306a36Sopenharmony_ci}; 50962306a36Sopenharmony_ci 51062306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx0_link_clk_src = { 51162306a36Sopenharmony_ci .cmd_rcgr = 0x21a4, 51262306a36Sopenharmony_ci .mnd_width = 0, 51362306a36Sopenharmony_ci .hid_width = 5, 51462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 51562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 51662306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_link_clk_src", 51762306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_0, 51862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_0), 51962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 52062306a36Sopenharmony_ci .ops = &clk_byte2_ops, 52162306a36Sopenharmony_ci }, 52262306a36Sopenharmony_ci}; 52362306a36Sopenharmony_ci 52462306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx0_link_clk_src = { 52562306a36Sopenharmony_ci .cmd_rcgr = 0x21a4, 52662306a36Sopenharmony_ci .mnd_width = 0, 52762306a36Sopenharmony_ci .hid_width = 5, 52862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 52962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 53062306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_link_clk_src", 53162306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_0, 53262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_0), 53362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 53462306a36Sopenharmony_ci .ops = &clk_byte2_ops, 53562306a36Sopenharmony_ci }, 53662306a36Sopenharmony_ci}; 53762306a36Sopenharmony_ci 53862306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx0_pixel0_clk_src = { 53962306a36Sopenharmony_ci .cmd_rcgr = 0x21d8, 54062306a36Sopenharmony_ci .mnd_width = 16, 54162306a36Sopenharmony_ci .hid_width = 5, 54262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 54362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 54462306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_pixel0_clk_src", 54562306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 54662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 54762306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 54862306a36Sopenharmony_ci .ops = &clk_dp_ops, 54962306a36Sopenharmony_ci }, 55062306a36Sopenharmony_ci}; 55162306a36Sopenharmony_ci 55262306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx0_pixel0_clk_src = { 55362306a36Sopenharmony_ci .cmd_rcgr = 0x21d8, 55462306a36Sopenharmony_ci .mnd_width = 16, 55562306a36Sopenharmony_ci .hid_width = 5, 55662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 55762306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 55862306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_pixel0_clk_src", 55962306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 56062306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 56162306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 56262306a36Sopenharmony_ci .ops = &clk_dp_ops, 56362306a36Sopenharmony_ci }, 56462306a36Sopenharmony_ci}; 56562306a36Sopenharmony_ci 56662306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx0_pixel1_clk_src = { 56762306a36Sopenharmony_ci .cmd_rcgr = 0x21f0, 56862306a36Sopenharmony_ci .mnd_width = 16, 56962306a36Sopenharmony_ci .hid_width = 5, 57062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 57162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 57262306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_pixel1_clk_src", 57362306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 57462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 57562306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 57662306a36Sopenharmony_ci .ops = &clk_dp_ops, 57762306a36Sopenharmony_ci }, 57862306a36Sopenharmony_ci}; 57962306a36Sopenharmony_ci 58062306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx0_pixel1_clk_src = { 58162306a36Sopenharmony_ci .cmd_rcgr = 0x21f0, 58262306a36Sopenharmony_ci .mnd_width = 16, 58362306a36Sopenharmony_ci .hid_width = 5, 58462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 58562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 58662306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_pixel1_clk_src", 58762306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 58862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 58962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 59062306a36Sopenharmony_ci .ops = &clk_dp_ops, 59162306a36Sopenharmony_ci }, 59262306a36Sopenharmony_ci}; 59362306a36Sopenharmony_ci 59462306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx1_aux_clk_src = { 59562306a36Sopenharmony_ci .cmd_rcgr = 0x22d0, 59662306a36Sopenharmony_ci .mnd_width = 0, 59762306a36Sopenharmony_ci .hid_width = 5, 59862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 59962306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 60062306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 60162306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_aux_clk_src", 60262306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 60362306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 60462306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 60562306a36Sopenharmony_ci }, 60662306a36Sopenharmony_ci}; 60762306a36Sopenharmony_ci 60862306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx1_aux_clk_src = { 60962306a36Sopenharmony_ci .cmd_rcgr = 0x22d0, 61062306a36Sopenharmony_ci .mnd_width = 0, 61162306a36Sopenharmony_ci .hid_width = 5, 61262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 61362306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 61462306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 61562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_aux_clk_src", 61662306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 61762306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 61862306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 61962306a36Sopenharmony_ci }, 62062306a36Sopenharmony_ci}; 62162306a36Sopenharmony_ci 62262306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx1_link_clk_src = { 62362306a36Sopenharmony_ci .cmd_rcgr = 0x2268, 62462306a36Sopenharmony_ci .mnd_width = 0, 62562306a36Sopenharmony_ci .hid_width = 5, 62662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 62762306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 62862306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_link_clk_src", 62962306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_0, 63062306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_0), 63162306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 63262306a36Sopenharmony_ci .ops = &clk_byte2_ops, 63362306a36Sopenharmony_ci }, 63462306a36Sopenharmony_ci}; 63562306a36Sopenharmony_ci 63662306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx1_link_clk_src = { 63762306a36Sopenharmony_ci .cmd_rcgr = 0x2268, 63862306a36Sopenharmony_ci .mnd_width = 0, 63962306a36Sopenharmony_ci .hid_width = 5, 64062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 64162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 64262306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_link_clk_src", 64362306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_0, 64462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_0), 64562306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 64662306a36Sopenharmony_ci .ops = &clk_byte2_ops, 64762306a36Sopenharmony_ci }, 64862306a36Sopenharmony_ci}; 64962306a36Sopenharmony_ci 65062306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx1_pixel0_clk_src = { 65162306a36Sopenharmony_ci .cmd_rcgr = 0x2250, 65262306a36Sopenharmony_ci .mnd_width = 16, 65362306a36Sopenharmony_ci .hid_width = 5, 65462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 65562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 65662306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_pixel0_clk_src", 65762306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 65862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 65962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 66062306a36Sopenharmony_ci .ops = &clk_dp_ops, 66162306a36Sopenharmony_ci }, 66262306a36Sopenharmony_ci}; 66362306a36Sopenharmony_ci 66462306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx1_pixel0_clk_src = { 66562306a36Sopenharmony_ci .cmd_rcgr = 0x2250, 66662306a36Sopenharmony_ci .mnd_width = 16, 66762306a36Sopenharmony_ci .hid_width = 5, 66862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 66962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 67062306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_pixel0_clk_src", 67162306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 67262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 67362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 67462306a36Sopenharmony_ci .ops = &clk_dp_ops, 67562306a36Sopenharmony_ci }, 67662306a36Sopenharmony_ci}; 67762306a36Sopenharmony_ci 67862306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx1_pixel1_clk_src = { 67962306a36Sopenharmony_ci .cmd_rcgr = 0x2370, 68062306a36Sopenharmony_ci .mnd_width = 16, 68162306a36Sopenharmony_ci .hid_width = 5, 68262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 68362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 68462306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_pixel1_clk_src", 68562306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 68662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 68762306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 68862306a36Sopenharmony_ci .ops = &clk_dp_ops, 68962306a36Sopenharmony_ci }, 69062306a36Sopenharmony_ci}; 69162306a36Sopenharmony_ci 69262306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx1_pixel1_clk_src = { 69362306a36Sopenharmony_ci .cmd_rcgr = 0x2370, 69462306a36Sopenharmony_ci .mnd_width = 16, 69562306a36Sopenharmony_ci .hid_width = 5, 69662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 69762306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 69862306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_pixel1_clk_src", 69962306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 70062306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 70162306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 70262306a36Sopenharmony_ci .ops = &clk_dp_ops, 70362306a36Sopenharmony_ci }, 70462306a36Sopenharmony_ci}; 70562306a36Sopenharmony_ci 70662306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx2_aux_clk_src = { 70762306a36Sopenharmony_ci .cmd_rcgr = 0x22e8, 70862306a36Sopenharmony_ci .mnd_width = 0, 70962306a36Sopenharmony_ci .hid_width = 5, 71062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 71162306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 71262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 71362306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_aux_clk_src", 71462306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 71562306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 71662306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 71762306a36Sopenharmony_ci }, 71862306a36Sopenharmony_ci}; 71962306a36Sopenharmony_ci 72062306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx2_aux_clk_src = { 72162306a36Sopenharmony_ci .cmd_rcgr = 0x22e8, 72262306a36Sopenharmony_ci .mnd_width = 0, 72362306a36Sopenharmony_ci .hid_width = 5, 72462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 72562306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 72662306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 72762306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_aux_clk_src", 72862306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 72962306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 73062306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 73162306a36Sopenharmony_ci }, 73262306a36Sopenharmony_ci}; 73362306a36Sopenharmony_ci 73462306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx2_link_clk_src = { 73562306a36Sopenharmony_ci .cmd_rcgr = 0x2284, 73662306a36Sopenharmony_ci .mnd_width = 0, 73762306a36Sopenharmony_ci .hid_width = 5, 73862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 73962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 74062306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_link_clk_src", 74162306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_0, 74262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_0), 74362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 74462306a36Sopenharmony_ci .ops = &clk_byte2_ops, 74562306a36Sopenharmony_ci }, 74662306a36Sopenharmony_ci}; 74762306a36Sopenharmony_ci 74862306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx2_link_clk_src = { 74962306a36Sopenharmony_ci .cmd_rcgr = 0x2284, 75062306a36Sopenharmony_ci .mnd_width = 0, 75162306a36Sopenharmony_ci .hid_width = 5, 75262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 75362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 75462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_link_clk_src", 75562306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_0, 75662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_0), 75762306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 75862306a36Sopenharmony_ci .ops = &clk_byte2_ops, 75962306a36Sopenharmony_ci }, 76062306a36Sopenharmony_ci}; 76162306a36Sopenharmony_ci 76262306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx2_pixel0_clk_src = { 76362306a36Sopenharmony_ci .cmd_rcgr = 0x2208, 76462306a36Sopenharmony_ci .mnd_width = 16, 76562306a36Sopenharmony_ci .hid_width = 5, 76662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 76762306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 76862306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_pixel0_clk_src", 76962306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 77062306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 77162306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 77262306a36Sopenharmony_ci .ops = &clk_dp_ops, 77362306a36Sopenharmony_ci }, 77462306a36Sopenharmony_ci}; 77562306a36Sopenharmony_ci 77662306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx2_pixel0_clk_src = { 77762306a36Sopenharmony_ci .cmd_rcgr = 0x2208, 77862306a36Sopenharmony_ci .mnd_width = 16, 77962306a36Sopenharmony_ci .hid_width = 5, 78062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 78162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 78262306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_pixel0_clk_src", 78362306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 78462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 78562306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 78662306a36Sopenharmony_ci .ops = &clk_dp_ops, 78762306a36Sopenharmony_ci }, 78862306a36Sopenharmony_ci}; 78962306a36Sopenharmony_ci 79062306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx2_pixel1_clk_src = { 79162306a36Sopenharmony_ci .cmd_rcgr = 0x2220, 79262306a36Sopenharmony_ci .mnd_width = 16, 79362306a36Sopenharmony_ci .hid_width = 5, 79462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 79562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 79662306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_pixel1_clk_src", 79762306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 79862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 79962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 80062306a36Sopenharmony_ci .ops = &clk_dp_ops, 80162306a36Sopenharmony_ci }, 80262306a36Sopenharmony_ci}; 80362306a36Sopenharmony_ci 80462306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx2_pixel1_clk_src = { 80562306a36Sopenharmony_ci .cmd_rcgr = 0x2220, 80662306a36Sopenharmony_ci .mnd_width = 16, 80762306a36Sopenharmony_ci .hid_width = 5, 80862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 80962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 81062306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_pixel1_clk_src", 81162306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 81262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 81362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 81462306a36Sopenharmony_ci .ops = &clk_dp_ops, 81562306a36Sopenharmony_ci }, 81662306a36Sopenharmony_ci}; 81762306a36Sopenharmony_ci 81862306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx3_aux_clk_src = { 81962306a36Sopenharmony_ci .cmd_rcgr = 0x234c, 82062306a36Sopenharmony_ci .mnd_width = 0, 82162306a36Sopenharmony_ci .hid_width = 5, 82262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 82362306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 82462306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 82562306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_aux_clk_src", 82662306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 82762306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 82862306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 82962306a36Sopenharmony_ci }, 83062306a36Sopenharmony_ci}; 83162306a36Sopenharmony_ci 83262306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx3_aux_clk_src = { 83362306a36Sopenharmony_ci .cmd_rcgr = 0x234c, 83462306a36Sopenharmony_ci .mnd_width = 0, 83562306a36Sopenharmony_ci .hid_width = 5, 83662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 83762306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 83862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 83962306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_aux_clk_src", 84062306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 84162306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 84262306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 84362306a36Sopenharmony_ci }, 84462306a36Sopenharmony_ci}; 84562306a36Sopenharmony_ci 84662306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx3_link_clk_src = { 84762306a36Sopenharmony_ci .cmd_rcgr = 0x2318, 84862306a36Sopenharmony_ci .mnd_width = 0, 84962306a36Sopenharmony_ci .hid_width = 5, 85062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 85162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 85262306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_link_clk_src", 85362306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_0, 85462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_0), 85562306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 85662306a36Sopenharmony_ci .ops = &clk_byte2_ops, 85762306a36Sopenharmony_ci }, 85862306a36Sopenharmony_ci}; 85962306a36Sopenharmony_ci 86062306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx3_link_clk_src = { 86162306a36Sopenharmony_ci .cmd_rcgr = 0x2318, 86262306a36Sopenharmony_ci .mnd_width = 0, 86362306a36Sopenharmony_ci .hid_width = 5, 86462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_0, 86562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 86662306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_link_clk_src", 86762306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_0, 86862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_0), 86962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 87062306a36Sopenharmony_ci .ops = &clk_byte2_ops, 87162306a36Sopenharmony_ci }, 87262306a36Sopenharmony_ci}; 87362306a36Sopenharmony_ci 87462306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_dptx3_pixel0_clk_src = { 87562306a36Sopenharmony_ci .cmd_rcgr = 0x2300, 87662306a36Sopenharmony_ci .mnd_width = 16, 87762306a36Sopenharmony_ci .hid_width = 5, 87862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 87962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 88062306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_pixel0_clk_src", 88162306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_1, 88262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_1), 88362306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 88462306a36Sopenharmony_ci .ops = &clk_dp_ops, 88562306a36Sopenharmony_ci }, 88662306a36Sopenharmony_ci}; 88762306a36Sopenharmony_ci 88862306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_dptx3_pixel0_clk_src = { 88962306a36Sopenharmony_ci .cmd_rcgr = 0x2300, 89062306a36Sopenharmony_ci .mnd_width = 16, 89162306a36Sopenharmony_ci .hid_width = 5, 89262306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_1, 89362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 89462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_pixel0_clk_src", 89562306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_1, 89662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_1), 89762306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 89862306a36Sopenharmony_ci .ops = &clk_dp_ops, 89962306a36Sopenharmony_ci }, 90062306a36Sopenharmony_ci}; 90162306a36Sopenharmony_ci 90262306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_esc0_clk_src = { 90362306a36Sopenharmony_ci .cmd_rcgr = 0x2174, 90462306a36Sopenharmony_ci .mnd_width = 0, 90562306a36Sopenharmony_ci .hid_width = 5, 90662306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_4, 90762306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 90862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 90962306a36Sopenharmony_ci .name = "disp0_cc_mdss_esc0_clk_src", 91062306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_4, 91162306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_4), 91262306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 91362306a36Sopenharmony_ci }, 91462306a36Sopenharmony_ci}; 91562306a36Sopenharmony_ci 91662306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_esc0_clk_src = { 91762306a36Sopenharmony_ci .cmd_rcgr = 0x2174, 91862306a36Sopenharmony_ci .mnd_width = 0, 91962306a36Sopenharmony_ci .hid_width = 5, 92062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_4, 92162306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 92262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 92362306a36Sopenharmony_ci .name = "disp1_cc_mdss_esc0_clk_src", 92462306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_4, 92562306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_4), 92662306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 92762306a36Sopenharmony_ci }, 92862306a36Sopenharmony_ci}; 92962306a36Sopenharmony_ci 93062306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_esc1_clk_src = { 93162306a36Sopenharmony_ci .cmd_rcgr = 0x218c, 93262306a36Sopenharmony_ci .mnd_width = 0, 93362306a36Sopenharmony_ci .hid_width = 5, 93462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_4, 93562306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 93662306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 93762306a36Sopenharmony_ci .name = "disp0_cc_mdss_esc1_clk_src", 93862306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_4, 93962306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_4), 94062306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 94162306a36Sopenharmony_ci }, 94262306a36Sopenharmony_ci}; 94362306a36Sopenharmony_ci 94462306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_esc1_clk_src = { 94562306a36Sopenharmony_ci .cmd_rcgr = 0x218c, 94662306a36Sopenharmony_ci .mnd_width = 0, 94762306a36Sopenharmony_ci .hid_width = 5, 94862306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_4, 94962306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 95062306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 95162306a36Sopenharmony_ci .name = "disp1_cc_mdss_esc1_clk_src", 95262306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_4, 95362306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_4), 95462306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 95562306a36Sopenharmony_ci }, 95662306a36Sopenharmony_ci}; 95762306a36Sopenharmony_ci 95862306a36Sopenharmony_cistatic const struct freq_tbl ftbl_disp_cc_mdss_mdp_clk_src[] = { 95962306a36Sopenharmony_ci F(19200000, P_BI_TCXO, 1, 0, 0), 96062306a36Sopenharmony_ci F(85714286, P_DISPn_CC_PLL1_OUT_MAIN, 7, 0, 0), 96162306a36Sopenharmony_ci F(100000000, P_DISPn_CC_PLL1_OUT_MAIN, 6, 0, 0), 96262306a36Sopenharmony_ci F(150000000, P_DISPn_CC_PLL1_OUT_MAIN, 4, 0, 0), 96362306a36Sopenharmony_ci F(200000000, P_DISPn_CC_PLL1_OUT_MAIN, 3, 0, 0), 96462306a36Sopenharmony_ci F(300000000, P_DISPn_CC_PLL1_OUT_MAIN, 2, 0, 0), 96562306a36Sopenharmony_ci F(375000000, P_DISPn_CC_PLL0_OUT_MAIN, 4, 0, 0), 96662306a36Sopenharmony_ci F(500000000, P_DISPn_CC_PLL0_OUT_MAIN, 3, 0, 0), 96762306a36Sopenharmony_ci F(600000000, P_DISPn_CC_PLL1_OUT_MAIN, 1, 0, 0), 96862306a36Sopenharmony_ci { } 96962306a36Sopenharmony_ci}; 97062306a36Sopenharmony_ci 97162306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_mdp_clk_src = { 97262306a36Sopenharmony_ci .cmd_rcgr = 0x20f4, 97362306a36Sopenharmony_ci .mnd_width = 0, 97462306a36Sopenharmony_ci .hid_width = 5, 97562306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_5, 97662306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_mdp_clk_src, 97762306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 97862306a36Sopenharmony_ci .name = "disp0_cc_mdss_mdp_clk_src", 97962306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_5, 98062306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_5), 98162306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 98262306a36Sopenharmony_ci }, 98362306a36Sopenharmony_ci}; 98462306a36Sopenharmony_ci 98562306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_mdp_clk_src = { 98662306a36Sopenharmony_ci .cmd_rcgr = 0x20f4, 98762306a36Sopenharmony_ci .mnd_width = 0, 98862306a36Sopenharmony_ci .hid_width = 5, 98962306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_5, 99062306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_mdp_clk_src, 99162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 99262306a36Sopenharmony_ci .name = "disp1_cc_mdss_mdp_clk_src", 99362306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_5, 99462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_5), 99562306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 99662306a36Sopenharmony_ci }, 99762306a36Sopenharmony_ci}; 99862306a36Sopenharmony_ci 99962306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_pclk0_clk_src = { 100062306a36Sopenharmony_ci .cmd_rcgr = 0x20c4, 100162306a36Sopenharmony_ci .mnd_width = 8, 100262306a36Sopenharmony_ci .hid_width = 5, 100362306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 100462306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 100562306a36Sopenharmony_ci .name = "disp0_cc_mdss_pclk0_clk_src", 100662306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 100762306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 100862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 100962306a36Sopenharmony_ci .ops = &clk_pixel_ops, 101062306a36Sopenharmony_ci }, 101162306a36Sopenharmony_ci}; 101262306a36Sopenharmony_ci 101362306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_pclk0_clk_src = { 101462306a36Sopenharmony_ci .cmd_rcgr = 0x20c4, 101562306a36Sopenharmony_ci .mnd_width = 8, 101662306a36Sopenharmony_ci .hid_width = 5, 101762306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 101862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 101962306a36Sopenharmony_ci .name = "disp1_cc_mdss_pclk0_clk_src", 102062306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 102162306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 102262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 102362306a36Sopenharmony_ci .ops = &clk_pixel_ops, 102462306a36Sopenharmony_ci }, 102562306a36Sopenharmony_ci}; 102662306a36Sopenharmony_ci 102762306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_pclk1_clk_src = { 102862306a36Sopenharmony_ci .cmd_rcgr = 0x20dc, 102962306a36Sopenharmony_ci .mnd_width = 8, 103062306a36Sopenharmony_ci .hid_width = 5, 103162306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 103262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 103362306a36Sopenharmony_ci .name = "disp0_cc_mdss_pclk1_clk_src", 103462306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 103562306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 103662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 103762306a36Sopenharmony_ci .ops = &clk_pixel_ops, 103862306a36Sopenharmony_ci }, 103962306a36Sopenharmony_ci}; 104062306a36Sopenharmony_ci 104162306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_pclk1_clk_src = { 104262306a36Sopenharmony_ci .cmd_rcgr = 0x20dc, 104362306a36Sopenharmony_ci .mnd_width = 8, 104462306a36Sopenharmony_ci .hid_width = 5, 104562306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_3, 104662306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 104762306a36Sopenharmony_ci .name = "disp1_cc_mdss_pclk1_clk_src", 104862306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_3, 104962306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_3), 105062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 105162306a36Sopenharmony_ci .ops = &clk_pixel_ops, 105262306a36Sopenharmony_ci }, 105362306a36Sopenharmony_ci}; 105462306a36Sopenharmony_ci 105562306a36Sopenharmony_cistatic const struct freq_tbl ftbl_disp_cc_mdss_rot_clk_src[] = { 105662306a36Sopenharmony_ci F(19200000, P_BI_TCXO, 1, 0, 0), 105762306a36Sopenharmony_ci F(200000000, P_DISPn_CC_PLL1_OUT_MAIN, 3, 0, 0), 105862306a36Sopenharmony_ci F(300000000, P_DISPn_CC_PLL1_OUT_MAIN, 2, 0, 0), 105962306a36Sopenharmony_ci F(375000000, P_DISPn_CC_PLL0_OUT_MAIN, 4, 0, 0), 106062306a36Sopenharmony_ci F(500000000, P_DISPn_CC_PLL0_OUT_MAIN, 3, 0, 0), 106162306a36Sopenharmony_ci F(600000000, P_DISPn_CC_PLL1_OUT_MAIN, 1, 0, 0), 106262306a36Sopenharmony_ci { } 106362306a36Sopenharmony_ci}; 106462306a36Sopenharmony_ci 106562306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_rot_clk_src = { 106662306a36Sopenharmony_ci .cmd_rcgr = 0x210c, 106762306a36Sopenharmony_ci .mnd_width = 0, 106862306a36Sopenharmony_ci .hid_width = 5, 106962306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_5, 107062306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_rot_clk_src, 107162306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 107262306a36Sopenharmony_ci .name = "disp0_cc_mdss_rot_clk_src", 107362306a36Sopenharmony_ci .parent_data = disp0_cc_parent_data_5, 107462306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp0_cc_parent_data_5), 107562306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 107662306a36Sopenharmony_ci }, 107762306a36Sopenharmony_ci}; 107862306a36Sopenharmony_ci 107962306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_rot_clk_src = { 108062306a36Sopenharmony_ci .cmd_rcgr = 0x210c, 108162306a36Sopenharmony_ci .mnd_width = 0, 108262306a36Sopenharmony_ci .hid_width = 5, 108362306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_5, 108462306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_rot_clk_src, 108562306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 108662306a36Sopenharmony_ci .name = "disp1_cc_mdss_rot_clk_src", 108762306a36Sopenharmony_ci .parent_data = disp1_cc_parent_data_5, 108862306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp1_cc_parent_data_5), 108962306a36Sopenharmony_ci .ops = &clk_rcg2_shared_ops, 109062306a36Sopenharmony_ci }, 109162306a36Sopenharmony_ci}; 109262306a36Sopenharmony_ci 109362306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_mdss_vsync_clk_src = { 109462306a36Sopenharmony_ci .cmd_rcgr = 0x2124, 109562306a36Sopenharmony_ci .mnd_width = 0, 109662306a36Sopenharmony_ci .hid_width = 5, 109762306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 109862306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 109962306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 110062306a36Sopenharmony_ci .name = "disp0_cc_mdss_vsync_clk_src", 110162306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 110262306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 110362306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 110462306a36Sopenharmony_ci }, 110562306a36Sopenharmony_ci}; 110662306a36Sopenharmony_ci 110762306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_mdss_vsync_clk_src = { 110862306a36Sopenharmony_ci .cmd_rcgr = 0x2124, 110962306a36Sopenharmony_ci .mnd_width = 0, 111062306a36Sopenharmony_ci .hid_width = 5, 111162306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_2, 111262306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src, 111362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 111462306a36Sopenharmony_ci .name = "disp1_cc_mdss_vsync_clk_src", 111562306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_2, 111662306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_2), 111762306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 111862306a36Sopenharmony_ci }, 111962306a36Sopenharmony_ci}; 112062306a36Sopenharmony_ci 112162306a36Sopenharmony_cistatic const struct freq_tbl ftbl_disp_cc_sleep_clk_src[] = { 112262306a36Sopenharmony_ci F(32000, P_SLEEP_CLK, 1, 0, 0), 112362306a36Sopenharmony_ci { } 112462306a36Sopenharmony_ci}; 112562306a36Sopenharmony_ci 112662306a36Sopenharmony_cistatic struct clk_rcg2 disp0_cc_sleep_clk_src = { 112762306a36Sopenharmony_ci .cmd_rcgr = 0x6060, 112862306a36Sopenharmony_ci .mnd_width = 0, 112962306a36Sopenharmony_ci .hid_width = 5, 113062306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_7, 113162306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_sleep_clk_src, 113262306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 113362306a36Sopenharmony_ci .name = "disp0_cc_sleep_clk_src", 113462306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_7, 113562306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_7), 113662306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 113762306a36Sopenharmony_ci }, 113862306a36Sopenharmony_ci}; 113962306a36Sopenharmony_ci 114062306a36Sopenharmony_cistatic struct clk_rcg2 disp1_cc_sleep_clk_src = { 114162306a36Sopenharmony_ci .cmd_rcgr = 0x6060, 114262306a36Sopenharmony_ci .mnd_width = 0, 114362306a36Sopenharmony_ci .hid_width = 5, 114462306a36Sopenharmony_ci .parent_map = disp_cc_parent_map_7, 114562306a36Sopenharmony_ci .freq_tbl = ftbl_disp_cc_sleep_clk_src, 114662306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 114762306a36Sopenharmony_ci .name = "disp1_cc_sleep_clk_src", 114862306a36Sopenharmony_ci .parent_data = disp_cc_parent_data_7, 114962306a36Sopenharmony_ci .num_parents = ARRAY_SIZE(disp_cc_parent_data_7), 115062306a36Sopenharmony_ci .ops = &clk_rcg2_ops, 115162306a36Sopenharmony_ci }, 115262306a36Sopenharmony_ci}; 115362306a36Sopenharmony_ci 115462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_byte0_div_clk_src = { 115562306a36Sopenharmony_ci .reg = 0x2154, 115662306a36Sopenharmony_ci .shift = 0, 115762306a36Sopenharmony_ci .width = 4, 115862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 115962306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte0_div_clk_src", 116062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 116162306a36Sopenharmony_ci &disp0_cc_mdss_byte0_clk_src.clkr.hw, 116262306a36Sopenharmony_ci }, 116362306a36Sopenharmony_ci .num_parents = 1, 116462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 116562306a36Sopenharmony_ci .ops = &clk_regmap_div_ops, 116662306a36Sopenharmony_ci }, 116762306a36Sopenharmony_ci}; 116862306a36Sopenharmony_ci 116962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_byte0_div_clk_src = { 117062306a36Sopenharmony_ci .reg = 0x2154, 117162306a36Sopenharmony_ci .shift = 0, 117262306a36Sopenharmony_ci .width = 4, 117362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 117462306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte0_div_clk_src", 117562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 117662306a36Sopenharmony_ci &disp1_cc_mdss_byte0_clk_src.clkr.hw, 117762306a36Sopenharmony_ci }, 117862306a36Sopenharmony_ci .num_parents = 1, 117962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 118062306a36Sopenharmony_ci .ops = &clk_regmap_div_ops, 118162306a36Sopenharmony_ci }, 118262306a36Sopenharmony_ci}; 118362306a36Sopenharmony_ci 118462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_byte1_div_clk_src = { 118562306a36Sopenharmony_ci .reg = 0x2170, 118662306a36Sopenharmony_ci .shift = 0, 118762306a36Sopenharmony_ci .width = 4, 118862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 118962306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte1_div_clk_src", 119062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 119162306a36Sopenharmony_ci &disp0_cc_mdss_byte1_clk_src.clkr.hw, 119262306a36Sopenharmony_ci }, 119362306a36Sopenharmony_ci .num_parents = 1, 119462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 119562306a36Sopenharmony_ci .ops = &clk_regmap_div_ops, 119662306a36Sopenharmony_ci }, 119762306a36Sopenharmony_ci}; 119862306a36Sopenharmony_ci 119962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_byte1_div_clk_src = { 120062306a36Sopenharmony_ci .reg = 0x2170, 120162306a36Sopenharmony_ci .shift = 0, 120262306a36Sopenharmony_ci .width = 4, 120362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 120462306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte1_div_clk_src", 120562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 120662306a36Sopenharmony_ci &disp1_cc_mdss_byte1_clk_src.clkr.hw, 120762306a36Sopenharmony_ci }, 120862306a36Sopenharmony_ci .num_parents = 1, 120962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 121062306a36Sopenharmony_ci .ops = &clk_regmap_div_ops, 121162306a36Sopenharmony_ci }, 121262306a36Sopenharmony_ci}; 121362306a36Sopenharmony_ci 121462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_dptx0_link_div_clk_src = { 121562306a36Sopenharmony_ci .reg = 0x21bc, 121662306a36Sopenharmony_ci .shift = 0, 121762306a36Sopenharmony_ci .width = 4, 121862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 121962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_link_div_clk_src", 122062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 122162306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_link_clk_src.clkr.hw, 122262306a36Sopenharmony_ci }, 122362306a36Sopenharmony_ci .num_parents = 1, 122462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 122562306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 122662306a36Sopenharmony_ci }, 122762306a36Sopenharmony_ci}; 122862306a36Sopenharmony_ci 122962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_dptx0_link_div_clk_src = { 123062306a36Sopenharmony_ci .reg = 0x21bc, 123162306a36Sopenharmony_ci .shift = 0, 123262306a36Sopenharmony_ci .width = 4, 123362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 123462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_link_div_clk_src", 123562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 123662306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_link_clk_src.clkr.hw, 123762306a36Sopenharmony_ci }, 123862306a36Sopenharmony_ci .num_parents = 1, 123962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 124062306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 124162306a36Sopenharmony_ci }, 124262306a36Sopenharmony_ci}; 124362306a36Sopenharmony_ci 124462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_dptx1_link_div_clk_src = { 124562306a36Sopenharmony_ci .reg = 0x2280, 124662306a36Sopenharmony_ci .shift = 0, 124762306a36Sopenharmony_ci .width = 4, 124862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 124962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_link_div_clk_src", 125062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 125162306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_link_clk_src.clkr.hw, 125262306a36Sopenharmony_ci }, 125362306a36Sopenharmony_ci .num_parents = 1, 125462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 125562306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 125662306a36Sopenharmony_ci }, 125762306a36Sopenharmony_ci}; 125862306a36Sopenharmony_ci 125962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_dptx1_link_div_clk_src = { 126062306a36Sopenharmony_ci .reg = 0x2280, 126162306a36Sopenharmony_ci .shift = 0, 126262306a36Sopenharmony_ci .width = 4, 126362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 126462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_link_div_clk_src", 126562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 126662306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_link_clk_src.clkr.hw, 126762306a36Sopenharmony_ci }, 126862306a36Sopenharmony_ci .num_parents = 1, 126962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 127062306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 127162306a36Sopenharmony_ci }, 127262306a36Sopenharmony_ci}; 127362306a36Sopenharmony_ci 127462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_dptx2_link_div_clk_src = { 127562306a36Sopenharmony_ci .reg = 0x229c, 127662306a36Sopenharmony_ci .shift = 0, 127762306a36Sopenharmony_ci .width = 4, 127862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 127962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_link_div_clk_src", 128062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 128162306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_link_clk_src.clkr.hw, 128262306a36Sopenharmony_ci }, 128362306a36Sopenharmony_ci .num_parents = 1, 128462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 128562306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 128662306a36Sopenharmony_ci }, 128762306a36Sopenharmony_ci}; 128862306a36Sopenharmony_ci 128962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_dptx2_link_div_clk_src = { 129062306a36Sopenharmony_ci .reg = 0x229c, 129162306a36Sopenharmony_ci .shift = 0, 129262306a36Sopenharmony_ci .width = 4, 129362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 129462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_link_div_clk_src", 129562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 129662306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_link_clk_src.clkr.hw, 129762306a36Sopenharmony_ci }, 129862306a36Sopenharmony_ci .num_parents = 1, 129962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 130062306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 130162306a36Sopenharmony_ci }, 130262306a36Sopenharmony_ci}; 130362306a36Sopenharmony_ci 130462306a36Sopenharmony_cistatic struct clk_regmap_div disp0_cc_mdss_dptx3_link_div_clk_src = { 130562306a36Sopenharmony_ci .reg = 0x2330, 130662306a36Sopenharmony_ci .shift = 0, 130762306a36Sopenharmony_ci .width = 4, 130862306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 130962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_link_div_clk_src", 131062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 131162306a36Sopenharmony_ci &disp0_cc_mdss_dptx3_link_clk_src.clkr.hw, 131262306a36Sopenharmony_ci }, 131362306a36Sopenharmony_ci .num_parents = 1, 131462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 131562306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 131662306a36Sopenharmony_ci }, 131762306a36Sopenharmony_ci}; 131862306a36Sopenharmony_ci 131962306a36Sopenharmony_cistatic struct clk_regmap_div disp1_cc_mdss_dptx3_link_div_clk_src = { 132062306a36Sopenharmony_ci .reg = 0x2330, 132162306a36Sopenharmony_ci .shift = 0, 132262306a36Sopenharmony_ci .width = 4, 132362306a36Sopenharmony_ci .clkr.hw.init = &(const struct clk_init_data) { 132462306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_link_div_clk_src", 132562306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 132662306a36Sopenharmony_ci &disp1_cc_mdss_dptx3_link_clk_src.clkr.hw, 132762306a36Sopenharmony_ci }, 132862306a36Sopenharmony_ci .num_parents = 1, 132962306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 133062306a36Sopenharmony_ci .ops = &clk_regmap_div_ro_ops, 133162306a36Sopenharmony_ci }, 133262306a36Sopenharmony_ci}; 133362306a36Sopenharmony_ci 133462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_ahb1_clk = { 133562306a36Sopenharmony_ci .halt_reg = 0x20c0, 133662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 133762306a36Sopenharmony_ci .clkr = { 133862306a36Sopenharmony_ci .enable_reg = 0x20c0, 133962306a36Sopenharmony_ci .enable_mask = BIT(0), 134062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 134162306a36Sopenharmony_ci .name = "disp0_cc_mdss_ahb1_clk", 134262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 134362306a36Sopenharmony_ci &disp0_cc_mdss_ahb_clk_src.clkr.hw, 134462306a36Sopenharmony_ci }, 134562306a36Sopenharmony_ci .num_parents = 1, 134662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 134762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 134862306a36Sopenharmony_ci }, 134962306a36Sopenharmony_ci }, 135062306a36Sopenharmony_ci}; 135162306a36Sopenharmony_ci 135262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_ahb1_clk = { 135362306a36Sopenharmony_ci .halt_reg = 0x20c0, 135462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 135562306a36Sopenharmony_ci .clkr = { 135662306a36Sopenharmony_ci .enable_reg = 0x20c0, 135762306a36Sopenharmony_ci .enable_mask = BIT(0), 135862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 135962306a36Sopenharmony_ci .name = "disp1_cc_mdss_ahb1_clk", 136062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 136162306a36Sopenharmony_ci &disp1_cc_mdss_ahb_clk_src.clkr.hw, 136262306a36Sopenharmony_ci }, 136362306a36Sopenharmony_ci .num_parents = 1, 136462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 136562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 136662306a36Sopenharmony_ci }, 136762306a36Sopenharmony_ci }, 136862306a36Sopenharmony_ci}; 136962306a36Sopenharmony_ci 137062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_ahb_clk = { 137162306a36Sopenharmony_ci .halt_reg = 0x20bc, 137262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 137362306a36Sopenharmony_ci .clkr = { 137462306a36Sopenharmony_ci .enable_reg = 0x20bc, 137562306a36Sopenharmony_ci .enable_mask = BIT(0), 137662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 137762306a36Sopenharmony_ci .name = "disp0_cc_mdss_ahb_clk", 137862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 137962306a36Sopenharmony_ci &disp0_cc_mdss_ahb_clk_src.clkr.hw, 138062306a36Sopenharmony_ci }, 138162306a36Sopenharmony_ci .num_parents = 1, 138262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 138362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 138462306a36Sopenharmony_ci }, 138562306a36Sopenharmony_ci }, 138662306a36Sopenharmony_ci}; 138762306a36Sopenharmony_ci 138862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_ahb_clk = { 138962306a36Sopenharmony_ci .halt_reg = 0x20bc, 139062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 139162306a36Sopenharmony_ci .clkr = { 139262306a36Sopenharmony_ci .enable_reg = 0x20bc, 139362306a36Sopenharmony_ci .enable_mask = BIT(0), 139462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 139562306a36Sopenharmony_ci .name = "disp1_cc_mdss_ahb_clk", 139662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 139762306a36Sopenharmony_ci &disp1_cc_mdss_ahb_clk_src.clkr.hw, 139862306a36Sopenharmony_ci }, 139962306a36Sopenharmony_ci .num_parents = 1, 140062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 140162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 140262306a36Sopenharmony_ci }, 140362306a36Sopenharmony_ci }, 140462306a36Sopenharmony_ci}; 140562306a36Sopenharmony_ci 140662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_byte0_clk = { 140762306a36Sopenharmony_ci .halt_reg = 0x2044, 140862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 140962306a36Sopenharmony_ci .clkr = { 141062306a36Sopenharmony_ci .enable_reg = 0x2044, 141162306a36Sopenharmony_ci .enable_mask = BIT(0), 141262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 141362306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte0_clk", 141462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 141562306a36Sopenharmony_ci &disp0_cc_mdss_byte0_clk_src.clkr.hw, 141662306a36Sopenharmony_ci }, 141762306a36Sopenharmony_ci .num_parents = 1, 141862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 141962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 142062306a36Sopenharmony_ci }, 142162306a36Sopenharmony_ci }, 142262306a36Sopenharmony_ci}; 142362306a36Sopenharmony_ci 142462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_byte0_clk = { 142562306a36Sopenharmony_ci .halt_reg = 0x2044, 142662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 142762306a36Sopenharmony_ci .clkr = { 142862306a36Sopenharmony_ci .enable_reg = 0x2044, 142962306a36Sopenharmony_ci .enable_mask = BIT(0), 143062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 143162306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte0_clk", 143262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 143362306a36Sopenharmony_ci &disp1_cc_mdss_byte0_clk_src.clkr.hw, 143462306a36Sopenharmony_ci }, 143562306a36Sopenharmony_ci .num_parents = 1, 143662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 143762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 143862306a36Sopenharmony_ci }, 143962306a36Sopenharmony_ci }, 144062306a36Sopenharmony_ci}; 144162306a36Sopenharmony_ci 144262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_byte0_intf_clk = { 144362306a36Sopenharmony_ci .halt_reg = 0x2048, 144462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 144562306a36Sopenharmony_ci .clkr = { 144662306a36Sopenharmony_ci .enable_reg = 0x2048, 144762306a36Sopenharmony_ci .enable_mask = BIT(0), 144862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 144962306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte0_intf_clk", 145062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 145162306a36Sopenharmony_ci &disp0_cc_mdss_byte0_div_clk_src.clkr.hw, 145262306a36Sopenharmony_ci }, 145362306a36Sopenharmony_ci .num_parents = 1, 145462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 145562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 145662306a36Sopenharmony_ci }, 145762306a36Sopenharmony_ci }, 145862306a36Sopenharmony_ci}; 145962306a36Sopenharmony_ci 146062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_byte0_intf_clk = { 146162306a36Sopenharmony_ci .halt_reg = 0x2048, 146262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 146362306a36Sopenharmony_ci .clkr = { 146462306a36Sopenharmony_ci .enable_reg = 0x2048, 146562306a36Sopenharmony_ci .enable_mask = BIT(0), 146662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 146762306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte0_intf_clk", 146862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 146962306a36Sopenharmony_ci &disp1_cc_mdss_byte0_div_clk_src.clkr.hw, 147062306a36Sopenharmony_ci }, 147162306a36Sopenharmony_ci .num_parents = 1, 147262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 147362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 147462306a36Sopenharmony_ci }, 147562306a36Sopenharmony_ci }, 147662306a36Sopenharmony_ci}; 147762306a36Sopenharmony_ci 147862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_byte1_clk = { 147962306a36Sopenharmony_ci .halt_reg = 0x204c, 148062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 148162306a36Sopenharmony_ci .clkr = { 148262306a36Sopenharmony_ci .enable_reg = 0x204c, 148362306a36Sopenharmony_ci .enable_mask = BIT(0), 148462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 148562306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte1_clk", 148662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 148762306a36Sopenharmony_ci &disp0_cc_mdss_byte1_clk_src.clkr.hw, 148862306a36Sopenharmony_ci }, 148962306a36Sopenharmony_ci .num_parents = 1, 149062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 149162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 149262306a36Sopenharmony_ci }, 149362306a36Sopenharmony_ci }, 149462306a36Sopenharmony_ci}; 149562306a36Sopenharmony_ci 149662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_byte1_clk = { 149762306a36Sopenharmony_ci .halt_reg = 0x204c, 149862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 149962306a36Sopenharmony_ci .clkr = { 150062306a36Sopenharmony_ci .enable_reg = 0x204c, 150162306a36Sopenharmony_ci .enable_mask = BIT(0), 150262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 150362306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte1_clk", 150462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 150562306a36Sopenharmony_ci &disp1_cc_mdss_byte1_clk_src.clkr.hw, 150662306a36Sopenharmony_ci }, 150762306a36Sopenharmony_ci .num_parents = 1, 150862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 150962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 151062306a36Sopenharmony_ci }, 151162306a36Sopenharmony_ci }, 151262306a36Sopenharmony_ci}; 151362306a36Sopenharmony_ci 151462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_byte1_intf_clk = { 151562306a36Sopenharmony_ci .halt_reg = 0x2050, 151662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 151762306a36Sopenharmony_ci .clkr = { 151862306a36Sopenharmony_ci .enable_reg = 0x2050, 151962306a36Sopenharmony_ci .enable_mask = BIT(0), 152062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 152162306a36Sopenharmony_ci .name = "disp0_cc_mdss_byte1_intf_clk", 152262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 152362306a36Sopenharmony_ci &disp0_cc_mdss_byte1_div_clk_src.clkr.hw, 152462306a36Sopenharmony_ci }, 152562306a36Sopenharmony_ci .num_parents = 1, 152662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 152762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 152862306a36Sopenharmony_ci }, 152962306a36Sopenharmony_ci }, 153062306a36Sopenharmony_ci}; 153162306a36Sopenharmony_ci 153262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_byte1_intf_clk = { 153362306a36Sopenharmony_ci .halt_reg = 0x2050, 153462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 153562306a36Sopenharmony_ci .clkr = { 153662306a36Sopenharmony_ci .enable_reg = 0x2050, 153762306a36Sopenharmony_ci .enable_mask = BIT(0), 153862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 153962306a36Sopenharmony_ci .name = "disp1_cc_mdss_byte1_intf_clk", 154062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 154162306a36Sopenharmony_ci &disp1_cc_mdss_byte1_div_clk_src.clkr.hw, 154262306a36Sopenharmony_ci }, 154362306a36Sopenharmony_ci .num_parents = 1, 154462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 154562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 154662306a36Sopenharmony_ci }, 154762306a36Sopenharmony_ci }, 154862306a36Sopenharmony_ci}; 154962306a36Sopenharmony_ci 155062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_aux_clk = { 155162306a36Sopenharmony_ci .halt_reg = 0x206c, 155262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 155362306a36Sopenharmony_ci .clkr = { 155462306a36Sopenharmony_ci .enable_reg = 0x206c, 155562306a36Sopenharmony_ci .enable_mask = BIT(0), 155662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 155762306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_aux_clk", 155862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 155962306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_aux_clk_src.clkr.hw, 156062306a36Sopenharmony_ci }, 156162306a36Sopenharmony_ci .num_parents = 1, 156262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 156362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 156462306a36Sopenharmony_ci }, 156562306a36Sopenharmony_ci }, 156662306a36Sopenharmony_ci}; 156762306a36Sopenharmony_ci 156862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_aux_clk = { 156962306a36Sopenharmony_ci .halt_reg = 0x206c, 157062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 157162306a36Sopenharmony_ci .clkr = { 157262306a36Sopenharmony_ci .enable_reg = 0x206c, 157362306a36Sopenharmony_ci .enable_mask = BIT(0), 157462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 157562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_aux_clk", 157662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 157762306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_aux_clk_src.clkr.hw, 157862306a36Sopenharmony_ci }, 157962306a36Sopenharmony_ci .num_parents = 1, 158062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 158162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 158262306a36Sopenharmony_ci }, 158362306a36Sopenharmony_ci }, 158462306a36Sopenharmony_ci}; 158562306a36Sopenharmony_ci 158662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_link_clk = { 158762306a36Sopenharmony_ci .halt_reg = 0x205c, 158862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 158962306a36Sopenharmony_ci .clkr = { 159062306a36Sopenharmony_ci .enable_reg = 0x205c, 159162306a36Sopenharmony_ci .enable_mask = BIT(0), 159262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 159362306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_link_clk", 159462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 159562306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_link_clk_src.clkr.hw, 159662306a36Sopenharmony_ci }, 159762306a36Sopenharmony_ci .num_parents = 1, 159862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 159962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 160062306a36Sopenharmony_ci }, 160162306a36Sopenharmony_ci }, 160262306a36Sopenharmony_ci}; 160362306a36Sopenharmony_ci 160462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_link_clk = { 160562306a36Sopenharmony_ci .halt_reg = 0x205c, 160662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 160762306a36Sopenharmony_ci .clkr = { 160862306a36Sopenharmony_ci .enable_reg = 0x205c, 160962306a36Sopenharmony_ci .enable_mask = BIT(0), 161062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 161162306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_link_clk", 161262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 161362306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_link_clk_src.clkr.hw, 161462306a36Sopenharmony_ci }, 161562306a36Sopenharmony_ci .num_parents = 1, 161662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 161762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 161862306a36Sopenharmony_ci }, 161962306a36Sopenharmony_ci }, 162062306a36Sopenharmony_ci}; 162162306a36Sopenharmony_ci 162262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_link_intf_clk = { 162362306a36Sopenharmony_ci .halt_reg = 0x2060, 162462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 162562306a36Sopenharmony_ci .clkr = { 162662306a36Sopenharmony_ci .enable_reg = 0x2060, 162762306a36Sopenharmony_ci .enable_mask = BIT(0), 162862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 162962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_link_intf_clk", 163062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 163162306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_link_div_clk_src.clkr.hw, 163262306a36Sopenharmony_ci }, 163362306a36Sopenharmony_ci .num_parents = 1, 163462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 163562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 163662306a36Sopenharmony_ci }, 163762306a36Sopenharmony_ci }, 163862306a36Sopenharmony_ci}; 163962306a36Sopenharmony_ci 164062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_link_intf_clk = { 164162306a36Sopenharmony_ci .halt_reg = 0x2060, 164262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 164362306a36Sopenharmony_ci .clkr = { 164462306a36Sopenharmony_ci .enable_reg = 0x2060, 164562306a36Sopenharmony_ci .enable_mask = BIT(0), 164662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 164762306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_link_intf_clk", 164862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 164962306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_link_div_clk_src.clkr.hw, 165062306a36Sopenharmony_ci }, 165162306a36Sopenharmony_ci .num_parents = 1, 165262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 165362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 165462306a36Sopenharmony_ci }, 165562306a36Sopenharmony_ci }, 165662306a36Sopenharmony_ci}; 165762306a36Sopenharmony_ci 165862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_pixel0_clk = { 165962306a36Sopenharmony_ci .halt_reg = 0x2070, 166062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 166162306a36Sopenharmony_ci .clkr = { 166262306a36Sopenharmony_ci .enable_reg = 0x2070, 166362306a36Sopenharmony_ci .enable_mask = BIT(0), 166462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 166562306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_pixel0_clk", 166662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 166762306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_pixel0_clk_src.clkr.hw, 166862306a36Sopenharmony_ci }, 166962306a36Sopenharmony_ci .num_parents = 1, 167062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 167162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 167262306a36Sopenharmony_ci }, 167362306a36Sopenharmony_ci }, 167462306a36Sopenharmony_ci}; 167562306a36Sopenharmony_ci 167662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_pixel0_clk = { 167762306a36Sopenharmony_ci .halt_reg = 0x2070, 167862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 167962306a36Sopenharmony_ci .clkr = { 168062306a36Sopenharmony_ci .enable_reg = 0x2070, 168162306a36Sopenharmony_ci .enable_mask = BIT(0), 168262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 168362306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_pixel0_clk", 168462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 168562306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_pixel0_clk_src.clkr.hw, 168662306a36Sopenharmony_ci }, 168762306a36Sopenharmony_ci .num_parents = 1, 168862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 168962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 169062306a36Sopenharmony_ci }, 169162306a36Sopenharmony_ci }, 169262306a36Sopenharmony_ci}; 169362306a36Sopenharmony_ci 169462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_pixel1_clk = { 169562306a36Sopenharmony_ci .halt_reg = 0x2074, 169662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 169762306a36Sopenharmony_ci .clkr = { 169862306a36Sopenharmony_ci .enable_reg = 0x2074, 169962306a36Sopenharmony_ci .enable_mask = BIT(0), 170062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 170162306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_pixel1_clk", 170262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 170362306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_pixel1_clk_src.clkr.hw, 170462306a36Sopenharmony_ci }, 170562306a36Sopenharmony_ci .num_parents = 1, 170662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 170762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 170862306a36Sopenharmony_ci }, 170962306a36Sopenharmony_ci }, 171062306a36Sopenharmony_ci}; 171162306a36Sopenharmony_ci 171262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_pixel1_clk = { 171362306a36Sopenharmony_ci .halt_reg = 0x2074, 171462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 171562306a36Sopenharmony_ci .clkr = { 171662306a36Sopenharmony_ci .enable_reg = 0x2074, 171762306a36Sopenharmony_ci .enable_mask = BIT(0), 171862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 171962306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_pixel1_clk", 172062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 172162306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_pixel1_clk_src.clkr.hw, 172262306a36Sopenharmony_ci }, 172362306a36Sopenharmony_ci .num_parents = 1, 172462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 172562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 172662306a36Sopenharmony_ci }, 172762306a36Sopenharmony_ci }, 172862306a36Sopenharmony_ci}; 172962306a36Sopenharmony_ci 173062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx0_usb_router_link_intf_clk = { 173162306a36Sopenharmony_ci .halt_reg = 0x2064, 173262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 173362306a36Sopenharmony_ci .clkr = { 173462306a36Sopenharmony_ci .enable_reg = 0x2064, 173562306a36Sopenharmony_ci .enable_mask = BIT(0), 173662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 173762306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx0_usb_router_link_intf_clk", 173862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 173962306a36Sopenharmony_ci &disp0_cc_mdss_dptx0_link_div_clk_src.clkr.hw, 174062306a36Sopenharmony_ci }, 174162306a36Sopenharmony_ci .num_parents = 1, 174262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 174362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 174462306a36Sopenharmony_ci }, 174562306a36Sopenharmony_ci }, 174662306a36Sopenharmony_ci}; 174762306a36Sopenharmony_ci 174862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx0_usb_router_link_intf_clk = { 174962306a36Sopenharmony_ci .halt_reg = 0x2064, 175062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 175162306a36Sopenharmony_ci .clkr = { 175262306a36Sopenharmony_ci .enable_reg = 0x2064, 175362306a36Sopenharmony_ci .enable_mask = BIT(0), 175462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 175562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx0_usb_router_link_intf_clk", 175662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 175762306a36Sopenharmony_ci &disp1_cc_mdss_dptx0_link_div_clk_src.clkr.hw, 175862306a36Sopenharmony_ci }, 175962306a36Sopenharmony_ci .num_parents = 1, 176062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 176162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 176262306a36Sopenharmony_ci }, 176362306a36Sopenharmony_ci }, 176462306a36Sopenharmony_ci}; 176562306a36Sopenharmony_ci 176662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_aux_clk = { 176762306a36Sopenharmony_ci .halt_reg = 0x20a0, 176862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 176962306a36Sopenharmony_ci .clkr = { 177062306a36Sopenharmony_ci .enable_reg = 0x20a0, 177162306a36Sopenharmony_ci .enable_mask = BIT(0), 177262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 177362306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_aux_clk", 177462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 177562306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_aux_clk_src.clkr.hw, 177662306a36Sopenharmony_ci }, 177762306a36Sopenharmony_ci .num_parents = 1, 177862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 177962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 178062306a36Sopenharmony_ci }, 178162306a36Sopenharmony_ci }, 178262306a36Sopenharmony_ci}; 178362306a36Sopenharmony_ci 178462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_aux_clk = { 178562306a36Sopenharmony_ci .halt_reg = 0x20a0, 178662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 178762306a36Sopenharmony_ci .clkr = { 178862306a36Sopenharmony_ci .enable_reg = 0x20a0, 178962306a36Sopenharmony_ci .enable_mask = BIT(0), 179062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 179162306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_aux_clk", 179262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 179362306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_aux_clk_src.clkr.hw, 179462306a36Sopenharmony_ci }, 179562306a36Sopenharmony_ci .num_parents = 1, 179662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 179762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 179862306a36Sopenharmony_ci }, 179962306a36Sopenharmony_ci }, 180062306a36Sopenharmony_ci}; 180162306a36Sopenharmony_ci 180262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_link_clk = { 180362306a36Sopenharmony_ci .halt_reg = 0x2084, 180462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 180562306a36Sopenharmony_ci .clkr = { 180662306a36Sopenharmony_ci .enable_reg = 0x2084, 180762306a36Sopenharmony_ci .enable_mask = BIT(0), 180862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 180962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_link_clk", 181062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 181162306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_link_clk_src.clkr.hw, 181262306a36Sopenharmony_ci }, 181362306a36Sopenharmony_ci .num_parents = 1, 181462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 181562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 181662306a36Sopenharmony_ci }, 181762306a36Sopenharmony_ci }, 181862306a36Sopenharmony_ci}; 181962306a36Sopenharmony_ci 182062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_link_clk = { 182162306a36Sopenharmony_ci .halt_reg = 0x2084, 182262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 182362306a36Sopenharmony_ci .clkr = { 182462306a36Sopenharmony_ci .enable_reg = 0x2084, 182562306a36Sopenharmony_ci .enable_mask = BIT(0), 182662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 182762306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_link_clk", 182862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 182962306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_link_clk_src.clkr.hw, 183062306a36Sopenharmony_ci }, 183162306a36Sopenharmony_ci .num_parents = 1, 183262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 183362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 183462306a36Sopenharmony_ci }, 183562306a36Sopenharmony_ci }, 183662306a36Sopenharmony_ci}; 183762306a36Sopenharmony_ci 183862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_link_intf_clk = { 183962306a36Sopenharmony_ci .halt_reg = 0x2088, 184062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 184162306a36Sopenharmony_ci .clkr = { 184262306a36Sopenharmony_ci .enable_reg = 0x2088, 184362306a36Sopenharmony_ci .enable_mask = BIT(0), 184462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 184562306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_link_intf_clk", 184662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 184762306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_link_div_clk_src.clkr.hw, 184862306a36Sopenharmony_ci }, 184962306a36Sopenharmony_ci .num_parents = 1, 185062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 185162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 185262306a36Sopenharmony_ci }, 185362306a36Sopenharmony_ci }, 185462306a36Sopenharmony_ci}; 185562306a36Sopenharmony_ci 185662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_link_intf_clk = { 185762306a36Sopenharmony_ci .halt_reg = 0x2088, 185862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 185962306a36Sopenharmony_ci .clkr = { 186062306a36Sopenharmony_ci .enable_reg = 0x2088, 186162306a36Sopenharmony_ci .enable_mask = BIT(0), 186262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 186362306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_link_intf_clk", 186462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 186562306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_link_div_clk_src.clkr.hw, 186662306a36Sopenharmony_ci }, 186762306a36Sopenharmony_ci .num_parents = 1, 186862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 186962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 187062306a36Sopenharmony_ci }, 187162306a36Sopenharmony_ci }, 187262306a36Sopenharmony_ci}; 187362306a36Sopenharmony_ci 187462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_pixel0_clk = { 187562306a36Sopenharmony_ci .halt_reg = 0x2078, 187662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 187762306a36Sopenharmony_ci .clkr = { 187862306a36Sopenharmony_ci .enable_reg = 0x2078, 187962306a36Sopenharmony_ci .enable_mask = BIT(0), 188062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 188162306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_pixel0_clk", 188262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 188362306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_pixel0_clk_src.clkr.hw, 188462306a36Sopenharmony_ci }, 188562306a36Sopenharmony_ci .num_parents = 1, 188662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 188762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 188862306a36Sopenharmony_ci }, 188962306a36Sopenharmony_ci }, 189062306a36Sopenharmony_ci}; 189162306a36Sopenharmony_ci 189262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_pixel0_clk = { 189362306a36Sopenharmony_ci .halt_reg = 0x2078, 189462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 189562306a36Sopenharmony_ci .clkr = { 189662306a36Sopenharmony_ci .enable_reg = 0x2078, 189762306a36Sopenharmony_ci .enable_mask = BIT(0), 189862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 189962306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_pixel0_clk", 190062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 190162306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_pixel0_clk_src.clkr.hw, 190262306a36Sopenharmony_ci }, 190362306a36Sopenharmony_ci .num_parents = 1, 190462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 190562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 190662306a36Sopenharmony_ci }, 190762306a36Sopenharmony_ci }, 190862306a36Sopenharmony_ci}; 190962306a36Sopenharmony_ci 191062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_pixel1_clk = { 191162306a36Sopenharmony_ci .halt_reg = 0x236c, 191262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 191362306a36Sopenharmony_ci .clkr = { 191462306a36Sopenharmony_ci .enable_reg = 0x236c, 191562306a36Sopenharmony_ci .enable_mask = BIT(0), 191662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 191762306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_pixel1_clk", 191862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 191962306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_pixel1_clk_src.clkr.hw, 192062306a36Sopenharmony_ci }, 192162306a36Sopenharmony_ci .num_parents = 1, 192262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 192362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 192462306a36Sopenharmony_ci }, 192562306a36Sopenharmony_ci }, 192662306a36Sopenharmony_ci}; 192762306a36Sopenharmony_ci 192862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_pixel1_clk = { 192962306a36Sopenharmony_ci .halt_reg = 0x236c, 193062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 193162306a36Sopenharmony_ci .clkr = { 193262306a36Sopenharmony_ci .enable_reg = 0x236c, 193362306a36Sopenharmony_ci .enable_mask = BIT(0), 193462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 193562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_pixel1_clk", 193662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 193762306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_pixel1_clk_src.clkr.hw, 193862306a36Sopenharmony_ci }, 193962306a36Sopenharmony_ci .num_parents = 1, 194062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 194162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 194262306a36Sopenharmony_ci }, 194362306a36Sopenharmony_ci }, 194462306a36Sopenharmony_ci}; 194562306a36Sopenharmony_ci 194662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx1_usb_router_link_intf_clk = { 194762306a36Sopenharmony_ci .halt_reg = 0x208c, 194862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 194962306a36Sopenharmony_ci .clkr = { 195062306a36Sopenharmony_ci .enable_reg = 0x208c, 195162306a36Sopenharmony_ci .enable_mask = BIT(0), 195262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 195362306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx1_usb_router_link_intf_clk", 195462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 195562306a36Sopenharmony_ci &disp0_cc_mdss_dptx1_link_div_clk_src.clkr.hw, 195662306a36Sopenharmony_ci }, 195762306a36Sopenharmony_ci .num_parents = 1, 195862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 195962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 196062306a36Sopenharmony_ci }, 196162306a36Sopenharmony_ci }, 196262306a36Sopenharmony_ci}; 196362306a36Sopenharmony_ci 196462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx1_usb_router_link_intf_clk = { 196562306a36Sopenharmony_ci .halt_reg = 0x208c, 196662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 196762306a36Sopenharmony_ci .clkr = { 196862306a36Sopenharmony_ci .enable_reg = 0x208c, 196962306a36Sopenharmony_ci .enable_mask = BIT(0), 197062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 197162306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx1_usb_router_link_intf_clk", 197262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 197362306a36Sopenharmony_ci &disp1_cc_mdss_dptx1_link_div_clk_src.clkr.hw, 197462306a36Sopenharmony_ci }, 197562306a36Sopenharmony_ci .num_parents = 1, 197662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 197762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 197862306a36Sopenharmony_ci }, 197962306a36Sopenharmony_ci }, 198062306a36Sopenharmony_ci}; 198162306a36Sopenharmony_ci 198262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx2_aux_clk = { 198362306a36Sopenharmony_ci .halt_reg = 0x20a4, 198462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 198562306a36Sopenharmony_ci .clkr = { 198662306a36Sopenharmony_ci .enable_reg = 0x20a4, 198762306a36Sopenharmony_ci .enable_mask = BIT(0), 198862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 198962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_aux_clk", 199062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 199162306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_aux_clk_src.clkr.hw, 199262306a36Sopenharmony_ci }, 199362306a36Sopenharmony_ci .num_parents = 1, 199462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 199562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 199662306a36Sopenharmony_ci }, 199762306a36Sopenharmony_ci }, 199862306a36Sopenharmony_ci}; 199962306a36Sopenharmony_ci 200062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx2_aux_clk = { 200162306a36Sopenharmony_ci .halt_reg = 0x20a4, 200262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 200362306a36Sopenharmony_ci .clkr = { 200462306a36Sopenharmony_ci .enable_reg = 0x20a4, 200562306a36Sopenharmony_ci .enable_mask = BIT(0), 200662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 200762306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_aux_clk", 200862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 200962306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_aux_clk_src.clkr.hw, 201062306a36Sopenharmony_ci }, 201162306a36Sopenharmony_ci .num_parents = 1, 201262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 201362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 201462306a36Sopenharmony_ci }, 201562306a36Sopenharmony_ci }, 201662306a36Sopenharmony_ci}; 201762306a36Sopenharmony_ci 201862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx2_link_clk = { 201962306a36Sopenharmony_ci .halt_reg = 0x2090, 202062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 202162306a36Sopenharmony_ci .clkr = { 202262306a36Sopenharmony_ci .enable_reg = 0x2090, 202362306a36Sopenharmony_ci .enable_mask = BIT(0), 202462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 202562306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_link_clk", 202662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 202762306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_link_clk_src.clkr.hw, 202862306a36Sopenharmony_ci }, 202962306a36Sopenharmony_ci .num_parents = 1, 203062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 203162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 203262306a36Sopenharmony_ci }, 203362306a36Sopenharmony_ci }, 203462306a36Sopenharmony_ci}; 203562306a36Sopenharmony_ci 203662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx2_link_clk = { 203762306a36Sopenharmony_ci .halt_reg = 0x2090, 203862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 203962306a36Sopenharmony_ci .clkr = { 204062306a36Sopenharmony_ci .enable_reg = 0x2090, 204162306a36Sopenharmony_ci .enable_mask = BIT(0), 204262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 204362306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_link_clk", 204462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 204562306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_link_clk_src.clkr.hw, 204662306a36Sopenharmony_ci }, 204762306a36Sopenharmony_ci .num_parents = 1, 204862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 204962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 205062306a36Sopenharmony_ci }, 205162306a36Sopenharmony_ci }, 205262306a36Sopenharmony_ci}; 205362306a36Sopenharmony_ci 205462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx2_link_intf_clk = { 205562306a36Sopenharmony_ci .halt_reg = 0x2094, 205662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 205762306a36Sopenharmony_ci .clkr = { 205862306a36Sopenharmony_ci .enable_reg = 0x2094, 205962306a36Sopenharmony_ci .enable_mask = BIT(0), 206062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 206162306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_link_intf_clk", 206262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 206362306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_link_div_clk_src.clkr.hw, 206462306a36Sopenharmony_ci }, 206562306a36Sopenharmony_ci .num_parents = 1, 206662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 206762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 206862306a36Sopenharmony_ci }, 206962306a36Sopenharmony_ci }, 207062306a36Sopenharmony_ci}; 207162306a36Sopenharmony_ci 207262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx2_link_intf_clk = { 207362306a36Sopenharmony_ci .halt_reg = 0x2094, 207462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 207562306a36Sopenharmony_ci .clkr = { 207662306a36Sopenharmony_ci .enable_reg = 0x2094, 207762306a36Sopenharmony_ci .enable_mask = BIT(0), 207862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 207962306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_link_intf_clk", 208062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 208162306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_link_div_clk_src.clkr.hw, 208262306a36Sopenharmony_ci }, 208362306a36Sopenharmony_ci .num_parents = 1, 208462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 208562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 208662306a36Sopenharmony_ci }, 208762306a36Sopenharmony_ci }, 208862306a36Sopenharmony_ci}; 208962306a36Sopenharmony_ci 209062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx2_pixel0_clk = { 209162306a36Sopenharmony_ci .halt_reg = 0x207c, 209262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 209362306a36Sopenharmony_ci .clkr = { 209462306a36Sopenharmony_ci .enable_reg = 0x207c, 209562306a36Sopenharmony_ci .enable_mask = BIT(0), 209662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 209762306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_pixel0_clk", 209862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 209962306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_pixel0_clk_src.clkr.hw, 210062306a36Sopenharmony_ci }, 210162306a36Sopenharmony_ci .num_parents = 1, 210262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 210362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 210462306a36Sopenharmony_ci }, 210562306a36Sopenharmony_ci }, 210662306a36Sopenharmony_ci}; 210762306a36Sopenharmony_ci 210862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx2_pixel0_clk = { 210962306a36Sopenharmony_ci .halt_reg = 0x207c, 211062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 211162306a36Sopenharmony_ci .clkr = { 211262306a36Sopenharmony_ci .enable_reg = 0x207c, 211362306a36Sopenharmony_ci .enable_mask = BIT(0), 211462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 211562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_pixel0_clk", 211662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 211762306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_pixel0_clk_src.clkr.hw, 211862306a36Sopenharmony_ci }, 211962306a36Sopenharmony_ci .num_parents = 1, 212062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 212162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 212262306a36Sopenharmony_ci }, 212362306a36Sopenharmony_ci }, 212462306a36Sopenharmony_ci}; 212562306a36Sopenharmony_ci 212662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx2_pixel1_clk = { 212762306a36Sopenharmony_ci .halt_reg = 0x2080, 212862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 212962306a36Sopenharmony_ci .clkr = { 213062306a36Sopenharmony_ci .enable_reg = 0x2080, 213162306a36Sopenharmony_ci .enable_mask = BIT(0), 213262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 213362306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx2_pixel1_clk", 213462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 213562306a36Sopenharmony_ci &disp0_cc_mdss_dptx2_pixel1_clk_src.clkr.hw, 213662306a36Sopenharmony_ci }, 213762306a36Sopenharmony_ci .num_parents = 1, 213862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 213962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 214062306a36Sopenharmony_ci }, 214162306a36Sopenharmony_ci }, 214262306a36Sopenharmony_ci}; 214362306a36Sopenharmony_ci 214462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx2_pixel1_clk = { 214562306a36Sopenharmony_ci .halt_reg = 0x2080, 214662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 214762306a36Sopenharmony_ci .clkr = { 214862306a36Sopenharmony_ci .enable_reg = 0x2080, 214962306a36Sopenharmony_ci .enable_mask = BIT(0), 215062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 215162306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx2_pixel1_clk", 215262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 215362306a36Sopenharmony_ci &disp1_cc_mdss_dptx2_pixel1_clk_src.clkr.hw, 215462306a36Sopenharmony_ci }, 215562306a36Sopenharmony_ci .num_parents = 1, 215662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 215762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 215862306a36Sopenharmony_ci }, 215962306a36Sopenharmony_ci }, 216062306a36Sopenharmony_ci}; 216162306a36Sopenharmony_ci 216262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx3_aux_clk = { 216362306a36Sopenharmony_ci .halt_reg = 0x20b8, 216462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 216562306a36Sopenharmony_ci .clkr = { 216662306a36Sopenharmony_ci .enable_reg = 0x20b8, 216762306a36Sopenharmony_ci .enable_mask = BIT(0), 216862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 216962306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_aux_clk", 217062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 217162306a36Sopenharmony_ci &disp0_cc_mdss_dptx3_aux_clk_src.clkr.hw, 217262306a36Sopenharmony_ci }, 217362306a36Sopenharmony_ci .num_parents = 1, 217462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 217562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 217662306a36Sopenharmony_ci }, 217762306a36Sopenharmony_ci }, 217862306a36Sopenharmony_ci}; 217962306a36Sopenharmony_ci 218062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx3_aux_clk = { 218162306a36Sopenharmony_ci .halt_reg = 0x20b8, 218262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 218362306a36Sopenharmony_ci .clkr = { 218462306a36Sopenharmony_ci .enable_reg = 0x20b8, 218562306a36Sopenharmony_ci .enable_mask = BIT(0), 218662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 218762306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_aux_clk", 218862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 218962306a36Sopenharmony_ci &disp1_cc_mdss_dptx3_aux_clk_src.clkr.hw, 219062306a36Sopenharmony_ci }, 219162306a36Sopenharmony_ci .num_parents = 1, 219262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 219362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 219462306a36Sopenharmony_ci }, 219562306a36Sopenharmony_ci }, 219662306a36Sopenharmony_ci}; 219762306a36Sopenharmony_ci 219862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx3_link_clk = { 219962306a36Sopenharmony_ci .halt_reg = 0x20ac, 220062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 220162306a36Sopenharmony_ci .clkr = { 220262306a36Sopenharmony_ci .enable_reg = 0x20ac, 220362306a36Sopenharmony_ci .enable_mask = BIT(0), 220462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 220562306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_link_clk", 220662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 220762306a36Sopenharmony_ci &disp0_cc_mdss_dptx3_link_clk_src.clkr.hw, 220862306a36Sopenharmony_ci }, 220962306a36Sopenharmony_ci .num_parents = 1, 221062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 221162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 221262306a36Sopenharmony_ci }, 221362306a36Sopenharmony_ci }, 221462306a36Sopenharmony_ci}; 221562306a36Sopenharmony_ci 221662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx3_link_clk = { 221762306a36Sopenharmony_ci .halt_reg = 0x20ac, 221862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 221962306a36Sopenharmony_ci .clkr = { 222062306a36Sopenharmony_ci .enable_reg = 0x20ac, 222162306a36Sopenharmony_ci .enable_mask = BIT(0), 222262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 222362306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_link_clk", 222462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 222562306a36Sopenharmony_ci &disp1_cc_mdss_dptx3_link_clk_src.clkr.hw, 222662306a36Sopenharmony_ci }, 222762306a36Sopenharmony_ci .num_parents = 1, 222862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 222962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 223062306a36Sopenharmony_ci }, 223162306a36Sopenharmony_ci }, 223262306a36Sopenharmony_ci}; 223362306a36Sopenharmony_ci 223462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx3_link_intf_clk = { 223562306a36Sopenharmony_ci .halt_reg = 0x20b0, 223662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 223762306a36Sopenharmony_ci .clkr = { 223862306a36Sopenharmony_ci .enable_reg = 0x20b0, 223962306a36Sopenharmony_ci .enable_mask = BIT(0), 224062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 224162306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_link_intf_clk", 224262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 224362306a36Sopenharmony_ci &disp0_cc_mdss_dptx3_link_div_clk_src.clkr.hw, 224462306a36Sopenharmony_ci }, 224562306a36Sopenharmony_ci .num_parents = 1, 224662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 224762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 224862306a36Sopenharmony_ci }, 224962306a36Sopenharmony_ci }, 225062306a36Sopenharmony_ci}; 225162306a36Sopenharmony_ci 225262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx3_link_intf_clk = { 225362306a36Sopenharmony_ci .halt_reg = 0x20b0, 225462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 225562306a36Sopenharmony_ci .clkr = { 225662306a36Sopenharmony_ci .enable_reg = 0x20b0, 225762306a36Sopenharmony_ci .enable_mask = BIT(0), 225862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 225962306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_link_intf_clk", 226062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 226162306a36Sopenharmony_ci &disp1_cc_mdss_dptx3_link_div_clk_src.clkr.hw, 226262306a36Sopenharmony_ci }, 226362306a36Sopenharmony_ci .num_parents = 1, 226462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 226562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 226662306a36Sopenharmony_ci }, 226762306a36Sopenharmony_ci }, 226862306a36Sopenharmony_ci}; 226962306a36Sopenharmony_ci 227062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_dptx3_pixel0_clk = { 227162306a36Sopenharmony_ci .halt_reg = 0x20a8, 227262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 227362306a36Sopenharmony_ci .clkr = { 227462306a36Sopenharmony_ci .enable_reg = 0x20a8, 227562306a36Sopenharmony_ci .enable_mask = BIT(0), 227662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 227762306a36Sopenharmony_ci .name = "disp0_cc_mdss_dptx3_pixel0_clk", 227862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 227962306a36Sopenharmony_ci &disp0_cc_mdss_dptx3_pixel0_clk_src.clkr.hw, 228062306a36Sopenharmony_ci }, 228162306a36Sopenharmony_ci .num_parents = 1, 228262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 228362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 228462306a36Sopenharmony_ci }, 228562306a36Sopenharmony_ci }, 228662306a36Sopenharmony_ci}; 228762306a36Sopenharmony_ci 228862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_dptx3_pixel0_clk = { 228962306a36Sopenharmony_ci .halt_reg = 0x20a8, 229062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 229162306a36Sopenharmony_ci .clkr = { 229262306a36Sopenharmony_ci .enable_reg = 0x20a8, 229362306a36Sopenharmony_ci .enable_mask = BIT(0), 229462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 229562306a36Sopenharmony_ci .name = "disp1_cc_mdss_dptx3_pixel0_clk", 229662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 229762306a36Sopenharmony_ci &disp1_cc_mdss_dptx3_pixel0_clk_src.clkr.hw, 229862306a36Sopenharmony_ci }, 229962306a36Sopenharmony_ci .num_parents = 1, 230062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 230162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 230262306a36Sopenharmony_ci }, 230362306a36Sopenharmony_ci }, 230462306a36Sopenharmony_ci}; 230562306a36Sopenharmony_ci 230662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_esc0_clk = { 230762306a36Sopenharmony_ci .halt_reg = 0x2054, 230862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 230962306a36Sopenharmony_ci .clkr = { 231062306a36Sopenharmony_ci .enable_reg = 0x2054, 231162306a36Sopenharmony_ci .enable_mask = BIT(0), 231262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 231362306a36Sopenharmony_ci .name = "disp0_cc_mdss_esc0_clk", 231462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 231562306a36Sopenharmony_ci &disp0_cc_mdss_esc0_clk_src.clkr.hw, 231662306a36Sopenharmony_ci }, 231762306a36Sopenharmony_ci .num_parents = 1, 231862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 231962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 232062306a36Sopenharmony_ci }, 232162306a36Sopenharmony_ci }, 232262306a36Sopenharmony_ci}; 232362306a36Sopenharmony_ci 232462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_esc0_clk = { 232562306a36Sopenharmony_ci .halt_reg = 0x2054, 232662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 232762306a36Sopenharmony_ci .clkr = { 232862306a36Sopenharmony_ci .enable_reg = 0x2054, 232962306a36Sopenharmony_ci .enable_mask = BIT(0), 233062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 233162306a36Sopenharmony_ci .name = "disp1_cc_mdss_esc0_clk", 233262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 233362306a36Sopenharmony_ci &disp1_cc_mdss_esc0_clk_src.clkr.hw, 233462306a36Sopenharmony_ci }, 233562306a36Sopenharmony_ci .num_parents = 1, 233662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 233762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 233862306a36Sopenharmony_ci }, 233962306a36Sopenharmony_ci }, 234062306a36Sopenharmony_ci}; 234162306a36Sopenharmony_ci 234262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_esc1_clk = { 234362306a36Sopenharmony_ci .halt_reg = 0x2058, 234462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 234562306a36Sopenharmony_ci .clkr = { 234662306a36Sopenharmony_ci .enable_reg = 0x2058, 234762306a36Sopenharmony_ci .enable_mask = BIT(0), 234862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 234962306a36Sopenharmony_ci .name = "disp0_cc_mdss_esc1_clk", 235062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 235162306a36Sopenharmony_ci &disp0_cc_mdss_esc1_clk_src.clkr.hw, 235262306a36Sopenharmony_ci }, 235362306a36Sopenharmony_ci .num_parents = 1, 235462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 235562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 235662306a36Sopenharmony_ci }, 235762306a36Sopenharmony_ci }, 235862306a36Sopenharmony_ci}; 235962306a36Sopenharmony_ci 236062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_esc1_clk = { 236162306a36Sopenharmony_ci .halt_reg = 0x2058, 236262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 236362306a36Sopenharmony_ci .clkr = { 236462306a36Sopenharmony_ci .enable_reg = 0x2058, 236562306a36Sopenharmony_ci .enable_mask = BIT(0), 236662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 236762306a36Sopenharmony_ci .name = "disp1_cc_mdss_esc1_clk", 236862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 236962306a36Sopenharmony_ci &disp1_cc_mdss_esc1_clk_src.clkr.hw, 237062306a36Sopenharmony_ci }, 237162306a36Sopenharmony_ci .num_parents = 1, 237262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 237362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 237462306a36Sopenharmony_ci }, 237562306a36Sopenharmony_ci }, 237662306a36Sopenharmony_ci}; 237762306a36Sopenharmony_ci 237862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_mdp1_clk = { 237962306a36Sopenharmony_ci .halt_reg = 0x2014, 238062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 238162306a36Sopenharmony_ci .clkr = { 238262306a36Sopenharmony_ci .enable_reg = 0x2014, 238362306a36Sopenharmony_ci .enable_mask = BIT(0), 238462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 238562306a36Sopenharmony_ci .name = "disp0_cc_mdss_mdp1_clk", 238662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 238762306a36Sopenharmony_ci &disp0_cc_mdss_mdp_clk_src.clkr.hw, 238862306a36Sopenharmony_ci }, 238962306a36Sopenharmony_ci .num_parents = 1, 239062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 239162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 239262306a36Sopenharmony_ci }, 239362306a36Sopenharmony_ci }, 239462306a36Sopenharmony_ci}; 239562306a36Sopenharmony_ci 239662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_mdp1_clk = { 239762306a36Sopenharmony_ci .halt_reg = 0x2014, 239862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 239962306a36Sopenharmony_ci .clkr = { 240062306a36Sopenharmony_ci .enable_reg = 0x2014, 240162306a36Sopenharmony_ci .enable_mask = BIT(0), 240262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 240362306a36Sopenharmony_ci .name = "disp1_cc_mdss_mdp1_clk", 240462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 240562306a36Sopenharmony_ci &disp1_cc_mdss_mdp_clk_src.clkr.hw, 240662306a36Sopenharmony_ci }, 240762306a36Sopenharmony_ci .num_parents = 1, 240862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 240962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 241062306a36Sopenharmony_ci }, 241162306a36Sopenharmony_ci }, 241262306a36Sopenharmony_ci}; 241362306a36Sopenharmony_ci 241462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_mdp_clk = { 241562306a36Sopenharmony_ci .halt_reg = 0x200c, 241662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 241762306a36Sopenharmony_ci .clkr = { 241862306a36Sopenharmony_ci .enable_reg = 0x200c, 241962306a36Sopenharmony_ci .enable_mask = BIT(0), 242062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 242162306a36Sopenharmony_ci .name = "disp0_cc_mdss_mdp_clk", 242262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 242362306a36Sopenharmony_ci &disp0_cc_mdss_mdp_clk_src.clkr.hw, 242462306a36Sopenharmony_ci }, 242562306a36Sopenharmony_ci .num_parents = 1, 242662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 242762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 242862306a36Sopenharmony_ci }, 242962306a36Sopenharmony_ci }, 243062306a36Sopenharmony_ci}; 243162306a36Sopenharmony_ci 243262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_mdp_clk = { 243362306a36Sopenharmony_ci .halt_reg = 0x200c, 243462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 243562306a36Sopenharmony_ci .clkr = { 243662306a36Sopenharmony_ci .enable_reg = 0x200c, 243762306a36Sopenharmony_ci .enable_mask = BIT(0), 243862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 243962306a36Sopenharmony_ci .name = "disp1_cc_mdss_mdp_clk", 244062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 244162306a36Sopenharmony_ci &disp1_cc_mdss_mdp_clk_src.clkr.hw, 244262306a36Sopenharmony_ci }, 244362306a36Sopenharmony_ci .num_parents = 1, 244462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 244562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 244662306a36Sopenharmony_ci }, 244762306a36Sopenharmony_ci }, 244862306a36Sopenharmony_ci}; 244962306a36Sopenharmony_ci 245062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_mdp_lut1_clk = { 245162306a36Sopenharmony_ci .halt_reg = 0x2034, 245262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 245362306a36Sopenharmony_ci .clkr = { 245462306a36Sopenharmony_ci .enable_reg = 0x2034, 245562306a36Sopenharmony_ci .enable_mask = BIT(0), 245662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 245762306a36Sopenharmony_ci .name = "disp0_cc_mdss_mdp_lut1_clk", 245862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 245962306a36Sopenharmony_ci &disp0_cc_mdss_mdp_clk_src.clkr.hw, 246062306a36Sopenharmony_ci }, 246162306a36Sopenharmony_ci .num_parents = 1, 246262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 246362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 246462306a36Sopenharmony_ci }, 246562306a36Sopenharmony_ci }, 246662306a36Sopenharmony_ci}; 246762306a36Sopenharmony_ci 246862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_mdp_lut1_clk = { 246962306a36Sopenharmony_ci .halt_reg = 0x2034, 247062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 247162306a36Sopenharmony_ci .clkr = { 247262306a36Sopenharmony_ci .enable_reg = 0x2034, 247362306a36Sopenharmony_ci .enable_mask = BIT(0), 247462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 247562306a36Sopenharmony_ci .name = "disp1_cc_mdss_mdp_lut1_clk", 247662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 247762306a36Sopenharmony_ci &disp1_cc_mdss_mdp_clk_src.clkr.hw, 247862306a36Sopenharmony_ci }, 247962306a36Sopenharmony_ci .num_parents = 1, 248062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 248162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 248262306a36Sopenharmony_ci }, 248362306a36Sopenharmony_ci }, 248462306a36Sopenharmony_ci}; 248562306a36Sopenharmony_ci 248662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_mdp_lut_clk = { 248762306a36Sopenharmony_ci .halt_reg = 0x202c, 248862306a36Sopenharmony_ci .halt_check = BRANCH_HALT_VOTED, 248962306a36Sopenharmony_ci .clkr = { 249062306a36Sopenharmony_ci .enable_reg = 0x202c, 249162306a36Sopenharmony_ci .enable_mask = BIT(0), 249262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 249362306a36Sopenharmony_ci .name = "disp0_cc_mdss_mdp_lut_clk", 249462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 249562306a36Sopenharmony_ci &disp0_cc_mdss_mdp_clk_src.clkr.hw, 249662306a36Sopenharmony_ci }, 249762306a36Sopenharmony_ci .num_parents = 1, 249862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 249962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 250062306a36Sopenharmony_ci }, 250162306a36Sopenharmony_ci }, 250262306a36Sopenharmony_ci}; 250362306a36Sopenharmony_ci 250462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_mdp_lut_clk = { 250562306a36Sopenharmony_ci .halt_reg = 0x202c, 250662306a36Sopenharmony_ci .halt_check = BRANCH_HALT_VOTED, 250762306a36Sopenharmony_ci .clkr = { 250862306a36Sopenharmony_ci .enable_reg = 0x202c, 250962306a36Sopenharmony_ci .enable_mask = BIT(0), 251062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 251162306a36Sopenharmony_ci .name = "disp1_cc_mdss_mdp_lut_clk", 251262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 251362306a36Sopenharmony_ci &disp1_cc_mdss_mdp_clk_src.clkr.hw, 251462306a36Sopenharmony_ci }, 251562306a36Sopenharmony_ci .num_parents = 1, 251662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 251762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 251862306a36Sopenharmony_ci }, 251962306a36Sopenharmony_ci }, 252062306a36Sopenharmony_ci}; 252162306a36Sopenharmony_ci 252262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_non_gdsc_ahb_clk = { 252362306a36Sopenharmony_ci .halt_reg = 0x4004, 252462306a36Sopenharmony_ci .halt_check = BRANCH_HALT_VOTED, 252562306a36Sopenharmony_ci .clkr = { 252662306a36Sopenharmony_ci .enable_reg = 0x4004, 252762306a36Sopenharmony_ci .enable_mask = BIT(0), 252862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 252962306a36Sopenharmony_ci .name = "disp0_cc_mdss_non_gdsc_ahb_clk", 253062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 253162306a36Sopenharmony_ci &disp0_cc_mdss_ahb_clk_src.clkr.hw, 253262306a36Sopenharmony_ci }, 253362306a36Sopenharmony_ci .num_parents = 1, 253462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 253562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 253662306a36Sopenharmony_ci }, 253762306a36Sopenharmony_ci }, 253862306a36Sopenharmony_ci}; 253962306a36Sopenharmony_ci 254062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_non_gdsc_ahb_clk = { 254162306a36Sopenharmony_ci .halt_reg = 0x4004, 254262306a36Sopenharmony_ci .halt_check = BRANCH_HALT_VOTED, 254362306a36Sopenharmony_ci .clkr = { 254462306a36Sopenharmony_ci .enable_reg = 0x4004, 254562306a36Sopenharmony_ci .enable_mask = BIT(0), 254662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 254762306a36Sopenharmony_ci .name = "disp1_cc_mdss_non_gdsc_ahb_clk", 254862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 254962306a36Sopenharmony_ci &disp1_cc_mdss_ahb_clk_src.clkr.hw, 255062306a36Sopenharmony_ci }, 255162306a36Sopenharmony_ci .num_parents = 1, 255262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 255362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 255462306a36Sopenharmony_ci }, 255562306a36Sopenharmony_ci }, 255662306a36Sopenharmony_ci}; 255762306a36Sopenharmony_ci 255862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_pclk0_clk = { 255962306a36Sopenharmony_ci .halt_reg = 0x2004, 256062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 256162306a36Sopenharmony_ci .clkr = { 256262306a36Sopenharmony_ci .enable_reg = 0x2004, 256362306a36Sopenharmony_ci .enable_mask = BIT(0), 256462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 256562306a36Sopenharmony_ci .name = "disp0_cc_mdss_pclk0_clk", 256662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 256762306a36Sopenharmony_ci &disp0_cc_mdss_pclk0_clk_src.clkr.hw, 256862306a36Sopenharmony_ci }, 256962306a36Sopenharmony_ci .num_parents = 1, 257062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 257162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 257262306a36Sopenharmony_ci }, 257362306a36Sopenharmony_ci }, 257462306a36Sopenharmony_ci}; 257562306a36Sopenharmony_ci 257662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_pclk0_clk = { 257762306a36Sopenharmony_ci .halt_reg = 0x2004, 257862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 257962306a36Sopenharmony_ci .clkr = { 258062306a36Sopenharmony_ci .enable_reg = 0x2004, 258162306a36Sopenharmony_ci .enable_mask = BIT(0), 258262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 258362306a36Sopenharmony_ci .name = "disp1_cc_mdss_pclk0_clk", 258462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 258562306a36Sopenharmony_ci &disp1_cc_mdss_pclk0_clk_src.clkr.hw, 258662306a36Sopenharmony_ci }, 258762306a36Sopenharmony_ci .num_parents = 1, 258862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 258962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 259062306a36Sopenharmony_ci }, 259162306a36Sopenharmony_ci }, 259262306a36Sopenharmony_ci}; 259362306a36Sopenharmony_ci 259462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_pclk1_clk = { 259562306a36Sopenharmony_ci .halt_reg = 0x2008, 259662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 259762306a36Sopenharmony_ci .clkr = { 259862306a36Sopenharmony_ci .enable_reg = 0x2008, 259962306a36Sopenharmony_ci .enable_mask = BIT(0), 260062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 260162306a36Sopenharmony_ci .name = "disp0_cc_mdss_pclk1_clk", 260262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 260362306a36Sopenharmony_ci &disp0_cc_mdss_pclk1_clk_src.clkr.hw, 260462306a36Sopenharmony_ci }, 260562306a36Sopenharmony_ci .num_parents = 1, 260662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 260762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 260862306a36Sopenharmony_ci }, 260962306a36Sopenharmony_ci }, 261062306a36Sopenharmony_ci}; 261162306a36Sopenharmony_ci 261262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_pclk1_clk = { 261362306a36Sopenharmony_ci .halt_reg = 0x2008, 261462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 261562306a36Sopenharmony_ci .clkr = { 261662306a36Sopenharmony_ci .enable_reg = 0x2008, 261762306a36Sopenharmony_ci .enable_mask = BIT(0), 261862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 261962306a36Sopenharmony_ci .name = "disp1_cc_mdss_pclk1_clk", 262062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 262162306a36Sopenharmony_ci &disp1_cc_mdss_pclk1_clk_src.clkr.hw, 262262306a36Sopenharmony_ci }, 262362306a36Sopenharmony_ci .num_parents = 1, 262462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 262562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 262662306a36Sopenharmony_ci }, 262762306a36Sopenharmony_ci }, 262862306a36Sopenharmony_ci}; 262962306a36Sopenharmony_ci 263062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_rot1_clk = { 263162306a36Sopenharmony_ci .halt_reg = 0x2024, 263262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 263362306a36Sopenharmony_ci .clkr = { 263462306a36Sopenharmony_ci .enable_reg = 0x2024, 263562306a36Sopenharmony_ci .enable_mask = BIT(0), 263662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 263762306a36Sopenharmony_ci .name = "disp0_cc_mdss_rot1_clk", 263862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 263962306a36Sopenharmony_ci &disp0_cc_mdss_rot_clk_src.clkr.hw, 264062306a36Sopenharmony_ci }, 264162306a36Sopenharmony_ci .num_parents = 1, 264262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 264362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 264462306a36Sopenharmony_ci }, 264562306a36Sopenharmony_ci }, 264662306a36Sopenharmony_ci}; 264762306a36Sopenharmony_ci 264862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_rot1_clk = { 264962306a36Sopenharmony_ci .halt_reg = 0x2024, 265062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 265162306a36Sopenharmony_ci .clkr = { 265262306a36Sopenharmony_ci .enable_reg = 0x2024, 265362306a36Sopenharmony_ci .enable_mask = BIT(0), 265462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 265562306a36Sopenharmony_ci .name = "disp1_cc_mdss_rot1_clk", 265662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 265762306a36Sopenharmony_ci &disp1_cc_mdss_rot_clk_src.clkr.hw, 265862306a36Sopenharmony_ci }, 265962306a36Sopenharmony_ci .num_parents = 1, 266062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 266162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 266262306a36Sopenharmony_ci }, 266362306a36Sopenharmony_ci }, 266462306a36Sopenharmony_ci}; 266562306a36Sopenharmony_ci 266662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_rot_clk = { 266762306a36Sopenharmony_ci .halt_reg = 0x201c, 266862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 266962306a36Sopenharmony_ci .clkr = { 267062306a36Sopenharmony_ci .enable_reg = 0x201c, 267162306a36Sopenharmony_ci .enable_mask = BIT(0), 267262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 267362306a36Sopenharmony_ci .name = "disp0_cc_mdss_rot_clk", 267462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 267562306a36Sopenharmony_ci &disp0_cc_mdss_rot_clk_src.clkr.hw, 267662306a36Sopenharmony_ci }, 267762306a36Sopenharmony_ci .num_parents = 1, 267862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 267962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 268062306a36Sopenharmony_ci }, 268162306a36Sopenharmony_ci }, 268262306a36Sopenharmony_ci}; 268362306a36Sopenharmony_ci 268462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_rot_clk = { 268562306a36Sopenharmony_ci .halt_reg = 0x201c, 268662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 268762306a36Sopenharmony_ci .clkr = { 268862306a36Sopenharmony_ci .enable_reg = 0x201c, 268962306a36Sopenharmony_ci .enable_mask = BIT(0), 269062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 269162306a36Sopenharmony_ci .name = "disp1_cc_mdss_rot_clk", 269262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 269362306a36Sopenharmony_ci &disp1_cc_mdss_rot_clk_src.clkr.hw, 269462306a36Sopenharmony_ci }, 269562306a36Sopenharmony_ci .num_parents = 1, 269662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 269762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 269862306a36Sopenharmony_ci }, 269962306a36Sopenharmony_ci }, 270062306a36Sopenharmony_ci}; 270162306a36Sopenharmony_ci 270262306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_rscc_ahb_clk = { 270362306a36Sopenharmony_ci .halt_reg = 0x400c, 270462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 270562306a36Sopenharmony_ci .clkr = { 270662306a36Sopenharmony_ci .enable_reg = 0x400c, 270762306a36Sopenharmony_ci .enable_mask = BIT(0), 270862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 270962306a36Sopenharmony_ci .name = "disp0_cc_mdss_rscc_ahb_clk", 271062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 271162306a36Sopenharmony_ci &disp0_cc_mdss_ahb_clk_src.clkr.hw, 271262306a36Sopenharmony_ci }, 271362306a36Sopenharmony_ci .num_parents = 1, 271462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 271562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 271662306a36Sopenharmony_ci }, 271762306a36Sopenharmony_ci }, 271862306a36Sopenharmony_ci}; 271962306a36Sopenharmony_ci 272062306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_rscc_ahb_clk = { 272162306a36Sopenharmony_ci .halt_reg = 0x400c, 272262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 272362306a36Sopenharmony_ci .clkr = { 272462306a36Sopenharmony_ci .enable_reg = 0x400c, 272562306a36Sopenharmony_ci .enable_mask = BIT(0), 272662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 272762306a36Sopenharmony_ci .name = "disp1_cc_mdss_rscc_ahb_clk", 272862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 272962306a36Sopenharmony_ci &disp1_cc_mdss_ahb_clk_src.clkr.hw, 273062306a36Sopenharmony_ci }, 273162306a36Sopenharmony_ci .num_parents = 1, 273262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 273362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 273462306a36Sopenharmony_ci }, 273562306a36Sopenharmony_ci }, 273662306a36Sopenharmony_ci}; 273762306a36Sopenharmony_ci 273862306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_rscc_vsync_clk = { 273962306a36Sopenharmony_ci .halt_reg = 0x4008, 274062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 274162306a36Sopenharmony_ci .clkr = { 274262306a36Sopenharmony_ci .enable_reg = 0x4008, 274362306a36Sopenharmony_ci .enable_mask = BIT(0), 274462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 274562306a36Sopenharmony_ci .name = "disp0_cc_mdss_rscc_vsync_clk", 274662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 274762306a36Sopenharmony_ci &disp0_cc_mdss_vsync_clk_src.clkr.hw, 274862306a36Sopenharmony_ci }, 274962306a36Sopenharmony_ci .num_parents = 1, 275062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 275162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 275262306a36Sopenharmony_ci }, 275362306a36Sopenharmony_ci }, 275462306a36Sopenharmony_ci}; 275562306a36Sopenharmony_ci 275662306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_rscc_vsync_clk = { 275762306a36Sopenharmony_ci .halt_reg = 0x4008, 275862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 275962306a36Sopenharmony_ci .clkr = { 276062306a36Sopenharmony_ci .enable_reg = 0x4008, 276162306a36Sopenharmony_ci .enable_mask = BIT(0), 276262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 276362306a36Sopenharmony_ci .name = "disp1_cc_mdss_rscc_vsync_clk", 276462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 276562306a36Sopenharmony_ci &disp1_cc_mdss_vsync_clk_src.clkr.hw, 276662306a36Sopenharmony_ci }, 276762306a36Sopenharmony_ci .num_parents = 1, 276862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 276962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 277062306a36Sopenharmony_ci }, 277162306a36Sopenharmony_ci }, 277262306a36Sopenharmony_ci}; 277362306a36Sopenharmony_ci 277462306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_vsync1_clk = { 277562306a36Sopenharmony_ci .halt_reg = 0x2040, 277662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 277762306a36Sopenharmony_ci .clkr = { 277862306a36Sopenharmony_ci .enable_reg = 0x2040, 277962306a36Sopenharmony_ci .enable_mask = BIT(0), 278062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 278162306a36Sopenharmony_ci .name = "disp0_cc_mdss_vsync1_clk", 278262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 278362306a36Sopenharmony_ci &disp0_cc_mdss_vsync_clk_src.clkr.hw, 278462306a36Sopenharmony_ci }, 278562306a36Sopenharmony_ci .num_parents = 1, 278662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 278762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 278862306a36Sopenharmony_ci }, 278962306a36Sopenharmony_ci }, 279062306a36Sopenharmony_ci}; 279162306a36Sopenharmony_ci 279262306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_vsync1_clk = { 279362306a36Sopenharmony_ci .halt_reg = 0x2040, 279462306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 279562306a36Sopenharmony_ci .clkr = { 279662306a36Sopenharmony_ci .enable_reg = 0x2040, 279762306a36Sopenharmony_ci .enable_mask = BIT(0), 279862306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 279962306a36Sopenharmony_ci .name = "disp1_cc_mdss_vsync1_clk", 280062306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 280162306a36Sopenharmony_ci &disp1_cc_mdss_vsync_clk_src.clkr.hw, 280262306a36Sopenharmony_ci }, 280362306a36Sopenharmony_ci .num_parents = 1, 280462306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 280562306a36Sopenharmony_ci .ops = &clk_branch2_ops, 280662306a36Sopenharmony_ci }, 280762306a36Sopenharmony_ci }, 280862306a36Sopenharmony_ci}; 280962306a36Sopenharmony_ci 281062306a36Sopenharmony_cistatic struct clk_branch disp0_cc_mdss_vsync_clk = { 281162306a36Sopenharmony_ci .halt_reg = 0x203c, 281262306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 281362306a36Sopenharmony_ci .clkr = { 281462306a36Sopenharmony_ci .enable_reg = 0x203c, 281562306a36Sopenharmony_ci .enable_mask = BIT(0), 281662306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 281762306a36Sopenharmony_ci .name = "disp0_cc_mdss_vsync_clk", 281862306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 281962306a36Sopenharmony_ci &disp0_cc_mdss_vsync_clk_src.clkr.hw, 282062306a36Sopenharmony_ci }, 282162306a36Sopenharmony_ci .num_parents = 1, 282262306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 282362306a36Sopenharmony_ci .ops = &clk_branch2_ops, 282462306a36Sopenharmony_ci }, 282562306a36Sopenharmony_ci }, 282662306a36Sopenharmony_ci}; 282762306a36Sopenharmony_ci 282862306a36Sopenharmony_cistatic struct clk_branch disp1_cc_mdss_vsync_clk = { 282962306a36Sopenharmony_ci .halt_reg = 0x203c, 283062306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 283162306a36Sopenharmony_ci .clkr = { 283262306a36Sopenharmony_ci .enable_reg = 0x203c, 283362306a36Sopenharmony_ci .enable_mask = BIT(0), 283462306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 283562306a36Sopenharmony_ci .name = "disp1_cc_mdss_vsync_clk", 283662306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 283762306a36Sopenharmony_ci &disp1_cc_mdss_vsync_clk_src.clkr.hw, 283862306a36Sopenharmony_ci }, 283962306a36Sopenharmony_ci .num_parents = 1, 284062306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 284162306a36Sopenharmony_ci .ops = &clk_branch2_ops, 284262306a36Sopenharmony_ci }, 284362306a36Sopenharmony_ci }, 284462306a36Sopenharmony_ci}; 284562306a36Sopenharmony_ci 284662306a36Sopenharmony_cistatic struct clk_branch disp0_cc_sleep_clk = { 284762306a36Sopenharmony_ci .halt_reg = 0x6078, 284862306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 284962306a36Sopenharmony_ci .clkr = { 285062306a36Sopenharmony_ci .enable_reg = 0x6078, 285162306a36Sopenharmony_ci .enable_mask = BIT(0), 285262306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 285362306a36Sopenharmony_ci .name = "disp0_cc_sleep_clk", 285462306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 285562306a36Sopenharmony_ci &disp0_cc_sleep_clk_src.clkr.hw, 285662306a36Sopenharmony_ci }, 285762306a36Sopenharmony_ci .num_parents = 1, 285862306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 285962306a36Sopenharmony_ci .ops = &clk_branch2_ops, 286062306a36Sopenharmony_ci }, 286162306a36Sopenharmony_ci }, 286262306a36Sopenharmony_ci}; 286362306a36Sopenharmony_ci 286462306a36Sopenharmony_cistatic struct clk_branch disp1_cc_sleep_clk = { 286562306a36Sopenharmony_ci .halt_reg = 0x6078, 286662306a36Sopenharmony_ci .halt_check = BRANCH_HALT, 286762306a36Sopenharmony_ci .clkr = { 286862306a36Sopenharmony_ci .enable_reg = 0x6078, 286962306a36Sopenharmony_ci .enable_mask = BIT(0), 287062306a36Sopenharmony_ci .hw.init = &(const struct clk_init_data) { 287162306a36Sopenharmony_ci .name = "disp1_cc_sleep_clk", 287262306a36Sopenharmony_ci .parent_hws = (const struct clk_hw*[]){ 287362306a36Sopenharmony_ci &disp1_cc_sleep_clk_src.clkr.hw, 287462306a36Sopenharmony_ci }, 287562306a36Sopenharmony_ci .num_parents = 1, 287662306a36Sopenharmony_ci .flags = CLK_SET_RATE_PARENT, 287762306a36Sopenharmony_ci .ops = &clk_branch2_ops, 287862306a36Sopenharmony_ci }, 287962306a36Sopenharmony_ci }, 288062306a36Sopenharmony_ci}; 288162306a36Sopenharmony_ci 288262306a36Sopenharmony_cistatic struct clk_regmap *disp0_cc_sc8280xp_clocks[] = { 288362306a36Sopenharmony_ci [DISP_CC_MDSS_AHB1_CLK] = &disp0_cc_mdss_ahb1_clk.clkr, 288462306a36Sopenharmony_ci [DISP_CC_MDSS_AHB_CLK] = &disp0_cc_mdss_ahb_clk.clkr, 288562306a36Sopenharmony_ci [DISP_CC_MDSS_AHB_CLK_SRC] = &disp0_cc_mdss_ahb_clk_src.clkr, 288662306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_CLK] = &disp0_cc_mdss_byte0_clk.clkr, 288762306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_CLK_SRC] = &disp0_cc_mdss_byte0_clk_src.clkr, 288862306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_DIV_CLK_SRC] = &disp0_cc_mdss_byte0_div_clk_src.clkr, 288962306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_INTF_CLK] = &disp0_cc_mdss_byte0_intf_clk.clkr, 289062306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_CLK] = &disp0_cc_mdss_byte1_clk.clkr, 289162306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_CLK_SRC] = &disp0_cc_mdss_byte1_clk_src.clkr, 289262306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_DIV_CLK_SRC] = &disp0_cc_mdss_byte1_div_clk_src.clkr, 289362306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_INTF_CLK] = &disp0_cc_mdss_byte1_intf_clk.clkr, 289462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_AUX_CLK] = &disp0_cc_mdss_dptx0_aux_clk.clkr, 289562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_AUX_CLK_SRC] = &disp0_cc_mdss_dptx0_aux_clk_src.clkr, 289662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_CLK] = &disp0_cc_mdss_dptx0_link_clk.clkr, 289762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_CLK_SRC] = &disp0_cc_mdss_dptx0_link_clk_src.clkr, 289862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_DIV_CLK_SRC] = &disp0_cc_mdss_dptx0_link_div_clk_src.clkr, 289962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_INTF_CLK] = &disp0_cc_mdss_dptx0_link_intf_clk.clkr, 290062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL0_CLK] = &disp0_cc_mdss_dptx0_pixel0_clk.clkr, 290162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL0_CLK_SRC] = &disp0_cc_mdss_dptx0_pixel0_clk_src.clkr, 290262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL1_CLK] = &disp0_cc_mdss_dptx0_pixel1_clk.clkr, 290362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL1_CLK_SRC] = &disp0_cc_mdss_dptx0_pixel1_clk_src.clkr, 290462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_USB_ROUTER_LINK_INTF_CLK] = &disp0_cc_mdss_dptx0_usb_router_link_intf_clk.clkr, 290562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_AUX_CLK] = &disp0_cc_mdss_dptx1_aux_clk.clkr, 290662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_AUX_CLK_SRC] = &disp0_cc_mdss_dptx1_aux_clk_src.clkr, 290762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_CLK] = &disp0_cc_mdss_dptx1_link_clk.clkr, 290862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_CLK_SRC] = &disp0_cc_mdss_dptx1_link_clk_src.clkr, 290962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_DIV_CLK_SRC] = &disp0_cc_mdss_dptx1_link_div_clk_src.clkr, 291062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_INTF_CLK] = &disp0_cc_mdss_dptx1_link_intf_clk.clkr, 291162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL0_CLK] = &disp0_cc_mdss_dptx1_pixel0_clk.clkr, 291262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL0_CLK_SRC] = &disp0_cc_mdss_dptx1_pixel0_clk_src.clkr, 291362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL1_CLK] = &disp0_cc_mdss_dptx1_pixel1_clk.clkr, 291462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL1_CLK_SRC] = &disp0_cc_mdss_dptx1_pixel1_clk_src.clkr, 291562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_USB_ROUTER_LINK_INTF_CLK] = &disp0_cc_mdss_dptx1_usb_router_link_intf_clk.clkr, 291662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_AUX_CLK] = &disp0_cc_mdss_dptx2_aux_clk.clkr, 291762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_AUX_CLK_SRC] = &disp0_cc_mdss_dptx2_aux_clk_src.clkr, 291862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_CLK] = &disp0_cc_mdss_dptx2_link_clk.clkr, 291962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_CLK_SRC] = &disp0_cc_mdss_dptx2_link_clk_src.clkr, 292062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_DIV_CLK_SRC] = &disp0_cc_mdss_dptx2_link_div_clk_src.clkr, 292162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_INTF_CLK] = &disp0_cc_mdss_dptx2_link_intf_clk.clkr, 292262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL0_CLK] = &disp0_cc_mdss_dptx2_pixel0_clk.clkr, 292362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL0_CLK_SRC] = &disp0_cc_mdss_dptx2_pixel0_clk_src.clkr, 292462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL1_CLK] = &disp0_cc_mdss_dptx2_pixel1_clk.clkr, 292562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL1_CLK_SRC] = &disp0_cc_mdss_dptx2_pixel1_clk_src.clkr, 292662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_AUX_CLK] = &disp0_cc_mdss_dptx3_aux_clk.clkr, 292762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_AUX_CLK_SRC] = &disp0_cc_mdss_dptx3_aux_clk_src.clkr, 292862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_CLK] = &disp0_cc_mdss_dptx3_link_clk.clkr, 292962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_CLK_SRC] = &disp0_cc_mdss_dptx3_link_clk_src.clkr, 293062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_DIV_CLK_SRC] = &disp0_cc_mdss_dptx3_link_div_clk_src.clkr, 293162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_INTF_CLK] = &disp0_cc_mdss_dptx3_link_intf_clk.clkr, 293262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_PIXEL0_CLK] = &disp0_cc_mdss_dptx3_pixel0_clk.clkr, 293362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_PIXEL0_CLK_SRC] = &disp0_cc_mdss_dptx3_pixel0_clk_src.clkr, 293462306a36Sopenharmony_ci [DISP_CC_MDSS_ESC0_CLK] = &disp0_cc_mdss_esc0_clk.clkr, 293562306a36Sopenharmony_ci [DISP_CC_MDSS_ESC0_CLK_SRC] = &disp0_cc_mdss_esc0_clk_src.clkr, 293662306a36Sopenharmony_ci [DISP_CC_MDSS_ESC1_CLK] = &disp0_cc_mdss_esc1_clk.clkr, 293762306a36Sopenharmony_ci [DISP_CC_MDSS_ESC1_CLK_SRC] = &disp0_cc_mdss_esc1_clk_src.clkr, 293862306a36Sopenharmony_ci [DISP_CC_MDSS_MDP1_CLK] = &disp0_cc_mdss_mdp1_clk.clkr, 293962306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_CLK] = &disp0_cc_mdss_mdp_clk.clkr, 294062306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_CLK_SRC] = &disp0_cc_mdss_mdp_clk_src.clkr, 294162306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_LUT1_CLK] = &disp0_cc_mdss_mdp_lut1_clk.clkr, 294262306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_LUT_CLK] = &disp0_cc_mdss_mdp_lut_clk.clkr, 294362306a36Sopenharmony_ci [DISP_CC_MDSS_NON_GDSC_AHB_CLK] = &disp0_cc_mdss_non_gdsc_ahb_clk.clkr, 294462306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK0_CLK] = &disp0_cc_mdss_pclk0_clk.clkr, 294562306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK0_CLK_SRC] = &disp0_cc_mdss_pclk0_clk_src.clkr, 294662306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK1_CLK] = &disp0_cc_mdss_pclk1_clk.clkr, 294762306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK1_CLK_SRC] = &disp0_cc_mdss_pclk1_clk_src.clkr, 294862306a36Sopenharmony_ci [DISP_CC_MDSS_ROT1_CLK] = &disp0_cc_mdss_rot1_clk.clkr, 294962306a36Sopenharmony_ci [DISP_CC_MDSS_ROT_CLK] = &disp0_cc_mdss_rot_clk.clkr, 295062306a36Sopenharmony_ci [DISP_CC_MDSS_ROT_CLK_SRC] = &disp0_cc_mdss_rot_clk_src.clkr, 295162306a36Sopenharmony_ci [DISP_CC_MDSS_RSCC_AHB_CLK] = &disp0_cc_mdss_rscc_ahb_clk.clkr, 295262306a36Sopenharmony_ci [DISP_CC_MDSS_RSCC_VSYNC_CLK] = &disp0_cc_mdss_rscc_vsync_clk.clkr, 295362306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC1_CLK] = &disp0_cc_mdss_vsync1_clk.clkr, 295462306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC_CLK] = &disp0_cc_mdss_vsync_clk.clkr, 295562306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC_CLK_SRC] = &disp0_cc_mdss_vsync_clk_src.clkr, 295662306a36Sopenharmony_ci [DISP_CC_PLL0] = &disp0_cc_pll0.clkr, 295762306a36Sopenharmony_ci [DISP_CC_PLL1] = &disp0_cc_pll1.clkr, 295862306a36Sopenharmony_ci [DISP_CC_PLL1_OUT_EVEN] = &disp0_cc_pll1_out_even.clkr, 295962306a36Sopenharmony_ci [DISP_CC_PLL2] = &disp0_cc_pll2.clkr, 296062306a36Sopenharmony_ci [DISP_CC_SLEEP_CLK] = &disp0_cc_sleep_clk.clkr, 296162306a36Sopenharmony_ci [DISP_CC_SLEEP_CLK_SRC] = &disp0_cc_sleep_clk_src.clkr, 296262306a36Sopenharmony_ci}; 296362306a36Sopenharmony_ci 296462306a36Sopenharmony_cistatic struct clk_regmap *disp1_cc_sc8280xp_clocks[] = { 296562306a36Sopenharmony_ci [DISP_CC_MDSS_AHB1_CLK] = &disp1_cc_mdss_ahb1_clk.clkr, 296662306a36Sopenharmony_ci [DISP_CC_MDSS_AHB_CLK] = &disp1_cc_mdss_ahb_clk.clkr, 296762306a36Sopenharmony_ci [DISP_CC_MDSS_AHB_CLK_SRC] = &disp1_cc_mdss_ahb_clk_src.clkr, 296862306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_CLK] = &disp1_cc_mdss_byte0_clk.clkr, 296962306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_CLK_SRC] = &disp1_cc_mdss_byte0_clk_src.clkr, 297062306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_DIV_CLK_SRC] = &disp1_cc_mdss_byte0_div_clk_src.clkr, 297162306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE0_INTF_CLK] = &disp1_cc_mdss_byte0_intf_clk.clkr, 297262306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_CLK] = &disp1_cc_mdss_byte1_clk.clkr, 297362306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_CLK_SRC] = &disp1_cc_mdss_byte1_clk_src.clkr, 297462306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_DIV_CLK_SRC] = &disp1_cc_mdss_byte1_div_clk_src.clkr, 297562306a36Sopenharmony_ci [DISP_CC_MDSS_BYTE1_INTF_CLK] = &disp1_cc_mdss_byte1_intf_clk.clkr, 297662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_AUX_CLK] = &disp1_cc_mdss_dptx0_aux_clk.clkr, 297762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_AUX_CLK_SRC] = &disp1_cc_mdss_dptx0_aux_clk_src.clkr, 297862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_CLK] = &disp1_cc_mdss_dptx0_link_clk.clkr, 297962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_CLK_SRC] = &disp1_cc_mdss_dptx0_link_clk_src.clkr, 298062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_DIV_CLK_SRC] = &disp1_cc_mdss_dptx0_link_div_clk_src.clkr, 298162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_LINK_INTF_CLK] = &disp1_cc_mdss_dptx0_link_intf_clk.clkr, 298262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL0_CLK] = &disp1_cc_mdss_dptx0_pixel0_clk.clkr, 298362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL0_CLK_SRC] = &disp1_cc_mdss_dptx0_pixel0_clk_src.clkr, 298462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL1_CLK] = &disp1_cc_mdss_dptx0_pixel1_clk.clkr, 298562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_PIXEL1_CLK_SRC] = &disp1_cc_mdss_dptx0_pixel1_clk_src.clkr, 298662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX0_USB_ROUTER_LINK_INTF_CLK] = &disp1_cc_mdss_dptx0_usb_router_link_intf_clk.clkr, 298762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_AUX_CLK] = &disp1_cc_mdss_dptx1_aux_clk.clkr, 298862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_AUX_CLK_SRC] = &disp1_cc_mdss_dptx1_aux_clk_src.clkr, 298962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_CLK] = &disp1_cc_mdss_dptx1_link_clk.clkr, 299062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_CLK_SRC] = &disp1_cc_mdss_dptx1_link_clk_src.clkr, 299162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_DIV_CLK_SRC] = &disp1_cc_mdss_dptx1_link_div_clk_src.clkr, 299262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_LINK_INTF_CLK] = &disp1_cc_mdss_dptx1_link_intf_clk.clkr, 299362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL0_CLK] = &disp1_cc_mdss_dptx1_pixel0_clk.clkr, 299462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL0_CLK_SRC] = &disp1_cc_mdss_dptx1_pixel0_clk_src.clkr, 299562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL1_CLK] = &disp1_cc_mdss_dptx1_pixel1_clk.clkr, 299662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_PIXEL1_CLK_SRC] = &disp1_cc_mdss_dptx1_pixel1_clk_src.clkr, 299762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX1_USB_ROUTER_LINK_INTF_CLK] = &disp1_cc_mdss_dptx1_usb_router_link_intf_clk.clkr, 299862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_AUX_CLK] = &disp1_cc_mdss_dptx2_aux_clk.clkr, 299962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_AUX_CLK_SRC] = &disp1_cc_mdss_dptx2_aux_clk_src.clkr, 300062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_CLK] = &disp1_cc_mdss_dptx2_link_clk.clkr, 300162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_CLK_SRC] = &disp1_cc_mdss_dptx2_link_clk_src.clkr, 300262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_DIV_CLK_SRC] = &disp1_cc_mdss_dptx2_link_div_clk_src.clkr, 300362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_LINK_INTF_CLK] = &disp1_cc_mdss_dptx2_link_intf_clk.clkr, 300462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL0_CLK] = &disp1_cc_mdss_dptx2_pixel0_clk.clkr, 300562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL0_CLK_SRC] = &disp1_cc_mdss_dptx2_pixel0_clk_src.clkr, 300662306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL1_CLK] = &disp1_cc_mdss_dptx2_pixel1_clk.clkr, 300762306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX2_PIXEL1_CLK_SRC] = &disp1_cc_mdss_dptx2_pixel1_clk_src.clkr, 300862306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_AUX_CLK] = &disp1_cc_mdss_dptx3_aux_clk.clkr, 300962306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_AUX_CLK_SRC] = &disp1_cc_mdss_dptx3_aux_clk_src.clkr, 301062306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_CLK] = &disp1_cc_mdss_dptx3_link_clk.clkr, 301162306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_CLK_SRC] = &disp1_cc_mdss_dptx3_link_clk_src.clkr, 301262306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_DIV_CLK_SRC] = &disp1_cc_mdss_dptx3_link_div_clk_src.clkr, 301362306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_LINK_INTF_CLK] = &disp1_cc_mdss_dptx3_link_intf_clk.clkr, 301462306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_PIXEL0_CLK] = &disp1_cc_mdss_dptx3_pixel0_clk.clkr, 301562306a36Sopenharmony_ci [DISP_CC_MDSS_DPTX3_PIXEL0_CLK_SRC] = &disp1_cc_mdss_dptx3_pixel0_clk_src.clkr, 301662306a36Sopenharmony_ci [DISP_CC_MDSS_ESC0_CLK] = &disp1_cc_mdss_esc0_clk.clkr, 301762306a36Sopenharmony_ci [DISP_CC_MDSS_ESC0_CLK_SRC] = &disp1_cc_mdss_esc0_clk_src.clkr, 301862306a36Sopenharmony_ci [DISP_CC_MDSS_ESC1_CLK] = &disp1_cc_mdss_esc1_clk.clkr, 301962306a36Sopenharmony_ci [DISP_CC_MDSS_ESC1_CLK_SRC] = &disp1_cc_mdss_esc1_clk_src.clkr, 302062306a36Sopenharmony_ci [DISP_CC_MDSS_MDP1_CLK] = &disp1_cc_mdss_mdp1_clk.clkr, 302162306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_CLK] = &disp1_cc_mdss_mdp_clk.clkr, 302262306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_CLK_SRC] = &disp1_cc_mdss_mdp_clk_src.clkr, 302362306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_LUT1_CLK] = &disp1_cc_mdss_mdp_lut1_clk.clkr, 302462306a36Sopenharmony_ci [DISP_CC_MDSS_MDP_LUT_CLK] = &disp1_cc_mdss_mdp_lut_clk.clkr, 302562306a36Sopenharmony_ci [DISP_CC_MDSS_NON_GDSC_AHB_CLK] = &disp1_cc_mdss_non_gdsc_ahb_clk.clkr, 302662306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK0_CLK] = &disp1_cc_mdss_pclk0_clk.clkr, 302762306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK0_CLK_SRC] = &disp1_cc_mdss_pclk0_clk_src.clkr, 302862306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK1_CLK] = &disp1_cc_mdss_pclk1_clk.clkr, 302962306a36Sopenharmony_ci [DISP_CC_MDSS_PCLK1_CLK_SRC] = &disp1_cc_mdss_pclk1_clk_src.clkr, 303062306a36Sopenharmony_ci [DISP_CC_MDSS_ROT1_CLK] = &disp1_cc_mdss_rot1_clk.clkr, 303162306a36Sopenharmony_ci [DISP_CC_MDSS_ROT_CLK] = &disp1_cc_mdss_rot_clk.clkr, 303262306a36Sopenharmony_ci [DISP_CC_MDSS_ROT_CLK_SRC] = &disp1_cc_mdss_rot_clk_src.clkr, 303362306a36Sopenharmony_ci [DISP_CC_MDSS_RSCC_AHB_CLK] = &disp1_cc_mdss_rscc_ahb_clk.clkr, 303462306a36Sopenharmony_ci [DISP_CC_MDSS_RSCC_VSYNC_CLK] = &disp1_cc_mdss_rscc_vsync_clk.clkr, 303562306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC1_CLK] = &disp1_cc_mdss_vsync1_clk.clkr, 303662306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC_CLK] = &disp1_cc_mdss_vsync_clk.clkr, 303762306a36Sopenharmony_ci [DISP_CC_MDSS_VSYNC_CLK_SRC] = &disp1_cc_mdss_vsync_clk_src.clkr, 303862306a36Sopenharmony_ci [DISP_CC_PLL0] = &disp1_cc_pll0.clkr, 303962306a36Sopenharmony_ci [DISP_CC_PLL1] = &disp1_cc_pll1.clkr, 304062306a36Sopenharmony_ci [DISP_CC_PLL1_OUT_EVEN] = &disp1_cc_pll1_out_even.clkr, 304162306a36Sopenharmony_ci [DISP_CC_PLL2] = &disp1_cc_pll2.clkr, 304262306a36Sopenharmony_ci [DISP_CC_SLEEP_CLK] = &disp1_cc_sleep_clk.clkr, 304362306a36Sopenharmony_ci [DISP_CC_SLEEP_CLK_SRC] = &disp1_cc_sleep_clk_src.clkr, 304462306a36Sopenharmony_ci}; 304562306a36Sopenharmony_ci 304662306a36Sopenharmony_cistatic const struct qcom_reset_map disp_cc_sc8280xp_resets[] = { 304762306a36Sopenharmony_ci [DISP_CC_MDSS_CORE_BCR] = { 0x2000 }, 304862306a36Sopenharmony_ci [DISP_CC_MDSS_RSCC_BCR] = { 0x4000 }, 304962306a36Sopenharmony_ci}; 305062306a36Sopenharmony_ci 305162306a36Sopenharmony_cistatic struct gdsc disp0_mdss_gdsc = { 305262306a36Sopenharmony_ci .gdscr = 0x3000, 305362306a36Sopenharmony_ci .en_rest_wait_val = 0x2, 305462306a36Sopenharmony_ci .en_few_wait_val = 0x2, 305562306a36Sopenharmony_ci .clk_dis_wait_val = 0xf, 305662306a36Sopenharmony_ci .pd = { 305762306a36Sopenharmony_ci .name = "disp0_mdss_gdsc", 305862306a36Sopenharmony_ci }, 305962306a36Sopenharmony_ci .pwrsts = PWRSTS_OFF_ON, 306062306a36Sopenharmony_ci .flags = HW_CTRL | RETAIN_FF_ENABLE, 306162306a36Sopenharmony_ci}; 306262306a36Sopenharmony_ci 306362306a36Sopenharmony_cistatic struct gdsc disp1_mdss_gdsc = { 306462306a36Sopenharmony_ci .gdscr = 0x3000, 306562306a36Sopenharmony_ci .en_rest_wait_val = 0x2, 306662306a36Sopenharmony_ci .en_few_wait_val = 0x2, 306762306a36Sopenharmony_ci .clk_dis_wait_val = 0xf, 306862306a36Sopenharmony_ci .pd = { 306962306a36Sopenharmony_ci .name = "disp1_mdss_gdsc", 307062306a36Sopenharmony_ci }, 307162306a36Sopenharmony_ci .pwrsts = PWRSTS_OFF_ON, 307262306a36Sopenharmony_ci .flags = HW_CTRL | RETAIN_FF_ENABLE, 307362306a36Sopenharmony_ci}; 307462306a36Sopenharmony_ci 307562306a36Sopenharmony_cistatic struct gdsc disp0_mdss_int2_gdsc = { 307662306a36Sopenharmony_ci .gdscr = 0xa000, 307762306a36Sopenharmony_ci .en_rest_wait_val = 0x2, 307862306a36Sopenharmony_ci .en_few_wait_val = 0x2, 307962306a36Sopenharmony_ci .clk_dis_wait_val = 0xf, 308062306a36Sopenharmony_ci .pd = { 308162306a36Sopenharmony_ci .name = "disp0_mdss_int2_gdsc", 308262306a36Sopenharmony_ci }, 308362306a36Sopenharmony_ci .pwrsts = PWRSTS_OFF_ON, 308462306a36Sopenharmony_ci .flags = HW_CTRL | RETAIN_FF_ENABLE, 308562306a36Sopenharmony_ci}; 308662306a36Sopenharmony_ci 308762306a36Sopenharmony_cistatic struct gdsc disp1_mdss_int2_gdsc = { 308862306a36Sopenharmony_ci .gdscr = 0xa000, 308962306a36Sopenharmony_ci .en_rest_wait_val = 0x2, 309062306a36Sopenharmony_ci .en_few_wait_val = 0x2, 309162306a36Sopenharmony_ci .clk_dis_wait_val = 0xf, 309262306a36Sopenharmony_ci .pd = { 309362306a36Sopenharmony_ci .name = "disp1_mdss_int2_gdsc", 309462306a36Sopenharmony_ci }, 309562306a36Sopenharmony_ci .pwrsts = PWRSTS_OFF_ON, 309662306a36Sopenharmony_ci .flags = HW_CTRL | RETAIN_FF_ENABLE, 309762306a36Sopenharmony_ci}; 309862306a36Sopenharmony_ci 309962306a36Sopenharmony_cistatic struct gdsc *disp0_cc_sc8280xp_gdscs[] = { 310062306a36Sopenharmony_ci [MDSS_GDSC] = &disp0_mdss_gdsc, 310162306a36Sopenharmony_ci [MDSS_INT2_GDSC] = &disp0_mdss_int2_gdsc, 310262306a36Sopenharmony_ci}; 310362306a36Sopenharmony_ci 310462306a36Sopenharmony_cistatic struct gdsc *disp1_cc_sc8280xp_gdscs[] = { 310562306a36Sopenharmony_ci [MDSS_GDSC] = &disp1_mdss_gdsc, 310662306a36Sopenharmony_ci [MDSS_INT2_GDSC] = &disp1_mdss_int2_gdsc, 310762306a36Sopenharmony_ci}; 310862306a36Sopenharmony_ci 310962306a36Sopenharmony_cistatic const struct regmap_config disp_cc_sc8280xp_regmap_config = { 311062306a36Sopenharmony_ci .reg_bits = 32, 311162306a36Sopenharmony_ci .reg_stride = 4, 311262306a36Sopenharmony_ci .val_bits = 32, 311362306a36Sopenharmony_ci .max_register = 0x10000, 311462306a36Sopenharmony_ci .fast_io = true, 311562306a36Sopenharmony_ci}; 311662306a36Sopenharmony_ci 311762306a36Sopenharmony_cistatic struct qcom_cc_desc disp0_cc_sc8280xp_desc = { 311862306a36Sopenharmony_ci .config = &disp_cc_sc8280xp_regmap_config, 311962306a36Sopenharmony_ci .clks = disp0_cc_sc8280xp_clocks, 312062306a36Sopenharmony_ci .num_clks = ARRAY_SIZE(disp0_cc_sc8280xp_clocks), 312162306a36Sopenharmony_ci .resets = disp_cc_sc8280xp_resets, 312262306a36Sopenharmony_ci .num_resets = ARRAY_SIZE(disp_cc_sc8280xp_resets), 312362306a36Sopenharmony_ci .gdscs = disp0_cc_sc8280xp_gdscs, 312462306a36Sopenharmony_ci .num_gdscs = ARRAY_SIZE(disp0_cc_sc8280xp_gdscs), 312562306a36Sopenharmony_ci}; 312662306a36Sopenharmony_ci 312762306a36Sopenharmony_cistatic struct qcom_cc_desc disp1_cc_sc8280xp_desc = { 312862306a36Sopenharmony_ci .config = &disp_cc_sc8280xp_regmap_config, 312962306a36Sopenharmony_ci .clks = disp1_cc_sc8280xp_clocks, 313062306a36Sopenharmony_ci .num_clks = ARRAY_SIZE(disp1_cc_sc8280xp_clocks), 313162306a36Sopenharmony_ci .resets = disp_cc_sc8280xp_resets, 313262306a36Sopenharmony_ci .num_resets = ARRAY_SIZE(disp_cc_sc8280xp_resets), 313362306a36Sopenharmony_ci .gdscs = disp1_cc_sc8280xp_gdscs, 313462306a36Sopenharmony_ci .num_gdscs = ARRAY_SIZE(disp1_cc_sc8280xp_gdscs), 313562306a36Sopenharmony_ci}; 313662306a36Sopenharmony_ci 313762306a36Sopenharmony_ci#define clkr_to_alpha_clk_pll(_clkr) container_of(_clkr, struct clk_alpha_pll, clkr) 313862306a36Sopenharmony_ci 313962306a36Sopenharmony_cistatic int disp_cc_sc8280xp_probe(struct platform_device *pdev) 314062306a36Sopenharmony_ci{ 314162306a36Sopenharmony_ci const struct qcom_cc_desc *desc; 314262306a36Sopenharmony_ci struct regmap *regmap; 314362306a36Sopenharmony_ci int ret; 314462306a36Sopenharmony_ci 314562306a36Sopenharmony_ci desc = device_get_match_data(&pdev->dev); 314662306a36Sopenharmony_ci 314762306a36Sopenharmony_ci ret = devm_pm_runtime_enable(&pdev->dev); 314862306a36Sopenharmony_ci if (ret) 314962306a36Sopenharmony_ci return ret; 315062306a36Sopenharmony_ci 315162306a36Sopenharmony_ci ret = devm_pm_clk_create(&pdev->dev); 315262306a36Sopenharmony_ci if (ret) 315362306a36Sopenharmony_ci return ret; 315462306a36Sopenharmony_ci 315562306a36Sopenharmony_ci ret = pm_clk_add(&pdev->dev, NULL); 315662306a36Sopenharmony_ci if (ret < 0) { 315762306a36Sopenharmony_ci dev_err(&pdev->dev, "failed to acquire ahb clock\n"); 315862306a36Sopenharmony_ci return ret; 315962306a36Sopenharmony_ci } 316062306a36Sopenharmony_ci 316162306a36Sopenharmony_ci ret = pm_runtime_resume_and_get(&pdev->dev); 316262306a36Sopenharmony_ci if (ret) 316362306a36Sopenharmony_ci return ret; 316462306a36Sopenharmony_ci 316562306a36Sopenharmony_ci regmap = qcom_cc_map(pdev, desc); 316662306a36Sopenharmony_ci if (IS_ERR(regmap)) { 316762306a36Sopenharmony_ci ret = PTR_ERR(regmap); 316862306a36Sopenharmony_ci goto out_pm_runtime_put; 316962306a36Sopenharmony_ci } 317062306a36Sopenharmony_ci 317162306a36Sopenharmony_ci clk_lucid_pll_configure(clkr_to_alpha_clk_pll(desc->clks[DISP_CC_PLL0]), regmap, &disp_cc_pll0_config); 317262306a36Sopenharmony_ci clk_lucid_pll_configure(clkr_to_alpha_clk_pll(desc->clks[DISP_CC_PLL1]), regmap, &disp_cc_pll1_config); 317362306a36Sopenharmony_ci clk_lucid_pll_configure(clkr_to_alpha_clk_pll(desc->clks[DISP_CC_PLL2]), regmap, &disp_cc_pll2_config); 317462306a36Sopenharmony_ci 317562306a36Sopenharmony_ci ret = qcom_cc_really_probe(pdev, desc, regmap); 317662306a36Sopenharmony_ci if (ret) { 317762306a36Sopenharmony_ci dev_err(&pdev->dev, "Failed to register display clock controller\n"); 317862306a36Sopenharmony_ci goto out_pm_runtime_put; 317962306a36Sopenharmony_ci } 318062306a36Sopenharmony_ci 318162306a36Sopenharmony_ci /* DISP_CC_XO_CLK always-on */ 318262306a36Sopenharmony_ci regmap_update_bits(regmap, 0x605c, BIT(0), BIT(0)); 318362306a36Sopenharmony_ci 318462306a36Sopenharmony_ciout_pm_runtime_put: 318562306a36Sopenharmony_ci pm_runtime_put_sync(&pdev->dev); 318662306a36Sopenharmony_ci 318762306a36Sopenharmony_ci return ret; 318862306a36Sopenharmony_ci} 318962306a36Sopenharmony_ci 319062306a36Sopenharmony_cistatic const struct of_device_id disp_cc_sc8280xp_match_table[] = { 319162306a36Sopenharmony_ci { .compatible = "qcom,sc8280xp-dispcc0", .data = &disp0_cc_sc8280xp_desc }, 319262306a36Sopenharmony_ci { .compatible = "qcom,sc8280xp-dispcc1", .data = &disp1_cc_sc8280xp_desc }, 319362306a36Sopenharmony_ci { } 319462306a36Sopenharmony_ci}; 319562306a36Sopenharmony_ciMODULE_DEVICE_TABLE(of, disp_cc_sc8280xp_match_table); 319662306a36Sopenharmony_ci 319762306a36Sopenharmony_cistatic struct platform_driver disp_cc_sc8280xp_driver = { 319862306a36Sopenharmony_ci .probe = disp_cc_sc8280xp_probe, 319962306a36Sopenharmony_ci .driver = { 320062306a36Sopenharmony_ci .name = "disp_cc-sc8280xp", 320162306a36Sopenharmony_ci .of_match_table = disp_cc_sc8280xp_match_table, 320262306a36Sopenharmony_ci }, 320362306a36Sopenharmony_ci}; 320462306a36Sopenharmony_ci 320562306a36Sopenharmony_cistatic int __init disp_cc_sc8280xp_init(void) 320662306a36Sopenharmony_ci{ 320762306a36Sopenharmony_ci return platform_driver_register(&disp_cc_sc8280xp_driver); 320862306a36Sopenharmony_ci} 320962306a36Sopenharmony_cisubsys_initcall(disp_cc_sc8280xp_init); 321062306a36Sopenharmony_ci 321162306a36Sopenharmony_cistatic void __exit disp_cc_sc8280xp_exit(void) 321262306a36Sopenharmony_ci{ 321362306a36Sopenharmony_ci platform_driver_unregister(&disp_cc_sc8280xp_driver); 321462306a36Sopenharmony_ci} 321562306a36Sopenharmony_cimodule_exit(disp_cc_sc8280xp_exit); 321662306a36Sopenharmony_ci 321762306a36Sopenharmony_ciMODULE_DESCRIPTION("Qualcomm SC8280XP dispcc driver"); 321862306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 3219