Commit 8873aab8 authored by Greg Kurz's avatar Greg Kurz Committed by Michael Ellerman

powerpc/xmon: Check cpu id in commands "c#", "dp#" and "dx#"

All these commands end up peeking into the PACA using the user
originated cpu id as an index. Check the cpu id is valid in order
to prevent xmon to crash. Instead of printing an error, this follows
the same behavior as the "lp s #" command : ignore the buggy cpu id
parameter and fall back to the #-less version of the command.
Signed-off-by: default avatarGreg Kurz <groug@kaod.org>
Reviewed-by: default avatarCédric Le Goater <clg@kaod.org>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://msgid.link/161531347060.252863.10490063933688958044.stgit@bahia.lan
parent c3710ee7
...@@ -1350,7 +1350,7 @@ static int cpu_cmd(void) ...@@ -1350,7 +1350,7 @@ static int cpu_cmd(void)
} }
termch = cpu; termch = cpu;
if (!scanhex(&cpu)) { if (!scanhex(&cpu) || cpu >= num_possible_cpus()) {
/* print cpus waiting or in xmon */ /* print cpus waiting or in xmon */
printf("cpus stopped:"); printf("cpus stopped:");
last_cpu = first_cpu = NR_CPUS; last_cpu = first_cpu = NR_CPUS;
...@@ -2772,7 +2772,7 @@ static void dump_pacas(void) ...@@ -2772,7 +2772,7 @@ static void dump_pacas(void)
termch = c; /* Put c back, it wasn't 'a' */ termch = c; /* Put c back, it wasn't 'a' */
if (scanhex(&num)) if (scanhex(&num) && num < num_possible_cpus())
dump_one_paca(num); dump_one_paca(num);
else else
dump_one_paca(xmon_owner); dump_one_paca(xmon_owner);
...@@ -2845,7 +2845,7 @@ static void dump_xives(void) ...@@ -2845,7 +2845,7 @@ static void dump_xives(void)
termch = c; /* Put c back, it wasn't 'a' */ termch = c; /* Put c back, it wasn't 'a' */
if (scanhex(&num)) if (scanhex(&num) && num < num_possible_cpus())
dump_one_xive(num); dump_one_xive(num);
else else
dump_one_xive(xmon_owner); dump_one_xive(xmon_owner);
......
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