Commit a6638746 authored by Dan Carpenter's avatar Dan Carpenter Committed by Greg Kroah-Hartman

xen, cpu_hotplug: Prevent an out of bounds access

[ Upstream commit 20167609 ]

The "cpu" variable comes from the sscanf() so Smatch marks it as
untrusted data.  We can't pass a higher value than "nr_cpu_ids" to
cpu_possible() or it results in an out of bounds access.

Fixes: d68d82af ("xen: implement CPU hotplugging")
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Reviewed-by: default avatarJuergen Gross <jgross@suse.com>
Signed-off-by: default avatarJuergen Gross <jgross@suse.com>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent 5f414482
...@@ -54,7 +54,7 @@ static int vcpu_online(unsigned int cpu) ...@@ -54,7 +54,7 @@ static int vcpu_online(unsigned int cpu)
} }
static void vcpu_hotplug(unsigned int cpu) static void vcpu_hotplug(unsigned int cpu)
{ {
if (!cpu_possible(cpu)) if (cpu >= nr_cpu_ids || !cpu_possible(cpu))
return; return;
switch (vcpu_online(cpu)) { switch (vcpu_online(cpu)) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment