console: Correct printing of hexadecimal integers
Commit b19946cc62
(console: Remove support for printing extra bases)
truncated the digits string to only print integers of up to base 16.
However, that string was also used to print the leading 'x' or 'X' for
hexadecimal integers and is now too short. Fix this to prevent an out
of bounds read.
Change-Id: Iab6470cc88f445f074cf7c0b675346b37f3f2375
Signed-off-by: Jacob Garber <jgarber1@ualberta.ca>
Found-by: Coverity CID 1402999
Reviewed-on: https://review.coreboot.org/c/coreboot/+/34211
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Patrick Georgi <pgeorgi@google.com>
Reviewed-by: HAOUAS Elyes <ehaouas@noos.fr>
Reviewed-by: Nico Huber <nico.h@gmx.de>
Reviewed-by: Julius Werner <jwerner@chromium.org>
This commit is contained in:
parent
15947182fd
commit
5b9948140f
|
@ -107,7 +107,10 @@ static int number(void (*tx_byte)(unsigned char byte, void *data),
|
||||||
call_tx('0'), count++;
|
call_tx('0'), count++;
|
||||||
else if (base == 16) {
|
else if (base == 16) {
|
||||||
call_tx('0'), count++;
|
call_tx('0'), count++;
|
||||||
call_tx(digits[33]), count++;
|
if (type & LARGE)
|
||||||
|
call_tx('X'), count++;
|
||||||
|
else
|
||||||
|
call_tx('x'), count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!(type & LEFT)) {
|
if (!(type & LEFT)) {
|
||||||
|
|
Loading…
Reference in New Issue