Commit d4af73e3 authored by Vlastimil Babka's avatar Vlastimil Babka Committed by Linus Torvalds

mm/hugetlb: remove unnecessary memory fetch in PageHeadHuge()

Commit f1e61557 ("mm: pack compound_dtor and compound_order into one
word in struct page") changed compound_dtor from a pointer to an array
index in order to pack it.  To check if page has the hugeltbfs
compound_dtor, we can just compare the index directly without fetching the
function pointer.  Said commit did that with PageHuge() and we can do the
same with PageHeadHuge() to make the code a bit smaller and faster.
Signed-off-by: default avatarVlastimil Babka <vbabka@suse.cz>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Reviewed-by: default avatarMike Kravetz <mike.kravetz@oracle.com>
Acked-by: default avatarDavid Rientjes <rientjes@google.com>
Acked-by: default avatarKirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Neha Agarwal <nehaagarwal@google.com>
Link: http://lkml.kernel.org/r/20200311172440.6988-1-vbabka@suse.czSigned-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 353b2de4
...@@ -1528,7 +1528,7 @@ int PageHeadHuge(struct page *page_head) ...@@ -1528,7 +1528,7 @@ int PageHeadHuge(struct page *page_head)
if (!PageHead(page_head)) if (!PageHead(page_head))
return 0; return 0;
return get_compound_page_dtor(page_head) == free_huge_page; return page_head[1].compound_dtor == HUGETLB_PAGE_DTOR;
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment