linux/drivers/clk/qcom/camcc-sm6350.c

// SPDX-License-Identifier: GPL-2.0-only
/*
 * Copyright (c) 2022, The Linux Foundation. All rights reserved.
 * Copyright (c) 2022, Linaro Limited
 */

#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[] =;

/* 600MHz configuration */
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 =;

/* 808MHz configuration */
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 =;

/* 1920MHz configuration */
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 =;

/* 384MHz configuration */
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();