aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoman Gushchin <guro@fb.com>2018-01-31 19:16:22 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2018-01-31 20:18:36 -0500
commitfcb2b0c577f145c7616843c9d4dcb4f9e5d88e29 (patch)
treee5e0adca3b30b9d2eac5cec139a9b588844766c8
parent9852a7212324fd25f896932f4f4607ce47b0a22f (diff)
mm: show total hugetlb memory consumption in /proc/meminfo
Currently we display some hugepage statistics (total, free, etc) in /proc/meminfo, but only for default hugepage size (e.g. 2Mb). If hugepages of different sizes are used (like 2Mb and 1Gb on x86-64), /proc/meminfo output can be confusing, as non-default sized hugepages are not reflected at all, and there are no signs that they are existing and consuming system memory. To solve this problem, let's display the total amount of memory, consumed by hugetlb pages of all sized (both free and used). Let's call it "Hugetlb", and display size in kB to match generic /proc/meminfo style. For example, (1024 2Mb pages and 2 1Gb pages are pre-allocated): $ cat /proc/meminfo MemTotal: 8168984 kB MemFree: 3789276 kB <...> CmaFree: 0 kB HugePages_Total: 1024 HugePages_Free: 1024 HugePages_Rsvd: 0 HugePages_Surp: 0 Hugepagesize: 2048 kB Hugetlb: 4194304 kB DirectMap4k: 32632 kB DirectMap2M: 4161536 kB DirectMap1G: 6291456 kB Also, this patch updates corresponding docs to reflect Hugetlb entry meaning and difference between Hugetlb and HugePages_Total * Hugepagesize. Link: http://lkml.kernel.org/r/20171115231409.12131-1-guro@fb.com Signed-off-by: Roman Gushchin <guro@fb.com> Acked-by: Michal Hocko <mhocko@suse.com> Acked-by: Johannes Weiner <hannes@cmpxchg.org> Acked-by: David Rientjes <rientjes@google.com> Cc: Mike Kravetz <mike.kravetz@oracle.com> Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Dave Hansen <dave.hansen@intel.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--Documentation/vm/hugetlbpage.txt27
-rw-r--r--mm/hugetlb.c36
2 files changed, 42 insertions, 21 deletions
diff --git a/Documentation/vm/hugetlbpage.txt b/Documentation/vm/hugetlbpage.txt
index 59cbc803aad6..faf077d50d42 100644
--- a/Documentation/vm/hugetlbpage.txt
+++ b/Documentation/vm/hugetlbpage.txt
@@ -20,19 +20,20 @@ options.
20 20
21The /proc/meminfo file provides information about the total number of 21The /proc/meminfo file provides information about the total number of
22persistent hugetlb pages in the kernel's huge page pool. It also displays 22persistent hugetlb pages in the kernel's huge page pool. It also displays
23information about the number of free, reserved and surplus huge pages and the 23default huge page size and information about the number of free, reserved
24default huge page size. The huge page size is needed for generating the 24and surplus huge pages in the pool of huge pages of default size.
25proper alignment and size of the arguments to system calls that map huge page 25The huge page size is needed for generating the proper alignment and
26regions. 26size of the arguments to system calls that map huge page regions.
27 27
28The output of "cat /proc/meminfo" will include lines like: 28The output of "cat /proc/meminfo" will include lines like:
29 29
30..... 30.....
31HugePages_Total: vvv 31HugePages_Total: uuu
32HugePages_Free: www 32HugePages_Free: vvv
33HugePages_Rsvd: xxx 33HugePages_Rsvd: www
34HugePages_Surp: yyy 34HugePages_Surp: xxx
35Hugepagesize: zzz kB 35Hugepagesize: yyy kB
36Hugetlb: zzz kB
36 37
37where: 38where:
38HugePages_Total is the size of the pool of huge pages. 39HugePages_Total is the size of the pool of huge pages.
@@ -47,6 +48,14 @@ HugePages_Surp is short for "surplus," and is the number of huge pages in
47 the pool above the value in /proc/sys/vm/nr_hugepages. The 48 the pool above the value in /proc/sys/vm/nr_hugepages. The
48 maximum number of surplus huge pages is controlled by 49 maximum number of surplus huge pages is controlled by
49 /proc/sys/vm/nr_overcommit_hugepages. 50 /proc/sys/vm/nr_overcommit_hugepages.
51Hugepagesize is the default hugepage size (in Kb).
52Hugetlb is the total amount of memory (in kB), consumed by huge
53 pages of all sizes.
54 If huge pages of different sizes are in use, this number
55 will exceed HugePages_Total * Hugepagesize. To get more
56 detailed information, please, refer to
57 /sys/kernel/mm/hugepages (described below).
58
50 59
51/proc/filesystems should also show a filesystem of type "hugetlbfs" configured 60/proc/filesystems should also show a filesystem of type "hugetlbfs" configured
52in the kernel. 61in the kernel.
diff --git a/mm/hugetlb.c b/mm/hugetlb.c
index 9a334f5fb730..1e6a5ad0d420 100644
--- a/mm/hugetlb.c
+++ b/mm/hugetlb.c
@@ -2975,20 +2975,32 @@ out:
2975 2975
2976void hugetlb_report_meminfo(struct seq_file *m) 2976void hugetlb_report_meminfo(struct seq_file *m)
2977{ 2977{
2978 struct hstate *h = &default_hstate; 2978 struct hstate *h;
2979 unsigned long total = 0;
2980
2979 if (!hugepages_supported()) 2981 if (!hugepages_supported())
2980 return; 2982 return;
2981 seq_printf(m, 2983
2982 "HugePages_Total: %5lu\n" 2984 for_each_hstate(h) {
2983 "HugePages_Free: %5lu\n" 2985 unsigned long count = h->nr_huge_pages;
2984 "HugePages_Rsvd: %5lu\n" 2986
2985 "HugePages_Surp: %5lu\n" 2987 total += (PAGE_SIZE << huge_page_order(h)) * count;
2986 "Hugepagesize: %8lu kB\n", 2988
2987 h->nr_huge_pages, 2989 if (h == &default_hstate)
2988 h->free_huge_pages, 2990 seq_printf(m,
2989 h->resv_huge_pages, 2991 "HugePages_Total: %5lu\n"
2990 h->surplus_huge_pages, 2992 "HugePages_Free: %5lu\n"
2991 1UL << (huge_page_order(h) + PAGE_SHIFT - 10)); 2993 "HugePages_Rsvd: %5lu\n"
2994 "HugePages_Surp: %5lu\n"
2995 "Hugepagesize: %8lu kB\n",
2996 count,
2997 h->free_huge_pages,
2998 h->resv_huge_pages,
2999 h->surplus_huge_pages,
3000 (PAGE_SIZE << huge_page_order(h)) / 1024);
3001 }
3002
3003 seq_printf(m, "Hugetlb: %8lu kB\n", total / 1024);
2992} 3004}
2993 3005
2994int hugetlb_report_node_meminfo(int nid, char *buf) 3006int hugetlb_report_node_meminfo(int nid, char *buf)