Blame view

arch/x86/kernel/resource.c 1.03 KB
30919b0bf   Bjorn Helgaas   x86: avoid low BI...
1
2
  #include <linux/ioport.h>
  #include <asm/e820.h>
4dc2287c1   Bjorn Helgaas   x86: avoid E820 r...
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
  static void resource_clip(struct resource *res, resource_size_t start,
  			  resource_size_t end)
  {
  	resource_size_t low = 0, high = 0;
  
  	if (res->end < start || res->start > end)
  		return;		/* no conflict */
  
  	if (res->start < start)
  		low = start - res->start;
  
  	if (res->end > end)
  		high = res->end - end;
  
  	/* Keep the area above or below the conflict, whichever is larger */
  	if (low > high)
  		res->end = start - 1;
  	else
  		res->start = end + 1;
  }
  
  static void remove_e820_regions(struct resource *avail)
  {
  	int i;
  	struct e820entry *entry;
  
  	for (i = 0; i < e820.nr_map; i++) {
  		entry = &e820.map[i];
  
  		resource_clip(avail, entry->addr,
  			      entry->addr + entry->size - 1);
  	}
  }
30919b0bf   Bjorn Helgaas   x86: avoid low BI...
36
37
  void arch_remove_reservations(struct resource *avail)
  {
a2c606d53   Bjorn Helgaas   x86: avoid high B...
38
  	/* Trim out BIOS areas (low 1MB and high 2MB) and E820 regions */
30919b0bf   Bjorn Helgaas   x86: avoid low BI...
39
40
41
  	if (avail->flags & IORESOURCE_MEM) {
  		if (avail->start < BIOS_END)
  			avail->start = BIOS_END;
a2c606d53   Bjorn Helgaas   x86: avoid high B...
42
  		resource_clip(avail, BIOS_ROM_BASE, BIOS_ROM_END);
4dc2287c1   Bjorn Helgaas   x86: avoid E820 r...
43
44
  
  		remove_e820_regions(avail);
30919b0bf   Bjorn Helgaas   x86: avoid low BI...
45
46
  	}
  }