Commit 689d92cc authored by Wei Yang's avatar Wei Yang Committed by Andrew Morton

mm/page_alloc: remove prefetchw() on freeing page to buddy system

The prefetchw() is introduced from an ancient patch[1].

The change log says:

    The basic idea is to free higher order pages instead of going
    through every single one.  Also, some unnecessary atomic operations
    are done away with and replaced with non-atomic equivalents, and
    prefetching is done where it helps the most.  For a more in-depth
    discusion of this patch, please see the linux-ia64 archives (topic
    is "free bootmem feedback patch").

So there are several changes improve the bootmem freeing, in which the
most basic idea is freeing higher order pages.  And as Matthew says,
"Itanium CPUs of this era had no prefetchers."

I did 10 round bootup tests before and after this change, the data doesn't
prove prefetchw() help speeding up bootmem freeing.  The sum of the 10
round bootmem freeing time after prefetchw() removal even 5.2% faster than
before.

[1]: https://lore.kernel.org/linux-ia64/40F46962.4090604@sgi.com/

Link: https://lkml.kernel.org/r/20240702020931.7061-1-richard.weiyang@gmail.comSigned-off-by: default avatarWei Yang <richard.weiyang@gmail.com>
Suggested-by: default avatarMatthew Wilcox <willy@infradead.org>
Reviewed-by: default avatarMatthew Wilcox <willy@infradead.org>
Reviewed-by: default avatarDavid Hildenbrand <david@redhat.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 93255852
...@@ -1236,16 +1236,11 @@ void __free_pages_core(struct page *page, unsigned int order, ...@@ -1236,16 +1236,11 @@ void __free_pages_core(struct page *page, unsigned int order,
*/ */
if (IS_ENABLED(CONFIG_MEMORY_HOTPLUG) && if (IS_ENABLED(CONFIG_MEMORY_HOTPLUG) &&
unlikely(context == MEMINIT_HOTPLUG)) { unlikely(context == MEMINIT_HOTPLUG)) {
prefetchw(p); for (loop = 0; loop < nr_pages; loop++, p++) {
for (loop = 0; loop < (nr_pages - 1); loop++, p++) {
prefetchw(p + 1);
VM_WARN_ON_ONCE(PageReserved(p)); VM_WARN_ON_ONCE(PageReserved(p));
__ClearPageOffline(p); __ClearPageOffline(p);
set_page_count(p, 0); set_page_count(p, 0);
} }
VM_WARN_ON_ONCE(PageReserved(p));
__ClearPageOffline(p);
set_page_count(p, 0);
/* /*
* Freeing the page with debug_pagealloc enabled will try to * Freeing the page with debug_pagealloc enabled will try to
...@@ -1255,14 +1250,10 @@ void __free_pages_core(struct page *page, unsigned int order, ...@@ -1255,14 +1250,10 @@ void __free_pages_core(struct page *page, unsigned int order,
debug_pagealloc_map_pages(page, nr_pages); debug_pagealloc_map_pages(page, nr_pages);
adjust_managed_page_count(page, nr_pages); adjust_managed_page_count(page, nr_pages);
} else { } else {
prefetchw(p); for (loop = 0; loop < nr_pages; loop++, p++) {
for (loop = 0; loop < (nr_pages - 1); loop++, p++) {
prefetchw(p + 1);
__ClearPageReserved(p); __ClearPageReserved(p);
set_page_count(p, 0); set_page_count(p, 0);
} }
__ClearPageReserved(p);
set_page_count(p, 0);
/* memblock adjusts totalram_pages() manually. */ /* memblock adjusts totalram_pages() manually. */
atomic_long_add(nr_pages, &page_zone(page)->managed_pages); atomic_long_add(nr_pages, &page_zone(page)->managed_pages);
......
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