X86: intel_ips, check for kzalloc properly
authorJiri Slaby <jslaby@suse.cz>
Mon, 21 Jun 2010 15:40:15 +0000 (17:40 +0200)
committerMatthew Garrett <mjg@redhat.com>
Tue, 3 Aug 2010 13:48:48 +0000 (09:48 -0400)
Stanse found that there are two NULL checks missing in ips_monitor. So
check their value too and bail out appropriately if the allocation
failed.

While at it, add one more kfree to the fail path. It is not necessary
now, but may be needed in the future when a new allocation is added.
And for completeness.

Also remove unneeded initialization of the variables. They are all set
right after their declaration.

Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Signed-off-by: Matthew Garrett <mjg@redhat.com>
Acked-by: Jesse Barnes <jbarnes@virtuousgeek.org>
drivers/platform/x86/intel_ips.c

index cdaf40e444600a0bb089214c2d726f71d830fe4d..03448224aedb3570fc8dc13ed2df03ab60cc34c8 100644 (file)
@@ -920,9 +920,8 @@ static int ips_monitor(void *data)
        struct timer_list timer;
        unsigned long seqno_timestamp, expire, last_msecs, last_sample_period;
        int i;
-       u32 *cpu_samples = NULL, *mchp_samples = NULL, old_cpu_power;
-       u16 *mcp_samples = NULL, *ctv1_samples = NULL, *ctv2_samples = NULL,
-               *mch_samples = NULL;
+       u32 *cpu_samples, *mchp_samples, old_cpu_power;
+       u16 *mcp_samples, *ctv1_samples, *ctv2_samples, *mch_samples;
        u8 cur_seqno, last_seqno;
 
        mcp_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL);
@@ -931,7 +930,8 @@ static int ips_monitor(void *data)
        mch_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL);
        cpu_samples = kzalloc(sizeof(u32) * IPS_SAMPLE_COUNT, GFP_KERNEL);
        mchp_samples = kzalloc(sizeof(u32) * IPS_SAMPLE_COUNT, GFP_KERNEL);
-       if (!mcp_samples || !ctv1_samples || !ctv2_samples || !mch_samples) {
+       if (!mcp_samples || !ctv1_samples || !ctv2_samples || !mch_samples ||
+                       !cpu_samples || !mchp_samples) {
                dev_err(&ips->dev->dev,
                        "failed to allocate sample array, ips disabled\n");
                kfree(mcp_samples);
@@ -939,6 +939,7 @@ static int ips_monitor(void *data)
                kfree(ctv2_samples);
                kfree(mch_samples);
                kfree(cpu_samples);
+               kfree(mchp_samples);
                kthread_stop(ips->adjust);
                return -ENOMEM;
        }