Commit 8bc1ad7d authored by Zhang Rui's avatar Zhang Rui Committed by Linus Torvalds

kernel/resource.c: fix sign extension in reserve_setup()

When the 32-bit signed quantities get assigned to the u64 resource_size_t,
they are incorrectly sign-extended.

Addresses http://bugzilla.kernel.org/show_bug.cgi?id=13253
Addresses http://bugzilla.kernel.org/show_bug.cgi?id=9905Signed-off-by: default avatarZhang Rui <rui.zhang@intel.com>
Reported-by: default avatarLeann Ogasawara <leann@ubuntu.com>
Cc: Pierre Ossman <drzeus@drzeus.cx>
Reported-by: <pablomme@googlemail.com>
Tested-by: <pablomme@googlemail.com>
Cc: <stable@kernel.org>
Cc: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 529ba0d9
...@@ -787,7 +787,7 @@ static int __init reserve_setup(char *str) ...@@ -787,7 +787,7 @@ static int __init reserve_setup(char *str)
static struct resource reserve[MAXRESERVE]; static struct resource reserve[MAXRESERVE];
for (;;) { for (;;) {
int io_start, io_num; unsigned int io_start, io_num;
int x = reserved; int x = reserved;
if (get_option (&str, &io_start) != 2) if (get_option (&str, &io_start) != 2)
......
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