[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1bfbbae5-42b0-4c7d-9544-e98855715294@piie.net>
Date: Mon, 5 Aug 2024 23:51:35 +0200
From: Peter Kästle <peter@...e.net>
To: "Rafael J. Wysocki" <rafael@...nel.org>
Cc: "Rafael J. Wysocki" <rjw@...ysocki.net>,
Linux PM <linux-pm@...r.kernel.org>, LKML <linux-kernel@...r.kernel.org>,
Linux ACPI <linux-acpi@...r.kernel.org>,
Daniel Lezcano <daniel.lezcano@...aro.org>, Lukasz Luba
<lukasz.luba@....com>, Zhang Rui <rui.zhang@...el.com>,
Peter Kaestle <peter@...e.net>, platform-driver-x86@...r.kernel.org
Subject: Re: [PATCH v1 12/17] platform/x86: acerhdf: Use the .should_bind()
thermal zone callback
Hi Rafael,
On 01.08.24 12:14, Rafael J. Wysocki wrote:
> Hi Peter,
>
> On Wed, Jul 31, 2024 at 10:50 PM Peter Kästle <xypiie@...il.com> wrote:
>>
>> Hi Rafael,
>>
>> On 30.07.24 20:33, Rafael J. Wysocki wrote:
>>> From: Rafael J. Wysocki <rafael.j.wysocki@...el.com>
>>>
>>> Make the acerhdf driver use the .should_bind() thermal zone
>>> callback to provide the thermal core with the information on whether or
>>> not to bind the given cooling device to the given trip point in the
>>> given thermal zone. If it returns 'true', the thermal core will bind
>>> the cooling device to the trip and the corresponding unbinding will be
>>> taken care of automatically by the core on the removal of the involved
>>> thermal zone or cooling device.
>>>
>>> The previously existing acerhdf_bind() function bound cooling devices
>>> to thermal trip point 0 only, so the new callback needs to return 'true'
>>> for trip point 0. However, it is straightforward to observe that trip
>>> point 0 is an active trip point and the only other trip point in the
>>> driver's thermal zone is a critical one, so it is sufficient to return
>>> 'true' from that callback if the type of the given trip point is
>>> THERMAL_TRIP_ACTIVE.
>>>
>>> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@...el.com>
>>
>> Thanks for including me on the review.
>> I'm working on it, but unfortunately the refactoring of the thermal layer
>> around gov_bang_bang.c earlier this year broke acerhdf.
>
> Well, sorry about that.
I already fixed the main problem, which caused full malfunction of acerhdf:
The new functionality of .trip_crossed in the gov_bang_bang is missing an
initial check, whether the temperature is below the fanoff temperature
(trip_point.temperature - hysteresis) and by that it did not turn the
fan off. This then caused that the system will never heat up as much to
cross the upper temperature. As a consequence it could never cross the
lower temperature to turn the fan off. -> Fan was locked always on.
And that's obviously not what we want.
As I didn't find any API call, to ask the governor doing that for me, I
added an "acerhdf_init_fan()" functionality into acerhdf init function right
after registering the thermal zone (and on resume from suspend) which turns
the fan off if the temperature is lower than the fanoff parameter.
Probably not the nicest solution, but maybe the most pragmatic one without
touching the thermal layer.
>> This needs some debugging and refactoring. I think I can finish it on
>> upcoming weekend.
>
> Thank you!
I'll need some more time to check why other features of acerhdf broke:
* interval cannot be changed to longer than one second.
No idea yet, do you have any idea? Maybe I'll simply drop this
functionality, as there's no big overhead by polling every second.
* changing /sys/module/acerhdf/parameters/{fanon,fanoff} at runtime
to change the trip point settings stopped working. This needs some
restructuring using module_param_cb callbacks.
> I'll be offline next week, so I'll go back to this material in two
> weeks or so anyway.
I still need some time to fix the remaining part anyhow. Once this is
done, I'll check your latest patch series and send my acerhdf rework for
review / submission.
--
regards,
--peter;
Powered by blists - more mailing lists