diff mbox

of: thermal: Fixed governor at each thermal zone

Message ID 1474247932-1026-1-git-send-email-hugh.kang@lge.com (mailing list archive)
State Rejected
Delegated to: Zhang Rui
Headers show

Commit Message

Hugh Kang Sept. 19, 2016, 1:18 a.m. UTC
It is necessary to be added governor at each thermal_zone.
Because some governors should be operated in the during the kernel booting
in order to avoid heating problem.

Default governor cannot be covered all thermal zones policy because
some thermal zones want to apply different one.
For example, the power allocator governor operates differently with
step wise governor.
Hence, it is better to parse governor parameter from the device tree.

Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>

Comments

Zhang Rui Sept. 27, 2016, 1:46 a.m. UTC | #1
On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:
> It is necessary to be added governor at each thermal_zone.
> Because some governors should be operated in the during the kernel
> booting
> in order to avoid heating problem.
> 
> Default governor cannot be covered all thermal zones policy because
> some thermal zones want to apply different one.
> For example, the power allocator governor operates differently with
> step wise governor.
> Hence, it is better to parse governor parameter from the device tree.
> 
> Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>
> 
The patch looks okay to me.
Eduardo, what do you think of this patch?

thanks,
rui
> diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-
> thermal.c
> index b8e509c..382c440 100644
> --- a/drivers/thermal/of-thermal.c
> +++ b/drivers/thermal/of-thermal.c
> @@ -970,6 +970,7 @@ int __init of_parse_thermal_zones(void)
>  		struct thermal_zone_device *zone;
>  		struct thermal_zone_params *tzp;
>  		int i, mask = 0;
> +		const char *governor;
>  		u32 prop;
>  
>  		tz = thermal_of_build_thermal_zone(child);
> @@ -996,6 +997,9 @@ int __init of_parse_thermal_zones(void)
>  		if (!of_property_read_u32(child, "sustainable-
> power", &prop))
>  			tzp->sustainable_power = prop;
>  
> +		if (!of_property_read_string(child, "governor-name", 
> &governor))
> +			strcpy(tzp->governor_name, governor);
> +
>  		for (i = 0; i < tz->ntrips; i++)
>  			mask |= 1 << i;
>  
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Javi Merino Sept. 27, 2016, 11:28 a.m. UTC | #2
On Tue, Sep 27, 2016 at 09:46:57AM +0800, Zhang Rui wrote:
> On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:
> > It is necessary to be added governor at each thermal_zone.
> > Because some governors should be operated in the during the kernel
> > booting
> > in order to avoid heating problem.
> > 
> > Default governor cannot be covered all thermal zones policy because
> > some thermal zones want to apply different one.
> > For example, the power allocator governor operates differently with
> > step wise governor.
> > Hence, it is better to parse governor parameter from the device tree.
> > 
> > Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>
> > 
> The patch looks okay to me.
> Eduardo, what do you think of this patch?

This has been proposed in the past[0] and Eduardo said no[1] (as did
Krzysztof Kozlowski and Mark Rutland)

[0] https://marc.info/?l=linux-kernel&m=143893141227189&w=4
[1] https://marc.info/?l=linux-pm&m=144649947022547&w=4

Cheers,
Javi

> > diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-
> > thermal.c
> > index b8e509c..382c440 100644
> > --- a/drivers/thermal/of-thermal.c
> > +++ b/drivers/thermal/of-thermal.c
> > @@ -970,6 +970,7 @@ int __init of_parse_thermal_zones(void)
> >  		struct thermal_zone_device *zone;
> >  		struct thermal_zone_params *tzp;
> >  		int i, mask = 0;
> > +		const char *governor;
> >  		u32 prop;
> >  
> >  		tz = thermal_of_build_thermal_zone(child);
> > @@ -996,6 +997,9 @@ int __init of_parse_thermal_zones(void)
> >  		if (!of_property_read_u32(child, "sustainable-
> > power", &prop))
> >  			tzp->sustainable_power = prop;
> >  
> > +		if (!of_property_read_string(child, "governor-name", 
> > &governor))
> > +			strcpy(tzp->governor_name, governor);
> > +
> >  		for (i = 0; i < tz->ntrips; i++)
> >  			mask |= 1 << i;
> >  
> --
> To unsubscribe from this list: send the line "unsubscribe linux-pm" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Lukasz Luba Sept. 27, 2016, 11:52 a.m. UTC | #3
On 27/09/16 02:46, Zhang Rui wrote:
> On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:
>> It is necessary to be added governor at each thermal_zone.
>> Because some governors should be operated in the during the kernel
>> booting
>> in order to avoid heating problem.
>>
>> Default governor cannot be covered all thermal zones policy because
>> some thermal zones want to apply different one.
>> For example, the power allocator governor operates differently with
>> step wise governor.
>> Hence, it is better to parse governor parameter from the device tree.
>>
>> Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>
>>
> The patch looks okay to me.
> Eduardo, what do you think of this patch?
Hi Rui,

Beside the fact which Javi pointed out in his email, there is an issue 
in the patch itself.
The idea behind the patch is good, but the patch should have some 
improvements, i.e:
- strncpy instead of strcpy,
- if the governor name is not found in the registered governor's list by 
__find_governor (and then null is set) we should probably switch to 
default governor,
- add DT documentation,

Regards,
Lukasz

>
> thanks,
> rui
>> diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-
>> thermal.c
>> index b8e509c..382c440 100644
>> --- a/drivers/thermal/of-thermal.c
>> +++ b/drivers/thermal/of-thermal.c
>> @@ -970,6 +970,7 @@ int __init of_parse_thermal_zones(void)
>>  		struct thermal_zone_device *zone;
>>  		struct thermal_zone_params *tzp;
>>  		int i, mask = 0;
>> +		const char *governor;
>>  		u32 prop;
>>
>>  		tz = thermal_of_build_thermal_zone(child);
>> @@ -996,6 +997,9 @@ int __init of_parse_thermal_zones(void)
>>  		if (!of_property_read_u32(child, "sustainable-
>> power", &prop))
>>  			tzp->sustainable_power = prop;
>>
>> +		if (!of_property_read_string(child, "governor-name",
>> &governor))
>> +			strcpy(tzp->governor_name, governor);
>> +
>>  		for (i = 0; i < tz->ntrips; i++)
>>  			mask |= 1 << i;
>>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-pm" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Eduardo Valentin Sept. 27, 2016, 1:22 p.m. UTC | #4
Hello, Lukasz, Inhyuk, Javi,

On Tue, Sep 27, 2016 at 12:52:04PM +0100, Lukasz Luba wrote:
> 
> On 27/09/16 02:46, Zhang Rui wrote:
> >On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:
> >>It is necessary to be added governor at each thermal_zone.
> >>Because some governors should be operated in the during the kernel
> >>booting
> >>in order to avoid heating problem.
> >>
> >>Default governor cannot be covered all thermal zones policy because
> >>some thermal zones want to apply different one.
> >>For example, the power allocator governor operates differently with
> >>step wise governor.
> >>Hence, it is better to parse governor parameter from the device tree.
> >>
> >>Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>
> >>
> >The patch looks okay to me.
> >Eduardo, what do you think of this patch?
> Hi Rui,
> 
> Beside the fact which Javi pointed out in his email, there is an issue in
> the patch itself.
> The idea behind the patch is good, but the patch should have some
> improvements, i.e:
> - strncpy instead of strcpy,
> - if the governor name is not found in the registered governor's list by
> __find_governor (and then null is set) we should probably switch to default
> governor,
> - add DT documentation,

Also, the idea of the patch is good, almost tempting to do it, but
unfortunately, not acceptable from DT perspective. The patch infringes
two of the DT conceptual and design decision of:
(a) DT should describe hardware, not policy;
(b) DT should describe hardware, not OS specific implementations.

As already pointed by Javi, this patch has already been proposed (more
than one time by different people), but, it still continues to be
unacceptable.

Cheers,


> 
> Regards,
> Lukasz
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Zhang Rui Sept. 28, 2016, 1:30 a.m. UTC | #5
Hi, Javi, Lukasz and Eduardo,

thanks for your input.

thanks,
rui

On 二, 2016-09-27 at 06:22 -0700, Eduardo Valentin wrote:
> Hello, Lukasz, Inhyuk, Javi,
> 
> On Tue, Sep 27, 2016 at 12:52:04PM +0100, Lukasz Luba wrote:
> > 
> > 
> > On 27/09/16 02:46, Zhang Rui wrote:
> > > 
> > > On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:
> > > > 
> > > > It is necessary to be added governor at each thermal_zone.
> > > > Because some governors should be operated in the during the
> > > > kernel
> > > > booting
> > > > in order to avoid heating problem.
> > > > 
> > > > Default governor cannot be covered all thermal zones policy
> > > > because
> > > > some thermal zones want to apply different one.
> > > > For example, the power allocator governor operates differently
> > > > with
> > > > step wise governor.
> > > > Hence, it is better to parse governor parameter from the device
> > > > tree.
> > > > 
> > > > Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>
> > > > 
> > > The patch looks okay to me.
> > > Eduardo, what do you think of this patch?
> > Hi Rui,
> > 
> > Beside the fact which Javi pointed out in his email, there is an
> > issue in
> > the patch itself.
> > The idea behind the patch is good, but the patch should have some
> > improvements, i.e:
> > - strncpy instead of strcpy,
> > - if the governor name is not found in the registered governor's
> > list by
> > __find_governor (and then null is set) we should probably switch to
> > default
> > governor,
> > - add DT documentation,
> Also, the idea of the patch is good, almost tempting to do it, but
> unfortunately, not acceptable from DT perspective. The patch
> infringes
> two of the DT conceptual and design decision of:
> (a) DT should describe hardware, not policy;
> (b) DT should describe hardware, not OS specific implementations.
> 
> As already pointed by Javi, this patch has already been proposed
> (more
> than one time by different people), but, it still continues to be
> unacceptable.
> 
> Cheers,
> 
> 
> > 
> > 
> > Regards,
> > Lukasz
> > 
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Hugh Kang Sept. 28, 2016, 7:13 a.m. UTC | #6
Hello Rui, Javi, Lukasz and Eduardo

> -----Original Message-----

> From: Zhang Rui [mailto:rui.zhang@intel.com]

> Sent: Wednesday, September 28, 2016 10:31 AM

> To: Eduardo Valentin; Lukasz Luba

> Cc: Inhyuk Kang; linux-pm@vger.kernel.org; linux-kernel@vger.kernel.org

> Subject: Re: [PATCH] of: thermal: Fixed governor at each thermal zone

> 

> Hi, Javi, Lukasz and Eduardo,

> 

> thanks for your input.

> 

> thanks,

> rui

> 

> On 二, 2016-09-27 at 06:22 -0700, Eduardo Valentin wrote:

> > Hello, Lukasz, Inhyuk, Javi,

> >

> > On Tue, Sep 27, 2016 at 12:52:04PM +0100, Lukasz Luba wrote:

> > >

> > >

> > > On 27/09/16 02:46, Zhang Rui wrote:

> > > >

> > > > On 一, 2016-09-19 at 10:18 +0900, Inhyuk Kang wrote:

> > > > >

> > > > > It is necessary to be added governor at each thermal_zone.

> > > > > Because some governors should be operated in the during the

> > > > > kernel booting in order to avoid heating problem.

> > > > >

> > > > > Default governor cannot be covered all thermal zones policy

> > > > > because some thermal zones want to apply different one.

> > > > > For example, the power allocator governor operates differently

> > > > > with step wise governor.

> > > > > Hence, it is better to parse governor parameter from the device

> > > > > tree.

> > > > >

> > > > > Signed-off-by: Inhyuk Kang <hugh.kang@lge.com>

> > > > >

> > > > The patch looks okay to me.

> > > > Eduardo, what do you think of this patch?

> > > Hi Rui,

> > >

> > > Beside the fact which Javi pointed out in his email, there is an

> > > issue in the patch itself.

> > > The idea behind the patch is good, but the patch should have some

> > > improvements, i.e:

> > > - strncpy instead of strcpy,

> > > - if the governor name is not found in the registered governor's

> > > list by __find_governor (and then null is set) we should probably

> > > switch to default governor,

> > > - add DT documentation,

> > Also, the idea of the patch is good, almost tempting to do it, but

> > unfortunately, not acceptable from DT perspective. The patch infringes

> > two of the DT conceptual and design decision of:

> > (a) DT should describe hardware, not policy;

> > (b) DT should describe hardware, not OS specific implementations.

> >

> > As already pointed by Javi, this patch has already been proposed (more

> > than one time by different people), but, it still continues to be

> > unacceptable.

> >

> > Cheers,

> >

> >

> > >

> > >

> > > Regards,

> > > Lukasz

> > >

Thank you for reviewing this patch. I understand your ideas. 
During the thermal testing into device, the thermal policy should be applied in the begging of kernel boot sometimes.
Hence, I have suggested above solution.

Anyway, the DT perspective like above, this patch is better not to be upstream.

Thank you very much.

Regards,
Hugh Kang

No One ever is defeated until defeat has been accepted as a reality.
강인혁 (Hugh Kang) Chief Engineer
SW Platform(연) Advanced OS Technology TEAM (AOT)
Mobile: +82-10-5513-7957
diff mbox

Patch

diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-thermal.c
index b8e509c..382c440 100644
--- a/drivers/thermal/of-thermal.c
+++ b/drivers/thermal/of-thermal.c
@@ -970,6 +970,7 @@  int __init of_parse_thermal_zones(void)
 		struct thermal_zone_device *zone;
 		struct thermal_zone_params *tzp;
 		int i, mask = 0;
+		const char *governor;
 		u32 prop;
 
 		tz = thermal_of_build_thermal_zone(child);
@@ -996,6 +997,9 @@  int __init of_parse_thermal_zones(void)
 		if (!of_property_read_u32(child, "sustainable-power", &prop))
 			tzp->sustainable_power = prop;
 
+		if (!of_property_read_string(child, "governor-name", &governor))
+			strcpy(tzp->governor_name, governor);
+
 		for (i = 0; i < tz->ntrips; i++)
 			mask |= 1 << i;