b1eea857d8
The Baytrail-T platform firmware has defined two customized operation regions for PMIC chip Crystal Cove - one is for power resource handling and one is for thermal: sensor temperature reporting, trip point setting, etc. This patch adds support for them on top of the existing Crystal Cove PMIC driver. The reason to split code into a separate file intel_pmic.c is that there are more PMIC drivers with ACPI operation region support coming and we can re-use those code. The intel_pmic_opregion_data structure is created also for this purpose: when we need to support a new PMIC's operation region, we just need to fill those callbacks and the two register mapping tables. Signed-off-by: Aaron Lu <aaron.lu@intel.com> Acked-by: Lee Jones <lee.jones@linaro.org> for the MFD part Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
25 lines
870 B
C
25 lines
870 B
C
#ifndef __INTEL_PMIC_H
|
|
#define __INTEL_PMIC_H
|
|
|
|
struct pmic_table {
|
|
int address; /* operation region address */
|
|
int reg; /* corresponding thermal register */
|
|
int bit; /* control bit for power */
|
|
};
|
|
|
|
struct intel_pmic_opregion_data {
|
|
int (*get_power)(struct regmap *r, int reg, int bit, u64 *value);
|
|
int (*update_power)(struct regmap *r, int reg, int bit, bool on);
|
|
int (*get_raw_temp)(struct regmap *r, int reg);
|
|
int (*update_aux)(struct regmap *r, int reg, int raw_temp);
|
|
int (*get_policy)(struct regmap *r, int reg, u64 *value);
|
|
int (*update_policy)(struct regmap *r, int reg, int enable);
|
|
struct pmic_table *power_table;
|
|
int power_table_count;
|
|
struct pmic_table *thermal_table;
|
|
int thermal_table_count;
|
|
};
|
|
|
|
int intel_pmic_install_opregion_handler(struct device *dev, acpi_handle handle, struct regmap *regmap, struct intel_pmic_opregion_data *d);
|
|
|
|
#endif
|