[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <7ee301b76beb679f89e946dfb5921a2d853bd8dc.camel@intel.com>
Date: Tue, 19 Jul 2022 09:14:55 +0800
From: Zhang Rui <rui.zhang@...el.com>
To: Daniel Lezcano <daniel.lezcano@...aro.org>, rafael@...nel.org
Cc: quic_manafm@...cinc.com, amitk@...nel.org, lukasz.luba@....com,
linux-pm@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH v3 3/4] thermal/core: Build ascending ordered indexes
for the trip points
On Mon, 2022-07-18 at 15:21 +0200, Daniel Lezcano wrote:
>
> Hi Zhang,
>
> thanks for the review
>
> On 18/07/2022 07:28, Zhang Rui wrote:
> > On Fri, 2022-07-15 at 23:09 +0200, Daniel Lezcano wrote:
>
> [ ... ]
>
> > > Instead of taking the risk of breaking the existing platforms,
> > > use an
> > > array of temperature ordered trip identifiers and make it
> > > available
> > > for the code needing to browse the trip points in an ordered way.
> > >
> > > Signed-off-by: Daniel Lezcano <daniel.lezcano@...aro.org>
> > > ---
>
> [ ... ]
>
> > > +static void sort_trips_indexes(struct thermal_zone_device *tz)
> > > +{
> > > + int i, j;
> > > +
> > > + for (i = 0; i < tz->trips; i++)
> > > + tz->trips_indexes[i] = i;
> > > +
> > > + for (i = 0; i < tz->trips; i++) {
> > > + for (j = i + 1; j < tz->trips; j++) {
> > > + int t1, t2;
> > > +
> > > + tz->ops->get_trip_temp(tz, tz-
> > > > trips_indexes[i], &t1);
> >
> > This line can be moved to the upper loop.
>
> Right, thanks!
>
> > > + tz->ops->get_trip_temp(tz, tz-
> > > > trips_indexes[j], &t2);
> > > +
> >
> > what about the disabled trip points?
> >
> > we should ignore those trip points and check the return value to
> > make
> > sure we're comparing the valid trip_temp values.
>
> We don't have to care about, whatever the position, the corresponding
> trip id will be disabled by the trip init function before calling
> this
> one and ignored in the handle_thermal_trip() function
hah, I missed this one and replied to your latest reply directly.
The thing I'm concerning is that if we don't check the return value,
for a disabled trip point, the trip_temp (t1/t2) returned is some
random value, it all depends on the previous value set by last
successful .get_trip_temp(), and this may screw up the sorting.
thanks,
rui
>
>
Powered by blists - more mailing lists