[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID:
<OSCPR01MB14647EF08573B0D26175426CEFF2AA@OSCPR01MB14647.jpnprd01.prod.outlook.com>
Date: Wed, 13 Aug 2025 17:44:29 +0000
From: John Madieu <john.madieu.xa@...renesas.com>
To: Daniel Lezcano <daniel.lezcano@...aro.org>
CC: "conor+dt@...nel.org" <conor+dt@...nel.org>, "geert+renesas@...der.be"
<geert+renesas@...der.be>, "krzk+dt@...nel.org" <krzk+dt@...nel.org>,
"rafael@...nel.org" <rafael@...nel.org>, Biju Das
<biju.das.jz@...renesas.com>, "devicetree@...r.kernel.org"
<devicetree@...r.kernel.org>, "john.madieu@...il.com"
<john.madieu@...il.com>, "linux-kernel@...r.kernel.org"
<linux-kernel@...r.kernel.org>, "linux-pm@...r.kernel.org"
<linux-pm@...r.kernel.org>, "linux-renesas-soc@...r.kernel.org"
<linux-renesas-soc@...r.kernel.org>, "lukasz.luba@....com"
<lukasz.luba@....com>, magnus.damm <magnus.damm@...il.com>, "robh@...nel.org"
<robh@...nel.org>, "rui.zhang@...el.com" <rui.zhang@...el.com>,
"sboyd@...nel.org" <sboyd@...nel.org>,
"niklas.soderlund+renesas@...natech.se"
<niklas.soderlund+renesas@...natech.se>
Subject: RE: [PATCH v6 3/5] thermal: renesas: rzg3e: Add thermal driver for
the Renesas RZ/G3E SoC
Hi Daniel,
Thanks again for the feedback.
> -----Original Message-----
> From: Daniel Lezcano <daniel.lezcano@...aro.org>
> Sent: Tuesday, August 5, 2025 12:06 PM
> To: John Madieu <john.madieu.xa@...renesas.com>
> Subject: Re: [PATCH v6 3/5] thermal: renesas: rzg3e: Add thermal driver for
> the Renesas RZ/G3E SoC
>
>
> Hi John,
>
>
> On 05/08/2025 09:49, John Madieu wrote:
>
> [ ... ]
>
> >>> I might not get what you are asking, but since I compute the
> >>> temperature in the hard IRQ handler, I just wait for it to complete
> >>> and notify the completion so I can grab the processed value to
> >>> notify the thermal core.
> >>>
> >>> Please let me know if this does not answer your question.
> >>
> >> Can you describe how the sensor works ? And perhaps if you have a
> >> pointer to some documentation ?
> >
> > Here is the documentation [1]. The thermal device is referred to as TSU.
> >
> > [1]
> > https://www.renesas.com/en/document/mah/rzg3e-group-users-manual-hardw
> > are?r=25574493
> >
> >> [ ... ]
>
> Thanks for the pointer. I got it now ;)
>
> I'm a bit worried about the latency introduced by this mechanism when the
> system is entering in a thermal pressure episode.
>
> The get_temp function wait for a completion up to 100ms, it is a lot.
> Especially if the userspace can be reading the temperature and blocking the
> read.
>
> There is also the spin_lock taken introducing another lock while the
> get_temp function is holding a mutex on the thermal zone.
>
> Did you it that under stress ?
>
After spending some time stressing the driver, I've noticed a
couple of issues:
* Spinlock/mutex mux caused some issues, and I had cases where
it timed-out while not even under stress.
* Mixing both compare (cmp) and conversion complete (conv) IRQs
introduced some latencies and inconsistencies.
After spending some time in the datasheet, I could notice that one
conversion takes around 50µs. In average mode (8 samples per conversion),
it would take 400µs, which I doubled (for margin) and used as timeout in
v7 series that is already ready.
Moreover, as per datasheet recommendations, I kept comparison IRQ
(for trip point violation) only, while using polling for get_temp()
(with the 800µs timeout), which gives better results.
If you don't mind, I'll send a v7 which addresses all the
requests from Geert as well as the above-mentioned changes.
It includes:
* 800µs timeout for get_temp() in polling read
* No spinlock/mutex mix and no completion anymore
* Comparison-only IRQ for trip point violations
* + Geert's change requests
What do you think ?
Regards,
John.
> --
> <http://www.linaro.org/> Linaro.org │ Open source software for ARM SoCs
>
> Follow Linaro: <http://www.facebook.com/pages/Linaro> Facebook |
> <http://twitter.com/#!/linaroorg> Twitter | <http://www.linaro.org/linaro-
> blog/> Blog
Powered by blists - more mailing lists