Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 217851
b: refs/heads/master
c: 42ee147
h: refs/heads/master
i:
  217849: 4bb89de
  217847: d319bb8
v: v3
  • Loading branch information
Jeremy Fitzhardinge committed Oct 22, 2010
1 parent fa59fc6 commit 797fba6
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 3 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 35ae11fd146384d222f3bb1f17eed1970cc92c36
refs/heads/master: 42ee1471e9b879479a15debac752314a596c738e
29 changes: 27 additions & 2 deletions trunk/arch/x86/xen/setup.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,26 @@ extern void xen_sysenter_target(void);
extern void xen_syscall_target(void);
extern void xen_syscall32_target(void);

/* Amount of extra memory space we add to the e820 ranges */
phys_addr_t xen_extra_mem_start, xen_extra_mem_size;

static __init void xen_add_extra_mem(unsigned long pages)
{
u64 size = (u64)pages * PAGE_SIZE;

if (!pages)
return;

e820_add_region(xen_extra_mem_start + xen_extra_mem_size, size, E820_RAM);
sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map);

reserve_early(xen_extra_mem_start + xen_extra_mem_size,
xen_extra_mem_start + xen_extra_mem_size + size,
"XEN EXTRA");

xen_extra_mem_size += size;
}

static unsigned long __init xen_release_chunk(phys_addr_t start_addr,
phys_addr_t end_addr)
{
Expand Down Expand Up @@ -105,7 +125,6 @@ static unsigned long __init xen_return_unused_memory(unsigned long max_pfn,
/**
* machine_specific_memory_setup - Hook for machine specific memory setup.
**/

char * __init xen_memory_setup(void)
{
static struct e820entry map[E820MAX] __initdata;
Expand All @@ -114,6 +133,7 @@ char * __init xen_memory_setup(void)
unsigned long long mem_end;
int rc;
struct xen_memory_map memmap;
unsigned long extra_pages = 0;
int i;

max_pfn = min(MAX_DOMAIN_PAGES, max_pfn);
Expand All @@ -135,6 +155,7 @@ char * __init xen_memory_setup(void)
BUG_ON(rc);

e820.nr_map = 0;
xen_extra_mem_start = mem_end;
for (i = 0; i < memmap.nr_entries; i++) {
unsigned long long end = map[i].addr + map[i].size;
if (map[i].type == E820_RAM) {
Expand All @@ -143,6 +164,8 @@ char * __init xen_memory_setup(void)
if (end > mem_end) {
/* Truncate region to max_mem. */
map[i].size -= end - mem_end;

extra_pages += PFN_DOWN(end - mem_end);
}
}
if (map[i].size > 0)
Expand All @@ -169,7 +192,9 @@ char * __init xen_memory_setup(void)

sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map);

xen_return_unused_memory(xen_start_info->nr_pages, &e820);
extra_pages += xen_return_unused_memory(xen_start_info->nr_pages, &e820);

xen_add_extra_mem(extra_pages);

return "Xen";
}
Expand Down

0 comments on commit 797fba6

Please sign in to comment.