aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJuergen Gross <jgross@suse.com>2015-07-17 00:51:28 -0400
committerDavid Vrabel <david.vrabel@citrix.com>2015-08-20 07:24:20 -0400
commite612b4a7db4ae1dd8c2bbe171e10c21723de95b2 (patch)
treeb8f5cba2c3ebb89e15e15704b907ae701f92eb59
parent5097cdf6cef15439f971df54f9abcf143d7ca698 (diff)
xen: check memory area against e820 map
Provide a service routine to check a physical memory area against the E820 map. The routine will return false if the complete area is RAM according to the E820 map and true otherwise. Signed-off-by: Juergen Gross <jgross@suse.com> Reviewed-by: David Vrabel <david.vrabel@citrix.com> Acked-by: Konrad Rzeszutek Wilk <Konrad.wilk@oracle.com> Signed-off-by: David Vrabel <david.vrabel@citrix.com>
-rw-r--r--arch/x86/xen/setup.c23
-rw-r--r--arch/x86/xen/xen-ops.h1
2 files changed, 24 insertions, 0 deletions
diff --git a/arch/x86/xen/setup.c b/arch/x86/xen/setup.c
index 87251b4c2e30..99ef82cc4edc 100644
--- a/arch/x86/xen/setup.c
+++ b/arch/x86/xen/setup.c
@@ -573,6 +573,29 @@ static unsigned long __init xen_count_remap_pages(unsigned long max_pfn)
573 return extra; 573 return extra;
574} 574}
575 575
576bool __init xen_is_e820_reserved(phys_addr_t start, phys_addr_t size)
577{
578 struct e820entry *entry;
579 unsigned mapcnt;
580 phys_addr_t end;
581
582 if (!size)
583 return false;
584
585 end = start + size;
586 entry = xen_e820_map;
587
588 for (mapcnt = 0; mapcnt < xen_e820_map_entries; mapcnt++) {
589 if (entry->type == E820_RAM && entry->addr <= start &&
590 (entry->addr + entry->size) >= end)
591 return false;
592
593 entry++;
594 }
595
596 return true;
597}
598
576/* 599/*
577 * Reserve Xen mfn_list. 600 * Reserve Xen mfn_list.
578 * See comment above "struct start_info" in <xen/interface/xen.h> 601 * See comment above "struct start_info" in <xen/interface/xen.h>
diff --git a/arch/x86/xen/xen-ops.h b/arch/x86/xen/xen-ops.h
index 2292721b1d10..a4cbb76642d8 100644
--- a/arch/x86/xen/xen-ops.h
+++ b/arch/x86/xen/xen-ops.h
@@ -39,6 +39,7 @@ void xen_reserve_top(void);
39void xen_mm_pin_all(void); 39void xen_mm_pin_all(void);
40void xen_mm_unpin_all(void); 40void xen_mm_unpin_all(void);
41 41
42bool __init xen_is_e820_reserved(phys_addr_t start, phys_addr_t size);
42unsigned long __ref xen_chk_extra_mem(unsigned long pfn); 43unsigned long __ref xen_chk_extra_mem(unsigned long pfn);
43void __init xen_inv_extra_mem(void); 44void __init xen_inv_extra_mem(void);
44void __init xen_remap_memory(void); 45void __init xen_remap_memory(void);