/* SPDX-License-Identifier: GPL-2.0 */ struct regmap; /** * enum icst_control_type - the type of ICST control register */ enum icst_control_type { ICST_VERSATILE, /* The standard type, all control bits available */ ICST_INTEGRATOR_AP_CM, /* Only 8 bits of VDW available */ ICST_INTEGRATOR_AP_SYS, /* Only 8 bits of VDW available */ ICST_INTEGRATOR_AP_PCI, /* Odd bit pattern storage */ ICST_INTEGRATOR_CP_CM_CORE, /* Only 8 bits of VDW and 3 bits of OD */ ICST_INTEGRATOR_CP_CM_MEM, /* Only 8 bits of VDW and 3 bits of OD */ ICST_INTEGRATOR_IM_PD1, /* Like the Versatile, all control bits */ }; /** * struct clk_icst_desc - descriptor for the ICST VCO * @params: ICST parameters * @vco_offset: offset to the ICST VCO from the provided memory base * @lock_offset: offset to the ICST VCO locking register from the provided * memory base */ struct clk_icst_desc { const struct icst_params *params; u32 vco_offset; u32 lock_offset; }; struct clk *icst_clk_register(struct device *dev, const struct clk_icst_desc *desc, const char *name, const char *parent_name, void __iomem *base); struct clk *icst_clk_setup(struct device *dev, const struct clk_icst_desc *desc, const char *name, const char *parent_name, struct regmap *map, enum icst_control_type ctype);