#include <linux/clk-provider.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/regmap.h>
#include <dt-bindings/clock/qcom,sm6350-camcc.h>
#include "clk-alpha-pll.h"
#include "clk-branch.h"
#include "clk-rcg.h"
#include "common.h"
#include "gdsc.h"
enum { … };
enum { … };
static const struct pll_vco fabia_vco[] = …;
static const struct alpha_pll_config camcc_pll0_config = …;
static struct clk_alpha_pll camcc_pll0 = …;
static const struct clk_div_table post_div_table_camcc_pll0_out_even[] = …;
static struct clk_alpha_pll_postdiv camcc_pll0_out_even = …;
static const struct alpha_pll_config camcc_pll1_config = …;
static struct clk_alpha_pll camcc_pll1 = …;
static const struct clk_div_table post_div_table_camcc_pll1_out_even[] = …;
static struct clk_alpha_pll_postdiv camcc_pll1_out_even = …;
static const struct alpha_pll_config camcc_pll2_config = …;
static struct clk_alpha_pll camcc_pll2 = …;
static struct clk_fixed_factor camcc_pll2_out_early = …;
static const struct clk_div_table post_div_table_camcc_pll2_out_main[] = …;
static struct clk_alpha_pll_postdiv camcc_pll2_out_main = …;
static const struct alpha_pll_config camcc_pll3_config = …;
static struct clk_alpha_pll camcc_pll3 = …;
static const struct parent_map camcc_parent_map_0[] = …;
static const struct clk_parent_data camcc_parent_data_0[] = …;
static const struct parent_map camcc_parent_map_1[] = …;
static const struct clk_parent_data camcc_parent_data_1[] = …;
static const struct parent_map camcc_parent_map_2[] = …;
static const struct clk_parent_data camcc_parent_data_2[] = …;
static const struct parent_map camcc_parent_map_3[] = …;
static const struct clk_parent_data camcc_parent_data_3[] = …;
static const struct parent_map camcc_parent_map_4[] = …;
static const struct clk_parent_data camcc_parent_data_4[] = …;
static const struct parent_map camcc_parent_map_5[] = …;
static const struct clk_parent_data camcc_parent_data_5[] = …;
static const struct parent_map camcc_parent_map_6[] = …;
static const struct clk_parent_data camcc_parent_data_6[] = …;
static const struct parent_map camcc_parent_map_7[] = …;
static const struct clk_parent_data camcc_parent_data_7[] = …;
static const struct parent_map camcc_parent_map_8[] = …;
static const struct clk_parent_data camcc_parent_data_8[] = …;
static const struct parent_map camcc_parent_map_9[] = …;
static const struct clk_parent_data camcc_parent_data_9[] = …;
static const struct freq_tbl ftbl_camcc_bps_clk_src[] = …;
static struct clk_rcg2 camcc_bps_clk_src = …;
static const struct freq_tbl ftbl_camcc_cci_0_clk_src[] = …;
static struct clk_rcg2 camcc_cci_0_clk_src = …;
static struct clk_rcg2 camcc_cci_1_clk_src = …;
static const struct freq_tbl ftbl_camcc_cphy_rx_clk_src[] = …;
static struct clk_rcg2 camcc_cphy_rx_clk_src = …;
static const struct freq_tbl ftbl_camcc_csi0phytimer_clk_src[] = …;
static struct clk_rcg2 camcc_csi0phytimer_clk_src = …;
static struct clk_rcg2 camcc_csi1phytimer_clk_src = …;
static struct clk_rcg2 camcc_csi2phytimer_clk_src = …;
static struct clk_rcg2 camcc_csi3phytimer_clk_src = …;
static const struct freq_tbl ftbl_camcc_fast_ahb_clk_src[] = …;
static struct clk_rcg2 camcc_fast_ahb_clk_src = …;
static const struct freq_tbl ftbl_camcc_icp_clk_src[] = …;
static struct clk_rcg2 camcc_icp_clk_src = …;
static const struct freq_tbl ftbl_camcc_ife_0_clk_src[] = …;
static struct clk_rcg2 camcc_ife_0_clk_src = …;
static struct clk_rcg2 camcc_ife_0_csid_clk_src = …;
static struct clk_rcg2 camcc_ife_1_clk_src = …;
static struct clk_rcg2 camcc_ife_1_csid_clk_src = …;
static struct clk_rcg2 camcc_ife_2_clk_src = …;
static struct clk_rcg2 camcc_ife_2_csid_clk_src = …;
static const struct freq_tbl ftbl_camcc_ife_lite_clk_src[] = …;
static struct clk_rcg2 camcc_ife_lite_clk_src = …;
static struct clk_rcg2 camcc_ife_lite_csid_clk_src = …;
static const struct freq_tbl ftbl_camcc_ipe_0_clk_src[] = …;
static struct clk_rcg2 camcc_ipe_0_clk_src = …;
static const struct freq_tbl ftbl_camcc_jpeg_clk_src[] = …;
static struct clk_rcg2 camcc_jpeg_clk_src = …;
static const struct freq_tbl ftbl_camcc_lrme_clk_src[] = …;
static struct clk_rcg2 camcc_lrme_clk_src = …;
static const struct freq_tbl ftbl_camcc_mclk0_clk_src[] = …;
static struct clk_rcg2 camcc_mclk0_clk_src = …;
static struct clk_rcg2 camcc_mclk1_clk_src = …;
static struct clk_rcg2 camcc_mclk2_clk_src = …;
static struct clk_rcg2 camcc_mclk3_clk_src = …;
static struct clk_rcg2 camcc_mclk4_clk_src = …;
static const struct freq_tbl ftbl_camcc_slow_ahb_clk_src[] = …;
static struct clk_rcg2 camcc_slow_ahb_clk_src = …;
static struct clk_branch camcc_bps_ahb_clk = …;
static struct clk_branch camcc_bps_areg_clk = …;
static struct clk_branch camcc_bps_axi_clk = …;
static struct clk_branch camcc_bps_clk = …;
static struct clk_branch camcc_camnoc_axi_clk = …;
static struct clk_branch camcc_cci_0_clk = …;
static struct clk_branch camcc_cci_1_clk = …;
static struct clk_branch camcc_core_ahb_clk = …;
static struct clk_branch camcc_cpas_ahb_clk = …;
static struct clk_branch camcc_csi0phytimer_clk = …;
static struct clk_branch camcc_csi1phytimer_clk = …;
static struct clk_branch camcc_csi2phytimer_clk = …;
static struct clk_branch camcc_csi3phytimer_clk = …;
static struct clk_branch camcc_csiphy0_clk = …;
static struct clk_branch camcc_csiphy1_clk = …;
static struct clk_branch camcc_csiphy2_clk = …;
static struct clk_branch camcc_csiphy3_clk = …;
static struct clk_branch camcc_icp_clk = …;
static struct clk_branch camcc_icp_ts_clk = …;
static struct clk_branch camcc_ife_0_axi_clk = …;
static struct clk_branch camcc_ife_0_clk = …;
static struct clk_branch camcc_ife_0_cphy_rx_clk = …;
static struct clk_branch camcc_ife_0_csid_clk = …;
static struct clk_branch camcc_ife_0_dsp_clk = …;
static struct clk_branch camcc_ife_1_axi_clk = …;
static struct clk_branch camcc_ife_1_clk = …;
static struct clk_branch camcc_ife_1_cphy_rx_clk = …;
static struct clk_branch camcc_ife_1_csid_clk = …;
static struct clk_branch camcc_ife_1_dsp_clk = …;
static struct clk_branch camcc_ife_2_axi_clk = …;
static struct clk_branch camcc_ife_2_clk = …;
static struct clk_branch camcc_ife_2_cphy_rx_clk = …;
static struct clk_branch camcc_ife_2_csid_clk = …;
static struct clk_branch camcc_ife_2_dsp_clk = …;
static struct clk_branch camcc_ife_lite_clk = …;
static struct clk_branch camcc_ife_lite_cphy_rx_clk = …;
static struct clk_branch camcc_ife_lite_csid_clk = …;
static struct clk_branch camcc_ipe_0_ahb_clk = …;
static struct clk_branch camcc_ipe_0_areg_clk = …;
static struct clk_branch camcc_ipe_0_axi_clk = …;
static struct clk_branch camcc_ipe_0_clk = …;
static struct clk_branch camcc_jpeg_clk = …;
static struct clk_branch camcc_lrme_clk = …;
static struct clk_branch camcc_mclk0_clk = …;
static struct clk_branch camcc_mclk1_clk = …;
static struct clk_branch camcc_mclk2_clk = …;
static struct clk_branch camcc_mclk3_clk = …;
static struct clk_branch camcc_mclk4_clk = …;
static struct clk_branch camcc_soc_ahb_clk = …;
static struct clk_branch camcc_sys_tmr_clk = …;
static struct gdsc bps_gdsc = …;
static struct gdsc ipe_0_gdsc = …;
static struct gdsc ife_0_gdsc = …;
static struct gdsc ife_1_gdsc = …;
static struct gdsc ife_2_gdsc = …;
static struct gdsc titan_top_gdsc = …;
static struct clk_hw *camcc_sm6350_hws[] = …;
static struct clk_regmap *camcc_sm6350_clocks[] = …;
static struct gdsc *camcc_sm6350_gdscs[] = …;
static const struct regmap_config camcc_sm6350_regmap_config = …;
static const struct qcom_cc_desc camcc_sm6350_desc = …;
static const struct of_device_id camcc_sm6350_match_table[] = …;
MODULE_DEVICE_TABLE(of, camcc_sm6350_match_table);
static int camcc_sm6350_probe(struct platform_device *pdev)
{ … }
static struct platform_driver camcc_sm6350_driver = …;
module_platform_driver(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;