|  | /* 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); |