public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Mikko Perttunen <mikko.perttunen@kapsi.fi>
To: Sascha Hauer <s.hauer@pengutronix.de>, linux-pm@vger.kernel.org
Cc: Zhang Rui <rui.zhang@intel.com>,
	Eduardo Valentin <edubezval@gmail.com>,
	linux-kernel@vger.kernel.org,
	Stephen Warren <swarren@wwwdotorg.org>,
	kernel@pengutronix.de, linux-mediatek@lists.infradead.org,
	linux-arm-kernel@lists.infradead.org,
	Brian Norris <computersforpeace@gmail.com>
Subject: Re: [PATCH 11/15] thermal: thermal: Add support for hardware-tracked trip points
Date: Mon, 18 May 2015 12:06:50 +0300	[thread overview]
Message-ID: <5559ABAA.6040001@kapsi.fi> (raw)
In-Reply-To: <1431507163-19933-12-git-send-email-s.hauer@pengutronix.de>

Thanks for picking up this patch :)

Sorry for being late with these, but here's a few comments..

On 05/13/2015 11:52 AM, Sascha Hauer wrote:
 > This adds support for hardware-tracked trip points to the device tree
 > thermal sensor framework.
 >
 > The framework supports an arbitrary number of trip points. Whenever
 > the current temperature is updated, the trip points immediately
 > below and above the current temperature are found. A .set_trips
 > callback is then called with the temperatures. If there is no trip
 > point above or below the current temperature, the passed trip
 > temperature will be -INT_MAX or INT_MAX respectively. In this callback,
 > the driver should program the hardware such that it is notified
 > when either of these trip points are triggered. When a trip point
 > is triggered, the driver should call `thermal_zone_device_update'
 > for the respective thermal zone. This will cause the trip points
 > to be updated again.
 >
 > If .set_trips is not implemented, the framework behaves as before.
 >
 > This patch is based on an earlier version from Mikko Perttunen
 > <mikko.perttunen@kapsi.fi>
 >
 > Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
 > ---
 >  drivers/thermal/thermal_core.c | 43 
++++++++++++++++++++++++++++++++++++++++++
 >  include/linux/thermal.h        |  3 +++
 >  2 files changed, 46 insertions(+)
 >
 > diff --git a/drivers/thermal/thermal_core.c 
b/drivers/thermal/thermal_core.c
 > index 6bbf61f..3ae1795 100644
 > --- a/drivers/thermal/thermal_core.c
 > +++ b/drivers/thermal/thermal_core.c
 > @@ -453,6 +453,45 @@ int thermal_zone_get_temp(struct 
thermal_zone_device *tz, int *temp)
 >  }
 >  EXPORT_SYMBOL_GPL(thermal_zone_get_temp);
 >
 > +static void thermal_zone_set_trips(struct thermal_zone_device *tz)
 > +{
 > +	int low = -INT_MAX;
 > +	int high = INT_MAX;
 > +	int trip_temp, hysteresis;
 > +	int temp = tz->temperature;
 > +	int i;
 > +
 > +	if (!tz->ops->set_trips)
 > +		return;
 > +
 > +	/* No need to change trip points */
 > +	if (temp > tz->prev_low_trip && temp < tz->prev_high_trip)
 > +		return;
 > +
 > +	for (i = 0; i < tz->trips; i++) {
 > +		int trip_low;
 > +
 > +		tz->ops->get_trip_temp(tz, i, &trip_temp);
 > +		tz->ops->get_trip_hyst(tz, i, &hysteresis);
 > +
 > +		trip_low = trip_temp - hysteresis;
 > +
 > +		if (trip_low < temp && trip_low > low)
 > +			low = trip_low;
 > +
 > +		if (trip_temp > temp && trip_temp < high)
 > +			high = trip_temp;
 > +	}
 > +
 > +	tz->prev_low_trip = low;
 > +	tz->prev_high_trip = high;
 > +
 > +	dev_dbg(&tz->device, "new temperature boundaries: %d < x < %d\n",
 > +			low, high);
 > +
 > +	tz->ops->set_trips(tz, low, high);

This should probably do something if set_trips returns an error code; at 
least an error message, perhaps enable polling? I'm not exactly sure 
what safety features the thermal framework has in general if errors happen..

One interesting thing I noticed was that at least the bang-bang governor 
only acts if the temperature is properly smaller than (trip temp - 
hysteresis). So perhaps we should specify the non-tripping range as 
[low, high)? Or we could change bang-bang.

 > +}
 > +
 >  void thermal_zone_device_update(struct thermal_zone_device *tz)
 >  {
 >  	int temp, ret, count;
 > @@ -479,6 +518,8 @@ void thermal_zone_device_update(struct 
thermal_zone_device *tz)
 >  	dev_dbg(&tz->device, "last_temperature=%d, current_temperature=%d\n",
 >  				tz->last_temperature, tz->temperature);
 >
 > +	thermal_zone_set_trips(tz);
 > +
 >  	for (count = 0; count < tz->trips; count++)
 >  		handle_thermal_trip(tz, count);
 >  }

set_trips should also be called from temp_store and other places that 
modify values that affect the trip points.

 > @@ -1494,6 +1535,8 @@ struct thermal_zone_device 
*thermal_zone_device_register(const char *type,
 >  	tz->trips = trips;
 >  	tz->passive_delay = passive_delay;
 >  	tz->polling_delay = polling_delay;
 > +	tz->prev_low_trip = INT_MAX;
 > +	tz->prev_high_trip = -INT_MAX;
 >
 >  	dev_set_name(&tz->device, "thermal_zone%d", tz->id);
 >  	result = device_register(&tz->device);
 > diff --git a/include/linux/thermal.h b/include/linux/thermal.h
 > index 07bd5e8..aef6e13 100644
 > --- a/include/linux/thermal.h
 > +++ b/include/linux/thermal.h
 > @@ -87,6 +87,7 @@ struct thermal_zone_device_ops {
 >  	int (*unbind) (struct thermal_zone_device *,
 >  		       struct thermal_cooling_device *);
 >  	int (*get_temp) (struct thermal_zone_device *, int *);
 > +	int (*set_trips) (struct thermal_zone_device *, int, int);
 >  	int (*get_mode) (struct thermal_zone_device *,
 >  			 enum thermal_device_mode *);
 >  	int (*set_mode) (struct thermal_zone_device *,
 > @@ -180,6 +181,8 @@ struct thermal_zone_device {
 >  	int last_temperature;
 >  	int emul_temperature;
 >  	int passive;
 > +	int prev_low_trip;
 > +	int prev_high_trip;
 >  	unsigned int forced_passive;
 >  	const struct thermal_zone_device_ops *ops;
 >  	const struct thermal_zone_params *tzp;
 >

  reply	other threads:[~2015-05-18  9:07 UTC|newest]

Thread overview: 34+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-05-13  8:52 [PATCH v3] Thermal hardware trip points and Mediatek thermal driver Sascha Hauer
2015-05-13  8:52 ` [PATCH 01/15] thermal: consistently use int for temperatures Sascha Hauer
2015-05-20  7:12   ` Mikko Perttunen
2015-05-20  8:34     ` Sascha Hauer
2015-05-20  8:42       ` Mikko Perttunen
2015-05-13  8:52 ` [PATCH 02/15] thermal: trivial: fix typo in comment Sascha Hauer
2015-05-13  8:52 ` [PATCH 03/15] thermal: remove useless call to thermal_zone_device_set_polling Sascha Hauer
2015-05-13  8:52 ` [PATCH 04/15] thermal: Use IS_ENABLED instead of #ifdef Sascha Hauer
2015-05-13  8:52 ` [PATCH 05/15] thermal: Add comment explaining test for critical temperature Sascha Hauer
2015-05-20  7:18   ` Mikko Perttunen
2015-05-13  8:52 ` [PATCH 06/15] thermal: inline only once used function Sascha Hauer
2015-05-20  7:28   ` Mikko Perttunen
2015-05-13  8:52 ` [PATCH 07/15] thermal: streamline get_trend callbacks Sascha Hauer
2015-05-13  8:52 ` [PATCH 08/15] thermal: Allow sensor ops to fail with -ENOSYS Sascha Hauer
2015-05-13  8:52 ` [PATCH 09/15] thermal: of: always set sensor related callbacks Sascha Hauer
2015-05-13  8:52 ` [PATCH 10/15] thermal: Make struct thermal_zone_device_ops const Sascha Hauer
2015-05-13  8:52 ` [PATCH 11/15] thermal: thermal: Add support for hardware-tracked trip points Sascha Hauer
2015-05-18  9:06   ` Mikko Perttunen [this message]
2015-05-18 12:09     ` Sascha Hauer
2015-05-18 18:44       ` Brian Norris
2015-05-18 19:13         ` Mikko Perttunen
2015-05-18 20:28           ` Brian Norris
2015-05-19 12:43             ` Mikko Perttunen
2015-05-19 14:05         ` Sascha Hauer
2015-05-19 13:58       ` Sascha Hauer
2015-05-19 14:05         ` Mikko Perttunen
2015-05-20 13:21           ` Sascha Hauer
2015-05-13  8:52 ` [PATCH 12/15] thermal: of: implement .set_trips for device tree thermal zones Sascha Hauer
2015-05-18  9:09   ` Mikko Perttunen
2015-05-13  8:52 ` [PATCH 13/15] dt-bindings: thermal: Add binding document for Mediatek thermal controller Sascha Hauer
2015-05-13  8:52 ` [PATCH 14/15] thermal: Add Mediatek thermal controller support Sascha Hauer
2015-05-14  9:52   ` Paul Bolle
     [not found]     ` <CABicQ-XxXbMMnYyFAst=Xk1HMOXc6N1-J1bvyutMFY_=iNd0fg@mail.gmail.com>
2015-05-15  6:12       ` Sascha Hauer
2015-05-13  8:52 ` [PATCH 15/15] ARM64: dts: mt8173: Add thermal/auxadc device nodes Sascha Hauer

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=5559ABAA.6040001@kapsi.fi \
    --to=mikko.perttunen@kapsi.fi \
    --cc=computersforpeace@gmail.com \
    --cc=edubezval@gmail.com \
    --cc=kernel@pengutronix.de \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mediatek@lists.infradead.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=rui.zhang@intel.com \
    --cc=s.hauer@pengutronix.de \
    --cc=swarren@wwwdotorg.org \
    /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