Re: [PATCH 22/25] thermal/drivers/hisi: Add support for multi temp threshold
From: Eduardo Valentin
Date: Tue Oct 17 2017 - 00:38:09 EST
On Tue, Oct 10, 2017 at 08:02:47PM +0200, Daniel Lezcano wrote:
> From: Kevin Wangtao <kevin.wangtao@xxxxxxxxxx>
>
> The next patches will provide the support for the hi3660 where the temperature
> sensor can have multiple alarm levels. In order to set the scene to support it,
> we have to convert the current code to be able to support multiple threshold
> values.
>
> [Daniel Lezcano: Restated the log]
CHECK: Prefer kernel type 'u32' over 'uint32_t'
#113: FILE: drivers/thermal/hisi_thermal.c:54:
+ uint32_t thres_temp[MAX_THRES_NUM];
total: 0 errors, 1 warnings, 1 checks, 67 lines checked
>
> Signed-off-by: Kevin Wangtao <kevin.wangtao@xxxxxxxxxx>
> Signed-off-by: Daniel Lezcano <daniel.lezcano@xxxxxxxxxx>
> ---
> drivers/thermal/hisi_thermal.c | 21 ++++++++++++---------
> 1 file changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/thermal/hisi_thermal.c b/drivers/thermal/hisi_thermal.c
> index b5a7159..e87ca6c 100644
> --- a/drivers/thermal/hisi_thermal.c
> +++ b/drivers/thermal/hisi_thermal.c
> @@ -46,10 +46,12 @@
>
> #define HI6220_DEFAULT_SENSOR 2
>
> +#define MAX_THRES_NUM 2
> +
> struct hisi_thermal_sensor {
> struct thermal_zone_device *tzd;
> uint32_t id;
> - uint32_t thres_temp;
> + uint32_t thres_temp[MAX_THRES_NUM];
> };
>
> struct hisi_thermal_data {
> @@ -244,7 +246,7 @@ static int hi6220_thermal_enable_sensor(struct hisi_thermal_data *data)
> hi6220_thermal_set_lag(data->regs, HI6220_TEMP_LAG);
>
> /* enable for interrupt */
> - hi6220_thermal_alarm_set(data->regs, sensor->thres_temp);
> + hi6220_thermal_alarm_set(data->regs, sensor->thres_temp[0]);
>
> hi6220_thermal_reset_set(data->regs, HI6220_TEMP_RESET);
>
> @@ -303,7 +305,7 @@ static int hisi_thermal_get_temp(void *__data, int *temp)
> *temp = data->get_temp(data);
>
> dev_dbg(&data->pdev->dev, "id=%d, temp=%d, thres=%d\n",
> - sensor->id, *temp, sensor->thres_temp);
> + sensor->id, *temp, sensor->thres_temp[0]);
>
> return 0;
> }
> @@ -322,16 +324,16 @@ static irqreturn_t hisi_thermal_alarm_irq_thread(int irq, void *dev)
>
> hisi_thermal_get_temp(data, &temp);
>
> - if (temp >= sensor->thres_temp) {
> + if (temp >= sensor->thres_temp[0]) {
> dev_crit(&data->pdev->dev, "THERMAL ALARM: %d > %d\n",
> - temp, sensor->thres_temp);
> + temp, sensor->thres_temp[0]);
>
> thermal_zone_device_update(data->sensor.tzd,
> THERMAL_EVENT_UNSPECIFIED);
>
> } else {
> dev_crit(&data->pdev->dev, "THERMAL ALARM stopped: %d < %d\n",
> - temp, sensor->thres_temp);
> + temp, sensor->thres_temp[0]);
> }
>
> return IRQ_HANDLED;
> @@ -341,7 +343,7 @@ static int hisi_thermal_register_sensor(struct platform_device *pdev,
> struct hisi_thermal_data *data,
> struct hisi_thermal_sensor *sensor)
> {
> - int ret, i;
> + int ret, i, thres_idx = 0;
> const struct thermal_trip *trip;
>
> sensor->tzd = devm_thermal_zone_of_sensor_register(&pdev->dev,
> @@ -359,8 +361,9 @@ static int hisi_thermal_register_sensor(struct platform_device *pdev,
>
> for (i = 0; i < of_thermal_get_ntrips(sensor->tzd); i++) {
> if (trip[i].type == THERMAL_TRIP_PASSIVE) {
> - sensor->thres_temp = trip[i].temperature;
> - break;
> + sensor->thres_temp[thres_idx++] = trip[i].temperature;
> + if (thres_idx >= MAX_THRES_NUM)
> + break;
> }
> }
>
> --
> 2.7.4
>