1
0
Fork 0
mirror of https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git synced 2025-01-24 09:13:20 -05:00

mm/debug: dump compound page information on a second line

Simplify both the implementation and the output by splitting all the
compound page information onto a second line.

Reported-by: John Hubbard <jhubbard@nvidia.com>
Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Tested-by: John Hubbard <jhubbard@nvidia.com>
Reviewed-by: John Hubbard <jhubbard@nvidia.com>
Acked-by: Mike Rapoport <rppt@linux.ibm.com>
Acked-by: Vlastimil Babka <vbabka@suse.cz>
Cc: "Kirill A. Shutemov" <kirill@shutemov.name>
Cc: William Kucharski <william.kucharski@oracle.com>
Link: http://lkml.kernel.org/r/20200709202117.7216-3-willy@infradead.org
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Matthew Wilcox (Oracle) 2020-08-06 23:19:35 -07:00 committed by Linus Torvalds
parent e1ab96f8cc
commit 452b557c95

View file

@ -95,27 +95,21 @@ void __dump_page(struct page *page, const char *reason)
*/ */
mapcount = PageSlab(head) ? 0 : page_mapcount(page); mapcount = PageSlab(head) ? 0 : page_mapcount(page);
if (compound) pr_warn("page:%px refcount:%d mapcount:%d mapping:%p index:%#lx\n",
page, page_ref_count(head), mapcount, mapping,
page_to_pgoff(page));
if (compound) {
if (hpage_pincount_available(page)) { if (hpage_pincount_available(page)) {
pr_warn("page:%px refcount:%d mapcount:%d mapping:%p " pr_warn("head:%px order:%u compound_mapcount:%d compound_pincount:%d\n",
"index:%#lx head:%px order:%u " head, compound_order(head),
"compound_mapcount:%d compound_pincount:%d\n", compound_mapcount(head),
page, page_ref_count(head), mapcount, compound_pincount(head));
mapping, page_to_pgoff(page), head,
compound_order(head), compound_mapcount(page),
compound_pincount(page));
} else { } else {
pr_warn("page:%px refcount:%d mapcount:%d mapping:%p " pr_warn("head:%px order:%u compound_mapcount:%d\n",
"index:%#lx head:%px order:%u " head, compound_order(head),
"compound_mapcount:%d\n", compound_mapcount(head));
page, page_ref_count(head), mapcount,
mapping, page_to_pgoff(page), head,
compound_order(head), compound_mapcount(page));
} }
else }
pr_warn("page:%px refcount:%d mapcount:%d mapping:%p index:%#lx\n",
page, page_ref_count(page), mapcount,
mapping, page_to_pgoff(page));
if (PageKsm(page)) if (PageKsm(page))
type = "ksm "; type = "ksm ";
else if (PageAnon(page)) else if (PageAnon(page))