[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <516BFF83.8040800@ti.com>
Date: Mon, 15 Apr 2013 09:24:19 -0400
From: Eduardo Valentin <eduardo.valentin@...com>
To: Zhang Rui <rui.zhang@...el.com>
CC: Eduardo Valentin <eduardo.valentin@...com>,
<linux-pm@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
<durgadoss.r@...el.com>, Greg KH <gregkh@...uxfoundation.org>
Subject: Re: [PATCHv3 3/3] staging: ti-soc-thermal: remove external heat while
extrapolating hotspot
On 14-04-2013 21:44, Zhang Rui wrote:
> On Fri, 2013-04-05 at 08:32 -0400, Eduardo Valentin wrote:
>> For boards that provide a PCB sensor close to SoC junction
>> temperature, it is possible to remove the cumulative heat
>> reported by the SoC temperature sensor.
>>
>> This patch changes the extrapolation computation to consider
>> an external sensor in the extrapolation equations.
>>
>> Signed-off-by: Eduardo Valentin <eduardo.valentin@...com>
>
> hmm, who should take this patch?
>
I will send this one to Greg, maintainer of the staging tree.
BTW, Rui, do you think there is still time to send the TI driver out of
the drivers/staging/ti-soc-thermal to drivers/thermal/ti-soc-thermal for
3.10? If yes, I can send a series straight away.
> thanks,
> rui
>> ---
>> drivers/staging/ti-soc-thermal/ti-thermal-common.c | 30 +++++++++++++------
>> 1 files changed, 20 insertions(+), 10 deletions(-)
>>
>> diff --git a/drivers/staging/ti-soc-thermal/ti-thermal-common.c b/drivers/staging/ti-soc-thermal/ti-thermal-common.c
>> index 231c549..780368b 100644
>> --- a/drivers/staging/ti-soc-thermal/ti-thermal-common.c
>> +++ b/drivers/staging/ti-soc-thermal/ti-thermal-common.c
>> @@ -38,6 +38,7 @@
>> /* common data structures */
>> struct ti_thermal_data {
>> struct thermal_zone_device *ti_thermal;
>> + struct thermal_zone_device *pcb_tz;
>> struct thermal_cooling_device *cool_dev;
>> struct ti_bandgap *bgp;
>> enum thermal_device_mode mode;
>> @@ -77,10 +78,12 @@ static inline int ti_thermal_hotspot_temperature(int t, int s, int c)
>> static inline int ti_thermal_get_temp(struct thermal_zone_device *thermal,
>> unsigned long *temp)
>> {
>> + struct thermal_zone_device *pcb_tz = NULL;
>> struct ti_thermal_data *data = thermal->devdata;
>> struct ti_bandgap *bgp;
>> const struct ti_temp_sensor *s;
>> - int ret, tmp, pcb_temp, slope, constant;
>> + int ret, tmp, slope, constant;
>> + unsigned long pcb_temp;
>>
>> if (!data)
>> return 0;
>> @@ -92,16 +95,22 @@ static inline int ti_thermal_get_temp(struct thermal_zone_device *thermal,
>> if (ret)
>> return ret;
>>
>> - pcb_temp = 0;
>> - /* TODO: Introduce pcb temperature lookup */
>> + /* Default constants */
>> + slope = s->slope;
>> + constant = s->constant;
>> +
>> + pcb_tz = data->pcb_tz;
>> /* In case pcb zone is available, use the extrapolation rule with it */
>> - if (pcb_temp) {
>> - tmp -= pcb_temp;
>> - slope = s->slope_pcb;
>> - constant = s->constant_pcb;
>> - } else {
>> - slope = s->slope;
>> - constant = s->constant;
>> + if (!IS_ERR_OR_NULL(pcb_tz)) {
>> + ret = thermal_zone_get_temp(pcb_tz, &pcb_temp);
>> + if (!ret) {
>> + tmp -= pcb_temp; /* got a valid PCB temp */
>> + slope = s->slope_pcb;
>> + constant = s->constant_pcb;
>> + } else {
>> + dev_err(bgp->dev,
>> + "Failed to read PCB state. Using defaults\n");
>> + }
>> }
>> *temp = ti_thermal_hotspot_temperature(tmp, slope, constant);
>>
>> @@ -248,6 +257,7 @@ static struct ti_thermal_data
>> data->sensor_id = id;
>> data->bgp = bgp;
>> data->mode = THERMAL_DEVICE_ENABLED;
>> + data->pcb_tz = thermal_zone_get_zone_by_name("pcb");
>> INIT_WORK(&data->thermal_wq, ti_thermal_work);
>>
>> return data;
>
>
>
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists