123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /* Copyright (c) 2014, 2018, 2020, The Linux Foundation. All rights reserved. */
- /* Copyright (c) 2022, Qualcomm Innovation Center, Inc. All rights reserved. */
- #ifndef __QCOM_CLK_COMMON_H__
- #define __QCOM_CLK_COMMON_H__
- #include <linux/reset-controller.h>
- struct platform_device;
- struct regmap_config;
- struct clk_regmap;
- struct qcom_reset_map;
- struct regmap;
- struct freq_tbl;
- struct clk_hw;
- #define PLL_LOCK_COUNT_SHIFT 8
- #define PLL_LOCK_COUNT_MASK 0x3f
- #define PLL_BIAS_COUNT_SHIFT 14
- #define PLL_BIAS_COUNT_MASK 0x3f
- #define PLL_VOTE_FSM_ENA BIT(20)
- #define PLL_VOTE_FSM_RESET BIT(21)
- /**
- * struct critical_clk_offset - list the critical clks for each clk controller
- * @offset: offset address for critical clk
- * @mask: enable mask for critical clk
- */
- struct critical_clk_offset {
- unsigned int offset;
- unsigned int mask;
- };
- struct qcom_cc_desc {
- const struct regmap_config *config;
- struct clk_regmap **clks;
- struct critical_clk_offset *critical_clk_en;
- size_t num_critical_clk;
- size_t num_clks;
- const struct qcom_reset_map *resets;
- size_t num_resets;
- struct gdsc **gdscs;
- size_t num_gdscs;
- struct clk_hw **clk_hws;
- size_t num_clk_hws;
- struct clk_vdd_class **clk_regulators;
- size_t num_clk_regulators;
- struct icc_path *path;
- };
- /**
- * struct parent_map - map table for source select configuration values
- * @src: source
- * @cfg: configuration value
- */
- struct parent_map {
- u8 src;
- u8 cfg;
- };
- struct clk_dummy {
- struct clk_hw hw;
- struct reset_controller_dev reset;
- unsigned long rrate;
- };
- /**
- * struct clk_crm - clk crm
- *
- * @crm_name: crm instance name
- * @regmap_crmc: corresponds to crmc instance
- * @crm_dev: crm dev
- * @crm_initialized: crm init flag
- */
- struct clk_crm {
- const char *name;
- struct regmap *regmap_crmc;
- const struct device *dev;
- bool initialized;
- };
- extern const struct freq_tbl *qcom_find_freq(const struct freq_tbl *f,
- unsigned long rate);
- extern const struct freq_tbl *qcom_find_freq_floor(const struct freq_tbl *f,
- unsigned long rate);
- int qcom_find_crm_freq_index(const struct freq_tbl *f, unsigned long rate);
- extern void
- qcom_pll_set_fsm_mode(struct regmap *m, u32 reg, u8 bias_count, u8 lock_count);
- extern int qcom_find_src_index(struct clk_hw *hw, const struct parent_map *map,
- u8 src);
- extern int qcom_find_cfg_index(struct clk_hw *hw, const struct parent_map *map,
- u8 cfg);
- extern int qcom_cc_register_board_clk(struct device *dev, const char *path,
- const char *name, unsigned long rate);
- extern int qcom_cc_register_sleep_clk(struct device *dev);
- extern struct regmap *qcom_cc_map(struct platform_device *pdev,
- const struct qcom_cc_desc *desc);
- extern int qcom_cc_really_probe(struct platform_device *pdev,
- const struct qcom_cc_desc *desc,
- struct regmap *regmap);
- extern int qcom_cc_probe(struct platform_device *pdev,
- const struct qcom_cc_desc *desc);
- extern int qcom_cc_probe_by_index(struct platform_device *pdev, int index,
- const struct qcom_cc_desc *desc);
- extern const struct clk_ops clk_dummy_ops;
- void qcom_cc_sync_state(struct device *dev, const struct qcom_cc_desc *desc);
- int qcom_cc_runtime_init(struct platform_device *pdev,
- struct qcom_cc_desc *desc);
- int qcom_cc_runtime_suspend(struct device *dev);
- int qcom_cc_runtime_resume(struct device *dev);
- int qcom_clk_crm_init(struct device *dev, struct clk_crm *crm);
- static inline const char *qcom_clk_hw_get_name(const struct clk_hw *hw)
- {
- return hw->init ? hw->init->name : clk_hw_get_name(hw);
- }
- #endif
|