提交 e9ec7f35 编写于 作者: J Jiri Slaby 提交者: Matthew Garrett

X86: intel_ips, check for kzalloc properly

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: NJiri Slaby <jslaby@suse.cz>
Signed-off-by: NMatthew Garrett <mjg@redhat.com>
Acked-by: NJesse Barnes <jbarnes@virtuousgeek.org>
上级 dfec5c48
...@@ -920,9 +920,8 @@ static int ips_monitor(void *data) ...@@ -920,9 +920,8 @@ static int ips_monitor(void *data)
struct timer_list timer; struct timer_list timer;
unsigned long seqno_timestamp, expire, last_msecs, last_sample_period; unsigned long seqno_timestamp, expire, last_msecs, last_sample_period;
int i; int i;
u32 *cpu_samples = NULL, *mchp_samples = NULL, old_cpu_power; u32 *cpu_samples, *mchp_samples, old_cpu_power;
u16 *mcp_samples = NULL, *ctv1_samples = NULL, *ctv2_samples = NULL, u16 *mcp_samples, *ctv1_samples, *ctv2_samples, *mch_samples;
*mch_samples = NULL;
u8 cur_seqno, last_seqno; u8 cur_seqno, last_seqno;
mcp_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL); mcp_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL);
...@@ -931,7 +930,8 @@ static int ips_monitor(void *data) ...@@ -931,7 +930,8 @@ static int ips_monitor(void *data)
mch_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL); mch_samples = kzalloc(sizeof(u16) * IPS_SAMPLE_COUNT, GFP_KERNEL);
cpu_samples = kzalloc(sizeof(u32) * 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); 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, dev_err(&ips->dev->dev,
"failed to allocate sample array, ips disabled\n"); "failed to allocate sample array, ips disabled\n");
kfree(mcp_samples); kfree(mcp_samples);
...@@ -939,6 +939,7 @@ static int ips_monitor(void *data) ...@@ -939,6 +939,7 @@ static int ips_monitor(void *data)
kfree(ctv2_samples); kfree(ctv2_samples);
kfree(mch_samples); kfree(mch_samples);
kfree(cpu_samples); kfree(cpu_samples);
kfree(mchp_samples);
kthread_stop(ips->adjust); kthread_stop(ips->adjust);
return -ENOMEM; return -ENOMEM;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册