aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorK. Y. Srinivasan <kys@microsoft.com>2012-11-15 17:34:42 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-11-15 18:41:22 -0500
commit997071bcb34005f42e0fe5bc7930e895b070f251 (patch)
tree7cc8056370e1c77314fdf0b3fd72bcc69743f24c /mm
parentd892de8d3fb1e807de561289cfb1fed42950440a (diff)
mm: export a function to get vm committed memory
It will be useful to be able to access global memory commitment from device drivers. On the Hyper-V platform, the host has a policy engine to balance the available physical memory amongst all competing virtual machines hosted on a given node. This policy engine is driven by a number of metrics including the memory commitment reported by the guests. The balloon driver for Linux on Hyper-V will use this function to retrieve guest memory commitment. This function is also used in Xen self ballooning code. [akpm@linux-foundation.org: coding-style tweak] Signed-off-by: K. Y. Srinivasan <kys@microsoft.com> Acked-by: David Rientjes <rientjes@google.com> Acked-by: Dan Magenheimer <dan.magenheimer@oracle.com> Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> Cc: Jeremy Fitzhardinge <jeremy@goop.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/mmap.c14
-rw-r--r--mm/nommu.c15
2 files changed, 29 insertions, 0 deletions
diff --git a/mm/mmap.c b/mm/mmap.c
index 2d942353d68..b064822be82 100644
--- a/mm/mmap.c
+++ b/mm/mmap.c
@@ -89,6 +89,20 @@ int sysctl_max_map_count __read_mostly = DEFAULT_MAX_MAP_COUNT;
89struct percpu_counter vm_committed_as ____cacheline_aligned_in_smp; 89struct percpu_counter vm_committed_as ____cacheline_aligned_in_smp;
90 90
91/* 91/*
92 * The global memory commitment made in the system can be a metric
93 * that can be used to drive ballooning decisions when Linux is hosted
94 * as a guest. On Hyper-V, the host implements a policy engine for dynamically
95 * balancing memory across competing virtual machines that are hosted.
96 * Several metrics drive this policy engine including the guest reported
97 * memory commitment.
98 */
99unsigned long vm_memory_committed(void)
100{
101 return percpu_counter_read_positive(&vm_committed_as);
102}
103EXPORT_SYMBOL_GPL(vm_memory_committed);
104
105/*
92 * Check that a process has enough memory to allocate a new virtual 106 * Check that a process has enough memory to allocate a new virtual
93 * mapping. 0 means there is enough memory for the allocation to 107 * mapping. 0 means there is enough memory for the allocation to
94 * succeed and -ENOMEM implies there is not. 108 * succeed and -ENOMEM implies there is not.
diff --git a/mm/nommu.c b/mm/nommu.c
index 45131b41bcd..79c3cac87af 100644
--- a/mm/nommu.c
+++ b/mm/nommu.c
@@ -66,6 +66,21 @@ int heap_stack_gap = 0;
66 66
67atomic_long_t mmap_pages_allocated; 67atomic_long_t mmap_pages_allocated;
68 68
69/*
70 * The global memory commitment made in the system can be a metric
71 * that can be used to drive ballooning decisions when Linux is hosted
72 * as a guest. On Hyper-V, the host implements a policy engine for dynamically
73 * balancing memory across competing virtual machines that are hosted.
74 * Several metrics drive this policy engine including the guest reported
75 * memory commitment.
76 */
77unsigned long vm_memory_committed(void)
78{
79 return percpu_counter_read_positive(&vm_committed_as);
80}
81
82EXPORT_SYMBOL_GPL(vm_memory_committed);
83
69EXPORT_SYMBOL(mem_map); 84EXPORT_SYMBOL(mem_map);
70EXPORT_SYMBOL(num_physpages); 85EXPORT_SYMBOL(num_physpages);
71 86