2019-05-27 08:55:01 +02:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2014-06-05 16:06:55 +01:00
/*
* ST Thermal Sensor Driver for STi series of SoCs
* Author : Ajit Pal Singh < ajitpal . singh @ st . com >
*
* Copyright ( C ) 2003 - 2014 STMicroelectronics ( R & D ) Limited
*/
# ifndef __STI_THERMAL_SYSCFG_H
# define __STI_THERMAL_SYSCFG_H
# include <linux/interrupt.h>
# include <linux/platform_device.h>
# include <linux/regmap.h>
# include <linux/thermal.h>
enum st_thermal_regfield_ids {
INT_THRESH_HI = 0 , /* Top two regfield IDs are mutually exclusive */
TEMP_PWR = 0 ,
DCORRECT ,
OVERFLOW ,
DATA ,
INT_ENABLE ,
MAX_REGFIELDS
} ;
/* Thermal sensor power states */
enum st_thermal_power_state {
POWER_OFF = 0 ,
POWER_ON
} ;
struct st_thermal_sensor ;
/**
* Description of private thermal sensor ops .
*
* @ power_ctrl : Function for powering on / off a sensor . Clock to the
* sensor is also controlled from this function .
* @ alloc_regfields : Allocate regmap register fields , specific to a sensor .
* @ do_memmap_regmap : Memory map the thermal register space and init regmap
* instance or find regmap instance .
* @ register_irq : Register an interrupt handler for a sensor .
*/
struct st_thermal_sensor_ops {
int ( * power_ctrl ) ( struct st_thermal_sensor * , enum st_thermal_power_state ) ;
int ( * alloc_regfields ) ( struct st_thermal_sensor * ) ;
int ( * regmap_init ) ( struct st_thermal_sensor * ) ;
int ( * register_enable_irq ) ( struct st_thermal_sensor * ) ;
int ( * enable_irq ) ( struct st_thermal_sensor * ) ;
} ;
/**
* Description of thermal driver compatible data .
*
* @ reg_fields : Pointer to the regfields array for a sensor .
* @ sys_compat : Pointer to the syscon node compatible string .
* @ ops : Pointer to private thermal ops for a sensor .
* @ calibration_val : Default calibration value to be written to the DCORRECT
* register field for a sensor .
* @ temp_adjust_val : Value to be added / subtracted from the data read from
* the sensor . If value needs to be added please provide a
* positive value and if it is to be subtracted please
* provide a negative value .
* @ crit_temp : The temperature beyond which the SoC should be shutdown
* to prevent damage .
*/
struct st_thermal_compat_data {
char * sys_compat ;
const struct reg_field * reg_fields ;
const struct st_thermal_sensor_ops * ops ;
unsigned int calibration_val ;
int temp_adjust_val ;
int crit_temp ;
} ;
struct st_thermal_sensor {
struct device * dev ;
struct thermal_zone_device * thermal_dev ;
const struct st_thermal_sensor_ops * ops ;
const struct st_thermal_compat_data * cdata ;
struct clk * clk ;
struct regmap * regmap ;
struct regmap_field * pwr ;
struct regmap_field * dcorrect ;
struct regmap_field * overflow ;
struct regmap_field * temp_data ;
struct regmap_field * int_thresh_hi ;
struct regmap_field * int_enable ;
int irq ;
void __iomem * mmio_base ;
} ;
extern int st_thermal_register ( struct platform_device * pdev ,
const struct of_device_id * st_thermal_of_match ) ;
extern int st_thermal_unregister ( struct platform_device * pdev ) ;
extern const struct dev_pm_ops st_thermal_pm_ops ;
# endif /* __STI_RESET_SYSCFG_H */