diff options
| author | John W. Linville <linville@tuxdriver.com> | 2006-08-14 15:33:54 -0400 |
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2006-08-14 15:33:54 -0400 |
| commit | e9ffb3d7ec94083a44a8721681391beca2ffd68c (patch) | |
| tree | 6768ab487b3f44c2a4995ee61307e47760ca9b88 /kernel/resource.c | |
| parent | 8b9411014e6f18a883c18b38f41338dbd53fddea (diff) | |
| parent | e9fa4f7bd291c29a785666e2fa5a9cf3241ee6c3 (diff) | |
Merge branch 'from-linus' into upstream
Diffstat (limited to 'kernel/resource.c')
| -rw-r--r-- | kernel/resource.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/kernel/resource.c b/kernel/resource.c index 0dd3a857579e..46286434af80 100644 --- a/kernel/resource.c +++ b/kernel/resource.c | |||
| @@ -244,6 +244,7 @@ int find_next_system_ram(struct resource *res) | |||
| 244 | 244 | ||
| 245 | start = res->start; | 245 | start = res->start; |
| 246 | end = res->end; | 246 | end = res->end; |
| 247 | BUG_ON(start >= end); | ||
| 247 | 248 | ||
| 248 | read_lock(&resource_lock); | 249 | read_lock(&resource_lock); |
| 249 | for (p = iomem_resource.child; p ; p = p->sibling) { | 250 | for (p = iomem_resource.child; p ; p = p->sibling) { |
| @@ -254,15 +255,17 @@ int find_next_system_ram(struct resource *res) | |||
| 254 | p = NULL; | 255 | p = NULL; |
| 255 | break; | 256 | break; |
| 256 | } | 257 | } |
| 257 | if (p->start >= start) | 258 | if ((p->end >= start) && (p->start < end)) |
| 258 | break; | 259 | break; |
| 259 | } | 260 | } |
| 260 | read_unlock(&resource_lock); | 261 | read_unlock(&resource_lock); |
| 261 | if (!p) | 262 | if (!p) |
| 262 | return -1; | 263 | return -1; |
| 263 | /* copy data */ | 264 | /* copy data */ |
| 264 | res->start = p->start; | 265 | if (res->start < p->start) |
| 265 | res->end = p->end; | 266 | res->start = p->start; |
| 267 | if (res->end > p->end) | ||
| 268 | res->end = p->end; | ||
| 266 | return 0; | 269 | return 0; |
| 267 | } | 270 | } |
| 268 | #endif | 271 | #endif |
