From: Zhang Rui Date: Tue, 30 Jun 2009 18:41:31 +0000 (-0700) Subject: kernel/resource.c: fix sign extension in reserve_setup() X-Git-Tag: firefly_0821_release~13542 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8bc1ad7dd301b7ca7454013519fa92e8c53655ff;p=firefly-linux-kernel-4.4.55.git 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=9905 Signed-off-by: Zhang Rui Reported-by: Leann Ogasawara Cc: Pierre Ossman Reported-by: Tested-by: Cc: Cc: Jesse Barnes Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/kernel/resource.c b/kernel/resource.c index ac5f3a36923f..78b087221c15 100644 --- a/kernel/resource.c +++ b/kernel/resource.c @@ -787,7 +787,7 @@ static int __init reserve_setup(char *str) static struct resource reserve[MAXRESERVE]; for (;;) { - int io_start, io_num; + unsigned int io_start, io_num; int x = reserved; if (get_option (&str, &io_start) != 2)