mm/page_alloc: reduce potential fragmentation in make_alloc_exact()
Try to avoid using the left over split page on the next request for a page by calling __free_pages_ok() with FPI_TO_TAIL. This increases the potential of defragmenting memory when it's used for a short period of time. Link: https://lkml.kernel.org/r/20220531185626.yvlmymbxyoe5vags@revolver Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com> Suggested-by: Matthew Wilcox (Oracle) <willy@infradead.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
08ac85521c
commit
df48a5f7a3
@ -5784,14 +5784,18 @@ static void *make_alloc_exact(unsigned long addr, unsigned int order,
|
|||||||
size_t size)
|
size_t size)
|
||||||
{
|
{
|
||||||
if (addr) {
|
if (addr) {
|
||||||
unsigned long alloc_end = addr + (PAGE_SIZE << order);
|
unsigned long nr = DIV_ROUND_UP(size, PAGE_SIZE);
|
||||||
unsigned long used = addr + PAGE_ALIGN(size);
|
struct page *page = virt_to_page((void *)addr);
|
||||||
|
struct page *last = page + nr;
|
||||||
|
|
||||||
split_page(virt_to_page((void *)addr), order);
|
split_page_owner(page, 1 << order);
|
||||||
while (used < alloc_end) {
|
split_page_memcg(page, 1 << order);
|
||||||
free_page(used);
|
while (page < --last)
|
||||||
used += PAGE_SIZE;
|
set_page_refcounted(last);
|
||||||
}
|
|
||||||
|
last = page + (1UL << order);
|
||||||
|
for (page += nr; page < last; page++)
|
||||||
|
__free_pages_ok(page, 0, FPI_TO_TAIL);
|
||||||
}
|
}
|
||||||
return (void *)addr;
|
return (void *)addr;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user