UPSTREAM: mm: vmalloc: show number of vmalloc pages in /proc/meminfo
Vmalloc() is getting more and more used these days (kernel stacks, bpf and
percpu allocator are new top users), and the total % of memory consumed by
vmalloc() can be pretty significant and changes dynamically.
/proc/meminfo is the best place to display this information: its top goal
is to show top consumers of the memory.
Since the VmallocUsed field in /proc/meminfo is not in use for quite a
long time (it has been defined to 0 by a5ad88ce8c
("mm: get rid of
'vmalloc_info' from /proc/meminfo")), let's reuse it for showing the
actual physical memory consumption of vmalloc().
Link: http://lkml.kernel.org/r/20190417194002.12369-3-guro@fb.com
Signed-off-by: Roman Gushchin <guro@fb.com>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Acked-by: Vlastimil Babka <vbabka@suse.cz>
Reviewed-by: Andrew Morton <akpm@linux-foundation.org>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Minchan Kim <minchan@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
(cherry picked from commit 97105f0ab7b877a8ece2005e214894e93793950c)
Signed-off-by: Minchan Kim <minchan@google.com>
Bug: 141257998
Test: "cat /proc/meminfo | grep VmallocUsed" doesn't show 0 any longer
Change-Id: Ibedcd5c1290ba7be3293e220a917434008a30996
This commit is contained in:
parent
d112bff3b7
commit
91711ef418
3 changed files with 13 additions and 1 deletions
|
@ -120,7 +120,7 @@ static int meminfo_proc_show(struct seq_file *m, void *v)
|
|||
show_val_kb(m, "Committed_AS: ", committed);
|
||||
seq_printf(m, "VmallocTotal: %8lu kB\n",
|
||||
(unsigned long)VMALLOC_TOTAL >> 10);
|
||||
show_val_kb(m, "VmallocUsed: ", 0ul);
|
||||
show_val_kb(m, "VmallocUsed: ", vmalloc_nr_pages());
|
||||
show_val_kb(m, "VmallocChunk: ", 0ul);
|
||||
show_val_kb(m, "Percpu: ", pcpu_nr_pages());
|
||||
|
||||
|
|
|
@ -63,10 +63,12 @@ extern void vm_unmap_aliases(void);
|
|||
|
||||
#ifdef CONFIG_MMU
|
||||
extern void __init vmalloc_init(void);
|
||||
extern unsigned long vmalloc_nr_pages(void);
|
||||
#else
|
||||
static inline void vmalloc_init(void)
|
||||
{
|
||||
}
|
||||
static inline unsigned long vmalloc_nr_pages(void) { return 0; }
|
||||
#endif
|
||||
|
||||
extern void *vmalloc(unsigned long size);
|
||||
|
|
10
mm/vmalloc.c
10
mm/vmalloc.c
|
@ -340,6 +340,13 @@ static unsigned long cached_align;
|
|||
|
||||
static unsigned long vmap_area_pcpu_hole;
|
||||
|
||||
static atomic_long_t nr_vmalloc_pages;
|
||||
|
||||
unsigned long vmalloc_nr_pages(void)
|
||||
{
|
||||
return atomic_long_read(&nr_vmalloc_pages);
|
||||
}
|
||||
|
||||
static struct vmap_area *__find_vmap_area(unsigned long addr)
|
||||
{
|
||||
struct rb_node *n = vmap_area_root.rb_node;
|
||||
|
@ -1529,6 +1536,7 @@ static void __vunmap(const void *addr, int deallocate_pages)
|
|||
BUG_ON(!page);
|
||||
__free_pages(page, 0);
|
||||
}
|
||||
atomic_long_sub(area->nr_pages, &nr_vmalloc_pages);
|
||||
|
||||
kvfree(area->pages);
|
||||
}
|
||||
|
@ -1694,12 +1702,14 @@ static void *__vmalloc_area_node(struct vm_struct *area, gfp_t gfp_mask,
|
|||
if (unlikely(!page)) {
|
||||
/* Successfully allocated i pages, free them in __vunmap() */
|
||||
area->nr_pages = i;
|
||||
atomic_long_add(area->nr_pages, &nr_vmalloc_pages);
|
||||
goto fail;
|
||||
}
|
||||
area->pages[i] = page;
|
||||
if (gfpflags_allow_blocking(gfp_mask|highmem_mask))
|
||||
cond_resched();
|
||||
}
|
||||
atomic_long_add(area->nr_pages, &nr_vmalloc_pages);
|
||||
|
||||
if (map_vm_area(area, prot, pages))
|
||||
goto fail;
|
||||
|
|
Loading…
Add table
Reference in a new issue