From: Kieran Bingham <kbingham@kernel.org>
To: "Niklas Söderlund" <niklas.soderlund+renesas@ragnatech.se>,
linux-pm@vger.kernel.org, linux-renesas-soc@vger.kernel.org
Cc: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Subject: Re: [PATCH] thermal: rcar_gen3_thermal: Generate interrupt when temperature changes
Date: Wed, 26 Feb 2020 09:05:22 +0000 [thread overview]
Message-ID: <46d8fe77-57f1-83e3-33ae-5080c6de2424@kernel.org> (raw)
In-Reply-To: <20200212224917.737314-1-niklas.soderlund+renesas@ragnatech.se>
Hi Niklas,
On 12/02/2020 22:49, Niklas Söderlund wrote:
> The desired behavior of the driver is to generate an interrupt and call
s/behavior/behaviour/ but that's me being English, so you can ignore
that ... (at your peril ... :-D )
> thermal_zone_device_update() as soon as the temperature have changed
> more then one degree.
>
> When the set_trips operation was implemented it was believed that the
> trip window set by the framework would move around the current
> temperature and the hysteresis value described in devicetree. The
Should the hysteresis value described in devicetree be a part of the
+-MCELCIUS(1) calculations? or is it determined that a one degree window
each side is sufficient to contain such hysteresis of the readings?
> behavior of the framework is however to set a window based on the trip
> points described in devicetree.
>
> Remove the set_trips operation which was not used correctly and update
> the temperatures that triggers interrupts directly from the interrupt
> handler.
>
> Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Sounds good to me.
Reviewed-by: Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
> ---
> drivers/thermal/rcar_gen3_thermal.c | 24 ++++++++++++------------
> 1 file changed, 12 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/thermal/rcar_gen3_thermal.c b/drivers/thermal/rcar_gen3_thermal.c
> index 72877bdc072daaed..55d1736f532cdb33 100644
> --- a/drivers/thermal/rcar_gen3_thermal.c
> +++ b/drivers/thermal/rcar_gen3_thermal.c
> @@ -81,8 +81,6 @@ struct rcar_gen3_thermal_tsc {
> void __iomem *base;
> struct thermal_zone_device *zone;
> struct equation_coefs coef;
> - int low;
> - int high;
> int tj_t;
> int id; /* thermal channel id */
> };
> @@ -204,12 +202,14 @@ static int rcar_gen3_thermal_mcelsius_to_temp(struct rcar_gen3_thermal_tsc *tsc,
> return INT_FIXPT(val);
> }
>
> -static int rcar_gen3_thermal_set_trips(void *devdata, int low, int high)
> +static int rcar_gen3_thermal_update_range(struct rcar_gen3_thermal_tsc *tsc)
> {
> - struct rcar_gen3_thermal_tsc *tsc = devdata;
> + int temperature, low, high;
>
> - low = clamp_val(low, -40000, 120000);
> - high = clamp_val(high, -40000, 120000);
> + rcar_gen3_thermal_get_temp(tsc, &temperature);
> +
> + low = temperature - MCELSIUS(1);
> + high = temperature + MCELSIUS(1);
>
> rcar_gen3_thermal_write(tsc, REG_GEN3_IRQTEMP1,
> rcar_gen3_thermal_mcelsius_to_temp(tsc, low));
> @@ -217,15 +217,11 @@ static int rcar_gen3_thermal_set_trips(void *devdata, int low, int high)
> rcar_gen3_thermal_write(tsc, REG_GEN3_IRQTEMP2,
> rcar_gen3_thermal_mcelsius_to_temp(tsc, high));
>
> - tsc->low = low;
> - tsc->high = high;
> -
> return 0;
> }
>
> static const struct thermal_zone_of_device_ops rcar_gen3_tz_of_ops = {
> .get_temp = rcar_gen3_thermal_get_temp,
> - .set_trips = rcar_gen3_thermal_set_trips,
> };
>
> static void rcar_thermal_irq_set(struct rcar_gen3_thermal_priv *priv, bool on)
> @@ -246,9 +242,11 @@ static irqreturn_t rcar_gen3_thermal_irq(int irq, void *data)
> for (i = 0; i < priv->num_tscs; i++) {
> status = rcar_gen3_thermal_read(priv->tscs[i], REG_GEN3_IRQSTR);
> rcar_gen3_thermal_write(priv->tscs[i], REG_GEN3_IRQSTR, 0);
> - if (status)
> + if (status) {
> + rcar_gen3_thermal_update_range(priv->tscs[i]);
> thermal_zone_device_update(priv->tscs[i]->zone,
> THERMAL_EVENT_UNSPECIFIED);
> + }
> }
>
> return IRQ_HANDLED;
> @@ -454,6 +452,8 @@ static int rcar_gen3_thermal_probe(struct platform_device *pdev)
> if (ret < 0)
> goto error_unregister;
>
> + rcar_gen3_thermal_update_range(tsc);
> +
> dev_info(dev, "TSC%d: Loaded %d trip points\n", i, ret);
> }
>
> @@ -492,7 +492,7 @@ static int __maybe_unused rcar_gen3_thermal_resume(struct device *dev)
> struct rcar_gen3_thermal_tsc *tsc = priv->tscs[i];
>
> priv->thermal_init(tsc);
> - rcar_gen3_thermal_set_trips(tsc, tsc->low, tsc->high);
> + rcar_gen3_thermal_update_range(tsc);
> }
>
> rcar_thermal_irq_set(priv, true);
>
next prev parent reply other threads:[~2020-02-26 9:05 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-02-12 22:49 [PATCH] thermal: rcar_gen3_thermal: Generate interrupt when temperature changes Niklas Söderlund
2020-02-13 8:19 ` Yoshihiro Shimoda
2020-02-26 9:05 ` Kieran Bingham [this message]
2020-02-26 11:24 ` Niklas Söderlund
2020-02-26 11:35 ` Kieran Bingham
2020-02-26 11:55 ` Niklas Söderlund
2020-02-26 11:41 ` Daniel Lezcano
2020-02-26 11:44 ` Niklas Söderlund
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=46d8fe77-57f1-83e3-33ae-5080c6de2424@kernel.org \
--to=kbingham@kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=linux-renesas-soc@vger.kernel.org \
--cc=niklas.soderlund+renesas@ragnatech.se \
--cc=yoshihiro.shimoda.uh@renesas.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).