diff options
author | Matthew Wilcox <mawilcox@microsoft.com> | 2018-06-07 20:08:23 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-06-07 20:34:37 -0400 |
commit | 1d40a5ea01d53251c23c7be541d3f4a656cfc537 (patch) | |
tree | 9c969d32e9baec47e0c0db4592a6a5bfb9a7964c /fs/proc/page.c | |
parent | 6e292b9be7f4358985ce33ae1f59ab30a8c09e08 (diff) |
mm: mark pages in use for page tables
Define a new PageTable bit in the page_type and use it to mark pages in
use as page tables. This can be helpful when debugging crashdumps or
analysing memory fragmentation. Add a KPF flag to report these pages to
userspace and update page-types.c to interpret that flag.
Note that only pages currently accounted as NR_PAGETABLES are tracked as
PageTable; this does not include pgd/p4d/pud/pmd pages. Those will be the
subject of a later patch.
Link: http://lkml.kernel.org/r/20180518194519.3820-4-willy@infradead.org
Signed-off-by: Matthew Wilcox <mawilcox@microsoft.com>
Acked-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Acked-by: Vlastimil Babka <vbabka@suse.cz>
Cc: Christoph Lameter <cl@linux.com>
Cc: Dave Hansen <dave.hansen@linux.intel.com>
Cc: Jérôme Glisse <jglisse@redhat.com>
Cc: Lai Jiangshan <jiangshanlai@gmail.com>
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Pekka Enberg <penberg@kernel.org>
Cc: Randy Dunlap <rdunlap@infradead.org>
Cc: Andrey Ryabinin <aryabinin@virtuozzo.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/proc/page.c')
-rw-r--r-- | fs/proc/page.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/proc/page.c b/fs/proc/page.c index 1491918a33c3..792c78a49174 100644 --- a/fs/proc/page.c +++ b/fs/proc/page.c | |||
@@ -154,6 +154,8 @@ u64 stable_page_flags(struct page *page) | |||
154 | 154 | ||
155 | if (PageBalloon(page)) | 155 | if (PageBalloon(page)) |
156 | u |= 1 << KPF_BALLOON; | 156 | u |= 1 << KPF_BALLOON; |
157 | if (PageTable(page)) | ||
158 | u |= 1 << KPF_PGTABLE; | ||
157 | 159 | ||
158 | if (page_is_idle(page)) | 160 | if (page_is_idle(page)) |
159 | u |= 1 << KPF_IDLE; | 161 | u |= 1 << KPF_IDLE; |