Re: [PATCH 3/8] cpufreq: powerenv: Fix memory leak
On Thu, 2016-06-02 at 17:13 +0530, Viresh Kumar wrote: > On 02-06-16, 21:37, Michael Ellerman wrote: > > On Thu, 2016-06-02 at 16:52 +0530, Viresh Kumar wrote: > > > On 02-06-16, 21:08, Michael Ellerman wrote: > > > > On Wed, 2016-06-01 at 16:04 +0530, Viresh Kumar wrote: > > > > > > > > > The policy is copied (unnecessarily) and is never freed. Fix it by > > > > > just > > > > > getting a reference to the existing policy structure and putting it > > > > > back. > > > > > > > > > > Signed-off-by: Viresh Kumar > > > > > > > > When was it broken, always? > > > > > > > > Cc: stable ? > > > > > > Its a small memory leak and its not that we will fail on something. So > > > didn't bother to add those details, but in case they are required: > > > > > > Cc: # 4.3+ > > > Fixes: 227942809b52 ("cpufreq: powernv: Restore cpu frequency to > > > policy->cur on unthrottling") > > > > OK. I can't actually see where the copy is? > > > > But if we are leaking even a small amount of memory in a loop like that, in > > a > > function that's run semi-regularly, then it's going to add up eventually. > > Urg, it wasn't a memory leak actually. I misread. > > I somehow thought that cpufreq_get_policy() is also allocating memory > for the policy, but it just memcpy's it into the callers buffer. So, > that's not a problem really. > > This patch should be just dropped. Sorry for the noise. OK, no worries. cheers ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev
Re: [PATCH 3/8] cpufreq: powerenv: Fix memory leak
On 02-06-16, 21:37, Michael Ellerman wrote: > On Thu, 2016-06-02 at 16:52 +0530, Viresh Kumar wrote: > > On 02-06-16, 21:08, Michael Ellerman wrote: > > > On Wed, 2016-06-01 at 16:04 +0530, Viresh Kumar wrote: > > > > > > > The policy is copied (unnecessarily) and is never freed. Fix it by just > > > > getting a reference to the existing policy structure and putting it > > > > back. > > > > > > > > Signed-off-by: Viresh Kumar > > > > > > When was it broken, always? > > > > > > Cc: stable ? > > > > Its a small memory leak and its not that we will fail on something. So > > didn't bother to add those details, but in case they are required: > > > > Cc: # 4.3+ > > Fixes: 227942809b52 ("cpufreq: powernv: Restore cpu frequency to > > policy->cur on unthrottling") > > OK. I can't actually see where the copy is? > > But if we are leaking even a small amount of memory in a loop like that, in a > function that's run semi-regularly, then it's going to add up eventually. Urg, it wasn't a memory leak actually. I misread. I somehow thought that cpufreq_get_policy() is also allocating memory for the policy, but it just memcpy's it into the callers buffer. So, that's not a problem really. This patch should be just dropped. Sorry for the noise. -- viresh ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev
Re: [PATCH 3/8] cpufreq: powerenv: Fix memory leak
On Thu, 2016-06-02 at 16:52 +0530, Viresh Kumar wrote: > On 02-06-16, 21:08, Michael Ellerman wrote: > > On Wed, 2016-06-01 at 16:04 +0530, Viresh Kumar wrote: > > > > > The policy is copied (unnecessarily) and is never freed. Fix it by just > > > getting a reference to the existing policy structure and putting it > > > back. > > > > > > Signed-off-by: Viresh Kumar > > > > When was it broken, always? > > > > Cc: stable ? > > Its a small memory leak and its not that we will fail on something. So > didn't bother to add those details, but in case they are required: > > Cc: # 4.3+ > Fixes: 227942809b52 ("cpufreq: powernv: Restore cpu frequency to policy->cur > on unthrottling") OK. I can't actually see where the copy is? But if we are leaking even a small amount of memory in a loop like that, in a function that's run semi-regularly, then it's going to add up eventually. cheers ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev
Re: [PATCH 3/8] cpufreq: powerenv: Fix memory leak
On 02-06-16, 21:08, Michael Ellerman wrote: > On Wed, 2016-06-01 at 16:04 +0530, Viresh Kumar wrote: > > > The policy is copied (unnecessarily) and is never freed. Fix it by just > > getting a reference to the existing policy structure and putting it > > back. > > > > Signed-off-by: Viresh Kumar > > When was it broken, always? > > Cc: stable ? Its a small memory leak and its not that we will fail on something. So didn't bother to add those details, but in case they are required: Cc: # 4.3+ Fixes: 227942809b52 ("cpufreq: powernv: Restore cpu frequency to policy->cur on unthrottling") -- viresh ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev
Re: [PATCH 3/8] cpufreq: powerenv: Fix memory leak
On Wed, 2016-06-01 at 16:04 +0530, Viresh Kumar wrote: > The policy is copied (unnecessarily) and is never freed. Fix it by just > getting a reference to the existing policy structure and putting it > back. > > Signed-off-by: Viresh Kumar When was it broken, always? Cc: stable ? cheers ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev
[PATCH 3/8] cpufreq: powerenv: Fix memory leak
The policy is copied (unnecessarily) and is never freed. Fix it by just getting a reference to the existing policy structure and putting it back. Signed-off-by: Viresh Kumar --- drivers/cpufreq/powernv-cpufreq.c | 15 +-- 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/drivers/cpufreq/powernv-cpufreq.c b/drivers/cpufreq/powernv-cpufreq.c index 54c45368e3f1..96bb4acd366e 100644 --- a/drivers/cpufreq/powernv-cpufreq.c +++ b/drivers/cpufreq/powernv-cpufreq.c @@ -756,15 +756,18 @@ void powernv_cpufreq_work_fn(struct work_struct *work) chip->restore = false; for_each_cpu(cpu, &mask) { + struct cpufreq_policy *policy = cpufreq_cpu_get(cpu) int index; - struct cpufreq_policy policy; - cpufreq_get_policy(&policy, cpu); - cpufreq_frequency_table_target(&policy, policy.freq_table, - policy.cur, + if (!policy) + continue; + + cpufreq_frequency_table_target(policy, policy->freq_table, + policy->cur, CPUFREQ_RELATION_C, &index); - powernv_cpufreq_target_index(&policy, index); - cpumask_andnot(&mask, &mask, policy.cpus); + powernv_cpufreq_target_index(policy, index); + cpumask_andnot(&mask, &mask, policy->cpus); + cpufreq_cpu_put(policy); } out: put_online_cpus(); -- 2.7.1.410.g6faf27b ___ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev