All of lore.kernel.org
 help / color / mirror / Atom feed
From: Eduardo Valentin <eduardo.valentin@ti.com>
To: Lukasz Majewski <l.majewski@samsung.com>
Cc: Eduardo Valentin <eduardo.valentin@ti.com>,
	Viresh Kumar <viresh.kumar@linaro.org>,
	"Rafael J. Wysocki" <rjw@rjwysocki.net>,
	Zhang Rui <rui.zhang@intel.com>,
	"cpufreq@vger.kernel.org" <cpufreq@vger.kernel.org>,
	Linux PM list <linux-pm@vger.kernel.org>,
	Jonghwa Lee <jonghwa3.lee@samsung.com>,
	Lukasz Majewski <l.majewski@majess.pl>,
	linux-kernel <linux-kernel@vger.kernel.org>,
	Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>,
	Myungjoo Ham <myungjoo.ham@samsung.com>, <durgadoss.r@intel.com>,
	Amit Daniel Kachhap <amit.daniel@samsung.com>
Subject: Re: [PATCH v10 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412)
Date: Thu, 5 Dec 2013 09:25:23 -0400	[thread overview]
Message-ID: <52A07EC3.5060002@ti.com> (raw)
In-Reply-To: <20131205120349.50029a30@amdc2363>

[-- Attachment #1: Type: text/plain, Size: 13388 bytes --]

Hey Lukasz,

On 05-12-2013 07:03, Lukasz Majewski wrote:
> Hi Eduardo,
> 
>> Hey Lukasz!,
>>
>> On 03-12-2013 11:42, Lukasz Majewski wrote:
>>> Hi Eduardo,
>>>
>>>> On 03-12-2013 03:31, Lukasz Majewski wrote:
>>>>> Hi Eduardo,
>>>>>
>>>>>> On 05-11-2013 13:26, Lukasz Majewski wrote:
>>>>>>> This patch provides auto disable/enable operation for boost. It
>>>>>>> uses already present thermal infrastructure to provide boost
>>>>>>> hysteresis. A special set of TMU data has been defined for
>>>>>>> Exynos4412, which is only considered when BOOST is enabled.
>>>>>>
>>>>>> Can you please add more description why you need a different set
>>>>>> of thermal data when boost is enabled? 
>>>>>
>>>>> It turned out that the Thermal subsystem (after rework done for
>>>>> v3.12) is capable of providing hysteresis for BOOST.
>>>>>
>>>>
>>>> So, the difference is only the hysteresis?
>>>>
>>>>> For version of the patch up to v8 I had to modify the thermal core
>>>>> to provide such functionality. Changes in core weren't accepted by
>>>>> Zhang Rui.
>>>>
>>>> Ok... But still I didn't get what you needed to modify and why..
>>>> Sorry I jumped in the middle of ongoing discussion.
>>>>
>>>>>
>>>>> Then I've looked again to the code and it turned out that proper
>>>>> setting of Exynos4x12 data (like trigger levels and freq_clip_max)
>>>>> can solve the problem in a much better way by using Exynos thermal
>>>>> interrupts.
>>>>> Another advantage is that those changes are done per device.
>>>>>
>>>>>> This is also important in case you
>>>>>> (Exynos thermal folks) would like to migrate this driver to have
>>>>>> thermal data support in DT.
>>>>>
>>>>> Some work on this driver is ongoing (mainly done by Bartek
>>>>> Zolnierkiewicz). This BOOST change doesn't break anything and only
>>>>> extend the current thermal code. Thereof it will not break
>>>>> anything.
>>>>
>>>> Well, good that it does not break anything, right?
>>>>
>>>> But, My point, Lukasz, is that I am failing to understand, based on
>>>> your patch and description why we need a different data definition,
>>>> one for boost, other for without boost. Can you help me to get your
>>>> intention with this patch properly?
>>>
>>> I reduce the trigger_level[0] and set new .freq_table[0] entry.
>>> It works as follow (for BOOST):
>>>
>>> 1. Non-boost freq is 1.4 GHz on Exynos4412. BOOST is 1.5GHz. The
>>> BOOST itself is enabled by CONFIG_CPU_FREQ_BOOST_SW. 
>>>
>>> 2. Exynos TMU driver reaches the lower TMU level (70 deg). Then the
>>> core thermal looks for proper frequency table (.freq_tab[0]). If the
>>> .temp_level matches the trigger_levels[0], then the frequency is
>>> reduced to .freq_clip_max = 1400 * 1000. 
>>>
>>> When the device cools down to 60 deg (trigger_levels[0] -
>>> threshold_falling), then the max freq is restored to 1.5 GHz. This
>>> is done automatically by thermal core.
>>>
>>> For BOOST disabled we only can run with 1.4 GHz freq. For this
>>> reason the freq_tab[X] entries must be modified. Also the Exynos
>>> part of thermal requires that trigger_levels[0] is the lowest
>>> temperature trip, so I cannot add the "BOOST disable" temp level in
>>> the end of TMU_DATA_BOOST.
>>
>> OK. The entire thing is to allow dynamic control on your speedbin
>> frequencies, I see.
> 
> Yes, correct.
> 
>> What bugs me, is that this themal driver keeps
>> another table of frequencies. 
> 
> Yes, it does. It is the part of thermal_cooling_conf data. 
> 
> It is a very practical solution, since we can specify the threshold
> temperature and corresponding maximal frequency (up to 8 values). 
> 
> Those values are afterwards used at exynos_bind to bind zone to cooling
> device.
> 
>> Ideally, it should not care about it,
> 
> The above procedure is a part of passive cooling implementation for
> Exynos.
> 
>> but about the thermal behavior changes, meaning, say, how fast your
>> temperature rises, when you jump from lowest opp to 1.4GHz or 1.5GHz,
>> on host process or cold process samples.
> 
> Could you be more specific here? I assume that you are asking if slope
> of the temperature rise has been measured?
> 
> I didn't measure this value, since it depends on the work environment
> (number of processes running, ambient temperature, current SoC
> temperature, etc.) and thereof is hard to reproduce.
> 
> However, the exynos_thermal_common.c defines .get_trend callback.
> Unfortunately it only gives an information about the trend (rising,
> falling). The exact slope value is not given.
> 
> Personally I think, that the slope measurement is not relevant for the
> BOOST.
> 
>>
>>>
>>>>
>>>> Side question is what happens in runtime if user echo 0 > boost?
>>>
>>> As we had agreed with Rafael and Viresh, we are here mimic the HW
>>> CPUs behaviour (like Intel CPU).
>>
>> Which is fine and expected.
>>
>>> When user writes 'echo 0 > boost' then at cpufreq core we switch to
>>> max freq to 1.4 GHz.
>>
>> OK.
>>
>>>
>>> Thermal here is only for safety reasons.  
>>>
>>>> Should we switch the data within the driver? 
>>>
>>> No. When one decides to enable CONFIG_CPU_FREQ_BOOST_SW, then
>>> corresponding Exynos data are persistent. 
>>>
>>>> Would we be penalizing
>>>> performance with strict hysteresis while we could be allowing
>>>> longer periods of high frequency usage? 
>>>
>>> But the hysteresis shows up only for emergency - when we go out from
>>> allowed power envelope.
>>>
>>> The BOOST is a component of LAB governor, which takes into account
>>> the number of running cores. The "normal" BOOST use case is a
>>> situation when at most two cores are running and other are down.
>>> In this situation we can use BOOST to finish work faster.
>>>
>>>> See what I am missing? Maybe we
>>>> actually need something else a part from defining one data
>>>> structure for boost other for non-boost systems.
>>>
>>> I'm open for suggestions.
>>>
>>> The current proposal aims to change TMU data only for target SoC -
>>> Exynos4412 in this case. I deliberately don't touch the thermal core
>>> code.
>>
>>
>> In fact, I see.
>>
>> I am just wondering if it makes sense to simply use the data that
>> represents BOOST always. 
>> Wouldn't be same as in the situation where
>> user echo 0 > boost?
> 
> I think I get your point here. You would like to reuse the NON BOOST
> value when user types echo 0 > boost.
> 
> The problem is that we would need some kind of notification from
> cpufreq subsystem to thermal that such change was done. 
> This seems like an overkill, and in my opinion it is better to
> use thermal without such notification.
> To be more specific, the thermal already implements the required
> functionality and we "only" need to came up with an idea how to
> appropriately feed data. 

Well, the real problem is that this driver relies on data structures
that duplicates cpufreq data and thermal core data. So, every time you
have a new speedbin frequency, you have to update at least two - three
places to make sure everything is correct.

My point is not exactly that I am suggesting to reuse the non-boost
data. My point is that temperature constraints do not change if you are
using boost or non-boost frequencies. Your temperature trip points will
be the same, because your silicon still is gonna start to break if cross
the line. And that is what I mean when I say, the thermal driver should
be aware of temperature constraints, not frequencies. At most, the
cooling device should be aware of frequencies, not thermal driver.

About the current patch proposal, still, would it work if you only use
BOOST data? Even on non-boost devices? Apparently yes, as you use BOOST
data when boost is disabled. So, that was my point here, why not using
only boost data, regardless of config?

> 
>>
>>>
>>>>
>>>>>
>>>>>>
>>>>>>
>>>>>>>
>>>>>>> Signed-off-by: Lukasz Majewski <l.majewski@samsung.com>
>>>>>>> Signed-off-by: Myungjoo Ham <myungjoo.ham@samsung.com>
>>>>>>>
>>>>>>> ---
>>>>>>> Changes for v10:
>>>>>>>     - Remove boost related code from thermal_core.c
>>>>>>>     - Use already present thermal infrastructure to provide
>>>>>>> thermal hysteresis
>>>>>>>     - Introduce special set of TMU data for BOOST
>>>>>>>
>>>>>>> Changes for v9:
>>>>>>>     - None
>>>>>>>
>>>>>>> Changes for v8:
>>>>>>>     - Move cpufreq_boost_* stub functions definition (needed
>>>>>>> when cpufreq is not compiled in) to cpufreq.h at cpufreq core
>>>>>>> support commit
>>>>>>>
>>>>>>> Changes for v7:
>>>>>>>     - None
>>>>>>>
>>>>>>> Changes for v6:
>>>>>>>     - Disable boost only when supported and enabled
>>>>>>>     - Protect boost related thermal_zone_device struct fields
>>>>>>> with mutex
>>>>>>>     - Evaluate temperature trend during boost enable decision
>>>>>>>     - Create separate methods to handle boost enable/disable
>>>>>>>       (thermal_boost_{enable|disable}) operations
>>>>>>>     - Boost is disabled at any trip point passage (not only the
>>>>>>> non critical one)
>>>>>>>     - Add stub definitions for cpufreq boost functions used when
>>>>>>>       CONFIG_CPU_FREQ is NOT defined.
>>>>>>>
>>>>>>> Changes for v5:
>>>>>>>     - Move boost disable code from cpu_cooling.c to
>>>>>>> thermal_core.c (to handle_non_critical_trips)
>>>>>>>     - Extent struct thermal_zone_device by adding overheated
>>>>>>> bool flag
>>>>>>>     - Implement auto enable of boost after device cools down
>>>>>>>     - Introduce boost_polling flag, which indicates if thermal
>>>>>>> uses it's predefined pool delay or has woken up thermal
>>>>>>> workqueue only to wait until device cools down.
>>>>>>>
>>>>>>> Changes for v4:
>>>>>>>     - New patch
>>>>>>
>>>>>>
>>>>>> Might be interesting to see the changelog for this patch only.
>>>>>
>>>>> The above list presents the development state of this particular
>>>>> patch (thermal). 
>>>>> Up to v8 I had modified the thermal core. For v10 I've decided to
>>>>> use proper Exynos data setting.
>>>>>
>>>>> If in any doubt, please ask. 
>>>>>
>>>>> This last thermal patch of the series hinders this code to be
>>>>> applied to cpufreq subsystem (Viresh had acked it some time ago
>>>>> and I hope that he hasn't changed his mind :-) ).
>>>>>
>>>>>
>>>>>>
>>>>>>>
>>>>>>>  drivers/thermal/samsung/exynos_tmu_data.c |   47
>>>>>>> +++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+)
>>>>>>>
>>>>>>> diff --git a/drivers/thermal/samsung/exynos_tmu_data.c
>>>>>>> b/drivers/thermal/samsung/exynos_tmu_data.c index
>>>>>>> 073c292..9346926 100644 ---
>>>>>>> a/drivers/thermal/samsung/exynos_tmu_data.c +++
>>>>>>> b/drivers/thermal/samsung/exynos_tmu_data.c @@ -167,13 +167,60
>>>>>>> @@ static const struct exynos_tmu_registers
>>>>>>> exynos4412_tmu_registers = { .features = (TMU_SUPPORT_EMULATION
>>>>>>> | TMU_SUPPORT_TRIM_RELOAD | \ TMU_SUPPORT_FALLING_TRIP |
>>>>>>> TMU_SUPPORT_READY_STATUS | \ TMU_SUPPORT_EMUL_TIME) +
>>>>>>> +#define EXYNOS4412_TMU_DATA_BOOST \
>>>>>>> +	.threshold_falling = 10, \
>>>>>>> +	.trigger_levels[0] = 70, \
>>>>>>> +	.trigger_levels[1] = 85, \
>>>>>>> +	.trigger_levels[2] = 103, \
>>>>>>> +	.trigger_levels[3] = 110, \
>>>>>>> +	.trigger_enable[0] = true, \
>>>>>>> +	.trigger_enable[1] = true, \
>>>>>>> +	.trigger_enable[2] = true, \
>>>>>>> +	.trigger_enable[3] = true, \
>>>>>>> +	.trigger_type[0] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[1] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[2] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[3] = SW_TRIP, \
>>>>>>> +	.max_trigger_level = 4, \
>>>>>>> +	.gain = 8, \
>>>>>>> +	.reference_voltage = 16, \
>>>>>>> +	.noise_cancel_mode = 4, \
>>>>>>> +	.cal_type = TYPE_ONE_POINT_TRIMMING, \
>>>>>>> +	.efuse_value = 55, \
>>>>>>> +	.min_efuse_value = 40, \
>>>>>>> +	.max_efuse_value = 100, \
>>>>>>> +	.first_point_trim = 25, \
>>>>>>> +	.second_point_trim = 85, \
>>>>>>> +	.default_temp_offset = 50, \
>>>>>>> +	.freq_tab[0] = { \
>>>>>>> +		.freq_clip_max = 1400 * 1000, \
>>>>>>> +		.temp_level = 70, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab[1] = { \
>>>>>>> +		.freq_clip_max = 800 * 1000, \
>>>>>>> +		.temp_level = 85, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab[2] = { \
>>>>>>> +		.freq_clip_max = 200 * 1000, \
>>>>>>> +		.temp_level = 103, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab_count = 3, \
>>>>>>> +	.registers = &exynos4412_tmu_registers, \
>>>>>>> +	.features = (TMU_SUPPORT_EMULATION |
>>>>>>> TMU_SUPPORT_TRIM_RELOAD | \
>>>>>>> +			TMU_SUPPORT_FALLING_TRIP |
>>>>>>> TMU_SUPPORT_READY_STATUS | \
>>>>>>> +			TMU_SUPPORT_EMUL_TIME)
>>>>>>>  #endif
>>>>>>>  
>>>>>>>  #if defined(CONFIG_SOC_EXYNOS4412)
>>>>>>>  struct exynos_tmu_init_data const exynos4412_default_tmu_data
>>>>>>> = { .tmu_data = {
>>>>>>>  		{
>>>>>>> +#ifdef CONFIG_CPU_FREQ_BOOST_SW
>>>>>>> +			EXYNOS4412_TMU_DATA_BOOST,
>>>>>>> +#else
>>>>>>>  			EXYNOS4412_TMU_DATA,
>>>>>>> +#endif
>>>>>>>  			.type = SOC_ARCH_EXYNOS4412,
>>>>>>>  			.test_mux = EXYNOS4412_MUX_ADDR_VALUE,
>>>>>>>  		},
>>>>>>>
>>>>>>
>>>>>>
>>>>>
>>>>
>>>>
>>>
>>>
>>>
>>
>>
> 
> 


-- 
You have got to be excited about what you are doing. (L. Lamport)

Eduardo Valentin


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 295 bytes --]

WARNING: multiple messages have this Message-ID (diff)
From: Eduardo Valentin <eduardo.valentin@ti.com>
To: Lukasz Majewski <l.majewski@samsung.com>
Cc: Eduardo Valentin <eduardo.valentin@ti.com>,
	Viresh Kumar <viresh.kumar@linaro.org>,
	"Rafael J. Wysocki" <rjw@rjwysocki.net>,
	Zhang Rui <rui.zhang@intel.com>,
	"cpufreq@vger.kernel.org" <cpufreq@vger.kernel.org>,
	Linux PM list <linux-pm@vger.kernel.org>,
	Jonghwa Lee <jonghwa3.lee@samsung.com>,
	Lukasz Majewski <l.majewski@majess.pl>,
	linux-kernel <linux-kernel@vger.kernel.org>,
	Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>,
	Myungjoo Ham <myungjoo.ham@samsung.com>,
	durgadoss.r@intel.com,
	Amit Daniel Kachhap <amit.daniel@samsung.com>
Subject: Re: [PATCH v10 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412)
Date: Thu, 5 Dec 2013 09:25:23 -0400	[thread overview]
Message-ID: <52A07EC3.5060002@ti.com> (raw)
In-Reply-To: <20131205120349.50029a30@amdc2363>

[-- Attachment #1: Type: text/plain, Size: 13388 bytes --]

Hey Lukasz,

On 05-12-2013 07:03, Lukasz Majewski wrote:
> Hi Eduardo,
> 
>> Hey Lukasz!,
>>
>> On 03-12-2013 11:42, Lukasz Majewski wrote:
>>> Hi Eduardo,
>>>
>>>> On 03-12-2013 03:31, Lukasz Majewski wrote:
>>>>> Hi Eduardo,
>>>>>
>>>>>> On 05-11-2013 13:26, Lukasz Majewski wrote:
>>>>>>> This patch provides auto disable/enable operation for boost. It
>>>>>>> uses already present thermal infrastructure to provide boost
>>>>>>> hysteresis. A special set of TMU data has been defined for
>>>>>>> Exynos4412, which is only considered when BOOST is enabled.
>>>>>>
>>>>>> Can you please add more description why you need a different set
>>>>>> of thermal data when boost is enabled? 
>>>>>
>>>>> It turned out that the Thermal subsystem (after rework done for
>>>>> v3.12) is capable of providing hysteresis for BOOST.
>>>>>
>>>>
>>>> So, the difference is only the hysteresis?
>>>>
>>>>> For version of the patch up to v8 I had to modify the thermal core
>>>>> to provide such functionality. Changes in core weren't accepted by
>>>>> Zhang Rui.
>>>>
>>>> Ok... But still I didn't get what you needed to modify and why..
>>>> Sorry I jumped in the middle of ongoing discussion.
>>>>
>>>>>
>>>>> Then I've looked again to the code and it turned out that proper
>>>>> setting of Exynos4x12 data (like trigger levels and freq_clip_max)
>>>>> can solve the problem in a much better way by using Exynos thermal
>>>>> interrupts.
>>>>> Another advantage is that those changes are done per device.
>>>>>
>>>>>> This is also important in case you
>>>>>> (Exynos thermal folks) would like to migrate this driver to have
>>>>>> thermal data support in DT.
>>>>>
>>>>> Some work on this driver is ongoing (mainly done by Bartek
>>>>> Zolnierkiewicz). This BOOST change doesn't break anything and only
>>>>> extend the current thermal code. Thereof it will not break
>>>>> anything.
>>>>
>>>> Well, good that it does not break anything, right?
>>>>
>>>> But, My point, Lukasz, is that I am failing to understand, based on
>>>> your patch and description why we need a different data definition,
>>>> one for boost, other for without boost. Can you help me to get your
>>>> intention with this patch properly?
>>>
>>> I reduce the trigger_level[0] and set new .freq_table[0] entry.
>>> It works as follow (for BOOST):
>>>
>>> 1. Non-boost freq is 1.4 GHz on Exynos4412. BOOST is 1.5GHz. The
>>> BOOST itself is enabled by CONFIG_CPU_FREQ_BOOST_SW. 
>>>
>>> 2. Exynos TMU driver reaches the lower TMU level (70 deg). Then the
>>> core thermal looks for proper frequency table (.freq_tab[0]). If the
>>> .temp_level matches the trigger_levels[0], then the frequency is
>>> reduced to .freq_clip_max = 1400 * 1000. 
>>>
>>> When the device cools down to 60 deg (trigger_levels[0] -
>>> threshold_falling), then the max freq is restored to 1.5 GHz. This
>>> is done automatically by thermal core.
>>>
>>> For BOOST disabled we only can run with 1.4 GHz freq. For this
>>> reason the freq_tab[X] entries must be modified. Also the Exynos
>>> part of thermal requires that trigger_levels[0] is the lowest
>>> temperature trip, so I cannot add the "BOOST disable" temp level in
>>> the end of TMU_DATA_BOOST.
>>
>> OK. The entire thing is to allow dynamic control on your speedbin
>> frequencies, I see.
> 
> Yes, correct.
> 
>> What bugs me, is that this themal driver keeps
>> another table of frequencies. 
> 
> Yes, it does. It is the part of thermal_cooling_conf data. 
> 
> It is a very practical solution, since we can specify the threshold
> temperature and corresponding maximal frequency (up to 8 values). 
> 
> Those values are afterwards used at exynos_bind to bind zone to cooling
> device.
> 
>> Ideally, it should not care about it,
> 
> The above procedure is a part of passive cooling implementation for
> Exynos.
> 
>> but about the thermal behavior changes, meaning, say, how fast your
>> temperature rises, when you jump from lowest opp to 1.4GHz or 1.5GHz,
>> on host process or cold process samples.
> 
> Could you be more specific here? I assume that you are asking if slope
> of the temperature rise has been measured?
> 
> I didn't measure this value, since it depends on the work environment
> (number of processes running, ambient temperature, current SoC
> temperature, etc.) and thereof is hard to reproduce.
> 
> However, the exynos_thermal_common.c defines .get_trend callback.
> Unfortunately it only gives an information about the trend (rising,
> falling). The exact slope value is not given.
> 
> Personally I think, that the slope measurement is not relevant for the
> BOOST.
> 
>>
>>>
>>>>
>>>> Side question is what happens in runtime if user echo 0 > boost?
>>>
>>> As we had agreed with Rafael and Viresh, we are here mimic the HW
>>> CPUs behaviour (like Intel CPU).
>>
>> Which is fine and expected.
>>
>>> When user writes 'echo 0 > boost' then at cpufreq core we switch to
>>> max freq to 1.4 GHz.
>>
>> OK.
>>
>>>
>>> Thermal here is only for safety reasons.  
>>>
>>>> Should we switch the data within the driver? 
>>>
>>> No. When one decides to enable CONFIG_CPU_FREQ_BOOST_SW, then
>>> corresponding Exynos data are persistent. 
>>>
>>>> Would we be penalizing
>>>> performance with strict hysteresis while we could be allowing
>>>> longer periods of high frequency usage? 
>>>
>>> But the hysteresis shows up only for emergency - when we go out from
>>> allowed power envelope.
>>>
>>> The BOOST is a component of LAB governor, which takes into account
>>> the number of running cores. The "normal" BOOST use case is a
>>> situation when at most two cores are running and other are down.
>>> In this situation we can use BOOST to finish work faster.
>>>
>>>> See what I am missing? Maybe we
>>>> actually need something else a part from defining one data
>>>> structure for boost other for non-boost systems.
>>>
>>> I'm open for suggestions.
>>>
>>> The current proposal aims to change TMU data only for target SoC -
>>> Exynos4412 in this case. I deliberately don't touch the thermal core
>>> code.
>>
>>
>> In fact, I see.
>>
>> I am just wondering if it makes sense to simply use the data that
>> represents BOOST always. 
>> Wouldn't be same as in the situation where
>> user echo 0 > boost?
> 
> I think I get your point here. You would like to reuse the NON BOOST
> value when user types echo 0 > boost.
> 
> The problem is that we would need some kind of notification from
> cpufreq subsystem to thermal that such change was done. 
> This seems like an overkill, and in my opinion it is better to
> use thermal without such notification.
> To be more specific, the thermal already implements the required
> functionality and we "only" need to came up with an idea how to
> appropriately feed data. 

Well, the real problem is that this driver relies on data structures
that duplicates cpufreq data and thermal core data. So, every time you
have a new speedbin frequency, you have to update at least two - three
places to make sure everything is correct.

My point is not exactly that I am suggesting to reuse the non-boost
data. My point is that temperature constraints do not change if you are
using boost or non-boost frequencies. Your temperature trip points will
be the same, because your silicon still is gonna start to break if cross
the line. And that is what I mean when I say, the thermal driver should
be aware of temperature constraints, not frequencies. At most, the
cooling device should be aware of frequencies, not thermal driver.

About the current patch proposal, still, would it work if you only use
BOOST data? Even on non-boost devices? Apparently yes, as you use BOOST
data when boost is disabled. So, that was my point here, why not using
only boost data, regardless of config?

> 
>>
>>>
>>>>
>>>>>
>>>>>>
>>>>>>
>>>>>>>
>>>>>>> Signed-off-by: Lukasz Majewski <l.majewski@samsung.com>
>>>>>>> Signed-off-by: Myungjoo Ham <myungjoo.ham@samsung.com>
>>>>>>>
>>>>>>> ---
>>>>>>> Changes for v10:
>>>>>>>     - Remove boost related code from thermal_core.c
>>>>>>>     - Use already present thermal infrastructure to provide
>>>>>>> thermal hysteresis
>>>>>>>     - Introduce special set of TMU data for BOOST
>>>>>>>
>>>>>>> Changes for v9:
>>>>>>>     - None
>>>>>>>
>>>>>>> Changes for v8:
>>>>>>>     - Move cpufreq_boost_* stub functions definition (needed
>>>>>>> when cpufreq is not compiled in) to cpufreq.h at cpufreq core
>>>>>>> support commit
>>>>>>>
>>>>>>> Changes for v7:
>>>>>>>     - None
>>>>>>>
>>>>>>> Changes for v6:
>>>>>>>     - Disable boost only when supported and enabled
>>>>>>>     - Protect boost related thermal_zone_device struct fields
>>>>>>> with mutex
>>>>>>>     - Evaluate temperature trend during boost enable decision
>>>>>>>     - Create separate methods to handle boost enable/disable
>>>>>>>       (thermal_boost_{enable|disable}) operations
>>>>>>>     - Boost is disabled at any trip point passage (not only the
>>>>>>> non critical one)
>>>>>>>     - Add stub definitions for cpufreq boost functions used when
>>>>>>>       CONFIG_CPU_FREQ is NOT defined.
>>>>>>>
>>>>>>> Changes for v5:
>>>>>>>     - Move boost disable code from cpu_cooling.c to
>>>>>>> thermal_core.c (to handle_non_critical_trips)
>>>>>>>     - Extent struct thermal_zone_device by adding overheated
>>>>>>> bool flag
>>>>>>>     - Implement auto enable of boost after device cools down
>>>>>>>     - Introduce boost_polling flag, which indicates if thermal
>>>>>>> uses it's predefined pool delay or has woken up thermal
>>>>>>> workqueue only to wait until device cools down.
>>>>>>>
>>>>>>> Changes for v4:
>>>>>>>     - New patch
>>>>>>
>>>>>>
>>>>>> Might be interesting to see the changelog for this patch only.
>>>>>
>>>>> The above list presents the development state of this particular
>>>>> patch (thermal). 
>>>>> Up to v8 I had modified the thermal core. For v10 I've decided to
>>>>> use proper Exynos data setting.
>>>>>
>>>>> If in any doubt, please ask. 
>>>>>
>>>>> This last thermal patch of the series hinders this code to be
>>>>> applied to cpufreq subsystem (Viresh had acked it some time ago
>>>>> and I hope that he hasn't changed his mind :-) ).
>>>>>
>>>>>
>>>>>>
>>>>>>>
>>>>>>>  drivers/thermal/samsung/exynos_tmu_data.c |   47
>>>>>>> +++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+)
>>>>>>>
>>>>>>> diff --git a/drivers/thermal/samsung/exynos_tmu_data.c
>>>>>>> b/drivers/thermal/samsung/exynos_tmu_data.c index
>>>>>>> 073c292..9346926 100644 ---
>>>>>>> a/drivers/thermal/samsung/exynos_tmu_data.c +++
>>>>>>> b/drivers/thermal/samsung/exynos_tmu_data.c @@ -167,13 +167,60
>>>>>>> @@ static const struct exynos_tmu_registers
>>>>>>> exynos4412_tmu_registers = { .features = (TMU_SUPPORT_EMULATION
>>>>>>> | TMU_SUPPORT_TRIM_RELOAD | \ TMU_SUPPORT_FALLING_TRIP |
>>>>>>> TMU_SUPPORT_READY_STATUS | \ TMU_SUPPORT_EMUL_TIME) +
>>>>>>> +#define EXYNOS4412_TMU_DATA_BOOST \
>>>>>>> +	.threshold_falling = 10, \
>>>>>>> +	.trigger_levels[0] = 70, \
>>>>>>> +	.trigger_levels[1] = 85, \
>>>>>>> +	.trigger_levels[2] = 103, \
>>>>>>> +	.trigger_levels[3] = 110, \
>>>>>>> +	.trigger_enable[0] = true, \
>>>>>>> +	.trigger_enable[1] = true, \
>>>>>>> +	.trigger_enable[2] = true, \
>>>>>>> +	.trigger_enable[3] = true, \
>>>>>>> +	.trigger_type[0] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[1] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[2] = THROTTLE_ACTIVE, \
>>>>>>> +	.trigger_type[3] = SW_TRIP, \
>>>>>>> +	.max_trigger_level = 4, \
>>>>>>> +	.gain = 8, \
>>>>>>> +	.reference_voltage = 16, \
>>>>>>> +	.noise_cancel_mode = 4, \
>>>>>>> +	.cal_type = TYPE_ONE_POINT_TRIMMING, \
>>>>>>> +	.efuse_value = 55, \
>>>>>>> +	.min_efuse_value = 40, \
>>>>>>> +	.max_efuse_value = 100, \
>>>>>>> +	.first_point_trim = 25, \
>>>>>>> +	.second_point_trim = 85, \
>>>>>>> +	.default_temp_offset = 50, \
>>>>>>> +	.freq_tab[0] = { \
>>>>>>> +		.freq_clip_max = 1400 * 1000, \
>>>>>>> +		.temp_level = 70, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab[1] = { \
>>>>>>> +		.freq_clip_max = 800 * 1000, \
>>>>>>> +		.temp_level = 85, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab[2] = { \
>>>>>>> +		.freq_clip_max = 200 * 1000, \
>>>>>>> +		.temp_level = 103, \
>>>>>>> +	}, \
>>>>>>> +	.freq_tab_count = 3, \
>>>>>>> +	.registers = &exynos4412_tmu_registers, \
>>>>>>> +	.features = (TMU_SUPPORT_EMULATION |
>>>>>>> TMU_SUPPORT_TRIM_RELOAD | \
>>>>>>> +			TMU_SUPPORT_FALLING_TRIP |
>>>>>>> TMU_SUPPORT_READY_STATUS | \
>>>>>>> +			TMU_SUPPORT_EMUL_TIME)
>>>>>>>  #endif
>>>>>>>  
>>>>>>>  #if defined(CONFIG_SOC_EXYNOS4412)
>>>>>>>  struct exynos_tmu_init_data const exynos4412_default_tmu_data
>>>>>>> = { .tmu_data = {
>>>>>>>  		{
>>>>>>> +#ifdef CONFIG_CPU_FREQ_BOOST_SW
>>>>>>> +			EXYNOS4412_TMU_DATA_BOOST,
>>>>>>> +#else
>>>>>>>  			EXYNOS4412_TMU_DATA,
>>>>>>> +#endif
>>>>>>>  			.type = SOC_ARCH_EXYNOS4412,
>>>>>>>  			.test_mux = EXYNOS4412_MUX_ADDR_VALUE,
>>>>>>>  		},
>>>>>>>
>>>>>>
>>>>>>
>>>>>
>>>>
>>>>
>>>
>>>
>>>
>>
>>
> 
> 


-- 
You have got to be excited about what you are doing. (L. Lamport)

Eduardo Valentin


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 295 bytes --]

  reply	other threads:[~2013-12-05 13:25 UTC|newest]

Thread overview: 329+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-06-06  7:07 [PATCH 0/5] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-06-06  7:07 ` [PATCH 1/5] cpufreq: Define cpufreq_set_drv_attr_files() to add per CPU sysfs attributes Lukasz Majewski
2013-06-06  8:27   ` Viresh Kumar
2013-06-06  8:58     ` Lukasz Majewski
2013-06-06  9:00       ` Viresh Kumar
2013-06-06  9:16         ` Lukasz Majewski
2013-06-06  7:07 ` [PATCH 2/5] cpufreq:boost: Add support for software based CPU frequency boost Lukasz Majewski
2013-06-06 10:53   ` Viresh Kumar
2013-06-06 11:49     ` Lukasz Majewski
2013-06-06 15:46       ` Viresh Kumar
2013-06-07 13:27         ` Lukasz Majewski
2013-06-07 14:13           ` Viresh Kumar
2013-06-07 14:34             ` Lukasz Majewski
2013-06-07 14:44               ` Viresh Kumar
2013-06-07 14:43         ` Lukasz Majewski
2013-06-06  7:07 ` [PATCH 3/5] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-06-06  7:07 ` [PATCH 4/5] cpufreq:exynos:Extend exynos cpufreq driver to support boost Lukasz Majewski
2013-06-06  7:07 ` [PATCH 5/5] cpufreq:boost:Kconfig: Enable boost support at Kconfig Lukasz Majewski
2013-06-06 14:49   ` Dave Jones
2013-06-06 15:14     ` Lukasz Majewski
2013-06-06 15:21       ` Dave Jones
2013-06-06 15:48         ` Viresh Kumar
2013-06-06 15:58   ` Borislav Petkov
2013-06-10 13:20     ` Lukasz Majewski
2013-06-10 13:22       ` Viresh Kumar
2013-06-10 13:42         ` Lukasz Majewski
2013-06-11  9:03 ` [PATCH v2 0/3] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-06-11  9:03   ` [PATCH v2 1/3] cpufreq:boost: CPU frequency boost code unification for software and hardware solutions Lukasz Majewski
2013-06-12  5:09     ` Viresh Kumar
2013-06-12  7:39       ` Lukasz Majewski
2013-06-12  8:09         ` Viresh Kumar
2013-06-12  9:09           ` Lukasz Majewski
2013-06-12  9:25             ` Viresh Kumar
2013-06-12 12:30               ` Lukasz Majewski
2013-06-12 11:23         ` Rafael J. Wysocki
2013-06-12 11:40           ` Lukasz Majewski
2013-06-11  9:03   ` [PATCH v2 2/3] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-06-11  9:03   ` [PATCH v2 3/3] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-06-26 11:05     ` Viresh Kumar
2013-06-26 13:58       ` Lukasz Majewski
2013-06-27  4:02         ` Viresh Kumar
2013-06-27  6:31           ` Lukasz Majewski
2013-06-12  5:15   ` [PATCH v2 0/3] cpufreq:boost: CPU Boost mode support Viresh Kumar
2013-06-12  6:00     ` Lukasz Majewski
2013-06-12  6:05       ` Viresh Kumar
2013-06-14  7:38 ` [PATCH v3 " Lukasz Majewski
2013-06-14  7:38   ` [PATCH v3 1/3] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-06-17  5:43     ` Viresh Kumar
2013-06-17  7:15       ` Lukasz Majewski
2013-06-17  7:43         ` Viresh Kumar
2013-06-17  9:08           ` Lukasz Majewski
2013-06-17  9:18             ` Viresh Kumar
2013-06-17  9:18               ` Viresh Kumar
2013-06-17  9:58               ` Lukasz Majewski
2013-06-17  9:58                 ` Lukasz Majewski
2013-06-17 13:10                 ` Viresh Kumar
2013-06-17 13:51                   ` Lukasz Majewski
2013-06-18  6:42                     ` Viresh Kumar
2013-06-18  8:24                       ` Lukasz Majewski
2013-06-18  8:40                         ` Viresh Kumar
2013-06-18  9:12                           ` Lukasz Majewski
2013-06-18 13:26                       ` Rafael J. Wysocki
2013-06-18 13:44                         ` Lukasz Majewski
2013-06-19  7:16                           ` Lukasz Majewski
2013-06-20  5:11                             ` Viresh Kumar
2013-06-20  6:41                               ` Lukasz Majewski
2013-06-20  5:05                           ` Viresh Kumar
2013-06-20  5:01                         ` Viresh Kumar
2013-06-20 10:04                           ` Lukasz Majewski
2013-06-14  7:38   ` [PATCH v3 2/3] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-06-14  7:39   ` [PATCH v3 3/3] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-06-17  3:20   ` [PATCH v3 0/3] cpufreq:boost: CPU Boost mode support Viresh Kumar
2013-06-17  5:41     ` Lukasz Majewski
2013-06-19 17:12 ` [PATCH v4 0/7] " Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 1/7] cpufreq: Store cpufreq policies in a list Lukasz Majewski
2013-06-26 10:35     ` Viresh Kumar
2013-06-26 10:54       ` Lukasz Majewski
2013-06-26 10:56         ` Viresh Kumar
2013-06-26 11:04           ` Lukasz Majewski
2013-06-26 11:08             ` Viresh Kumar
2013-06-26 12:15               ` Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 2/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-06-19 17:48     ` Dirk Brandewie
2013-06-19 20:31       ` Lukasz Majewski
2013-06-19 22:25         ` Rafael J. Wysocki
2013-07-17  7:58           ` Viresh Kumar
2013-07-17 11:31             ` Rafael J. Wysocki
2013-07-17 13:01               ` Viresh Kumar
2013-07-17 14:59                 ` Lukasz Majewski
2013-07-18  7:51                   ` Viresh Kumar
2013-06-20  5:13     ` Viresh Kumar
2013-06-20 20:03       ` Rafael J. Wysocki
2013-06-21  6:23         ` Lukasz Majewski
2013-06-26 10:54     ` Viresh Kumar
2013-06-26 12:54       ` Lukasz Majewski
2013-06-26 14:02         ` Lukasz Majewski
2013-06-27  9:02         ` Viresh Kumar
2013-06-27  9:48           ` Lukasz Majewski
2013-06-27 10:25             ` Viresh Kumar
2013-06-27 11:07               ` Lukasz Majewski
2013-06-27 15:55       ` Lukasz Majewski
2013-06-28  3:40         ` Viresh Kumar
2013-06-28  6:49           ` Lukasz Majewski
2013-06-28  6:51             ` Viresh Kumar
2013-06-28  7:31               ` Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 3/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-06-26 11:03     ` Viresh Kumar
2013-06-26 12:17       ` Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-06-27  8:58     ` Viresh Kumar
2013-06-27  9:08       ` Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 5/7] cpufreq: Calculate number of busy CPUs Lukasz Majewski
2013-06-19 18:01     ` Dirk Brandewie
2013-06-19 20:58       ` Lukasz Majewski
2013-06-19 22:26         ` Rafael J. Wysocki
2013-06-27  9:36     ` Viresh Kumar
2013-06-27 10:58       ` Lukasz Majewski
2013-06-27 11:16         ` Viresh Kumar
2013-06-27 14:42           ` Lukasz Majewski
2013-06-28  3:50             ` Viresh Kumar
2013-06-28  6:54               ` Lukasz Majewski
2013-07-01  8:15                 ` Lukasz Majewski
2013-07-04  5:06                   ` Viresh Kumar
2013-07-04  5:43                     ` Lukasz Majewski
2013-07-04  6:28                       ` Viresh Kumar
2013-07-04  6:49                         ` Lukasz Majewski
2013-07-04 12:50                     ` Rafael J. Wysocki
2013-06-19 17:12   ` [PATCH v4 6/7] cpufreq: Enable software boost only when up to one busy core is running Lukasz Majewski
2013-06-19 17:12   ` [PATCH v4 7/7] thermal:boost: Disable boost when trip point is reached Lukasz Majewski
2013-06-26  7:48   ` [PATCH v4 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-06-26  7:52     ` Viresh Kumar
2013-07-04  8:50 ` [PATCH v5 " Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 1/7] cpufreq: Store cpufreq policies in a list Lukasz Majewski
2013-07-16  8:51     ` Viresh Kumar
2013-07-16  9:39       ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 2/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-07-16  9:41     ` Viresh Kumar
2013-07-16 12:06       ` Lukasz Majewski
2013-07-17  5:28         ` Viresh Kumar
2013-07-17  7:00           ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 3/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-07-16 10:04     ` Viresh Kumar
2013-07-16 11:17       ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-07-16  9:48     ` Viresh Kumar
2013-07-16 10:58       ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 5/7] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-07-04 17:19     ` R, Durgadoss
2013-07-04 20:58       ` Lukasz Majewski
2013-07-05  5:31         ` R, Durgadoss
2013-07-05  6:43           ` Lukasz Majewski
2013-07-11  8:08     ` Lukasz Majewski
2013-07-16  7:28       ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 6/7] cpufreq:boost:Kconfig: Enable software managed BOOST support at Kconfig Lukasz Majewski
2013-07-16  9:58     ` Viresh Kumar
2013-07-16 11:50       ` Lukasz Majewski
2013-07-17  5:24         ` Viresh Kumar
2013-07-17  7:17           ` Lukasz Majewski
2013-07-17  7:52             ` Viresh Kumar
2013-07-17  8:12               ` Lukasz Majewski
2013-07-17  8:29                 ` Viresh Kumar
2013-07-17  9:11                   ` Lukasz Majewski
2013-07-04  8:50   ` [PATCH v5 7/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-07-16 10:01     ` Viresh Kumar
2013-07-16 11:33       ` Lukasz Majewski
2013-07-17  5:22         ` Viresh Kumar
2013-07-17  7:36           ` Lukasz Majewski
2013-07-17  7:59             ` Viresh Kumar
2013-07-17  8:13               ` Lukasz Majewski
2013-07-09  7:02   ` [PATCH v5 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-07-09  7:04     ` Viresh Kumar
2013-07-16  7:26     ` Lukasz Majewski
2013-07-16  8:46       ` Viresh Kumar
2013-07-16  9:09         ` Lukasz Majewski
2013-07-25 16:33 ` [PATCH v6 0/8] " Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 1/8] cpufreq: Store cpufreq policies in a list Lukasz Majewski
2013-07-26 10:14     ` Viresh Kumar
2013-07-26 10:58       ` Lukasz Majewski
2013-07-26 11:02         ` Viresh Kumar
2013-07-26 12:46           ` Lukasz Majewski
2013-07-29  7:03             ` Viresh Kumar
2013-07-25 16:33   ` [PATCH v6 2/8] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-07-26  7:17     ` Viresh Kumar
2013-07-26  8:33       ` Lukasz Majewski
2013-07-26  9:33         ` Viresh Kumar
2013-07-26 10:10           ` Lukasz Majewski
2013-07-26  9:36         ` Viresh Kumar
2013-07-26 10:11           ` Lukasz Majewski
2013-08-12  9:07           ` Lukasz Majewski
2013-08-12  9:10             ` Viresh Kumar
2013-07-26 12:36         ` Rafael J. Wysocki
2013-07-26 13:08           ` Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 3/8] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-07-26  7:28     ` Viresh Kumar
2013-07-26  8:09       ` Lukasz Majewski
2013-07-26  9:24         ` Viresh Kumar
2013-07-26  9:44           ` Lukasz Majewski
2013-08-12  9:12           ` Lukasz Majewski
2013-08-12  9:14             ` Viresh Kumar
2013-07-25 16:33   ` [PATCH v6 4/8] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-08-12  9:17     ` Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 5/8] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-07-26 10:24     ` Viresh Kumar
2013-07-26 11:21       ` Lukasz Majewski
2013-07-29  6:58         ` Viresh Kumar
2013-08-12 10:26           ` Lukasz Majewski
2013-08-12 10:28             ` Viresh Kumar
2013-08-12 10:50               ` Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 6/8] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-07-26 10:26     ` Viresh Kumar
2013-07-26 11:26       ` Lukasz Majewski
2013-07-29  7:01         ` Viresh Kumar
2013-08-12  9:52       ` Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 7/8] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-07-25 16:33   ` [PATCH v6 8/8] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-07-26 10:28   ` [PATCH v6 0/8] cpufreq:boost: CPU Boost mode support Viresh Kumar
2013-08-13 10:08 ` [PATCH v7 0/7] " Lukasz Majewski
2013-08-13 10:08   ` [PATCH v7 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-08-26  5:28     ` Viresh Kumar
2013-08-26  7:02       ` Lukasz Majewski
2013-08-26  7:06         ` Viresh Kumar
2013-08-26  7:11           ` Lukasz Majewski
2013-08-26 13:12             ` Rafael J. Wysocki
2013-08-26 14:00               ` Viresh Kumar
2013-08-26 14:46                 ` Lukasz Majewski
2013-08-13 10:08   ` [PATCH v7 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-08-26  5:32     ` Viresh Kumar
2013-08-13 10:08   ` [PATCH v7 3/7] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-08-26  5:33     ` Viresh Kumar
2013-08-26  6:50       ` Lukasz Majewski
2013-08-13 10:08   ` [PATCH v7 4/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-08-26  5:35     ` Viresh Kumar
2013-08-13 10:08   ` [PATCH v7 5/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-08-26  5:36     ` Viresh Kumar
2013-08-13 10:08   ` [PATCH v7 6/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-08-26  5:36     ` Viresh Kumar
2013-08-13 10:08   ` [PATCH v7 7/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-08-26  5:37     ` Viresh Kumar
2013-08-19  6:38   ` [PATCH v7 0/7] cpufreq:boost: CPU Boost mode support Viresh Kumar
2013-08-19  6:50     ` Lukasz Majewski
2013-08-19 23:29       ` Rafael J. Wysocki
2013-08-20  8:11         ` Lukasz Majewski
2013-08-20 12:32           ` Rafael J. Wysocki
2013-08-26 15:50 ` [PATCH v8 " Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 3/7] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 4/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 5/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 6/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-08-26 15:50   ` [PATCH v8 7/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-09-20 16:00 ` [PATCH RESEND v8 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-09-20 16:00   ` [PATCH RESEND v8 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-09-20 16:00   ` [PATCH RESEND v8 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-09-20 16:01   ` [PATCH RESEND v8 3/7] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-09-20 16:01   ` [PATCH RESEND v8 4/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-09-20 16:01   ` [PATCH RESEND v8 5/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-09-20 16:01   ` [PATCH RESEND v8 6/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-09-20 16:01   ` [PATCH RESEND v8 7/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-10-14 12:17 ` [PATCH v9 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 3/7] thermal:boost: Automatic enable/disable of BOOST feature Lukasz Majewski
2013-10-15  9:32     ` Zhang Rui
2013-10-15 15:43       ` Lukasz Majewski
2013-10-17 15:09         ` Zhang, Rui
2013-10-14 12:17   ` [PATCH v9 4/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 5/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 6/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-10-14 12:17   ` [PATCH v9 7/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-11-05 17:26 ` [PATCH v10 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 3/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 5/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 6/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-11-05 17:26   ` [PATCH v10 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412) Lukasz Majewski
2013-11-28 13:05     ` Lukasz Majewski
2013-12-02 14:53     ` Eduardo Valentin
2013-12-02 14:53       ` Eduardo Valentin
2013-12-03  7:31       ` Lukasz Majewski
2013-12-03 12:36         ` Eduardo Valentin
2013-12-03 12:36           ` Eduardo Valentin
2013-12-03 15:42           ` Lukasz Majewski
2013-12-04 14:10             ` Eduardo Valentin
2013-12-04 14:10               ` Eduardo Valentin
2013-12-05 11:03               ` Lukasz Majewski
2013-12-05 13:25                 ` Eduardo Valentin [this message]
2013-12-05 13:25                   ` Eduardo Valentin
2013-12-06 14:03                   ` Lukasz Majewski
2013-12-02 12:19 ` [PATCH RESEND v10 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 3/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 5/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 6/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-12-02 12:19   ` [PATCH RESEND v10 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412) Lukasz Majewski
2013-12-04  6:59   ` [PATCH RESEND v10 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-12-04 14:12     ` Eduardo Valentin
2013-12-04 14:12       ` Eduardo Valentin
2013-12-09 10:04       ` Lukasz Majewski
2013-12-13 16:38 ` [PATCH v11 " Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 3/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 5/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 6/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-12-13 16:38   ` [PATCH v11 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412) Lukasz Majewski
2013-12-19 14:50     ` Eduardo Valentin
2013-12-19 14:50       ` Eduardo Valentin
2013-12-20 14:24 ` [PATCH v12 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 1/7] cpufreq: Add boost frequency support in core Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 2/7] cpufreq:acpi:x86: Adjust the acpi-cpufreq.c code to work with common boost solution Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 3/7] cpufreq:boost:Kconfig: Provide support for software managed BOOST Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 4/7] cpufreq:exynos:Extend Exynos cpufreq driver to support boost framework Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 5/7] Documentation:cpufreq:boost: Update BOOST documentation Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 6/7] cpufreq:exynos4x12: Change L0 driver data to CPUFREQ_BOOST_FREQ Lukasz Majewski
2013-12-20 14:24   ` [PATCH v12 7/7] thermal:exynos:boost: Automatic enable/disable of BOOST feature (at Exynos4412) Lukasz Majewski
2014-01-10  6:35     ` Zhang Rui
2014-01-07  6:58   ` [PATCH v12 0/7] cpufreq:boost: CPU Boost mode support Lukasz Majewski
2014-01-08  0:35     ` Rafael J. Wysocki
2014-01-09  7:19       ` Lukasz Majewski
2014-01-10  6:33       ` Zhang Rui
2014-01-16  9:40         ` Lukasz Majewski
2014-01-16 15:51           ` Rafael J. Wysocki
2014-01-16 15:56             ` Lukasz Majewski

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=52A07EC3.5060002@ti.com \
    --to=eduardo.valentin@ti.com \
    --cc=amit.daniel@samsung.com \
    --cc=b.zolnierkie@samsung.com \
    --cc=cpufreq@vger.kernel.org \
    --cc=durgadoss.r@intel.com \
    --cc=jonghwa3.lee@samsung.com \
    --cc=l.majewski@majess.pl \
    --cc=l.majewski@samsung.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=myungjoo.ham@samsung.com \
    --cc=rjw@rjwysocki.net \
    --cc=rui.zhang@intel.com \
    --cc=viresh.kumar@linaro.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.