Commit 483dd9ad authored by Linus Torvalds's avatar Linus Torvalds

Be more careful about looking for gaps in the e820 table.

We really don't care about anything beyond the 4GB mark,
so make the tests for that explicit (and add a comment),
and use regular "unsigned long" for the gap information.
parent bba30a6e
...@@ -1168,7 +1168,7 @@ legacy_init_iomem_resources(struct resource *code_resource, struct resource *dat ...@@ -1168,7 +1168,7 @@ legacy_init_iomem_resources(struct resource *code_resource, struct resource *dat
*/ */
static void __init register_memory(void) static void __init register_memory(void)
{ {
long long gapsize; unsigned long gapsize;
unsigned long long last; unsigned long long last;
int i; int i;
...@@ -1191,13 +1191,21 @@ static void __init register_memory(void) ...@@ -1191,13 +1191,21 @@ static void __init register_memory(void)
while (--i >= 0) { while (--i >= 0) {
unsigned long long start = e820.map[i].addr; unsigned long long start = e820.map[i].addr;
unsigned long long end = start + e820.map[i].size; unsigned long long end = start + e820.map[i].size;
long long gap = last - end;
if (gap > gapsize) { /*
gapsize = gap; * Since "last" is at most 4GB, we know we'll
pci_mem_start = ((unsigned long) end + 0xfffff) & ~0xfffff; * fit in 32 bits if this condition is true
*/
if (last > end) {
unsigned long gap = last - end;
if (gap > gapsize) {
gapsize = gap;
pci_mem_start = ((unsigned long) end + 0xfffff) & ~0xfffff;
}
} }
last = start; if (start < last)
last = start;
} }
printk("Allocating PCI resources starting at %08lx\n", pci_mem_start); printk("Allocating PCI resources starting at %08lx\n", pci_mem_start);
} }
......
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