On 01/15/2013 07:26 PM, Cong Ding wrote: > On Tue, Jan 15, 2013 at 05:33:57PM +0100, Gregory CLEMENT wrote: >> On 01/15/2013 04:37 PM, Jason Cooper wrote: >>> Mike, >>> >>> On Tue, Jan 15, 2013 at 03:23:08PM +0000, Cong Ding wrote: >>>> From 75c73077905b822be6e8a32a09d6b0cdb5e61763 Mon Sep 17 00:00:00 2001 >>>> From: Cong Ding <ding...@gmail.com> >>>> Date: Mon, 14 Jan 2013 18:06:26 +0100 >>>> Subject: [PATCH v2] clk: mvebu/clk-cpu.c: fix memory leakage >>>> >>>> the variable cpuclk and clk_name should be properly freed when error >>>> happens. >>>> >>>> Signed-off-by: Cong Ding <ding...@gmail.com> >>>> --- >>>> drivers/clk/mvebu/clk-cpu.c | 15 ++++++++++----- >>>> 1 file changed, 10 insertions(+), 5 deletions(-) >>> >>> >>> Do you want to take this fix through the clock tree? If so, >>> >>> Acked-by: Jason Cooper <ja...@lakedaemon.net> >>> >> >> I also think it should go through the clock tree but before this >> I'd like we fix the last issue. >> >> Cong Ding, >> >> you didn't take in account the case when the allocation of the 1st clocks >> when the 2nd cpu clock failed. In this case there is still a memory leak with >> the clock_name of the first cpu clock. See below for my proposal: >> >>> Otherwise, just let me know. >>> >>> thx, >>> >>> Jason. >>> >>>> diff --git a/drivers/clk/mvebu/clk-cpu.c b/drivers/clk/mvebu/clk-cpu.c >>>> index ff004578..1066a43 100644 >>>> --- a/drivers/clk/mvebu/clk-cpu.c >>>> +++ b/drivers/clk/mvebu/clk-cpu.c >>>> @@ -124,7 +124,7 @@ void __init of_cpu_clk_setup(struct device_node *node) >>>> >>>> clks = kzalloc(ncpus * sizeof(*clks), GFP_KERNEL); >>>> if (WARN_ON(!clks)) >>>> - return; >>>> + goto clks_out; >>>> >>>> for_each_node_by_type(dn, "cpu") { >>>> struct clk_init_data init; >>>> @@ -134,11 +134,13 @@ void __init of_cpu_clk_setup(struct device_node >>>> *node) >>>> int cpu, err; >>>> >>>> if (WARN_ON(!clk_name)) >>>> - return; >>>> + goto bail_out; >>>> >>>> err = of_property_read_u32(dn, "reg", &cpu); >>>> - if (WARN_ON(err)) >>>> - return; >>>> + if (WARN_ON(err)) { >> >>>> + kfree(clk_name); >> we can free it later >> >>>> + goto bail_out; >>>> + } >>>> >>>> sprintf(clk_name, "cpu%d", cpu); >>>> parent_clk = of_clk_get(node, 0); >>>> @@ -156,8 +158,10 @@ void __init of_cpu_clk_setup(struct device_node *node) >>>> init.num_parents = 1; >>>> >>>> clk = clk_register(NULL, &cpuclk[cpu].hw); >>>> - if (WARN_ON(IS_ERR(clk))) >>>> + if (WARN_ON(IS_ERR(clk))) { >> >>>> + kfree(clk_name); >> we can free it later >> >>>> goto bail_out; >>>> + } >>>> clks[cpu] = clk; >>>> } >>>> clk_data.clk_num = MAX_CPU; >>>> @@ -167,6 +171,7 @@ void __init of_cpu_clk_setup(struct device_node *node) >>>> return; >>>> bail_out: >>>> kfree(clks); >>>> +clks_out: >> >> as cpuclk is allocated with all its member set to 0, and kfree(0) is a valid >> call. >> We can add the following lines: >> while(ncpus--) >> kfree(cpuclk[ncpus].clk_name); >> >>>> kfree(cpuclk); >>>> } > I agree the version 2 patch still includes memory leakage in terms of > clk_name, > but I am wondering whether it is safe to call kfree(cpuclk[ncpus].clkname) > directly or not. It's true that kfree(0) is valid, but cpuclk[ncpus].clkname > might not be 0 when it is allocated by kzalloc. kzalloc just allocates the > memory while doesn't ensure the initial value in this memory area is 0. So I
I think that you describe the behavior of kmalloc, but the main difference with kmalloc and kzalloc, is that kzalloc allocates _zeroed_ paged, so I am pretty sure that all the memory space allocated should be set to zero. > am thinking we should call memset after the alloction or use a counter to > remember the number of clk_names allocated? > > - cong > -- Gregory Clement, Free Electrons Kernel, drivers, real-time and embedded Linux development, consulting, training and support. http://free-electrons.com -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/