[PATCH] memory hotadd fixes: change find_next_system_ram's return value manner

find_next_system_ram() returns valid memory range which meets requested area,
only used by memory-hot-add.

This function always rewrite requested resource even if returned area is not
fully fit in requested one. And sometimes the returnd resource is larger than
requested area. This annoyes the caller. This patch changes the returned
value to fit in requested area.

Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Keith Mannthey <kmannth@gmail.com>
Cc: Yasunori Goto <y-goto@jp.fujitsu.com>
Cc: Dave Hansen <haveblue@us.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>

authored by KAMEZAWA Hiroyuki and committed by Linus Torvalds 0f04ab5e 6f712711

+4 -2
+4 -2
kernel/resource.c
··· 261 261 if (!p) 262 262 return -1; 263 263 /* copy data */ 264 - res->start = p->start; 265 - res->end = p->end; 264 + if (res->start < p->start) 265 + res->start = p->start; 266 + if (res->end > p->end) 267 + res->end = p->end; 266 268 return 0; 267 269 } 268 270 #endif