1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * linux/mm/page_alloc.c 4 * 5 * Manages the free list, the system allocates free pages here. 6 * Note that kmalloc() lives in slab.c 7 * 8 * Copyright (C) 1991, 1992, 1993, 1994 Linus Torvalds 9 * Swap reorganised 29.12.95, Stephen Tweedie 10 * Support of BIGMEM added by Gerhard Wichert, Siemens AG, July 1999 11 * Reshaped it to be a zoned allocator, Ingo Molnar, Red Hat, 1999 12 * Discontiguous memory support, Kanoj Sarcar, SGI, Nov 1999 13 * Zone balancing, Kanoj Sarcar, SGI, Jan 2000 14 * Per cpu hot/cold page lists, bulk allocation, Martin J. Bligh, Sept 2002 15 * (lots of bits borrowed from Ingo Molnar & Andrew Morton) 16 */ 17 18 #include <linux/stddef.h> 19 #include <linux/mm.h> 20 #include <linux/highmem.h> 21 #include <linux/swap.h> 22 #include <linux/swapops.h> 23 #include <linux/interrupt.h> 24 #include <linux/pagemap.h> 25 #include <linux/jiffies.h> 26 #include <linux/memblock.h> 27 #include <linux/compiler.h> 28 #include <linux/kernel.h> 29 #include <linux/kasan.h> 30 #include <linux/module.h> 31 #include <linux/suspend.h> 32 #include <linux/pagevec.h> 33 #include <linux/blkdev.h> 34 #include <linux/slab.h> 35 #include <linux/ratelimit.h> 36 #include <linux/oom.h> 37 #include <linux/topology.h> 38 #include <linux/sysctl.h> 39 #include <linux/cpu.h> 40 #include <linux/cpuset.h> 41 #include <linux/memory_hotplug.h> 42 #include <linux/nodemask.h> 43 #include <linux/vmalloc.h> 44 #include <linux/vmstat.h> 45 #include <linux/mempolicy.h> 46 #include <linux/memremap.h> 47 #include <linux/stop_machine.h> 48 #include <linux/random.h> 49 #include <linux/sort.h> 50 #include <linux/pfn.h> 51 #include <linux/backing-dev.h> 52 #include <linux/fault-inject.h> 53 #include <linux/page-isolation.h> 54 #include <linux/debugobjects.h> 55 #include <linux/kmemleak.h> 56 #include <linux/compaction.h> 57 #include <trace/events/kmem.h> 58 #include <trace/events/oom.h> 59 #include <linux/prefetch.h> 60 #include <linux/mm_inline.h> 61 #include <linux/mmu_notifier.h> 62 #include <linux/migrate.h> 63 #include <linux/hugetlb.h> 64 #include <linux/sched/rt.h> 65 #include <linux/sched/mm.h> 66 #include <linux/page_owner.h> 67 #include <linux/page_table_check.h> 68 #include <linux/kthread.h> 69 #include <linux/memcontrol.h> 70 #include <linux/ftrace.h> 71 #include <linux/lockdep.h> 72 #include <linux/nmi.h> 73 #include <linux/psi.h> 74 #include <linux/padata.h> 75 #include <linux/khugepaged.h> 76 #include <linux/buffer_head.h> 77 #include <linux/delayacct.h> 78 #include <asm/sections.h> 79 #include <asm/tlbflush.h> 80 #include <asm/div64.h> 81 #include "internal.h" 82 #include "shuffle.h" 83 #include "page_reporting.h" 84 85 /* Free Page Internal flags: for internal, non-pcp variants of free_pages(). */ 86 typedef int __bitwise fpi_t; 87 88 /* No special request */ 89 #define FPI_NONE ((__force fpi_t)0) 90 91 /* 92 * Skip free page reporting notification for the (possibly merged) page. 93 * This does not hinder free page reporting from grabbing the page, 94 * reporting it and marking it "reported" - it only skips notifying 95 * the free page reporting infrastructure about a newly freed page. For 96 * example, used when temporarily pulling a page from a freelist and 97 * putting it back unmodified. 98 */ 99 #define FPI_SKIP_REPORT_NOTIFY ((__force fpi_t)BIT(0)) 100 101 /* 102 * Place the (possibly merged) page to the tail of the freelist. Will ignore 103 * page shuffling (relevant code - e.g., memory onlining - is expected to 104 * shuffle the whole zone). 105 * 106 * Note: No code should rely on this flag for correctness - it's purely 107 * to allow for optimizations when handing back either fresh pages 108 * (memory onlining) or untouched pages (page isolation, free page 109 * reporting). 110 */ 111 #define FPI_TO_TAIL ((__force fpi_t)BIT(1)) 112 113 /* 114 * Don't poison memory with KASAN (only for the tag-based modes). 115 * During boot, all non-reserved memblock memory is exposed to page_alloc. 116 * Poisoning all that memory lengthens boot time, especially on systems with 117 * large amount of RAM. This flag is used to skip that poisoning. 118 * This is only done for the tag-based KASAN modes, as those are able to 119 * detect memory corruptions with the memory tags assigned by default. 120 * All memory allocated normally after boot gets poisoned as usual. 121 */ 122 #define FPI_SKIP_KASAN_POISON ((__force fpi_t)BIT(2)) 123 124 /* prevent >1 _updater_ of zone percpu pageset ->high and ->batch fields */ 125 static DEFINE_MUTEX(pcp_batch_high_lock); 126 #define MIN_PERCPU_PAGELIST_HIGH_FRACTION (8) 127 128 struct pagesets { 129 local_lock_t lock; 130 }; 131 static DEFINE_PER_CPU(struct pagesets, pagesets) = { 132 .lock = INIT_LOCAL_LOCK(lock), 133 }; 134 135 #ifdef CONFIG_USE_PERCPU_NUMA_NODE_ID 136 DEFINE_PER_CPU(int, numa_node); 137 EXPORT_PER_CPU_SYMBOL(numa_node); 138 #endif 139 140 DEFINE_STATIC_KEY_TRUE(vm_numa_stat_key); 141 142 #ifdef CONFIG_HAVE_MEMORYLESS_NODES 143 /* 144 * N.B., Do NOT reference the '_numa_mem_' per cpu variable directly. 145 * It will not be defined when CONFIG_HAVE_MEMORYLESS_NODES is not defined. 146 * Use the accessor functions set_numa_mem(), numa_mem_id() and cpu_to_mem() 147 * defined in <linux/topology.h>. 148 */ 149 DEFINE_PER_CPU(int, _numa_mem_); /* Kernel "local memory" node */ 150 EXPORT_PER_CPU_SYMBOL(_numa_mem_); 151 #endif 152 153 /* work_structs for global per-cpu drains */ 154 struct pcpu_drain { 155 struct zone *zone; 156 struct work_struct work; 157 }; 158 static DEFINE_MUTEX(pcpu_drain_mutex); 159 static DEFINE_PER_CPU(struct pcpu_drain, pcpu_drain); 160 161 #ifdef CONFIG_GCC_PLUGIN_LATENT_ENTROPY 162 volatile unsigned long latent_entropy __latent_entropy; 163 EXPORT_SYMBOL(latent_entropy); 164 #endif 165 166 /* 167 * Array of node states. 168 */ 169 nodemask_t node_states[NR_NODE_STATES] __read_mostly = { 170 [N_POSSIBLE] = NODE_MASK_ALL, 171 [N_ONLINE] = { { [0] = 1UL } }, 172 #ifndef CONFIG_NUMA 173 [N_NORMAL_MEMORY] = { { [0] = 1UL } }, 174 #ifdef CONFIG_HIGHMEM 175 [N_HIGH_MEMORY] = { { [0] = 1UL } }, 176 #endif 177 [N_MEMORY] = { { [0] = 1UL } }, 178 [N_CPU] = { { [0] = 1UL } }, 179 #endif /* NUMA */ 180 }; 181 EXPORT_SYMBOL(node_states); 182 183 atomic_long_t _totalram_pages __read_mostly; 184 EXPORT_SYMBOL(_totalram_pages); 185 unsigned long totalreserve_pages __read_mostly; 186 unsigned long totalcma_pages __read_mostly; 187 188 int percpu_pagelist_high_fraction; 189 gfp_t gfp_allowed_mask __read_mostly = GFP_BOOT_MASK; 190 DEFINE_STATIC_KEY_MAYBE(CONFIG_INIT_ON_ALLOC_DEFAULT_ON, init_on_alloc); 191 EXPORT_SYMBOL(init_on_alloc); 192 193 DEFINE_STATIC_KEY_MAYBE(CONFIG_INIT_ON_FREE_DEFAULT_ON, init_on_free); 194 EXPORT_SYMBOL(init_on_free); 195 196 static bool _init_on_alloc_enabled_early __read_mostly 197 = IS_ENABLED(CONFIG_INIT_ON_ALLOC_DEFAULT_ON); 198 static int __init early_init_on_alloc(char *buf) 199 { 200 201 return kstrtobool(buf, &_init_on_alloc_enabled_early); 202 } 203 early_param("init_on_alloc", early_init_on_alloc); 204 205 static bool _init_on_free_enabled_early __read_mostly 206 = IS_ENABLED(CONFIG_INIT_ON_FREE_DEFAULT_ON); 207 static int __init early_init_on_free(char *buf) 208 { 209 return kstrtobool(buf, &_init_on_free_enabled_early); 210 } 211 early_param("init_on_free", early_init_on_free); 212 213 /* 214 * A cached value of the page's pageblock's migratetype, used when the page is 215 * put on a pcplist. Used to avoid the pageblock migratetype lookup when 216 * freeing from pcplists in most cases, at the cost of possibly becoming stale. 217 * Also the migratetype set in the page does not necessarily match the pcplist 218 * index, e.g. page might have MIGRATE_CMA set but be on a pcplist with any 219 * other index - this ensures that it will be put on the correct CMA freelist. 220 */ 221 static inline int get_pcppage_migratetype(struct page *page) 222 { 223 return page->index; 224 } 225 226 static inline void set_pcppage_migratetype(struct page *page, int migratetype) 227 { 228 page->index = migratetype; 229 } 230 231 #ifdef CONFIG_PM_SLEEP 232 /* 233 * The following functions are used by the suspend/hibernate code to temporarily 234 * change gfp_allowed_mask in order to avoid using I/O during memory allocations 235 * while devices are suspended. To avoid races with the suspend/hibernate code, 236 * they should always be called with system_transition_mutex held 237 * (gfp_allowed_mask also should only be modified with system_transition_mutex 238 * held, unless the suspend/hibernate code is guaranteed not to run in parallel 239 * with that modification). 240 */ 241 242 static gfp_t saved_gfp_mask; 243 244 void pm_restore_gfp_mask(void) 245 { 246 WARN_ON(!mutex_is_locked(&system_transition_mutex)); 247 if (saved_gfp_mask) { 248 gfp_allowed_mask = saved_gfp_mask; 249 saved_gfp_mask = 0; 250 } 251 } 252 253 void pm_restrict_gfp_mask(void) 254 { 255 WARN_ON(!mutex_is_locked(&system_transition_mutex)); 256 WARN_ON(saved_gfp_mask); 257 saved_gfp_mask = gfp_allowed_mask; 258 gfp_allowed_mask &= ~(__GFP_IO | __GFP_FS); 259 } 260 261 bool pm_suspended_storage(void) 262 { 263 if ((gfp_allowed_mask & (__GFP_IO | __GFP_FS)) == (__GFP_IO | __GFP_FS)) 264 return false; 265 return true; 266 } 267 #endif /* CONFIG_PM_SLEEP */ 268 269 #ifdef CONFIG_HUGETLB_PAGE_SIZE_VARIABLE 270 unsigned int pageblock_order __read_mostly; 271 #endif 272 273 static void __free_pages_ok(struct page *page, unsigned int order, 274 fpi_t fpi_flags); 275 276 /* 277 * results with 256, 32 in the lowmem_reserve sysctl: 278 * 1G machine -> (16M dma, 800M-16M normal, 1G-800M high) 279 * 1G machine -> (16M dma, 784M normal, 224M high) 280 * NORMAL allocation will leave 784M/256 of ram reserved in the ZONE_DMA 281 * HIGHMEM allocation will leave 224M/32 of ram reserved in ZONE_NORMAL 282 * HIGHMEM allocation will leave (224M+784M)/256 of ram reserved in ZONE_DMA 283 * 284 * TBD: should special case ZONE_DMA32 machines here - in those we normally 285 * don't need any ZONE_NORMAL reservation 286 */ 287 int sysctl_lowmem_reserve_ratio[MAX_NR_ZONES] = { 288 #ifdef CONFIG_ZONE_DMA 289 [ZONE_DMA] = 256, 290 #endif 291 #ifdef CONFIG_ZONE_DMA32 292 [ZONE_DMA32] = 256, 293 #endif 294 [ZONE_NORMAL] = 32, 295 #ifdef CONFIG_HIGHMEM 296 [ZONE_HIGHMEM] = 0, 297 #endif 298 [ZONE_MOVABLE] = 0, 299 }; 300 301 static char * const zone_names[MAX_NR_ZONES] = { 302 #ifdef CONFIG_ZONE_DMA 303 "DMA", 304 #endif 305 #ifdef CONFIG_ZONE_DMA32 306 "DMA32", 307 #endif 308 "Normal", 309 #ifdef CONFIG_HIGHMEM 310 "HighMem", 311 #endif 312 "Movable", 313 #ifdef CONFIG_ZONE_DEVICE 314 "Device", 315 #endif 316 }; 317 318 const char * const migratetype_names[MIGRATE_TYPES] = { 319 "Unmovable", 320 "Movable", 321 "Reclaimable", 322 "HighAtomic", 323 #ifdef CONFIG_CMA 324 "CMA", 325 #endif 326 #ifdef CONFIG_MEMORY_ISOLATION 327 "Isolate", 328 #endif 329 }; 330 331 compound_page_dtor * const compound_page_dtors[NR_COMPOUND_DTORS] = { 332 [NULL_COMPOUND_DTOR] = NULL, 333 [COMPOUND_PAGE_DTOR] = free_compound_page, 334 #ifdef CONFIG_HUGETLB_PAGE 335 [HUGETLB_PAGE_DTOR] = free_huge_page, 336 #endif 337 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 338 [TRANSHUGE_PAGE_DTOR] = free_transhuge_page, 339 #endif 340 }; 341 342 int min_free_kbytes = 1024; 343 int user_min_free_kbytes = -1; 344 int watermark_boost_factor __read_mostly = 15000; 345 int watermark_scale_factor = 10; 346 347 static unsigned long nr_kernel_pages __initdata; 348 static unsigned long nr_all_pages __initdata; 349 static unsigned long dma_reserve __initdata; 350 351 static unsigned long arch_zone_lowest_possible_pfn[MAX_NR_ZONES] __initdata; 352 static unsigned long arch_zone_highest_possible_pfn[MAX_NR_ZONES] __initdata; 353 static unsigned long required_kernelcore __initdata; 354 static unsigned long required_kernelcore_percent __initdata; 355 static unsigned long required_movablecore __initdata; 356 static unsigned long required_movablecore_percent __initdata; 357 static unsigned long zone_movable_pfn[MAX_NUMNODES] __initdata; 358 static bool mirrored_kernelcore __meminitdata; 359 360 /* movable_zone is the "real" zone pages in ZONE_MOVABLE are taken from */ 361 int movable_zone; 362 EXPORT_SYMBOL(movable_zone); 363 364 #if MAX_NUMNODES > 1 365 unsigned int nr_node_ids __read_mostly = MAX_NUMNODES; 366 unsigned int nr_online_nodes __read_mostly = 1; 367 EXPORT_SYMBOL(nr_node_ids); 368 EXPORT_SYMBOL(nr_online_nodes); 369 #endif 370 371 int page_group_by_mobility_disabled __read_mostly; 372 373 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 374 /* 375 * During boot we initialize deferred pages on-demand, as needed, but once 376 * page_alloc_init_late() has finished, the deferred pages are all initialized, 377 * and we can permanently disable that path. 378 */ 379 static DEFINE_STATIC_KEY_TRUE(deferred_pages); 380 381 static inline bool deferred_pages_enabled(void) 382 { 383 return static_branch_unlikely(&deferred_pages); 384 } 385 386 /* Returns true if the struct page for the pfn is uninitialised */ 387 static inline bool __meminit early_page_uninitialised(unsigned long pfn) 388 { 389 int nid = early_pfn_to_nid(pfn); 390 391 if (node_online(nid) && pfn >= NODE_DATA(nid)->first_deferred_pfn) 392 return true; 393 394 return false; 395 } 396 397 /* 398 * Returns true when the remaining initialisation should be deferred until 399 * later in the boot cycle when it can be parallelised. 400 */ 401 static bool __meminit 402 defer_init(int nid, unsigned long pfn, unsigned long end_pfn) 403 { 404 static unsigned long prev_end_pfn, nr_initialised; 405 406 /* 407 * prev_end_pfn static that contains the end of previous zone 408 * No need to protect because called very early in boot before smp_init. 409 */ 410 if (prev_end_pfn != end_pfn) { 411 prev_end_pfn = end_pfn; 412 nr_initialised = 0; 413 } 414 415 /* Always populate low zones for address-constrained allocations */ 416 if (end_pfn < pgdat_end_pfn(NODE_DATA(nid))) 417 return false; 418 419 if (NODE_DATA(nid)->first_deferred_pfn != ULONG_MAX) 420 return true; 421 /* 422 * We start only with one section of pages, more pages are added as 423 * needed until the rest of deferred pages are initialized. 424 */ 425 nr_initialised++; 426 if ((nr_initialised > PAGES_PER_SECTION) && 427 (pfn & (PAGES_PER_SECTION - 1)) == 0) { 428 NODE_DATA(nid)->first_deferred_pfn = pfn; 429 return true; 430 } 431 return false; 432 } 433 #else 434 static inline bool deferred_pages_enabled(void) 435 { 436 return false; 437 } 438 439 static inline bool early_page_uninitialised(unsigned long pfn) 440 { 441 return false; 442 } 443 444 static inline bool defer_init(int nid, unsigned long pfn, unsigned long end_pfn) 445 { 446 return false; 447 } 448 #endif 449 450 /* Return a pointer to the bitmap storing bits affecting a block of pages */ 451 static inline unsigned long *get_pageblock_bitmap(const struct page *page, 452 unsigned long pfn) 453 { 454 #ifdef CONFIG_SPARSEMEM 455 return section_to_usemap(__pfn_to_section(pfn)); 456 #else 457 return page_zone(page)->pageblock_flags; 458 #endif /* CONFIG_SPARSEMEM */ 459 } 460 461 static inline int pfn_to_bitidx(const struct page *page, unsigned long pfn) 462 { 463 #ifdef CONFIG_SPARSEMEM 464 pfn &= (PAGES_PER_SECTION-1); 465 #else 466 pfn = pfn - round_down(page_zone(page)->zone_start_pfn, pageblock_nr_pages); 467 #endif /* CONFIG_SPARSEMEM */ 468 return (pfn >> pageblock_order) * NR_PAGEBLOCK_BITS; 469 } 470 471 static __always_inline 472 unsigned long __get_pfnblock_flags_mask(const struct page *page, 473 unsigned long pfn, 474 unsigned long mask) 475 { 476 unsigned long *bitmap; 477 unsigned long bitidx, word_bitidx; 478 unsigned long word; 479 480 bitmap = get_pageblock_bitmap(page, pfn); 481 bitidx = pfn_to_bitidx(page, pfn); 482 word_bitidx = bitidx / BITS_PER_LONG; 483 bitidx &= (BITS_PER_LONG-1); 484 485 word = bitmap[word_bitidx]; 486 return (word >> bitidx) & mask; 487 } 488 489 /** 490 * get_pfnblock_flags_mask - Return the requested group of flags for the pageblock_nr_pages block of pages 491 * @page: The page within the block of interest 492 * @pfn: The target page frame number 493 * @mask: mask of bits that the caller is interested in 494 * 495 * Return: pageblock_bits flags 496 */ 497 unsigned long get_pfnblock_flags_mask(const struct page *page, 498 unsigned long pfn, unsigned long mask) 499 { 500 return __get_pfnblock_flags_mask(page, pfn, mask); 501 } 502 503 static __always_inline int get_pfnblock_migratetype(const struct page *page, 504 unsigned long pfn) 505 { 506 return __get_pfnblock_flags_mask(page, pfn, MIGRATETYPE_MASK); 507 } 508 509 /** 510 * set_pfnblock_flags_mask - Set the requested group of flags for a pageblock_nr_pages block of pages 511 * @page: The page within the block of interest 512 * @flags: The flags to set 513 * @pfn: The target page frame number 514 * @mask: mask of bits that the caller is interested in 515 */ 516 void set_pfnblock_flags_mask(struct page *page, unsigned long flags, 517 unsigned long pfn, 518 unsigned long mask) 519 { 520 unsigned long *bitmap; 521 unsigned long bitidx, word_bitidx; 522 unsigned long old_word, word; 523 524 BUILD_BUG_ON(NR_PAGEBLOCK_BITS != 4); 525 BUILD_BUG_ON(MIGRATE_TYPES > (1 << PB_migratetype_bits)); 526 527 bitmap = get_pageblock_bitmap(page, pfn); 528 bitidx = pfn_to_bitidx(page, pfn); 529 word_bitidx = bitidx / BITS_PER_LONG; 530 bitidx &= (BITS_PER_LONG-1); 531 532 VM_BUG_ON_PAGE(!zone_spans_pfn(page_zone(page), pfn), page); 533 534 mask <<= bitidx; 535 flags <<= bitidx; 536 537 word = READ_ONCE(bitmap[word_bitidx]); 538 for (;;) { 539 old_word = cmpxchg(&bitmap[word_bitidx], word, (word & ~mask) | flags); 540 if (word == old_word) 541 break; 542 word = old_word; 543 } 544 } 545 546 void set_pageblock_migratetype(struct page *page, int migratetype) 547 { 548 if (unlikely(page_group_by_mobility_disabled && 549 migratetype < MIGRATE_PCPTYPES)) 550 migratetype = MIGRATE_UNMOVABLE; 551 552 set_pfnblock_flags_mask(page, (unsigned long)migratetype, 553 page_to_pfn(page), MIGRATETYPE_MASK); 554 } 555 556 #ifdef CONFIG_DEBUG_VM 557 static int page_outside_zone_boundaries(struct zone *zone, struct page *page) 558 { 559 int ret = 0; 560 unsigned seq; 561 unsigned long pfn = page_to_pfn(page); 562 unsigned long sp, start_pfn; 563 564 do { 565 seq = zone_span_seqbegin(zone); 566 start_pfn = zone->zone_start_pfn; 567 sp = zone->spanned_pages; 568 if (!zone_spans_pfn(zone, pfn)) 569 ret = 1; 570 } while (zone_span_seqretry(zone, seq)); 571 572 if (ret) 573 pr_err("page 0x%lx outside node %d zone %s [ 0x%lx - 0x%lx ]\n", 574 pfn, zone_to_nid(zone), zone->name, 575 start_pfn, start_pfn + sp); 576 577 return ret; 578 } 579 580 static int page_is_consistent(struct zone *zone, struct page *page) 581 { 582 if (zone != page_zone(page)) 583 return 0; 584 585 return 1; 586 } 587 /* 588 * Temporary debugging check for pages not lying within a given zone. 589 */ 590 static int __maybe_unused bad_range(struct zone *zone, struct page *page) 591 { 592 if (page_outside_zone_boundaries(zone, page)) 593 return 1; 594 if (!page_is_consistent(zone, page)) 595 return 1; 596 597 return 0; 598 } 599 #else 600 static inline int __maybe_unused bad_range(struct zone *zone, struct page *page) 601 { 602 return 0; 603 } 604 #endif 605 606 static void bad_page(struct page *page, const char *reason) 607 { 608 static unsigned long resume; 609 static unsigned long nr_shown; 610 static unsigned long nr_unshown; 611 612 /* 613 * Allow a burst of 60 reports, then keep quiet for that minute; 614 * or allow a steady drip of one report per second. 615 */ 616 if (nr_shown == 60) { 617 if (time_before(jiffies, resume)) { 618 nr_unshown++; 619 goto out; 620 } 621 if (nr_unshown) { 622 pr_alert( 623 "BUG: Bad page state: %lu messages suppressed\n", 624 nr_unshown); 625 nr_unshown = 0; 626 } 627 nr_shown = 0; 628 } 629 if (nr_shown++ == 0) 630 resume = jiffies + 60 * HZ; 631 632 pr_alert("BUG: Bad page state in process %s pfn:%05lx\n", 633 current->comm, page_to_pfn(page)); 634 dump_page(page, reason); 635 636 print_modules(); 637 dump_stack(); 638 out: 639 /* Leave bad fields for debug, except PageBuddy could make trouble */ 640 page_mapcount_reset(page); /* remove PageBuddy */ 641 add_taint(TAINT_BAD_PAGE, LOCKDEP_NOW_UNRELIABLE); 642 } 643 644 static inline unsigned int order_to_pindex(int migratetype, int order) 645 { 646 int base = order; 647 648 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 649 if (order > PAGE_ALLOC_COSTLY_ORDER) { 650 VM_BUG_ON(order != pageblock_order); 651 base = PAGE_ALLOC_COSTLY_ORDER + 1; 652 } 653 #else 654 VM_BUG_ON(order > PAGE_ALLOC_COSTLY_ORDER); 655 #endif 656 657 return (MIGRATE_PCPTYPES * base) + migratetype; 658 } 659 660 static inline int pindex_to_order(unsigned int pindex) 661 { 662 int order = pindex / MIGRATE_PCPTYPES; 663 664 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 665 if (order > PAGE_ALLOC_COSTLY_ORDER) 666 order = pageblock_order; 667 #else 668 VM_BUG_ON(order > PAGE_ALLOC_COSTLY_ORDER); 669 #endif 670 671 return order; 672 } 673 674 static inline bool pcp_allowed_order(unsigned int order) 675 { 676 if (order <= PAGE_ALLOC_COSTLY_ORDER) 677 return true; 678 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 679 if (order == pageblock_order) 680 return true; 681 #endif 682 return false; 683 } 684 685 static inline void free_the_page(struct page *page, unsigned int order) 686 { 687 if (pcp_allowed_order(order)) /* Via pcp? */ 688 free_unref_page(page, order); 689 else 690 __free_pages_ok(page, order, FPI_NONE); 691 } 692 693 /* 694 * Higher-order pages are called "compound pages". They are structured thusly: 695 * 696 * The first PAGE_SIZE page is called the "head page" and have PG_head set. 697 * 698 * The remaining PAGE_SIZE pages are called "tail pages". PageTail() is encoded 699 * in bit 0 of page->compound_head. The rest of bits is pointer to head page. 700 * 701 * The first tail page's ->compound_dtor holds the offset in array of compound 702 * page destructors. See compound_page_dtors. 703 * 704 * The first tail page's ->compound_order holds the order of allocation. 705 * This usage means that zero-order pages may not be compound. 706 */ 707 708 void free_compound_page(struct page *page) 709 { 710 mem_cgroup_uncharge(page_folio(page)); 711 free_the_page(page, compound_order(page)); 712 } 713 714 static void prep_compound_head(struct page *page, unsigned int order) 715 { 716 set_compound_page_dtor(page, COMPOUND_PAGE_DTOR); 717 set_compound_order(page, order); 718 atomic_set(compound_mapcount_ptr(page), -1); 719 atomic_set(compound_pincount_ptr(page), 0); 720 } 721 722 static void prep_compound_tail(struct page *head, int tail_idx) 723 { 724 struct page *p = head + tail_idx; 725 726 p->mapping = TAIL_MAPPING; 727 set_compound_head(p, head); 728 } 729 730 void prep_compound_page(struct page *page, unsigned int order) 731 { 732 int i; 733 int nr_pages = 1 << order; 734 735 __SetPageHead(page); 736 for (i = 1; i < nr_pages; i++) 737 prep_compound_tail(page, i); 738 739 prep_compound_head(page, order); 740 } 741 742 #ifdef CONFIG_DEBUG_PAGEALLOC 743 unsigned int _debug_guardpage_minorder; 744 745 bool _debug_pagealloc_enabled_early __read_mostly 746 = IS_ENABLED(CONFIG_DEBUG_PAGEALLOC_ENABLE_DEFAULT); 747 EXPORT_SYMBOL(_debug_pagealloc_enabled_early); 748 DEFINE_STATIC_KEY_FALSE(_debug_pagealloc_enabled); 749 EXPORT_SYMBOL(_debug_pagealloc_enabled); 750 751 DEFINE_STATIC_KEY_FALSE(_debug_guardpage_enabled); 752 753 static int __init early_debug_pagealloc(char *buf) 754 { 755 return kstrtobool(buf, &_debug_pagealloc_enabled_early); 756 } 757 early_param("debug_pagealloc", early_debug_pagealloc); 758 759 static int __init debug_guardpage_minorder_setup(char *buf) 760 { 761 unsigned long res; 762 763 if (kstrtoul(buf, 10, &res) < 0 || res > MAX_ORDER / 2) { 764 pr_err("Bad debug_guardpage_minorder value\n"); 765 return 0; 766 } 767 _debug_guardpage_minorder = res; 768 pr_info("Setting debug_guardpage_minorder to %lu\n", res); 769 return 0; 770 } 771 early_param("debug_guardpage_minorder", debug_guardpage_minorder_setup); 772 773 static inline bool set_page_guard(struct zone *zone, struct page *page, 774 unsigned int order, int migratetype) 775 { 776 if (!debug_guardpage_enabled()) 777 return false; 778 779 if (order >= debug_guardpage_minorder()) 780 return false; 781 782 __SetPageGuard(page); 783 INIT_LIST_HEAD(&page->lru); 784 set_page_private(page, order); 785 /* Guard pages are not available for any usage */ 786 __mod_zone_freepage_state(zone, -(1 << order), migratetype); 787 788 return true; 789 } 790 791 static inline void clear_page_guard(struct zone *zone, struct page *page, 792 unsigned int order, int migratetype) 793 { 794 if (!debug_guardpage_enabled()) 795 return; 796 797 __ClearPageGuard(page); 798 799 set_page_private(page, 0); 800 if (!is_migrate_isolate(migratetype)) 801 __mod_zone_freepage_state(zone, (1 << order), migratetype); 802 } 803 #else 804 static inline bool set_page_guard(struct zone *zone, struct page *page, 805 unsigned int order, int migratetype) { return false; } 806 static inline void clear_page_guard(struct zone *zone, struct page *page, 807 unsigned int order, int migratetype) {} 808 #endif 809 810 /* 811 * Enable static keys related to various memory debugging and hardening options. 812 * Some override others, and depend on early params that are evaluated in the 813 * order of appearance. So we need to first gather the full picture of what was 814 * enabled, and then make decisions. 815 */ 816 void init_mem_debugging_and_hardening(void) 817 { 818 bool page_poisoning_requested = false; 819 820 #ifdef CONFIG_PAGE_POISONING 821 /* 822 * Page poisoning is debug page alloc for some arches. If 823 * either of those options are enabled, enable poisoning. 824 */ 825 if (page_poisoning_enabled() || 826 (!IS_ENABLED(CONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC) && 827 debug_pagealloc_enabled())) { 828 static_branch_enable(&_page_poisoning_enabled); 829 page_poisoning_requested = true; 830 } 831 #endif 832 833 if ((_init_on_alloc_enabled_early || _init_on_free_enabled_early) && 834 page_poisoning_requested) { 835 pr_info("mem auto-init: CONFIG_PAGE_POISONING is on, " 836 "will take precedence over init_on_alloc and init_on_free\n"); 837 _init_on_alloc_enabled_early = false; 838 _init_on_free_enabled_early = false; 839 } 840 841 if (_init_on_alloc_enabled_early) 842 static_branch_enable(&init_on_alloc); 843 else 844 static_branch_disable(&init_on_alloc); 845 846 if (_init_on_free_enabled_early) 847 static_branch_enable(&init_on_free); 848 else 849 static_branch_disable(&init_on_free); 850 851 #ifdef CONFIG_DEBUG_PAGEALLOC 852 if (!debug_pagealloc_enabled()) 853 return; 854 855 static_branch_enable(&_debug_pagealloc_enabled); 856 857 if (!debug_guardpage_minorder()) 858 return; 859 860 static_branch_enable(&_debug_guardpage_enabled); 861 #endif 862 } 863 864 static inline void set_buddy_order(struct page *page, unsigned int order) 865 { 866 set_page_private(page, order); 867 __SetPageBuddy(page); 868 } 869 870 #ifdef CONFIG_COMPACTION 871 static inline struct capture_control *task_capc(struct zone *zone) 872 { 873 struct capture_control *capc = current->capture_control; 874 875 return unlikely(capc) && 876 !(current->flags & PF_KTHREAD) && 877 !capc->page && 878 capc->cc->zone == zone ? capc : NULL; 879 } 880 881 static inline bool 882 compaction_capture(struct capture_control *capc, struct page *page, 883 int order, int migratetype) 884 { 885 if (!capc || order != capc->cc->order) 886 return false; 887 888 /* Do not accidentally pollute CMA or isolated regions*/ 889 if (is_migrate_cma(migratetype) || 890 is_migrate_isolate(migratetype)) 891 return false; 892 893 /* 894 * Do not let lower order allocations pollute a movable pageblock. 895 * This might let an unmovable request use a reclaimable pageblock 896 * and vice-versa but no more than normal fallback logic which can 897 * have trouble finding a high-order free page. 898 */ 899 if (order < pageblock_order && migratetype == MIGRATE_MOVABLE) 900 return false; 901 902 capc->page = page; 903 return true; 904 } 905 906 #else 907 static inline struct capture_control *task_capc(struct zone *zone) 908 { 909 return NULL; 910 } 911 912 static inline bool 913 compaction_capture(struct capture_control *capc, struct page *page, 914 int order, int migratetype) 915 { 916 return false; 917 } 918 #endif /* CONFIG_COMPACTION */ 919 920 /* Used for pages not on another list */ 921 static inline void add_to_free_list(struct page *page, struct zone *zone, 922 unsigned int order, int migratetype) 923 { 924 struct free_area *area = &zone->free_area[order]; 925 926 list_add(&page->lru, &area->free_list[migratetype]); 927 area->nr_free++; 928 } 929 930 /* Used for pages not on another list */ 931 static inline void add_to_free_list_tail(struct page *page, struct zone *zone, 932 unsigned int order, int migratetype) 933 { 934 struct free_area *area = &zone->free_area[order]; 935 936 list_add_tail(&page->lru, &area->free_list[migratetype]); 937 area->nr_free++; 938 } 939 940 /* 941 * Used for pages which are on another list. Move the pages to the tail 942 * of the list - so the moved pages won't immediately be considered for 943 * allocation again (e.g., optimization for memory onlining). 944 */ 945 static inline void move_to_free_list(struct page *page, struct zone *zone, 946 unsigned int order, int migratetype) 947 { 948 struct free_area *area = &zone->free_area[order]; 949 950 list_move_tail(&page->lru, &area->free_list[migratetype]); 951 } 952 953 static inline void del_page_from_free_list(struct page *page, struct zone *zone, 954 unsigned int order) 955 { 956 /* clear reported state and update reported page count */ 957 if (page_reported(page)) 958 __ClearPageReported(page); 959 960 list_del(&page->lru); 961 __ClearPageBuddy(page); 962 set_page_private(page, 0); 963 zone->free_area[order].nr_free--; 964 } 965 966 /* 967 * If this is not the largest possible page, check if the buddy 968 * of the next-highest order is free. If it is, it's possible 969 * that pages are being freed that will coalesce soon. In case, 970 * that is happening, add the free page to the tail of the list 971 * so it's less likely to be used soon and more likely to be merged 972 * as a higher order page 973 */ 974 static inline bool 975 buddy_merge_likely(unsigned long pfn, unsigned long buddy_pfn, 976 struct page *page, unsigned int order) 977 { 978 unsigned long higher_page_pfn; 979 struct page *higher_page; 980 981 if (order >= MAX_ORDER - 2) 982 return false; 983 984 higher_page_pfn = buddy_pfn & pfn; 985 higher_page = page + (higher_page_pfn - pfn); 986 987 return find_buddy_page_pfn(higher_page, higher_page_pfn, order + 1, 988 NULL) != NULL; 989 } 990 991 /* 992 * Freeing function for a buddy system allocator. 993 * 994 * The concept of a buddy system is to maintain direct-mapped table 995 * (containing bit values) for memory blocks of various "orders". 996 * The bottom level table contains the map for the smallest allocatable 997 * units of memory (here, pages), and each level above it describes 998 * pairs of units from the levels below, hence, "buddies". 999 * At a high level, all that happens here is marking the table entry 1000 * at the bottom level available, and propagating the changes upward 1001 * as necessary, plus some accounting needed to play nicely with other 1002 * parts of the VM system. 1003 * At each level, we keep a list of pages, which are heads of continuous 1004 * free pages of length of (1 << order) and marked with PageBuddy. 1005 * Page's order is recorded in page_private(page) field. 1006 * So when we are allocating or freeing one, we can derive the state of the 1007 * other. That is, if we allocate a small block, and both were 1008 * free, the remainder of the region must be split into blocks. 1009 * If a block is freed, and its buddy is also free, then this 1010 * triggers coalescing into a block of larger size. 1011 * 1012 * -- nyc 1013 */ 1014 1015 static inline void __free_one_page(struct page *page, 1016 unsigned long pfn, 1017 struct zone *zone, unsigned int order, 1018 int migratetype, fpi_t fpi_flags) 1019 { 1020 struct capture_control *capc = task_capc(zone); 1021 unsigned long buddy_pfn; 1022 unsigned long combined_pfn; 1023 struct page *buddy; 1024 bool to_tail; 1025 1026 VM_BUG_ON(!zone_is_initialized(zone)); 1027 VM_BUG_ON_PAGE(page->flags & PAGE_FLAGS_CHECK_AT_PREP, page); 1028 1029 VM_BUG_ON(migratetype == -1); 1030 if (likely(!is_migrate_isolate(migratetype))) 1031 __mod_zone_freepage_state(zone, 1 << order, migratetype); 1032 1033 VM_BUG_ON_PAGE(pfn & ((1 << order) - 1), page); 1034 VM_BUG_ON_PAGE(bad_range(zone, page), page); 1035 1036 while (order < MAX_ORDER - 1) { 1037 if (compaction_capture(capc, page, order, migratetype)) { 1038 __mod_zone_freepage_state(zone, -(1 << order), 1039 migratetype); 1040 return; 1041 } 1042 1043 buddy = find_buddy_page_pfn(page, pfn, order, &buddy_pfn); 1044 if (!buddy) 1045 goto done_merging; 1046 1047 if (unlikely(order >= pageblock_order)) { 1048 /* 1049 * We want to prevent merge between freepages on pageblock 1050 * without fallbacks and normal pageblock. Without this, 1051 * pageblock isolation could cause incorrect freepage or CMA 1052 * accounting or HIGHATOMIC accounting. 1053 */ 1054 int buddy_mt = get_pageblock_migratetype(buddy); 1055 1056 if (migratetype != buddy_mt 1057 && (!migratetype_is_mergeable(migratetype) || 1058 !migratetype_is_mergeable(buddy_mt))) 1059 goto done_merging; 1060 } 1061 1062 /* 1063 * Our buddy is free or it is CONFIG_DEBUG_PAGEALLOC guard page, 1064 * merge with it and move up one order. 1065 */ 1066 if (page_is_guard(buddy)) 1067 clear_page_guard(zone, buddy, order, migratetype); 1068 else 1069 del_page_from_free_list(buddy, zone, order); 1070 combined_pfn = buddy_pfn & pfn; 1071 page = page + (combined_pfn - pfn); 1072 pfn = combined_pfn; 1073 order++; 1074 } 1075 1076 done_merging: 1077 set_buddy_order(page, order); 1078 1079 if (fpi_flags & FPI_TO_TAIL) 1080 to_tail = true; 1081 else if (is_shuffle_order(order)) 1082 to_tail = shuffle_pick_tail(); 1083 else 1084 to_tail = buddy_merge_likely(pfn, buddy_pfn, page, order); 1085 1086 if (to_tail) 1087 add_to_free_list_tail(page, zone, order, migratetype); 1088 else 1089 add_to_free_list(page, zone, order, migratetype); 1090 1091 /* Notify page reporting subsystem of freed page */ 1092 if (!(fpi_flags & FPI_SKIP_REPORT_NOTIFY)) 1093 page_reporting_notify_free(order); 1094 } 1095 1096 /* 1097 * A bad page could be due to a number of fields. Instead of multiple branches, 1098 * try and check multiple fields with one check. The caller must do a detailed 1099 * check if necessary. 1100 */ 1101 static inline bool page_expected_state(struct page *page, 1102 unsigned long check_flags) 1103 { 1104 if (unlikely(atomic_read(&page->_mapcount) != -1)) 1105 return false; 1106 1107 if (unlikely((unsigned long)page->mapping | 1108 page_ref_count(page) | 1109 #ifdef CONFIG_MEMCG 1110 page->memcg_data | 1111 #endif 1112 (page->flags & check_flags))) 1113 return false; 1114 1115 return true; 1116 } 1117 1118 static const char *page_bad_reason(struct page *page, unsigned long flags) 1119 { 1120 const char *bad_reason = NULL; 1121 1122 if (unlikely(atomic_read(&page->_mapcount) != -1)) 1123 bad_reason = "nonzero mapcount"; 1124 if (unlikely(page->mapping != NULL)) 1125 bad_reason = "non-NULL mapping"; 1126 if (unlikely(page_ref_count(page) != 0)) 1127 bad_reason = "nonzero _refcount"; 1128 if (unlikely(page->flags & flags)) { 1129 if (flags == PAGE_FLAGS_CHECK_AT_PREP) 1130 bad_reason = "PAGE_FLAGS_CHECK_AT_PREP flag(s) set"; 1131 else 1132 bad_reason = "PAGE_FLAGS_CHECK_AT_FREE flag(s) set"; 1133 } 1134 #ifdef CONFIG_MEMCG 1135 if (unlikely(page->memcg_data)) 1136 bad_reason = "page still charged to cgroup"; 1137 #endif 1138 return bad_reason; 1139 } 1140 1141 static void check_free_page_bad(struct page *page) 1142 { 1143 bad_page(page, 1144 page_bad_reason(page, PAGE_FLAGS_CHECK_AT_FREE)); 1145 } 1146 1147 static inline int check_free_page(struct page *page) 1148 { 1149 if (likely(page_expected_state(page, PAGE_FLAGS_CHECK_AT_FREE))) 1150 return 0; 1151 1152 /* Something has gone sideways, find it */ 1153 check_free_page_bad(page); 1154 return 1; 1155 } 1156 1157 static int free_tail_pages_check(struct page *head_page, struct page *page) 1158 { 1159 int ret = 1; 1160 1161 /* 1162 * We rely page->lru.next never has bit 0 set, unless the page 1163 * is PageTail(). Let's make sure that's true even for poisoned ->lru. 1164 */ 1165 BUILD_BUG_ON((unsigned long)LIST_POISON1 & 1); 1166 1167 if (!IS_ENABLED(CONFIG_DEBUG_VM)) { 1168 ret = 0; 1169 goto out; 1170 } 1171 switch (page - head_page) { 1172 case 1: 1173 /* the first tail page: ->mapping may be compound_mapcount() */ 1174 if (unlikely(compound_mapcount(page))) { 1175 bad_page(page, "nonzero compound_mapcount"); 1176 goto out; 1177 } 1178 break; 1179 case 2: 1180 /* 1181 * the second tail page: ->mapping is 1182 * deferred_list.next -- ignore value. 1183 */ 1184 break; 1185 default: 1186 if (page->mapping != TAIL_MAPPING) { 1187 bad_page(page, "corrupted mapping in tail page"); 1188 goto out; 1189 } 1190 break; 1191 } 1192 if (unlikely(!PageTail(page))) { 1193 bad_page(page, "PageTail not set"); 1194 goto out; 1195 } 1196 if (unlikely(compound_head(page) != head_page)) { 1197 bad_page(page, "compound_head not consistent"); 1198 goto out; 1199 } 1200 ret = 0; 1201 out: 1202 page->mapping = NULL; 1203 clear_compound_head(page); 1204 return ret; 1205 } 1206 1207 /* 1208 * Skip KASAN memory poisoning when either: 1209 * 1210 * 1. Deferred memory initialization has not yet completed, 1211 * see the explanation below. 1212 * 2. Skipping poisoning is requested via FPI_SKIP_KASAN_POISON, 1213 * see the comment next to it. 1214 * 3. Skipping poisoning is requested via __GFP_SKIP_KASAN_POISON, 1215 * see the comment next to it. 1216 * 1217 * Poisoning pages during deferred memory init will greatly lengthen the 1218 * process and cause problem in large memory systems as the deferred pages 1219 * initialization is done with interrupt disabled. 1220 * 1221 * Assuming that there will be no reference to those newly initialized 1222 * pages before they are ever allocated, this should have no effect on 1223 * KASAN memory tracking as the poison will be properly inserted at page 1224 * allocation time. The only corner case is when pages are allocated by 1225 * on-demand allocation and then freed again before the deferred pages 1226 * initialization is done, but this is not likely to happen. 1227 */ 1228 static inline bool should_skip_kasan_poison(struct page *page, fpi_t fpi_flags) 1229 { 1230 return deferred_pages_enabled() || 1231 (!IS_ENABLED(CONFIG_KASAN_GENERIC) && 1232 (fpi_flags & FPI_SKIP_KASAN_POISON)) || 1233 PageSkipKASanPoison(page); 1234 } 1235 1236 static void kernel_init_free_pages(struct page *page, int numpages) 1237 { 1238 int i; 1239 1240 /* s390's use of memset() could override KASAN redzones. */ 1241 kasan_disable_current(); 1242 for (i = 0; i < numpages; i++) { 1243 u8 tag = page_kasan_tag(page + i); 1244 page_kasan_tag_reset(page + i); 1245 clear_highpage(page + i); 1246 page_kasan_tag_set(page + i, tag); 1247 } 1248 kasan_enable_current(); 1249 } 1250 1251 static __always_inline bool free_pages_prepare(struct page *page, 1252 unsigned int order, bool check_free, fpi_t fpi_flags) 1253 { 1254 int bad = 0; 1255 bool init = want_init_on_free(); 1256 1257 VM_BUG_ON_PAGE(PageTail(page), page); 1258 1259 trace_mm_page_free(page, order); 1260 1261 if (unlikely(PageHWPoison(page)) && !order) { 1262 /* 1263 * Do not let hwpoison pages hit pcplists/buddy 1264 * Untie memcg state and reset page's owner 1265 */ 1266 if (memcg_kmem_enabled() && PageMemcgKmem(page)) 1267 __memcg_kmem_uncharge_page(page, order); 1268 reset_page_owner(page, order); 1269 page_table_check_free(page, order); 1270 return false; 1271 } 1272 1273 /* 1274 * Check tail pages before head page information is cleared to 1275 * avoid checking PageCompound for order-0 pages. 1276 */ 1277 if (unlikely(order)) { 1278 bool compound = PageCompound(page); 1279 int i; 1280 1281 VM_BUG_ON_PAGE(compound && compound_order(page) != order, page); 1282 1283 if (compound) { 1284 ClearPageDoubleMap(page); 1285 ClearPageHasHWPoisoned(page); 1286 } 1287 for (i = 1; i < (1 << order); i++) { 1288 if (compound) 1289 bad += free_tail_pages_check(page, page + i); 1290 if (unlikely(check_free_page(page + i))) { 1291 bad++; 1292 continue; 1293 } 1294 (page + i)->flags &= ~PAGE_FLAGS_CHECK_AT_PREP; 1295 } 1296 } 1297 if (PageMappingFlags(page)) 1298 page->mapping = NULL; 1299 if (memcg_kmem_enabled() && PageMemcgKmem(page)) 1300 __memcg_kmem_uncharge_page(page, order); 1301 if (check_free) 1302 bad += check_free_page(page); 1303 if (bad) 1304 return false; 1305 1306 page_cpupid_reset_last(page); 1307 page->flags &= ~PAGE_FLAGS_CHECK_AT_PREP; 1308 reset_page_owner(page, order); 1309 page_table_check_free(page, order); 1310 1311 if (!PageHighMem(page)) { 1312 debug_check_no_locks_freed(page_address(page), 1313 PAGE_SIZE << order); 1314 debug_check_no_obj_freed(page_address(page), 1315 PAGE_SIZE << order); 1316 } 1317 1318 kernel_poison_pages(page, 1 << order); 1319 1320 /* 1321 * As memory initialization might be integrated into KASAN, 1322 * KASAN poisoning and memory initialization code must be 1323 * kept together to avoid discrepancies in behavior. 1324 * 1325 * With hardware tag-based KASAN, memory tags must be set before the 1326 * page becomes unavailable via debug_pagealloc or arch_free_page. 1327 */ 1328 if (!should_skip_kasan_poison(page, fpi_flags)) { 1329 kasan_poison_pages(page, order, init); 1330 1331 /* Memory is already initialized if KASAN did it internally. */ 1332 if (kasan_has_integrated_init()) 1333 init = false; 1334 } 1335 if (init) 1336 kernel_init_free_pages(page, 1 << order); 1337 1338 /* 1339 * arch_free_page() can make the page's contents inaccessible. s390 1340 * does this. So nothing which can access the page's contents should 1341 * happen after this. 1342 */ 1343 arch_free_page(page, order); 1344 1345 debug_pagealloc_unmap_pages(page, 1 << order); 1346 1347 return true; 1348 } 1349 1350 #ifdef CONFIG_DEBUG_VM 1351 /* 1352 * With DEBUG_VM enabled, order-0 pages are checked immediately when being freed 1353 * to pcp lists. With debug_pagealloc also enabled, they are also rechecked when 1354 * moved from pcp lists to free lists. 1355 */ 1356 static bool free_pcp_prepare(struct page *page, unsigned int order) 1357 { 1358 return free_pages_prepare(page, order, true, FPI_NONE); 1359 } 1360 1361 static bool bulkfree_pcp_prepare(struct page *page) 1362 { 1363 if (debug_pagealloc_enabled_static()) 1364 return check_free_page(page); 1365 else 1366 return false; 1367 } 1368 #else 1369 /* 1370 * With DEBUG_VM disabled, order-0 pages being freed are checked only when 1371 * moving from pcp lists to free list in order to reduce overhead. With 1372 * debug_pagealloc enabled, they are checked also immediately when being freed 1373 * to the pcp lists. 1374 */ 1375 static bool free_pcp_prepare(struct page *page, unsigned int order) 1376 { 1377 if (debug_pagealloc_enabled_static()) 1378 return free_pages_prepare(page, order, true, FPI_NONE); 1379 else 1380 return free_pages_prepare(page, order, false, FPI_NONE); 1381 } 1382 1383 static bool bulkfree_pcp_prepare(struct page *page) 1384 { 1385 return check_free_page(page); 1386 } 1387 #endif /* CONFIG_DEBUG_VM */ 1388 1389 /* 1390 * Frees a number of pages from the PCP lists 1391 * Assumes all pages on list are in same zone. 1392 * count is the number of pages to free. 1393 */ 1394 static void free_pcppages_bulk(struct zone *zone, int count, 1395 struct per_cpu_pages *pcp, 1396 int pindex) 1397 { 1398 int min_pindex = 0; 1399 int max_pindex = NR_PCP_LISTS - 1; 1400 unsigned int order; 1401 bool isolated_pageblocks; 1402 struct page *page; 1403 1404 /* 1405 * Ensure proper count is passed which otherwise would stuck in the 1406 * below while (list_empty(list)) loop. 1407 */ 1408 count = min(pcp->count, count); 1409 1410 /* Ensure requested pindex is drained first. */ 1411 pindex = pindex - 1; 1412 1413 /* 1414 * local_lock_irq held so equivalent to spin_lock_irqsave for 1415 * both PREEMPT_RT and non-PREEMPT_RT configurations. 1416 */ 1417 spin_lock(&zone->lock); 1418 isolated_pageblocks = has_isolate_pageblock(zone); 1419 1420 while (count > 0) { 1421 struct list_head *list; 1422 int nr_pages; 1423 1424 /* Remove pages from lists in a round-robin fashion. */ 1425 do { 1426 if (++pindex > max_pindex) 1427 pindex = min_pindex; 1428 list = &pcp->lists[pindex]; 1429 if (!list_empty(list)) 1430 break; 1431 1432 if (pindex == max_pindex) 1433 max_pindex--; 1434 if (pindex == min_pindex) 1435 min_pindex++; 1436 } while (1); 1437 1438 order = pindex_to_order(pindex); 1439 nr_pages = 1 << order; 1440 BUILD_BUG_ON(MAX_ORDER >= (1<<NR_PCP_ORDER_WIDTH)); 1441 do { 1442 int mt; 1443 1444 page = list_last_entry(list, struct page, lru); 1445 mt = get_pcppage_migratetype(page); 1446 1447 /* must delete to avoid corrupting pcp list */ 1448 list_del(&page->lru); 1449 count -= nr_pages; 1450 pcp->count -= nr_pages; 1451 1452 if (bulkfree_pcp_prepare(page)) 1453 continue; 1454 1455 /* MIGRATE_ISOLATE page should not go to pcplists */ 1456 VM_BUG_ON_PAGE(is_migrate_isolate(mt), page); 1457 /* Pageblock could have been isolated meanwhile */ 1458 if (unlikely(isolated_pageblocks)) 1459 mt = get_pageblock_migratetype(page); 1460 1461 __free_one_page(page, page_to_pfn(page), zone, order, mt, FPI_NONE); 1462 trace_mm_page_pcpu_drain(page, order, mt); 1463 } while (count > 0 && !list_empty(list)); 1464 } 1465 1466 spin_unlock(&zone->lock); 1467 } 1468 1469 static void free_one_page(struct zone *zone, 1470 struct page *page, unsigned long pfn, 1471 unsigned int order, 1472 int migratetype, fpi_t fpi_flags) 1473 { 1474 unsigned long flags; 1475 1476 spin_lock_irqsave(&zone->lock, flags); 1477 if (unlikely(has_isolate_pageblock(zone) || 1478 is_migrate_isolate(migratetype))) { 1479 migratetype = get_pfnblock_migratetype(page, pfn); 1480 } 1481 __free_one_page(page, pfn, zone, order, migratetype, fpi_flags); 1482 spin_unlock_irqrestore(&zone->lock, flags); 1483 } 1484 1485 static void __meminit __init_single_page(struct page *page, unsigned long pfn, 1486 unsigned long zone, int nid) 1487 { 1488 mm_zero_struct_page(page); 1489 set_page_links(page, zone, nid, pfn); 1490 init_page_count(page); 1491 page_mapcount_reset(page); 1492 page_cpupid_reset_last(page); 1493 page_kasan_tag_reset(page); 1494 1495 INIT_LIST_HEAD(&page->lru); 1496 #ifdef WANT_PAGE_VIRTUAL 1497 /* The shift won't overflow because ZONE_NORMAL is below 4G. */ 1498 if (!is_highmem_idx(zone)) 1499 set_page_address(page, __va(pfn << PAGE_SHIFT)); 1500 #endif 1501 } 1502 1503 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 1504 static void __meminit init_reserved_page(unsigned long pfn) 1505 { 1506 pg_data_t *pgdat; 1507 int nid, zid; 1508 1509 if (!early_page_uninitialised(pfn)) 1510 return; 1511 1512 nid = early_pfn_to_nid(pfn); 1513 pgdat = NODE_DATA(nid); 1514 1515 for (zid = 0; zid < MAX_NR_ZONES; zid++) { 1516 struct zone *zone = &pgdat->node_zones[zid]; 1517 1518 if (zone_spans_pfn(zone, pfn)) 1519 break; 1520 } 1521 __init_single_page(pfn_to_page(pfn), pfn, zid, nid); 1522 } 1523 #else 1524 static inline void init_reserved_page(unsigned long pfn) 1525 { 1526 } 1527 #endif /* CONFIG_DEFERRED_STRUCT_PAGE_INIT */ 1528 1529 /* 1530 * Initialised pages do not have PageReserved set. This function is 1531 * called for each range allocated by the bootmem allocator and 1532 * marks the pages PageReserved. The remaining valid pages are later 1533 * sent to the buddy page allocator. 1534 */ 1535 void __meminit reserve_bootmem_region(phys_addr_t start, phys_addr_t end) 1536 { 1537 unsigned long start_pfn = PFN_DOWN(start); 1538 unsigned long end_pfn = PFN_UP(end); 1539 1540 for (; start_pfn < end_pfn; start_pfn++) { 1541 if (pfn_valid(start_pfn)) { 1542 struct page *page = pfn_to_page(start_pfn); 1543 1544 init_reserved_page(start_pfn); 1545 1546 /* Avoid false-positive PageTail() */ 1547 INIT_LIST_HEAD(&page->lru); 1548 1549 /* 1550 * no need for atomic set_bit because the struct 1551 * page is not visible yet so nobody should 1552 * access it yet. 1553 */ 1554 __SetPageReserved(page); 1555 } 1556 } 1557 } 1558 1559 static void __free_pages_ok(struct page *page, unsigned int order, 1560 fpi_t fpi_flags) 1561 { 1562 unsigned long flags; 1563 int migratetype; 1564 unsigned long pfn = page_to_pfn(page); 1565 struct zone *zone = page_zone(page); 1566 1567 if (!free_pages_prepare(page, order, true, fpi_flags)) 1568 return; 1569 1570 migratetype = get_pfnblock_migratetype(page, pfn); 1571 1572 spin_lock_irqsave(&zone->lock, flags); 1573 if (unlikely(has_isolate_pageblock(zone) || 1574 is_migrate_isolate(migratetype))) { 1575 migratetype = get_pfnblock_migratetype(page, pfn); 1576 } 1577 __free_one_page(page, pfn, zone, order, migratetype, fpi_flags); 1578 spin_unlock_irqrestore(&zone->lock, flags); 1579 1580 __count_vm_events(PGFREE, 1 << order); 1581 } 1582 1583 void __free_pages_core(struct page *page, unsigned int order) 1584 { 1585 unsigned int nr_pages = 1 << order; 1586 struct page *p = page; 1587 unsigned int loop; 1588 1589 /* 1590 * When initializing the memmap, __init_single_page() sets the refcount 1591 * of all pages to 1 ("allocated"/"not free"). We have to set the 1592 * refcount of all involved pages to 0. 1593 */ 1594 prefetchw(p); 1595 for (loop = 0; loop < (nr_pages - 1); loop++, p++) { 1596 prefetchw(p + 1); 1597 __ClearPageReserved(p); 1598 set_page_count(p, 0); 1599 } 1600 __ClearPageReserved(p); 1601 set_page_count(p, 0); 1602 1603 atomic_long_add(nr_pages, &page_zone(page)->managed_pages); 1604 1605 /* 1606 * Bypass PCP and place fresh pages right to the tail, primarily 1607 * relevant for memory onlining. 1608 */ 1609 __free_pages_ok(page, order, FPI_TO_TAIL | FPI_SKIP_KASAN_POISON); 1610 } 1611 1612 #ifdef CONFIG_NUMA 1613 1614 /* 1615 * During memory init memblocks map pfns to nids. The search is expensive and 1616 * this caches recent lookups. The implementation of __early_pfn_to_nid 1617 * treats start/end as pfns. 1618 */ 1619 struct mminit_pfnnid_cache { 1620 unsigned long last_start; 1621 unsigned long last_end; 1622 int last_nid; 1623 }; 1624 1625 static struct mminit_pfnnid_cache early_pfnnid_cache __meminitdata; 1626 1627 /* 1628 * Required by SPARSEMEM. Given a PFN, return what node the PFN is on. 1629 */ 1630 static int __meminit __early_pfn_to_nid(unsigned long pfn, 1631 struct mminit_pfnnid_cache *state) 1632 { 1633 unsigned long start_pfn, end_pfn; 1634 int nid; 1635 1636 if (state->last_start <= pfn && pfn < state->last_end) 1637 return state->last_nid; 1638 1639 nid = memblock_search_pfn_nid(pfn, &start_pfn, &end_pfn); 1640 if (nid != NUMA_NO_NODE) { 1641 state->last_start = start_pfn; 1642 state->last_end = end_pfn; 1643 state->last_nid = nid; 1644 } 1645 1646 return nid; 1647 } 1648 1649 int __meminit early_pfn_to_nid(unsigned long pfn) 1650 { 1651 static DEFINE_SPINLOCK(early_pfn_lock); 1652 int nid; 1653 1654 spin_lock(&early_pfn_lock); 1655 nid = __early_pfn_to_nid(pfn, &early_pfnnid_cache); 1656 if (nid < 0) 1657 nid = first_online_node; 1658 spin_unlock(&early_pfn_lock); 1659 1660 return nid; 1661 } 1662 #endif /* CONFIG_NUMA */ 1663 1664 void __init memblock_free_pages(struct page *page, unsigned long pfn, 1665 unsigned int order) 1666 { 1667 if (early_page_uninitialised(pfn)) 1668 return; 1669 __free_pages_core(page, order); 1670 } 1671 1672 /* 1673 * Check that the whole (or subset of) a pageblock given by the interval of 1674 * [start_pfn, end_pfn) is valid and within the same zone, before scanning it 1675 * with the migration of free compaction scanner. 1676 * 1677 * Return struct page pointer of start_pfn, or NULL if checks were not passed. 1678 * 1679 * It's possible on some configurations to have a setup like node0 node1 node0 1680 * i.e. it's possible that all pages within a zones range of pages do not 1681 * belong to a single zone. We assume that a border between node0 and node1 1682 * can occur within a single pageblock, but not a node0 node1 node0 1683 * interleaving within a single pageblock. It is therefore sufficient to check 1684 * the first and last page of a pageblock and avoid checking each individual 1685 * page in a pageblock. 1686 */ 1687 struct page *__pageblock_pfn_to_page(unsigned long start_pfn, 1688 unsigned long end_pfn, struct zone *zone) 1689 { 1690 struct page *start_page; 1691 struct page *end_page; 1692 1693 /* end_pfn is one past the range we are checking */ 1694 end_pfn--; 1695 1696 if (!pfn_valid(start_pfn) || !pfn_valid(end_pfn)) 1697 return NULL; 1698 1699 start_page = pfn_to_online_page(start_pfn); 1700 if (!start_page) 1701 return NULL; 1702 1703 if (page_zone(start_page) != zone) 1704 return NULL; 1705 1706 end_page = pfn_to_page(end_pfn); 1707 1708 /* This gives a shorter code than deriving page_zone(end_page) */ 1709 if (page_zone_id(start_page) != page_zone_id(end_page)) 1710 return NULL; 1711 1712 return start_page; 1713 } 1714 1715 void set_zone_contiguous(struct zone *zone) 1716 { 1717 unsigned long block_start_pfn = zone->zone_start_pfn; 1718 unsigned long block_end_pfn; 1719 1720 block_end_pfn = ALIGN(block_start_pfn + 1, pageblock_nr_pages); 1721 for (; block_start_pfn < zone_end_pfn(zone); 1722 block_start_pfn = block_end_pfn, 1723 block_end_pfn += pageblock_nr_pages) { 1724 1725 block_end_pfn = min(block_end_pfn, zone_end_pfn(zone)); 1726 1727 if (!__pageblock_pfn_to_page(block_start_pfn, 1728 block_end_pfn, zone)) 1729 return; 1730 cond_resched(); 1731 } 1732 1733 /* We confirm that there is no hole */ 1734 zone->contiguous = true; 1735 } 1736 1737 void clear_zone_contiguous(struct zone *zone) 1738 { 1739 zone->contiguous = false; 1740 } 1741 1742 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 1743 static void __init deferred_free_range(unsigned long pfn, 1744 unsigned long nr_pages) 1745 { 1746 struct page *page; 1747 unsigned long i; 1748 1749 if (!nr_pages) 1750 return; 1751 1752 page = pfn_to_page(pfn); 1753 1754 /* Free a large naturally-aligned chunk if possible */ 1755 if (nr_pages == pageblock_nr_pages && 1756 (pfn & (pageblock_nr_pages - 1)) == 0) { 1757 set_pageblock_migratetype(page, MIGRATE_MOVABLE); 1758 __free_pages_core(page, pageblock_order); 1759 return; 1760 } 1761 1762 for (i = 0; i < nr_pages; i++, page++, pfn++) { 1763 if ((pfn & (pageblock_nr_pages - 1)) == 0) 1764 set_pageblock_migratetype(page, MIGRATE_MOVABLE); 1765 __free_pages_core(page, 0); 1766 } 1767 } 1768 1769 /* Completion tracking for deferred_init_memmap() threads */ 1770 static atomic_t pgdat_init_n_undone __initdata; 1771 static __initdata DECLARE_COMPLETION(pgdat_init_all_done_comp); 1772 1773 static inline void __init pgdat_init_report_one_done(void) 1774 { 1775 if (atomic_dec_and_test(&pgdat_init_n_undone)) 1776 complete(&pgdat_init_all_done_comp); 1777 } 1778 1779 /* 1780 * Returns true if page needs to be initialized or freed to buddy allocator. 1781 * 1782 * First we check if pfn is valid on architectures where it is possible to have 1783 * holes within pageblock_nr_pages. On systems where it is not possible, this 1784 * function is optimized out. 1785 * 1786 * Then, we check if a current large page is valid by only checking the validity 1787 * of the head pfn. 1788 */ 1789 static inline bool __init deferred_pfn_valid(unsigned long pfn) 1790 { 1791 if (!(pfn & (pageblock_nr_pages - 1)) && !pfn_valid(pfn)) 1792 return false; 1793 return true; 1794 } 1795 1796 /* 1797 * Free pages to buddy allocator. Try to free aligned pages in 1798 * pageblock_nr_pages sizes. 1799 */ 1800 static void __init deferred_free_pages(unsigned long pfn, 1801 unsigned long end_pfn) 1802 { 1803 unsigned long nr_pgmask = pageblock_nr_pages - 1; 1804 unsigned long nr_free = 0; 1805 1806 for (; pfn < end_pfn; pfn++) { 1807 if (!deferred_pfn_valid(pfn)) { 1808 deferred_free_range(pfn - nr_free, nr_free); 1809 nr_free = 0; 1810 } else if (!(pfn & nr_pgmask)) { 1811 deferred_free_range(pfn - nr_free, nr_free); 1812 nr_free = 1; 1813 } else { 1814 nr_free++; 1815 } 1816 } 1817 /* Free the last block of pages to allocator */ 1818 deferred_free_range(pfn - nr_free, nr_free); 1819 } 1820 1821 /* 1822 * Initialize struct pages. We minimize pfn page lookups and scheduler checks 1823 * by performing it only once every pageblock_nr_pages. 1824 * Return number of pages initialized. 1825 */ 1826 static unsigned long __init deferred_init_pages(struct zone *zone, 1827 unsigned long pfn, 1828 unsigned long end_pfn) 1829 { 1830 unsigned long nr_pgmask = pageblock_nr_pages - 1; 1831 int nid = zone_to_nid(zone); 1832 unsigned long nr_pages = 0; 1833 int zid = zone_idx(zone); 1834 struct page *page = NULL; 1835 1836 for (; pfn < end_pfn; pfn++) { 1837 if (!deferred_pfn_valid(pfn)) { 1838 page = NULL; 1839 continue; 1840 } else if (!page || !(pfn & nr_pgmask)) { 1841 page = pfn_to_page(pfn); 1842 } else { 1843 page++; 1844 } 1845 __init_single_page(page, pfn, zid, nid); 1846 nr_pages++; 1847 } 1848 return (nr_pages); 1849 } 1850 1851 /* 1852 * This function is meant to pre-load the iterator for the zone init. 1853 * Specifically it walks through the ranges until we are caught up to the 1854 * first_init_pfn value and exits there. If we never encounter the value we 1855 * return false indicating there are no valid ranges left. 1856 */ 1857 static bool __init 1858 deferred_init_mem_pfn_range_in_zone(u64 *i, struct zone *zone, 1859 unsigned long *spfn, unsigned long *epfn, 1860 unsigned long first_init_pfn) 1861 { 1862 u64 j; 1863 1864 /* 1865 * Start out by walking through the ranges in this zone that have 1866 * already been initialized. We don't need to do anything with them 1867 * so we just need to flush them out of the system. 1868 */ 1869 for_each_free_mem_pfn_range_in_zone(j, zone, spfn, epfn) { 1870 if (*epfn <= first_init_pfn) 1871 continue; 1872 if (*spfn < first_init_pfn) 1873 *spfn = first_init_pfn; 1874 *i = j; 1875 return true; 1876 } 1877 1878 return false; 1879 } 1880 1881 /* 1882 * Initialize and free pages. We do it in two loops: first we initialize 1883 * struct page, then free to buddy allocator, because while we are 1884 * freeing pages we can access pages that are ahead (computing buddy 1885 * page in __free_one_page()). 1886 * 1887 * In order to try and keep some memory in the cache we have the loop 1888 * broken along max page order boundaries. This way we will not cause 1889 * any issues with the buddy page computation. 1890 */ 1891 static unsigned long __init 1892 deferred_init_maxorder(u64 *i, struct zone *zone, unsigned long *start_pfn, 1893 unsigned long *end_pfn) 1894 { 1895 unsigned long mo_pfn = ALIGN(*start_pfn + 1, MAX_ORDER_NR_PAGES); 1896 unsigned long spfn = *start_pfn, epfn = *end_pfn; 1897 unsigned long nr_pages = 0; 1898 u64 j = *i; 1899 1900 /* First we loop through and initialize the page values */ 1901 for_each_free_mem_pfn_range_in_zone_from(j, zone, start_pfn, end_pfn) { 1902 unsigned long t; 1903 1904 if (mo_pfn <= *start_pfn) 1905 break; 1906 1907 t = min(mo_pfn, *end_pfn); 1908 nr_pages += deferred_init_pages(zone, *start_pfn, t); 1909 1910 if (mo_pfn < *end_pfn) { 1911 *start_pfn = mo_pfn; 1912 break; 1913 } 1914 } 1915 1916 /* Reset values and now loop through freeing pages as needed */ 1917 swap(j, *i); 1918 1919 for_each_free_mem_pfn_range_in_zone_from(j, zone, &spfn, &epfn) { 1920 unsigned long t; 1921 1922 if (mo_pfn <= spfn) 1923 break; 1924 1925 t = min(mo_pfn, epfn); 1926 deferred_free_pages(spfn, t); 1927 1928 if (mo_pfn <= epfn) 1929 break; 1930 } 1931 1932 return nr_pages; 1933 } 1934 1935 static void __init 1936 deferred_init_memmap_chunk(unsigned long start_pfn, unsigned long end_pfn, 1937 void *arg) 1938 { 1939 unsigned long spfn, epfn; 1940 struct zone *zone = arg; 1941 u64 i; 1942 1943 deferred_init_mem_pfn_range_in_zone(&i, zone, &spfn, &epfn, start_pfn); 1944 1945 /* 1946 * Initialize and free pages in MAX_ORDER sized increments so that we 1947 * can avoid introducing any issues with the buddy allocator. 1948 */ 1949 while (spfn < end_pfn) { 1950 deferred_init_maxorder(&i, zone, &spfn, &epfn); 1951 cond_resched(); 1952 } 1953 } 1954 1955 /* An arch may override for more concurrency. */ 1956 __weak int __init 1957 deferred_page_init_max_threads(const struct cpumask *node_cpumask) 1958 { 1959 return 1; 1960 } 1961 1962 /* Initialise remaining memory on a node */ 1963 static int __init deferred_init_memmap(void *data) 1964 { 1965 pg_data_t *pgdat = data; 1966 const struct cpumask *cpumask = cpumask_of_node(pgdat->node_id); 1967 unsigned long spfn = 0, epfn = 0; 1968 unsigned long first_init_pfn, flags; 1969 unsigned long start = jiffies; 1970 struct zone *zone; 1971 int zid, max_threads; 1972 u64 i; 1973 1974 /* Bind memory initialisation thread to a local node if possible */ 1975 if (!cpumask_empty(cpumask)) 1976 set_cpus_allowed_ptr(current, cpumask); 1977 1978 pgdat_resize_lock(pgdat, &flags); 1979 first_init_pfn = pgdat->first_deferred_pfn; 1980 if (first_init_pfn == ULONG_MAX) { 1981 pgdat_resize_unlock(pgdat, &flags); 1982 pgdat_init_report_one_done(); 1983 return 0; 1984 } 1985 1986 /* Sanity check boundaries */ 1987 BUG_ON(pgdat->first_deferred_pfn < pgdat->node_start_pfn); 1988 BUG_ON(pgdat->first_deferred_pfn > pgdat_end_pfn(pgdat)); 1989 pgdat->first_deferred_pfn = ULONG_MAX; 1990 1991 /* 1992 * Once we unlock here, the zone cannot be grown anymore, thus if an 1993 * interrupt thread must allocate this early in boot, zone must be 1994 * pre-grown prior to start of deferred page initialization. 1995 */ 1996 pgdat_resize_unlock(pgdat, &flags); 1997 1998 /* Only the highest zone is deferred so find it */ 1999 for (zid = 0; zid < MAX_NR_ZONES; zid++) { 2000 zone = pgdat->node_zones + zid; 2001 if (first_init_pfn < zone_end_pfn(zone)) 2002 break; 2003 } 2004 2005 /* If the zone is empty somebody else may have cleared out the zone */ 2006 if (!deferred_init_mem_pfn_range_in_zone(&i, zone, &spfn, &epfn, 2007 first_init_pfn)) 2008 goto zone_empty; 2009 2010 max_threads = deferred_page_init_max_threads(cpumask); 2011 2012 while (spfn < epfn) { 2013 unsigned long epfn_align = ALIGN(epfn, PAGES_PER_SECTION); 2014 struct padata_mt_job job = { 2015 .thread_fn = deferred_init_memmap_chunk, 2016 .fn_arg = zone, 2017 .start = spfn, 2018 .size = epfn_align - spfn, 2019 .align = PAGES_PER_SECTION, 2020 .min_chunk = PAGES_PER_SECTION, 2021 .max_threads = max_threads, 2022 }; 2023 2024 padata_do_multithreaded(&job); 2025 deferred_init_mem_pfn_range_in_zone(&i, zone, &spfn, &epfn, 2026 epfn_align); 2027 } 2028 zone_empty: 2029 /* Sanity check that the next zone really is unpopulated */ 2030 WARN_ON(++zid < MAX_NR_ZONES && populated_zone(++zone)); 2031 2032 pr_info("node %d deferred pages initialised in %ums\n", 2033 pgdat->node_id, jiffies_to_msecs(jiffies - start)); 2034 2035 pgdat_init_report_one_done(); 2036 return 0; 2037 } 2038 2039 /* 2040 * If this zone has deferred pages, try to grow it by initializing enough 2041 * deferred pages to satisfy the allocation specified by order, rounded up to 2042 * the nearest PAGES_PER_SECTION boundary. So we're adding memory in increments 2043 * of SECTION_SIZE bytes by initializing struct pages in increments of 2044 * PAGES_PER_SECTION * sizeof(struct page) bytes. 2045 * 2046 * Return true when zone was grown, otherwise return false. We return true even 2047 * when we grow less than requested, to let the caller decide if there are 2048 * enough pages to satisfy the allocation. 2049 * 2050 * Note: We use noinline because this function is needed only during boot, and 2051 * it is called from a __ref function _deferred_grow_zone. This way we are 2052 * making sure that it is not inlined into permanent text section. 2053 */ 2054 static noinline bool __init 2055 deferred_grow_zone(struct zone *zone, unsigned int order) 2056 { 2057 unsigned long nr_pages_needed = ALIGN(1 << order, PAGES_PER_SECTION); 2058 pg_data_t *pgdat = zone->zone_pgdat; 2059 unsigned long first_deferred_pfn = pgdat->first_deferred_pfn; 2060 unsigned long spfn, epfn, flags; 2061 unsigned long nr_pages = 0; 2062 u64 i; 2063 2064 /* Only the last zone may have deferred pages */ 2065 if (zone_end_pfn(zone) != pgdat_end_pfn(pgdat)) 2066 return false; 2067 2068 pgdat_resize_lock(pgdat, &flags); 2069 2070 /* 2071 * If someone grew this zone while we were waiting for spinlock, return 2072 * true, as there might be enough pages already. 2073 */ 2074 if (first_deferred_pfn != pgdat->first_deferred_pfn) { 2075 pgdat_resize_unlock(pgdat, &flags); 2076 return true; 2077 } 2078 2079 /* If the zone is empty somebody else may have cleared out the zone */ 2080 if (!deferred_init_mem_pfn_range_in_zone(&i, zone, &spfn, &epfn, 2081 first_deferred_pfn)) { 2082 pgdat->first_deferred_pfn = ULONG_MAX; 2083 pgdat_resize_unlock(pgdat, &flags); 2084 /* Retry only once. */ 2085 return first_deferred_pfn != ULONG_MAX; 2086 } 2087 2088 /* 2089 * Initialize and free pages in MAX_ORDER sized increments so 2090 * that we can avoid introducing any issues with the buddy 2091 * allocator. 2092 */ 2093 while (spfn < epfn) { 2094 /* update our first deferred PFN for this section */ 2095 first_deferred_pfn = spfn; 2096 2097 nr_pages += deferred_init_maxorder(&i, zone, &spfn, &epfn); 2098 touch_nmi_watchdog(); 2099 2100 /* We should only stop along section boundaries */ 2101 if ((first_deferred_pfn ^ spfn) < PAGES_PER_SECTION) 2102 continue; 2103 2104 /* If our quota has been met we can stop here */ 2105 if (nr_pages >= nr_pages_needed) 2106 break; 2107 } 2108 2109 pgdat->first_deferred_pfn = spfn; 2110 pgdat_resize_unlock(pgdat, &flags); 2111 2112 return nr_pages > 0; 2113 } 2114 2115 /* 2116 * deferred_grow_zone() is __init, but it is called from 2117 * get_page_from_freelist() during early boot until deferred_pages permanently 2118 * disables this call. This is why we have refdata wrapper to avoid warning, 2119 * and to ensure that the function body gets unloaded. 2120 */ 2121 static bool __ref 2122 _deferred_grow_zone(struct zone *zone, unsigned int order) 2123 { 2124 return deferred_grow_zone(zone, order); 2125 } 2126 2127 #endif /* CONFIG_DEFERRED_STRUCT_PAGE_INIT */ 2128 2129 void __init page_alloc_init_late(void) 2130 { 2131 struct zone *zone; 2132 int nid; 2133 2134 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 2135 2136 /* There will be num_node_state(N_MEMORY) threads */ 2137 atomic_set(&pgdat_init_n_undone, num_node_state(N_MEMORY)); 2138 for_each_node_state(nid, N_MEMORY) { 2139 kthread_run(deferred_init_memmap, NODE_DATA(nid), "pgdatinit%d", nid); 2140 } 2141 2142 /* Block until all are initialised */ 2143 wait_for_completion(&pgdat_init_all_done_comp); 2144 2145 /* 2146 * We initialized the rest of the deferred pages. Permanently disable 2147 * on-demand struct page initialization. 2148 */ 2149 static_branch_disable(&deferred_pages); 2150 2151 /* Reinit limits that are based on free pages after the kernel is up */ 2152 files_maxfiles_init(); 2153 #endif 2154 2155 buffer_init(); 2156 2157 /* Discard memblock private memory */ 2158 memblock_discard(); 2159 2160 for_each_node_state(nid, N_MEMORY) 2161 shuffle_free_memory(NODE_DATA(nid)); 2162 2163 for_each_populated_zone(zone) 2164 set_zone_contiguous(zone); 2165 } 2166 2167 #ifdef CONFIG_CMA 2168 /* Free whole pageblock and set its migration type to MIGRATE_CMA. */ 2169 void __init init_cma_reserved_pageblock(struct page *page) 2170 { 2171 unsigned i = pageblock_nr_pages; 2172 struct page *p = page; 2173 2174 do { 2175 __ClearPageReserved(p); 2176 set_page_count(p, 0); 2177 } while (++p, --i); 2178 2179 set_pageblock_migratetype(page, MIGRATE_CMA); 2180 set_page_refcounted(page); 2181 __free_pages(page, pageblock_order); 2182 2183 adjust_managed_page_count(page, pageblock_nr_pages); 2184 page_zone(page)->cma_pages += pageblock_nr_pages; 2185 } 2186 #endif 2187 2188 /* 2189 * The order of subdivision here is critical for the IO subsystem. 2190 * Please do not alter this order without good reasons and regression 2191 * testing. Specifically, as large blocks of memory are subdivided, 2192 * the order in which smaller blocks are delivered depends on the order 2193 * they're subdivided in this function. This is the primary factor 2194 * influencing the order in which pages are delivered to the IO 2195 * subsystem according to empirical testing, and this is also justified 2196 * by considering the behavior of a buddy system containing a single 2197 * large block of memory acted on by a series of small allocations. 2198 * This behavior is a critical factor in sglist merging's success. 2199 * 2200 * -- nyc 2201 */ 2202 static inline void expand(struct zone *zone, struct page *page, 2203 int low, int high, int migratetype) 2204 { 2205 unsigned long size = 1 << high; 2206 2207 while (high > low) { 2208 high--; 2209 size >>= 1; 2210 VM_BUG_ON_PAGE(bad_range(zone, &page[size]), &page[size]); 2211 2212 /* 2213 * Mark as guard pages (or page), that will allow to 2214 * merge back to allocator when buddy will be freed. 2215 * Corresponding page table entries will not be touched, 2216 * pages will stay not present in virtual address space 2217 */ 2218 if (set_page_guard(zone, &page[size], high, migratetype)) 2219 continue; 2220 2221 add_to_free_list(&page[size], zone, high, migratetype); 2222 set_buddy_order(&page[size], high); 2223 } 2224 } 2225 2226 static void check_new_page_bad(struct page *page) 2227 { 2228 if (unlikely(page->flags & __PG_HWPOISON)) { 2229 /* Don't complain about hwpoisoned pages */ 2230 page_mapcount_reset(page); /* remove PageBuddy */ 2231 return; 2232 } 2233 2234 bad_page(page, 2235 page_bad_reason(page, PAGE_FLAGS_CHECK_AT_PREP)); 2236 } 2237 2238 /* 2239 * This page is about to be returned from the page allocator 2240 */ 2241 static inline int check_new_page(struct page *page) 2242 { 2243 if (likely(page_expected_state(page, 2244 PAGE_FLAGS_CHECK_AT_PREP|__PG_HWPOISON))) 2245 return 0; 2246 2247 check_new_page_bad(page); 2248 return 1; 2249 } 2250 2251 static bool check_new_pages(struct page *page, unsigned int order) 2252 { 2253 int i; 2254 for (i = 0; i < (1 << order); i++) { 2255 struct page *p = page + i; 2256 2257 if (unlikely(check_new_page(p))) 2258 return true; 2259 } 2260 2261 return false; 2262 } 2263 2264 #ifdef CONFIG_DEBUG_VM 2265 /* 2266 * With DEBUG_VM enabled, order-0 pages are checked for expected state when 2267 * being allocated from pcp lists. With debug_pagealloc also enabled, they are 2268 * also checked when pcp lists are refilled from the free lists. 2269 */ 2270 static inline bool check_pcp_refill(struct page *page, unsigned int order) 2271 { 2272 if (debug_pagealloc_enabled_static()) 2273 return check_new_pages(page, order); 2274 else 2275 return false; 2276 } 2277 2278 static inline bool check_new_pcp(struct page *page, unsigned int order) 2279 { 2280 return check_new_pages(page, order); 2281 } 2282 #else 2283 /* 2284 * With DEBUG_VM disabled, free order-0 pages are checked for expected state 2285 * when pcp lists are being refilled from the free lists. With debug_pagealloc 2286 * enabled, they are also checked when being allocated from the pcp lists. 2287 */ 2288 static inline bool check_pcp_refill(struct page *page, unsigned int order) 2289 { 2290 return check_new_pages(page, order); 2291 } 2292 static inline bool check_new_pcp(struct page *page, unsigned int order) 2293 { 2294 if (debug_pagealloc_enabled_static()) 2295 return check_new_pages(page, order); 2296 else 2297 return false; 2298 } 2299 #endif /* CONFIG_DEBUG_VM */ 2300 2301 static inline bool should_skip_kasan_unpoison(gfp_t flags, bool init_tags) 2302 { 2303 /* Don't skip if a software KASAN mode is enabled. */ 2304 if (IS_ENABLED(CONFIG_KASAN_GENERIC) || 2305 IS_ENABLED(CONFIG_KASAN_SW_TAGS)) 2306 return false; 2307 2308 /* Skip, if hardware tag-based KASAN is not enabled. */ 2309 if (!kasan_hw_tags_enabled()) 2310 return true; 2311 2312 /* 2313 * With hardware tag-based KASAN enabled, skip if either: 2314 * 2315 * 1. Memory tags have already been cleared via tag_clear_highpage(). 2316 * 2. Skipping has been requested via __GFP_SKIP_KASAN_UNPOISON. 2317 */ 2318 return init_tags || (flags & __GFP_SKIP_KASAN_UNPOISON); 2319 } 2320 2321 static inline bool should_skip_init(gfp_t flags) 2322 { 2323 /* Don't skip, if hardware tag-based KASAN is not enabled. */ 2324 if (!kasan_hw_tags_enabled()) 2325 return false; 2326 2327 /* For hardware tag-based KASAN, skip if requested. */ 2328 return (flags & __GFP_SKIP_ZERO); 2329 } 2330 2331 inline void post_alloc_hook(struct page *page, unsigned int order, 2332 gfp_t gfp_flags) 2333 { 2334 bool init = !want_init_on_free() && want_init_on_alloc(gfp_flags) && 2335 !should_skip_init(gfp_flags); 2336 bool init_tags = init && (gfp_flags & __GFP_ZEROTAGS); 2337 2338 set_page_private(page, 0); 2339 set_page_refcounted(page); 2340 2341 arch_alloc_page(page, order); 2342 debug_pagealloc_map_pages(page, 1 << order); 2343 2344 /* 2345 * Page unpoisoning must happen before memory initialization. 2346 * Otherwise, the poison pattern will be overwritten for __GFP_ZERO 2347 * allocations and the page unpoisoning code will complain. 2348 */ 2349 kernel_unpoison_pages(page, 1 << order); 2350 2351 /* 2352 * As memory initialization might be integrated into KASAN, 2353 * KASAN unpoisoning and memory initializion code must be 2354 * kept together to avoid discrepancies in behavior. 2355 */ 2356 2357 /* 2358 * If memory tags should be zeroed (which happens only when memory 2359 * should be initialized as well). 2360 */ 2361 if (init_tags) { 2362 int i; 2363 2364 /* Initialize both memory and tags. */ 2365 for (i = 0; i != 1 << order; ++i) 2366 tag_clear_highpage(page + i); 2367 2368 /* Note that memory is already initialized by the loop above. */ 2369 init = false; 2370 } 2371 if (!should_skip_kasan_unpoison(gfp_flags, init_tags)) { 2372 /* Unpoison shadow memory or set memory tags. */ 2373 kasan_unpoison_pages(page, order, init); 2374 2375 /* Note that memory is already initialized by KASAN. */ 2376 if (kasan_has_integrated_init()) 2377 init = false; 2378 } 2379 /* If memory is still not initialized, do it now. */ 2380 if (init) 2381 kernel_init_free_pages(page, 1 << order); 2382 /* Propagate __GFP_SKIP_KASAN_POISON to page flags. */ 2383 if (kasan_hw_tags_enabled() && (gfp_flags & __GFP_SKIP_KASAN_POISON)) 2384 SetPageSkipKASanPoison(page); 2385 2386 set_page_owner(page, order, gfp_flags); 2387 page_table_check_alloc(page, order); 2388 } 2389 2390 static void prep_new_page(struct page *page, unsigned int order, gfp_t gfp_flags, 2391 unsigned int alloc_flags) 2392 { 2393 post_alloc_hook(page, order, gfp_flags); 2394 2395 if (order && (gfp_flags & __GFP_COMP)) 2396 prep_compound_page(page, order); 2397 2398 /* 2399 * page is set pfmemalloc when ALLOC_NO_WATERMARKS was necessary to 2400 * allocate the page. The expectation is that the caller is taking 2401 * steps that will free more memory. The caller should avoid the page 2402 * being used for !PFMEMALLOC purposes. 2403 */ 2404 if (alloc_flags & ALLOC_NO_WATERMARKS) 2405 set_page_pfmemalloc(page); 2406 else 2407 clear_page_pfmemalloc(page); 2408 } 2409 2410 /* 2411 * Go through the free lists for the given migratetype and remove 2412 * the smallest available page from the freelists 2413 */ 2414 static __always_inline 2415 struct page *__rmqueue_smallest(struct zone *zone, unsigned int order, 2416 int migratetype) 2417 { 2418 unsigned int current_order; 2419 struct free_area *area; 2420 struct page *page; 2421 2422 /* Find a page of the appropriate size in the preferred list */ 2423 for (current_order = order; current_order < MAX_ORDER; ++current_order) { 2424 area = &(zone->free_area[current_order]); 2425 page = get_page_from_free_area(area, migratetype); 2426 if (!page) 2427 continue; 2428 del_page_from_free_list(page, zone, current_order); 2429 expand(zone, page, order, current_order, migratetype); 2430 set_pcppage_migratetype(page, migratetype); 2431 return page; 2432 } 2433 2434 return NULL; 2435 } 2436 2437 2438 /* 2439 * This array describes the order lists are fallen back to when 2440 * the free lists for the desirable migrate type are depleted 2441 * 2442 * The other migratetypes do not have fallbacks. 2443 */ 2444 static int fallbacks[MIGRATE_TYPES][3] = { 2445 [MIGRATE_UNMOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_MOVABLE, MIGRATE_TYPES }, 2446 [MIGRATE_MOVABLE] = { MIGRATE_RECLAIMABLE, MIGRATE_UNMOVABLE, MIGRATE_TYPES }, 2447 [MIGRATE_RECLAIMABLE] = { MIGRATE_UNMOVABLE, MIGRATE_MOVABLE, MIGRATE_TYPES }, 2448 }; 2449 2450 #ifdef CONFIG_CMA 2451 static __always_inline struct page *__rmqueue_cma_fallback(struct zone *zone, 2452 unsigned int order) 2453 { 2454 return __rmqueue_smallest(zone, order, MIGRATE_CMA); 2455 } 2456 #else 2457 static inline struct page *__rmqueue_cma_fallback(struct zone *zone, 2458 unsigned int order) { return NULL; } 2459 #endif 2460 2461 /* 2462 * Move the free pages in a range to the freelist tail of the requested type. 2463 * Note that start_page and end_pages are not aligned on a pageblock 2464 * boundary. If alignment is required, use move_freepages_block() 2465 */ 2466 static int move_freepages(struct zone *zone, 2467 unsigned long start_pfn, unsigned long end_pfn, 2468 int migratetype, int *num_movable) 2469 { 2470 struct page *page; 2471 unsigned long pfn; 2472 unsigned int order; 2473 int pages_moved = 0; 2474 2475 for (pfn = start_pfn; pfn <= end_pfn;) { 2476 page = pfn_to_page(pfn); 2477 if (!PageBuddy(page)) { 2478 /* 2479 * We assume that pages that could be isolated for 2480 * migration are movable. But we don't actually try 2481 * isolating, as that would be expensive. 2482 */ 2483 if (num_movable && 2484 (PageLRU(page) || __PageMovable(page))) 2485 (*num_movable)++; 2486 pfn++; 2487 continue; 2488 } 2489 2490 /* Make sure we are not inadvertently changing nodes */ 2491 VM_BUG_ON_PAGE(page_to_nid(page) != zone_to_nid(zone), page); 2492 VM_BUG_ON_PAGE(page_zone(page) != zone, page); 2493 2494 order = buddy_order(page); 2495 move_to_free_list(page, zone, order, migratetype); 2496 pfn += 1 << order; 2497 pages_moved += 1 << order; 2498 } 2499 2500 return pages_moved; 2501 } 2502 2503 int move_freepages_block(struct zone *zone, struct page *page, 2504 int migratetype, int *num_movable) 2505 { 2506 unsigned long start_pfn, end_pfn, pfn; 2507 2508 if (num_movable) 2509 *num_movable = 0; 2510 2511 pfn = page_to_pfn(page); 2512 start_pfn = pfn & ~(pageblock_nr_pages - 1); 2513 end_pfn = start_pfn + pageblock_nr_pages - 1; 2514 2515 /* Do not cross zone boundaries */ 2516 if (!zone_spans_pfn(zone, start_pfn)) 2517 start_pfn = pfn; 2518 if (!zone_spans_pfn(zone, end_pfn)) 2519 return 0; 2520 2521 return move_freepages(zone, start_pfn, end_pfn, migratetype, 2522 num_movable); 2523 } 2524 2525 static void change_pageblock_range(struct page *pageblock_page, 2526 int start_order, int migratetype) 2527 { 2528 int nr_pageblocks = 1 << (start_order - pageblock_order); 2529 2530 while (nr_pageblocks--) { 2531 set_pageblock_migratetype(pageblock_page, migratetype); 2532 pageblock_page += pageblock_nr_pages; 2533 } 2534 } 2535 2536 /* 2537 * When we are falling back to another migratetype during allocation, try to 2538 * steal extra free pages from the same pageblocks to satisfy further 2539 * allocations, instead of polluting multiple pageblocks. 2540 * 2541 * If we are stealing a relatively large buddy page, it is likely there will 2542 * be more free pages in the pageblock, so try to steal them all. For 2543 * reclaimable and unmovable allocations, we steal regardless of page size, 2544 * as fragmentation caused by those allocations polluting movable pageblocks 2545 * is worse than movable allocations stealing from unmovable and reclaimable 2546 * pageblocks. 2547 */ 2548 static bool can_steal_fallback(unsigned int order, int start_mt) 2549 { 2550 /* 2551 * Leaving this order check is intended, although there is 2552 * relaxed order check in next check. The reason is that 2553 * we can actually steal whole pageblock if this condition met, 2554 * but, below check doesn't guarantee it and that is just heuristic 2555 * so could be changed anytime. 2556 */ 2557 if (order >= pageblock_order) 2558 return true; 2559 2560 if (order >= pageblock_order / 2 || 2561 start_mt == MIGRATE_RECLAIMABLE || 2562 start_mt == MIGRATE_UNMOVABLE || 2563 page_group_by_mobility_disabled) 2564 return true; 2565 2566 return false; 2567 } 2568 2569 static inline bool boost_watermark(struct zone *zone) 2570 { 2571 unsigned long max_boost; 2572 2573 if (!watermark_boost_factor) 2574 return false; 2575 /* 2576 * Don't bother in zones that are unlikely to produce results. 2577 * On small machines, including kdump capture kernels running 2578 * in a small area, boosting the watermark can cause an out of 2579 * memory situation immediately. 2580 */ 2581 if ((pageblock_nr_pages * 4) > zone_managed_pages(zone)) 2582 return false; 2583 2584 max_boost = mult_frac(zone->_watermark[WMARK_HIGH], 2585 watermark_boost_factor, 10000); 2586 2587 /* 2588 * high watermark may be uninitialised if fragmentation occurs 2589 * very early in boot so do not boost. We do not fall 2590 * through and boost by pageblock_nr_pages as failing 2591 * allocations that early means that reclaim is not going 2592 * to help and it may even be impossible to reclaim the 2593 * boosted watermark resulting in a hang. 2594 */ 2595 if (!max_boost) 2596 return false; 2597 2598 max_boost = max(pageblock_nr_pages, max_boost); 2599 2600 zone->watermark_boost = min(zone->watermark_boost + pageblock_nr_pages, 2601 max_boost); 2602 2603 return true; 2604 } 2605 2606 /* 2607 * This function implements actual steal behaviour. If order is large enough, 2608 * we can steal whole pageblock. If not, we first move freepages in this 2609 * pageblock to our migratetype and determine how many already-allocated pages 2610 * are there in the pageblock with a compatible migratetype. If at least half 2611 * of pages are free or compatible, we can change migratetype of the pageblock 2612 * itself, so pages freed in the future will be put on the correct free list. 2613 */ 2614 static void steal_suitable_fallback(struct zone *zone, struct page *page, 2615 unsigned int alloc_flags, int start_type, bool whole_block) 2616 { 2617 unsigned int current_order = buddy_order(page); 2618 int free_pages, movable_pages, alike_pages; 2619 int old_block_type; 2620 2621 old_block_type = get_pageblock_migratetype(page); 2622 2623 /* 2624 * This can happen due to races and we want to prevent broken 2625 * highatomic accounting. 2626 */ 2627 if (is_migrate_highatomic(old_block_type)) 2628 goto single_page; 2629 2630 /* Take ownership for orders >= pageblock_order */ 2631 if (current_order >= pageblock_order) { 2632 change_pageblock_range(page, current_order, start_type); 2633 goto single_page; 2634 } 2635 2636 /* 2637 * Boost watermarks to increase reclaim pressure to reduce the 2638 * likelihood of future fallbacks. Wake kswapd now as the node 2639 * may be balanced overall and kswapd will not wake naturally. 2640 */ 2641 if (boost_watermark(zone) && (alloc_flags & ALLOC_KSWAPD)) 2642 set_bit(ZONE_BOOSTED_WATERMARK, &zone->flags); 2643 2644 /* We are not allowed to try stealing from the whole block */ 2645 if (!whole_block) 2646 goto single_page; 2647 2648 free_pages = move_freepages_block(zone, page, start_type, 2649 &movable_pages); 2650 /* 2651 * Determine how many pages are compatible with our allocation. 2652 * For movable allocation, it's the number of movable pages which 2653 * we just obtained. For other types it's a bit more tricky. 2654 */ 2655 if (start_type == MIGRATE_MOVABLE) { 2656 alike_pages = movable_pages; 2657 } else { 2658 /* 2659 * If we are falling back a RECLAIMABLE or UNMOVABLE allocation 2660 * to MOVABLE pageblock, consider all non-movable pages as 2661 * compatible. If it's UNMOVABLE falling back to RECLAIMABLE or 2662 * vice versa, be conservative since we can't distinguish the 2663 * exact migratetype of non-movable pages. 2664 */ 2665 if (old_block_type == MIGRATE_MOVABLE) 2666 alike_pages = pageblock_nr_pages 2667 - (free_pages + movable_pages); 2668 else 2669 alike_pages = 0; 2670 } 2671 2672 /* moving whole block can fail due to zone boundary conditions */ 2673 if (!free_pages) 2674 goto single_page; 2675 2676 /* 2677 * If a sufficient number of pages in the block are either free or of 2678 * comparable migratability as our allocation, claim the whole block. 2679 */ 2680 if (free_pages + alike_pages >= (1 << (pageblock_order-1)) || 2681 page_group_by_mobility_disabled) 2682 set_pageblock_migratetype(page, start_type); 2683 2684 return; 2685 2686 single_page: 2687 move_to_free_list(page, zone, current_order, start_type); 2688 } 2689 2690 /* 2691 * Check whether there is a suitable fallback freepage with requested order. 2692 * If only_stealable is true, this function returns fallback_mt only if 2693 * we can steal other freepages all together. This would help to reduce 2694 * fragmentation due to mixed migratetype pages in one pageblock. 2695 */ 2696 int find_suitable_fallback(struct free_area *area, unsigned int order, 2697 int migratetype, bool only_stealable, bool *can_steal) 2698 { 2699 int i; 2700 int fallback_mt; 2701 2702 if (area->nr_free == 0) 2703 return -1; 2704 2705 *can_steal = false; 2706 for (i = 0;; i++) { 2707 fallback_mt = fallbacks[migratetype][i]; 2708 if (fallback_mt == MIGRATE_TYPES) 2709 break; 2710 2711 if (free_area_empty(area, fallback_mt)) 2712 continue; 2713 2714 if (can_steal_fallback(order, migratetype)) 2715 *can_steal = true; 2716 2717 if (!only_stealable) 2718 return fallback_mt; 2719 2720 if (*can_steal) 2721 return fallback_mt; 2722 } 2723 2724 return -1; 2725 } 2726 2727 /* 2728 * Reserve a pageblock for exclusive use of high-order atomic allocations if 2729 * there are no empty page blocks that contain a page with a suitable order 2730 */ 2731 static void reserve_highatomic_pageblock(struct page *page, struct zone *zone, 2732 unsigned int alloc_order) 2733 { 2734 int mt; 2735 unsigned long max_managed, flags; 2736 2737 /* 2738 * Limit the number reserved to 1 pageblock or roughly 1% of a zone. 2739 * Check is race-prone but harmless. 2740 */ 2741 max_managed = (zone_managed_pages(zone) / 100) + pageblock_nr_pages; 2742 if (zone->nr_reserved_highatomic >= max_managed) 2743 return; 2744 2745 spin_lock_irqsave(&zone->lock, flags); 2746 2747 /* Recheck the nr_reserved_highatomic limit under the lock */ 2748 if (zone->nr_reserved_highatomic >= max_managed) 2749 goto out_unlock; 2750 2751 /* Yoink! */ 2752 mt = get_pageblock_migratetype(page); 2753 /* Only reserve normal pageblocks (i.e., they can merge with others) */ 2754 if (migratetype_is_mergeable(mt)) { 2755 zone->nr_reserved_highatomic += pageblock_nr_pages; 2756 set_pageblock_migratetype(page, MIGRATE_HIGHATOMIC); 2757 move_freepages_block(zone, page, MIGRATE_HIGHATOMIC, NULL); 2758 } 2759 2760 out_unlock: 2761 spin_unlock_irqrestore(&zone->lock, flags); 2762 } 2763 2764 /* 2765 * Used when an allocation is about to fail under memory pressure. This 2766 * potentially hurts the reliability of high-order allocations when under 2767 * intense memory pressure but failed atomic allocations should be easier 2768 * to recover from than an OOM. 2769 * 2770 * If @force is true, try to unreserve a pageblock even though highatomic 2771 * pageblock is exhausted. 2772 */ 2773 static bool unreserve_highatomic_pageblock(const struct alloc_context *ac, 2774 bool force) 2775 { 2776 struct zonelist *zonelist = ac->zonelist; 2777 unsigned long flags; 2778 struct zoneref *z; 2779 struct zone *zone; 2780 struct page *page; 2781 int order; 2782 bool ret; 2783 2784 for_each_zone_zonelist_nodemask(zone, z, zonelist, ac->highest_zoneidx, 2785 ac->nodemask) { 2786 /* 2787 * Preserve at least one pageblock unless memory pressure 2788 * is really high. 2789 */ 2790 if (!force && zone->nr_reserved_highatomic <= 2791 pageblock_nr_pages) 2792 continue; 2793 2794 spin_lock_irqsave(&zone->lock, flags); 2795 for (order = 0; order < MAX_ORDER; order++) { 2796 struct free_area *area = &(zone->free_area[order]); 2797 2798 page = get_page_from_free_area(area, MIGRATE_HIGHATOMIC); 2799 if (!page) 2800 continue; 2801 2802 /* 2803 * In page freeing path, migratetype change is racy so 2804 * we can counter several free pages in a pageblock 2805 * in this loop although we changed the pageblock type 2806 * from highatomic to ac->migratetype. So we should 2807 * adjust the count once. 2808 */ 2809 if (is_migrate_highatomic_page(page)) { 2810 /* 2811 * It should never happen but changes to 2812 * locking could inadvertently allow a per-cpu 2813 * drain to add pages to MIGRATE_HIGHATOMIC 2814 * while unreserving so be safe and watch for 2815 * underflows. 2816 */ 2817 zone->nr_reserved_highatomic -= min( 2818 pageblock_nr_pages, 2819 zone->nr_reserved_highatomic); 2820 } 2821 2822 /* 2823 * Convert to ac->migratetype and avoid the normal 2824 * pageblock stealing heuristics. Minimally, the caller 2825 * is doing the work and needs the pages. More 2826 * importantly, if the block was always converted to 2827 * MIGRATE_UNMOVABLE or another type then the number 2828 * of pageblocks that cannot be completely freed 2829 * may increase. 2830 */ 2831 set_pageblock_migratetype(page, ac->migratetype); 2832 ret = move_freepages_block(zone, page, ac->migratetype, 2833 NULL); 2834 if (ret) { 2835 spin_unlock_irqrestore(&zone->lock, flags); 2836 return ret; 2837 } 2838 } 2839 spin_unlock_irqrestore(&zone->lock, flags); 2840 } 2841 2842 return false; 2843 } 2844 2845 /* 2846 * Try finding a free buddy page on the fallback list and put it on the free 2847 * list of requested migratetype, possibly along with other pages from the same 2848 * block, depending on fragmentation avoidance heuristics. Returns true if 2849 * fallback was found so that __rmqueue_smallest() can grab it. 2850 * 2851 * The use of signed ints for order and current_order is a deliberate 2852 * deviation from the rest of this file, to make the for loop 2853 * condition simpler. 2854 */ 2855 static __always_inline bool 2856 __rmqueue_fallback(struct zone *zone, int order, int start_migratetype, 2857 unsigned int alloc_flags) 2858 { 2859 struct free_area *area; 2860 int current_order; 2861 int min_order = order; 2862 struct page *page; 2863 int fallback_mt; 2864 bool can_steal; 2865 2866 /* 2867 * Do not steal pages from freelists belonging to other pageblocks 2868 * i.e. orders < pageblock_order. If there are no local zones free, 2869 * the zonelists will be reiterated without ALLOC_NOFRAGMENT. 2870 */ 2871 if (alloc_flags & ALLOC_NOFRAGMENT) 2872 min_order = pageblock_order; 2873 2874 /* 2875 * Find the largest available free page in the other list. This roughly 2876 * approximates finding the pageblock with the most free pages, which 2877 * would be too costly to do exactly. 2878 */ 2879 for (current_order = MAX_ORDER - 1; current_order >= min_order; 2880 --current_order) { 2881 area = &(zone->free_area[current_order]); 2882 fallback_mt = find_suitable_fallback(area, current_order, 2883 start_migratetype, false, &can_steal); 2884 if (fallback_mt == -1) 2885 continue; 2886 2887 /* 2888 * We cannot steal all free pages from the pageblock and the 2889 * requested migratetype is movable. In that case it's better to 2890 * steal and split the smallest available page instead of the 2891 * largest available page, because even if the next movable 2892 * allocation falls back into a different pageblock than this 2893 * one, it won't cause permanent fragmentation. 2894 */ 2895 if (!can_steal && start_migratetype == MIGRATE_MOVABLE 2896 && current_order > order) 2897 goto find_smallest; 2898 2899 goto do_steal; 2900 } 2901 2902 return false; 2903 2904 find_smallest: 2905 for (current_order = order; current_order < MAX_ORDER; 2906 current_order++) { 2907 area = &(zone->free_area[current_order]); 2908 fallback_mt = find_suitable_fallback(area, current_order, 2909 start_migratetype, false, &can_steal); 2910 if (fallback_mt != -1) 2911 break; 2912 } 2913 2914 /* 2915 * This should not happen - we already found a suitable fallback 2916 * when looking for the largest page. 2917 */ 2918 VM_BUG_ON(current_order == MAX_ORDER); 2919 2920 do_steal: 2921 page = get_page_from_free_area(area, fallback_mt); 2922 2923 steal_suitable_fallback(zone, page, alloc_flags, start_migratetype, 2924 can_steal); 2925 2926 trace_mm_page_alloc_extfrag(page, order, current_order, 2927 start_migratetype, fallback_mt); 2928 2929 return true; 2930 2931 } 2932 2933 /* 2934 * Do the hard work of removing an element from the buddy allocator. 2935 * Call me with the zone->lock already held. 2936 */ 2937 static __always_inline struct page * 2938 __rmqueue(struct zone *zone, unsigned int order, int migratetype, 2939 unsigned int alloc_flags) 2940 { 2941 struct page *page; 2942 2943 if (IS_ENABLED(CONFIG_CMA)) { 2944 /* 2945 * Balance movable allocations between regular and CMA areas by 2946 * allocating from CMA when over half of the zone's free memory 2947 * is in the CMA area. 2948 */ 2949 if (alloc_flags & ALLOC_CMA && 2950 zone_page_state(zone, NR_FREE_CMA_PAGES) > 2951 zone_page_state(zone, NR_FREE_PAGES) / 2) { 2952 page = __rmqueue_cma_fallback(zone, order); 2953 if (page) 2954 goto out; 2955 } 2956 } 2957 retry: 2958 page = __rmqueue_smallest(zone, order, migratetype); 2959 if (unlikely(!page)) { 2960 if (alloc_flags & ALLOC_CMA) 2961 page = __rmqueue_cma_fallback(zone, order); 2962 2963 if (!page && __rmqueue_fallback(zone, order, migratetype, 2964 alloc_flags)) 2965 goto retry; 2966 } 2967 out: 2968 if (page) 2969 trace_mm_page_alloc_zone_locked(page, order, migratetype); 2970 return page; 2971 } 2972 2973 /* 2974 * Obtain a specified number of elements from the buddy allocator, all under 2975 * a single hold of the lock, for efficiency. Add them to the supplied list. 2976 * Returns the number of new pages which were placed at *list. 2977 */ 2978 static int rmqueue_bulk(struct zone *zone, unsigned int order, 2979 unsigned long count, struct list_head *list, 2980 int migratetype, unsigned int alloc_flags) 2981 { 2982 int i, allocated = 0; 2983 2984 /* 2985 * local_lock_irq held so equivalent to spin_lock_irqsave for 2986 * both PREEMPT_RT and non-PREEMPT_RT configurations. 2987 */ 2988 spin_lock(&zone->lock); 2989 for (i = 0; i < count; ++i) { 2990 struct page *page = __rmqueue(zone, order, migratetype, 2991 alloc_flags); 2992 if (unlikely(page == NULL)) 2993 break; 2994 2995 if (unlikely(check_pcp_refill(page, order))) 2996 continue; 2997 2998 /* 2999 * Split buddy pages returned by expand() are received here in 3000 * physical page order. The page is added to the tail of 3001 * caller's list. From the callers perspective, the linked list 3002 * is ordered by page number under some conditions. This is 3003 * useful for IO devices that can forward direction from the 3004 * head, thus also in the physical page order. This is useful 3005 * for IO devices that can merge IO requests if the physical 3006 * pages are ordered properly. 3007 */ 3008 list_add_tail(&page->lru, list); 3009 allocated++; 3010 if (is_migrate_cma(get_pcppage_migratetype(page))) 3011 __mod_zone_page_state(zone, NR_FREE_CMA_PAGES, 3012 -(1 << order)); 3013 } 3014 3015 /* 3016 * i pages were removed from the buddy list even if some leak due 3017 * to check_pcp_refill failing so adjust NR_FREE_PAGES based 3018 * on i. Do not confuse with 'allocated' which is the number of 3019 * pages added to the pcp list. 3020 */ 3021 __mod_zone_page_state(zone, NR_FREE_PAGES, -(i << order)); 3022 spin_unlock(&zone->lock); 3023 return allocated; 3024 } 3025 3026 #ifdef CONFIG_NUMA 3027 /* 3028 * Called from the vmstat counter updater to drain pagesets of this 3029 * currently executing processor on remote nodes after they have 3030 * expired. 3031 * 3032 * Note that this function must be called with the thread pinned to 3033 * a single processor. 3034 */ 3035 void drain_zone_pages(struct zone *zone, struct per_cpu_pages *pcp) 3036 { 3037 unsigned long flags; 3038 int to_drain, batch; 3039 3040 local_lock_irqsave(&pagesets.lock, flags); 3041 batch = READ_ONCE(pcp->batch); 3042 to_drain = min(pcp->count, batch); 3043 if (to_drain > 0) 3044 free_pcppages_bulk(zone, to_drain, pcp, 0); 3045 local_unlock_irqrestore(&pagesets.lock, flags); 3046 } 3047 #endif 3048 3049 /* 3050 * Drain pcplists of the indicated processor and zone. 3051 * 3052 * The processor must either be the current processor and the 3053 * thread pinned to the current processor or a processor that 3054 * is not online. 3055 */ 3056 static void drain_pages_zone(unsigned int cpu, struct zone *zone) 3057 { 3058 unsigned long flags; 3059 struct per_cpu_pages *pcp; 3060 3061 local_lock_irqsave(&pagesets.lock, flags); 3062 3063 pcp = per_cpu_ptr(zone->per_cpu_pageset, cpu); 3064 if (pcp->count) 3065 free_pcppages_bulk(zone, pcp->count, pcp, 0); 3066 3067 local_unlock_irqrestore(&pagesets.lock, flags); 3068 } 3069 3070 /* 3071 * Drain pcplists of all zones on the indicated processor. 3072 * 3073 * The processor must either be the current processor and the 3074 * thread pinned to the current processor or a processor that 3075 * is not online. 3076 */ 3077 static void drain_pages(unsigned int cpu) 3078 { 3079 struct zone *zone; 3080 3081 for_each_populated_zone(zone) { 3082 drain_pages_zone(cpu, zone); 3083 } 3084 } 3085 3086 /* 3087 * Spill all of this CPU's per-cpu pages back into the buddy allocator. 3088 * 3089 * The CPU has to be pinned. When zone parameter is non-NULL, spill just 3090 * the single zone's pages. 3091 */ 3092 void drain_local_pages(struct zone *zone) 3093 { 3094 int cpu = smp_processor_id(); 3095 3096 if (zone) 3097 drain_pages_zone(cpu, zone); 3098 else 3099 drain_pages(cpu); 3100 } 3101 3102 static void drain_local_pages_wq(struct work_struct *work) 3103 { 3104 struct pcpu_drain *drain; 3105 3106 drain = container_of(work, struct pcpu_drain, work); 3107 3108 /* 3109 * drain_all_pages doesn't use proper cpu hotplug protection so 3110 * we can race with cpu offline when the WQ can move this from 3111 * a cpu pinned worker to an unbound one. We can operate on a different 3112 * cpu which is alright but we also have to make sure to not move to 3113 * a different one. 3114 */ 3115 migrate_disable(); 3116 drain_local_pages(drain->zone); 3117 migrate_enable(); 3118 } 3119 3120 /* 3121 * The implementation of drain_all_pages(), exposing an extra parameter to 3122 * drain on all cpus. 3123 * 3124 * drain_all_pages() is optimized to only execute on cpus where pcplists are 3125 * not empty. The check for non-emptiness can however race with a free to 3126 * pcplist that has not yet increased the pcp->count from 0 to 1. Callers 3127 * that need the guarantee that every CPU has drained can disable the 3128 * optimizing racy check. 3129 */ 3130 static void __drain_all_pages(struct zone *zone, bool force_all_cpus) 3131 { 3132 int cpu; 3133 3134 /* 3135 * Allocate in the BSS so we won't require allocation in 3136 * direct reclaim path for CONFIG_CPUMASK_OFFSTACK=y 3137 */ 3138 static cpumask_t cpus_with_pcps; 3139 3140 /* 3141 * Make sure nobody triggers this path before mm_percpu_wq is fully 3142 * initialized. 3143 */ 3144 if (WARN_ON_ONCE(!mm_percpu_wq)) 3145 return; 3146 3147 /* 3148 * Do not drain if one is already in progress unless it's specific to 3149 * a zone. Such callers are primarily CMA and memory hotplug and need 3150 * the drain to be complete when the call returns. 3151 */ 3152 if (unlikely(!mutex_trylock(&pcpu_drain_mutex))) { 3153 if (!zone) 3154 return; 3155 mutex_lock(&pcpu_drain_mutex); 3156 } 3157 3158 /* 3159 * We don't care about racing with CPU hotplug event 3160 * as offline notification will cause the notified 3161 * cpu to drain that CPU pcps and on_each_cpu_mask 3162 * disables preemption as part of its processing 3163 */ 3164 for_each_online_cpu(cpu) { 3165 struct per_cpu_pages *pcp; 3166 struct zone *z; 3167 bool has_pcps = false; 3168 3169 if (force_all_cpus) { 3170 /* 3171 * The pcp.count check is racy, some callers need a 3172 * guarantee that no cpu is missed. 3173 */ 3174 has_pcps = true; 3175 } else if (zone) { 3176 pcp = per_cpu_ptr(zone->per_cpu_pageset, cpu); 3177 if (pcp->count) 3178 has_pcps = true; 3179 } else { 3180 for_each_populated_zone(z) { 3181 pcp = per_cpu_ptr(z->per_cpu_pageset, cpu); 3182 if (pcp->count) { 3183 has_pcps = true; 3184 break; 3185 } 3186 } 3187 } 3188 3189 if (has_pcps) 3190 cpumask_set_cpu(cpu, &cpus_with_pcps); 3191 else 3192 cpumask_clear_cpu(cpu, &cpus_with_pcps); 3193 } 3194 3195 for_each_cpu(cpu, &cpus_with_pcps) { 3196 struct pcpu_drain *drain = per_cpu_ptr(&pcpu_drain, cpu); 3197 3198 drain->zone = zone; 3199 INIT_WORK(&drain->work, drain_local_pages_wq); 3200 queue_work_on(cpu, mm_percpu_wq, &drain->work); 3201 } 3202 for_each_cpu(cpu, &cpus_with_pcps) 3203 flush_work(&per_cpu_ptr(&pcpu_drain, cpu)->work); 3204 3205 mutex_unlock(&pcpu_drain_mutex); 3206 } 3207 3208 /* 3209 * Spill all the per-cpu pages from all CPUs back into the buddy allocator. 3210 * 3211 * When zone parameter is non-NULL, spill just the single zone's pages. 3212 * 3213 * Note that this can be extremely slow as the draining happens in a workqueue. 3214 */ 3215 void drain_all_pages(struct zone *zone) 3216 { 3217 __drain_all_pages(zone, false); 3218 } 3219 3220 #ifdef CONFIG_HIBERNATION 3221 3222 /* 3223 * Touch the watchdog for every WD_PAGE_COUNT pages. 3224 */ 3225 #define WD_PAGE_COUNT (128*1024) 3226 3227 void mark_free_pages(struct zone *zone) 3228 { 3229 unsigned long pfn, max_zone_pfn, page_count = WD_PAGE_COUNT; 3230 unsigned long flags; 3231 unsigned int order, t; 3232 struct page *page; 3233 3234 if (zone_is_empty(zone)) 3235 return; 3236 3237 spin_lock_irqsave(&zone->lock, flags); 3238 3239 max_zone_pfn = zone_end_pfn(zone); 3240 for (pfn = zone->zone_start_pfn; pfn < max_zone_pfn; pfn++) 3241 if (pfn_valid(pfn)) { 3242 page = pfn_to_page(pfn); 3243 3244 if (!--page_count) { 3245 touch_nmi_watchdog(); 3246 page_count = WD_PAGE_COUNT; 3247 } 3248 3249 if (page_zone(page) != zone) 3250 continue; 3251 3252 if (!swsusp_page_is_forbidden(page)) 3253 swsusp_unset_page_free(page); 3254 } 3255 3256 for_each_migratetype_order(order, t) { 3257 list_for_each_entry(page, 3258 &zone->free_area[order].free_list[t], lru) { 3259 unsigned long i; 3260 3261 pfn = page_to_pfn(page); 3262 for (i = 0; i < (1UL << order); i++) { 3263 if (!--page_count) { 3264 touch_nmi_watchdog(); 3265 page_count = WD_PAGE_COUNT; 3266 } 3267 swsusp_set_page_free(pfn_to_page(pfn + i)); 3268 } 3269 } 3270 } 3271 spin_unlock_irqrestore(&zone->lock, flags); 3272 } 3273 #endif /* CONFIG_PM */ 3274 3275 static bool free_unref_page_prepare(struct page *page, unsigned long pfn, 3276 unsigned int order) 3277 { 3278 int migratetype; 3279 3280 if (!free_pcp_prepare(page, order)) 3281 return false; 3282 3283 migratetype = get_pfnblock_migratetype(page, pfn); 3284 set_pcppage_migratetype(page, migratetype); 3285 return true; 3286 } 3287 3288 static int nr_pcp_free(struct per_cpu_pages *pcp, int high, int batch, 3289 bool free_high) 3290 { 3291 int min_nr_free, max_nr_free; 3292 3293 /* Free everything if batch freeing high-order pages. */ 3294 if (unlikely(free_high)) 3295 return pcp->count; 3296 3297 /* Check for PCP disabled or boot pageset */ 3298 if (unlikely(high < batch)) 3299 return 1; 3300 3301 /* Leave at least pcp->batch pages on the list */ 3302 min_nr_free = batch; 3303 max_nr_free = high - batch; 3304 3305 /* 3306 * Double the number of pages freed each time there is subsequent 3307 * freeing of pages without any allocation. 3308 */ 3309 batch <<= pcp->free_factor; 3310 if (batch < max_nr_free) 3311 pcp->free_factor++; 3312 batch = clamp(batch, min_nr_free, max_nr_free); 3313 3314 return batch; 3315 } 3316 3317 static int nr_pcp_high(struct per_cpu_pages *pcp, struct zone *zone, 3318 bool free_high) 3319 { 3320 int high = READ_ONCE(pcp->high); 3321 3322 if (unlikely(!high || free_high)) 3323 return 0; 3324 3325 if (!test_bit(ZONE_RECLAIM_ACTIVE, &zone->flags)) 3326 return high; 3327 3328 /* 3329 * If reclaim is active, limit the number of pages that can be 3330 * stored on pcp lists 3331 */ 3332 return min(READ_ONCE(pcp->batch) << 2, high); 3333 } 3334 3335 static void free_unref_page_commit(struct page *page, int migratetype, 3336 unsigned int order) 3337 { 3338 struct zone *zone = page_zone(page); 3339 struct per_cpu_pages *pcp; 3340 int high; 3341 int pindex; 3342 bool free_high; 3343 3344 __count_vm_event(PGFREE); 3345 pcp = this_cpu_ptr(zone->per_cpu_pageset); 3346 pindex = order_to_pindex(migratetype, order); 3347 list_add(&page->lru, &pcp->lists[pindex]); 3348 pcp->count += 1 << order; 3349 3350 /* 3351 * As high-order pages other than THP's stored on PCP can contribute 3352 * to fragmentation, limit the number stored when PCP is heavily 3353 * freeing without allocation. The remainder after bulk freeing 3354 * stops will be drained from vmstat refresh context. 3355 */ 3356 free_high = (pcp->free_factor && order && order <= PAGE_ALLOC_COSTLY_ORDER); 3357 3358 high = nr_pcp_high(pcp, zone, free_high); 3359 if (pcp->count >= high) { 3360 int batch = READ_ONCE(pcp->batch); 3361 3362 free_pcppages_bulk(zone, nr_pcp_free(pcp, high, batch, free_high), pcp, pindex); 3363 } 3364 } 3365 3366 /* 3367 * Free a pcp page 3368 */ 3369 void free_unref_page(struct page *page, unsigned int order) 3370 { 3371 unsigned long flags; 3372 unsigned long pfn = page_to_pfn(page); 3373 int migratetype; 3374 3375 if (!free_unref_page_prepare(page, pfn, order)) 3376 return; 3377 3378 /* 3379 * We only track unmovable, reclaimable and movable on pcp lists. 3380 * Place ISOLATE pages on the isolated list because they are being 3381 * offlined but treat HIGHATOMIC as movable pages so we can get those 3382 * areas back if necessary. Otherwise, we may have to free 3383 * excessively into the page allocator 3384 */ 3385 migratetype = get_pcppage_migratetype(page); 3386 if (unlikely(migratetype >= MIGRATE_PCPTYPES)) { 3387 if (unlikely(is_migrate_isolate(migratetype))) { 3388 free_one_page(page_zone(page), page, pfn, order, migratetype, FPI_NONE); 3389 return; 3390 } 3391 migratetype = MIGRATE_MOVABLE; 3392 } 3393 3394 local_lock_irqsave(&pagesets.lock, flags); 3395 free_unref_page_commit(page, migratetype, order); 3396 local_unlock_irqrestore(&pagesets.lock, flags); 3397 } 3398 3399 /* 3400 * Free a list of 0-order pages 3401 */ 3402 void free_unref_page_list(struct list_head *list) 3403 { 3404 struct page *page, *next; 3405 unsigned long flags; 3406 int batch_count = 0; 3407 int migratetype; 3408 3409 /* Prepare pages for freeing */ 3410 list_for_each_entry_safe(page, next, list, lru) { 3411 unsigned long pfn = page_to_pfn(page); 3412 if (!free_unref_page_prepare(page, pfn, 0)) { 3413 list_del(&page->lru); 3414 continue; 3415 } 3416 3417 /* 3418 * Free isolated pages directly to the allocator, see 3419 * comment in free_unref_page. 3420 */ 3421 migratetype = get_pcppage_migratetype(page); 3422 if (unlikely(is_migrate_isolate(migratetype))) { 3423 list_del(&page->lru); 3424 free_one_page(page_zone(page), page, pfn, 0, migratetype, FPI_NONE); 3425 continue; 3426 } 3427 } 3428 3429 local_lock_irqsave(&pagesets.lock, flags); 3430 list_for_each_entry_safe(page, next, list, lru) { 3431 /* 3432 * Non-isolated types over MIGRATE_PCPTYPES get added 3433 * to the MIGRATE_MOVABLE pcp list. 3434 */ 3435 migratetype = get_pcppage_migratetype(page); 3436 if (unlikely(migratetype >= MIGRATE_PCPTYPES)) 3437 migratetype = MIGRATE_MOVABLE; 3438 3439 trace_mm_page_free_batched(page); 3440 free_unref_page_commit(page, migratetype, 0); 3441 3442 /* 3443 * Guard against excessive IRQ disabled times when we get 3444 * a large list of pages to free. 3445 */ 3446 if (++batch_count == SWAP_CLUSTER_MAX) { 3447 local_unlock_irqrestore(&pagesets.lock, flags); 3448 batch_count = 0; 3449 local_lock_irqsave(&pagesets.lock, flags); 3450 } 3451 } 3452 local_unlock_irqrestore(&pagesets.lock, flags); 3453 } 3454 3455 /* 3456 * split_page takes a non-compound higher-order page, and splits it into 3457 * n (1<<order) sub-pages: page[0..n] 3458 * Each sub-page must be freed individually. 3459 * 3460 * Note: this is probably too low level an operation for use in drivers. 3461 * Please consult with lkml before using this in your driver. 3462 */ 3463 void split_page(struct page *page, unsigned int order) 3464 { 3465 int i; 3466 3467 VM_BUG_ON_PAGE(PageCompound(page), page); 3468 VM_BUG_ON_PAGE(!page_count(page), page); 3469 3470 for (i = 1; i < (1 << order); i++) 3471 set_page_refcounted(page + i); 3472 split_page_owner(page, 1 << order); 3473 split_page_memcg(page, 1 << order); 3474 } 3475 EXPORT_SYMBOL_GPL(split_page); 3476 3477 int __isolate_free_page(struct page *page, unsigned int order) 3478 { 3479 unsigned long watermark; 3480 struct zone *zone; 3481 int mt; 3482 3483 BUG_ON(!PageBuddy(page)); 3484 3485 zone = page_zone(page); 3486 mt = get_pageblock_migratetype(page); 3487 3488 if (!is_migrate_isolate(mt)) { 3489 /* 3490 * Obey watermarks as if the page was being allocated. We can 3491 * emulate a high-order watermark check with a raised order-0 3492 * watermark, because we already know our high-order page 3493 * exists. 3494 */ 3495 watermark = zone->_watermark[WMARK_MIN] + (1UL << order); 3496 if (!zone_watermark_ok(zone, 0, watermark, 0, ALLOC_CMA)) 3497 return 0; 3498 3499 __mod_zone_freepage_state(zone, -(1UL << order), mt); 3500 } 3501 3502 /* Remove page from free list */ 3503 3504 del_page_from_free_list(page, zone, order); 3505 3506 /* 3507 * Set the pageblock if the isolated page is at least half of a 3508 * pageblock 3509 */ 3510 if (order >= pageblock_order - 1) { 3511 struct page *endpage = page + (1 << order) - 1; 3512 for (; page < endpage; page += pageblock_nr_pages) { 3513 int mt = get_pageblock_migratetype(page); 3514 /* 3515 * Only change normal pageblocks (i.e., they can merge 3516 * with others) 3517 */ 3518 if (migratetype_is_mergeable(mt)) 3519 set_pageblock_migratetype(page, 3520 MIGRATE_MOVABLE); 3521 } 3522 } 3523 3524 3525 return 1UL << order; 3526 } 3527 3528 /** 3529 * __putback_isolated_page - Return a now-isolated page back where we got it 3530 * @page: Page that was isolated 3531 * @order: Order of the isolated page 3532 * @mt: The page's pageblock's migratetype 3533 * 3534 * This function is meant to return a page pulled from the free lists via 3535 * __isolate_free_page back to the free lists they were pulled from. 3536 */ 3537 void __putback_isolated_page(struct page *page, unsigned int order, int mt) 3538 { 3539 struct zone *zone = page_zone(page); 3540 3541 /* zone lock should be held when this function is called */ 3542 lockdep_assert_held(&zone->lock); 3543 3544 /* Return isolated page to tail of freelist. */ 3545 __free_one_page(page, page_to_pfn(page), zone, order, mt, 3546 FPI_SKIP_REPORT_NOTIFY | FPI_TO_TAIL); 3547 } 3548 3549 /* 3550 * Update NUMA hit/miss statistics 3551 * 3552 * Must be called with interrupts disabled. 3553 */ 3554 static inline void zone_statistics(struct zone *preferred_zone, struct zone *z, 3555 long nr_account) 3556 { 3557 #ifdef CONFIG_NUMA 3558 enum numa_stat_item local_stat = NUMA_LOCAL; 3559 3560 /* skip numa counters update if numa stats is disabled */ 3561 if (!static_branch_likely(&vm_numa_stat_key)) 3562 return; 3563 3564 if (zone_to_nid(z) != numa_node_id()) 3565 local_stat = NUMA_OTHER; 3566 3567 if (zone_to_nid(z) == zone_to_nid(preferred_zone)) 3568 __count_numa_events(z, NUMA_HIT, nr_account); 3569 else { 3570 __count_numa_events(z, NUMA_MISS, nr_account); 3571 __count_numa_events(preferred_zone, NUMA_FOREIGN, nr_account); 3572 } 3573 __count_numa_events(z, local_stat, nr_account); 3574 #endif 3575 } 3576 3577 /* Remove page from the per-cpu list, caller must protect the list */ 3578 static inline 3579 struct page *__rmqueue_pcplist(struct zone *zone, unsigned int order, 3580 int migratetype, 3581 unsigned int alloc_flags, 3582 struct per_cpu_pages *pcp, 3583 struct list_head *list) 3584 { 3585 struct page *page; 3586 3587 do { 3588 if (list_empty(list)) { 3589 int batch = READ_ONCE(pcp->batch); 3590 int alloced; 3591 3592 /* 3593 * Scale batch relative to order if batch implies 3594 * free pages can be stored on the PCP. Batch can 3595 * be 1 for small zones or for boot pagesets which 3596 * should never store free pages as the pages may 3597 * belong to arbitrary zones. 3598 */ 3599 if (batch > 1) 3600 batch = max(batch >> order, 2); 3601 alloced = rmqueue_bulk(zone, order, 3602 batch, list, 3603 migratetype, alloc_flags); 3604 3605 pcp->count += alloced << order; 3606 if (unlikely(list_empty(list))) 3607 return NULL; 3608 } 3609 3610 page = list_first_entry(list, struct page, lru); 3611 list_del(&page->lru); 3612 pcp->count -= 1 << order; 3613 } while (check_new_pcp(page, order)); 3614 3615 return page; 3616 } 3617 3618 /* Lock and remove page from the per-cpu list */ 3619 static struct page *rmqueue_pcplist(struct zone *preferred_zone, 3620 struct zone *zone, unsigned int order, 3621 gfp_t gfp_flags, int migratetype, 3622 unsigned int alloc_flags) 3623 { 3624 struct per_cpu_pages *pcp; 3625 struct list_head *list; 3626 struct page *page; 3627 unsigned long flags; 3628 3629 local_lock_irqsave(&pagesets.lock, flags); 3630 3631 /* 3632 * On allocation, reduce the number of pages that are batch freed. 3633 * See nr_pcp_free() where free_factor is increased for subsequent 3634 * frees. 3635 */ 3636 pcp = this_cpu_ptr(zone->per_cpu_pageset); 3637 pcp->free_factor >>= 1; 3638 list = &pcp->lists[order_to_pindex(migratetype, order)]; 3639 page = __rmqueue_pcplist(zone, order, migratetype, alloc_flags, pcp, list); 3640 local_unlock_irqrestore(&pagesets.lock, flags); 3641 if (page) { 3642 __count_zid_vm_events(PGALLOC, page_zonenum(page), 1); 3643 zone_statistics(preferred_zone, zone, 1); 3644 } 3645 return page; 3646 } 3647 3648 /* 3649 * Allocate a page from the given zone. Use pcplists for order-0 allocations. 3650 */ 3651 static inline 3652 struct page *rmqueue(struct zone *preferred_zone, 3653 struct zone *zone, unsigned int order, 3654 gfp_t gfp_flags, unsigned int alloc_flags, 3655 int migratetype) 3656 { 3657 unsigned long flags; 3658 struct page *page; 3659 3660 if (likely(pcp_allowed_order(order))) { 3661 /* 3662 * MIGRATE_MOVABLE pcplist could have the pages on CMA area and 3663 * we need to skip it when CMA area isn't allowed. 3664 */ 3665 if (!IS_ENABLED(CONFIG_CMA) || alloc_flags & ALLOC_CMA || 3666 migratetype != MIGRATE_MOVABLE) { 3667 page = rmqueue_pcplist(preferred_zone, zone, order, 3668 gfp_flags, migratetype, alloc_flags); 3669 goto out; 3670 } 3671 } 3672 3673 /* 3674 * We most definitely don't want callers attempting to 3675 * allocate greater than order-1 page units with __GFP_NOFAIL. 3676 */ 3677 WARN_ON_ONCE((gfp_flags & __GFP_NOFAIL) && (order > 1)); 3678 3679 do { 3680 page = NULL; 3681 spin_lock_irqsave(&zone->lock, flags); 3682 /* 3683 * order-0 request can reach here when the pcplist is skipped 3684 * due to non-CMA allocation context. HIGHATOMIC area is 3685 * reserved for high-order atomic allocation, so order-0 3686 * request should skip it. 3687 */ 3688 if (order > 0 && alloc_flags & ALLOC_HARDER) { 3689 page = __rmqueue_smallest(zone, order, MIGRATE_HIGHATOMIC); 3690 if (page) 3691 trace_mm_page_alloc_zone_locked(page, order, migratetype); 3692 } 3693 if (!page) { 3694 page = __rmqueue(zone, order, migratetype, alloc_flags); 3695 if (!page) 3696 goto failed; 3697 } 3698 __mod_zone_freepage_state(zone, -(1 << order), 3699 get_pcppage_migratetype(page)); 3700 spin_unlock_irqrestore(&zone->lock, flags); 3701 } while (check_new_pages(page, order)); 3702 3703 __count_zid_vm_events(PGALLOC, page_zonenum(page), 1 << order); 3704 zone_statistics(preferred_zone, zone, 1); 3705 3706 out: 3707 /* Separate test+clear to avoid unnecessary atomics */ 3708 if (test_bit(ZONE_BOOSTED_WATERMARK, &zone->flags)) { 3709 clear_bit(ZONE_BOOSTED_WATERMARK, &zone->flags); 3710 wakeup_kswapd(zone, 0, 0, zone_idx(zone)); 3711 } 3712 3713 VM_BUG_ON_PAGE(page && bad_range(zone, page), page); 3714 return page; 3715 3716 failed: 3717 spin_unlock_irqrestore(&zone->lock, flags); 3718 return NULL; 3719 } 3720 3721 #ifdef CONFIG_FAIL_PAGE_ALLOC 3722 3723 static struct { 3724 struct fault_attr attr; 3725 3726 bool ignore_gfp_highmem; 3727 bool ignore_gfp_reclaim; 3728 u32 min_order; 3729 } fail_page_alloc = { 3730 .attr = FAULT_ATTR_INITIALIZER, 3731 .ignore_gfp_reclaim = true, 3732 .ignore_gfp_highmem = true, 3733 .min_order = 1, 3734 }; 3735 3736 static int __init setup_fail_page_alloc(char *str) 3737 { 3738 return setup_fault_attr(&fail_page_alloc.attr, str); 3739 } 3740 __setup("fail_page_alloc=", setup_fail_page_alloc); 3741 3742 static bool __should_fail_alloc_page(gfp_t gfp_mask, unsigned int order) 3743 { 3744 if (order < fail_page_alloc.min_order) 3745 return false; 3746 if (gfp_mask & __GFP_NOFAIL) 3747 return false; 3748 if (fail_page_alloc.ignore_gfp_highmem && (gfp_mask & __GFP_HIGHMEM)) 3749 return false; 3750 if (fail_page_alloc.ignore_gfp_reclaim && 3751 (gfp_mask & __GFP_DIRECT_RECLAIM)) 3752 return false; 3753 3754 return should_fail(&fail_page_alloc.attr, 1 << order); 3755 } 3756 3757 #ifdef CONFIG_FAULT_INJECTION_DEBUG_FS 3758 3759 static int __init fail_page_alloc_debugfs(void) 3760 { 3761 umode_t mode = S_IFREG | 0600; 3762 struct dentry *dir; 3763 3764 dir = fault_create_debugfs_attr("fail_page_alloc", NULL, 3765 &fail_page_alloc.attr); 3766 3767 debugfs_create_bool("ignore-gfp-wait", mode, dir, 3768 &fail_page_alloc.ignore_gfp_reclaim); 3769 debugfs_create_bool("ignore-gfp-highmem", mode, dir, 3770 &fail_page_alloc.ignore_gfp_highmem); 3771 debugfs_create_u32("min-order", mode, dir, &fail_page_alloc.min_order); 3772 3773 return 0; 3774 } 3775 3776 late_initcall(fail_page_alloc_debugfs); 3777 3778 #endif /* CONFIG_FAULT_INJECTION_DEBUG_FS */ 3779 3780 #else /* CONFIG_FAIL_PAGE_ALLOC */ 3781 3782 static inline bool __should_fail_alloc_page(gfp_t gfp_mask, unsigned int order) 3783 { 3784 return false; 3785 } 3786 3787 #endif /* CONFIG_FAIL_PAGE_ALLOC */ 3788 3789 noinline bool should_fail_alloc_page(gfp_t gfp_mask, unsigned int order) 3790 { 3791 return __should_fail_alloc_page(gfp_mask, order); 3792 } 3793 ALLOW_ERROR_INJECTION(should_fail_alloc_page, TRUE); 3794 3795 static inline long __zone_watermark_unusable_free(struct zone *z, 3796 unsigned int order, unsigned int alloc_flags) 3797 { 3798 const bool alloc_harder = (alloc_flags & (ALLOC_HARDER|ALLOC_OOM)); 3799 long unusable_free = (1 << order) - 1; 3800 3801 /* 3802 * If the caller does not have rights to ALLOC_HARDER then subtract 3803 * the high-atomic reserves. This will over-estimate the size of the 3804 * atomic reserve but it avoids a search. 3805 */ 3806 if (likely(!alloc_harder)) 3807 unusable_free += z->nr_reserved_highatomic; 3808 3809 #ifdef CONFIG_CMA 3810 /* If allocation can't use CMA areas don't use free CMA pages */ 3811 if (!(alloc_flags & ALLOC_CMA)) 3812 unusable_free += zone_page_state(z, NR_FREE_CMA_PAGES); 3813 #endif 3814 3815 return unusable_free; 3816 } 3817 3818 /* 3819 * Return true if free base pages are above 'mark'. For high-order checks it 3820 * will return true of the order-0 watermark is reached and there is at least 3821 * one free page of a suitable size. Checking now avoids taking the zone lock 3822 * to check in the allocation paths if no pages are free. 3823 */ 3824 bool __zone_watermark_ok(struct zone *z, unsigned int order, unsigned long mark, 3825 int highest_zoneidx, unsigned int alloc_flags, 3826 long free_pages) 3827 { 3828 long min = mark; 3829 int o; 3830 const bool alloc_harder = (alloc_flags & (ALLOC_HARDER|ALLOC_OOM)); 3831 3832 /* free_pages may go negative - that's OK */ 3833 free_pages -= __zone_watermark_unusable_free(z, order, alloc_flags); 3834 3835 if (alloc_flags & ALLOC_HIGH) 3836 min -= min / 2; 3837 3838 if (unlikely(alloc_harder)) { 3839 /* 3840 * OOM victims can try even harder than normal ALLOC_HARDER 3841 * users on the grounds that it's definitely going to be in 3842 * the exit path shortly and free memory. Any allocation it 3843 * makes during the free path will be small and short-lived. 3844 */ 3845 if (alloc_flags & ALLOC_OOM) 3846 min -= min / 2; 3847 else 3848 min -= min / 4; 3849 } 3850 3851 /* 3852 * Check watermarks for an order-0 allocation request. If these 3853 * are not met, then a high-order request also cannot go ahead 3854 * even if a suitable page happened to be free. 3855 */ 3856 if (free_pages <= min + z->lowmem_reserve[highest_zoneidx]) 3857 return false; 3858 3859 /* If this is an order-0 request then the watermark is fine */ 3860 if (!order) 3861 return true; 3862 3863 /* For a high-order request, check at least one suitable page is free */ 3864 for (o = order; o < MAX_ORDER; o++) { 3865 struct free_area *area = &z->free_area[o]; 3866 int mt; 3867 3868 if (!area->nr_free) 3869 continue; 3870 3871 for (mt = 0; mt < MIGRATE_PCPTYPES; mt++) { 3872 if (!free_area_empty(area, mt)) 3873 return true; 3874 } 3875 3876 #ifdef CONFIG_CMA 3877 if ((alloc_flags & ALLOC_CMA) && 3878 !free_area_empty(area, MIGRATE_CMA)) { 3879 return true; 3880 } 3881 #endif 3882 if (alloc_harder && !free_area_empty(area, MIGRATE_HIGHATOMIC)) 3883 return true; 3884 } 3885 return false; 3886 } 3887 3888 bool zone_watermark_ok(struct zone *z, unsigned int order, unsigned long mark, 3889 int highest_zoneidx, unsigned int alloc_flags) 3890 { 3891 return __zone_watermark_ok(z, order, mark, highest_zoneidx, alloc_flags, 3892 zone_page_state(z, NR_FREE_PAGES)); 3893 } 3894 3895 static inline bool zone_watermark_fast(struct zone *z, unsigned int order, 3896 unsigned long mark, int highest_zoneidx, 3897 unsigned int alloc_flags, gfp_t gfp_mask) 3898 { 3899 long free_pages; 3900 3901 free_pages = zone_page_state(z, NR_FREE_PAGES); 3902 3903 /* 3904 * Fast check for order-0 only. If this fails then the reserves 3905 * need to be calculated. 3906 */ 3907 if (!order) { 3908 long fast_free; 3909 3910 fast_free = free_pages; 3911 fast_free -= __zone_watermark_unusable_free(z, 0, alloc_flags); 3912 if (fast_free > mark + z->lowmem_reserve[highest_zoneidx]) 3913 return true; 3914 } 3915 3916 if (__zone_watermark_ok(z, order, mark, highest_zoneidx, alloc_flags, 3917 free_pages)) 3918 return true; 3919 /* 3920 * Ignore watermark boosting for GFP_ATOMIC order-0 allocations 3921 * when checking the min watermark. The min watermark is the 3922 * point where boosting is ignored so that kswapd is woken up 3923 * when below the low watermark. 3924 */ 3925 if (unlikely(!order && (gfp_mask & __GFP_ATOMIC) && z->watermark_boost 3926 && ((alloc_flags & ALLOC_WMARK_MASK) == WMARK_MIN))) { 3927 mark = z->_watermark[WMARK_MIN]; 3928 return __zone_watermark_ok(z, order, mark, highest_zoneidx, 3929 alloc_flags, free_pages); 3930 } 3931 3932 return false; 3933 } 3934 3935 bool zone_watermark_ok_safe(struct zone *z, unsigned int order, 3936 unsigned long mark, int highest_zoneidx) 3937 { 3938 long free_pages = zone_page_state(z, NR_FREE_PAGES); 3939 3940 if (z->percpu_drift_mark && free_pages < z->percpu_drift_mark) 3941 free_pages = zone_page_state_snapshot(z, NR_FREE_PAGES); 3942 3943 return __zone_watermark_ok(z, order, mark, highest_zoneidx, 0, 3944 free_pages); 3945 } 3946 3947 #ifdef CONFIG_NUMA 3948 int __read_mostly node_reclaim_distance = RECLAIM_DISTANCE; 3949 3950 static bool zone_allows_reclaim(struct zone *local_zone, struct zone *zone) 3951 { 3952 return node_distance(zone_to_nid(local_zone), zone_to_nid(zone)) <= 3953 node_reclaim_distance; 3954 } 3955 #else /* CONFIG_NUMA */ 3956 static bool zone_allows_reclaim(struct zone *local_zone, struct zone *zone) 3957 { 3958 return true; 3959 } 3960 #endif /* CONFIG_NUMA */ 3961 3962 /* 3963 * The restriction on ZONE_DMA32 as being a suitable zone to use to avoid 3964 * fragmentation is subtle. If the preferred zone was HIGHMEM then 3965 * premature use of a lower zone may cause lowmem pressure problems that 3966 * are worse than fragmentation. If the next zone is ZONE_DMA then it is 3967 * probably too small. It only makes sense to spread allocations to avoid 3968 * fragmentation between the Normal and DMA32 zones. 3969 */ 3970 static inline unsigned int 3971 alloc_flags_nofragment(struct zone *zone, gfp_t gfp_mask) 3972 { 3973 unsigned int alloc_flags; 3974 3975 /* 3976 * __GFP_KSWAPD_RECLAIM is assumed to be the same as ALLOC_KSWAPD 3977 * to save a branch. 3978 */ 3979 alloc_flags = (__force int) (gfp_mask & __GFP_KSWAPD_RECLAIM); 3980 3981 #ifdef CONFIG_ZONE_DMA32 3982 if (!zone) 3983 return alloc_flags; 3984 3985 if (zone_idx(zone) != ZONE_NORMAL) 3986 return alloc_flags; 3987 3988 /* 3989 * If ZONE_DMA32 exists, assume it is the one after ZONE_NORMAL and 3990 * the pointer is within zone->zone_pgdat->node_zones[]. Also assume 3991 * on UMA that if Normal is populated then so is DMA32. 3992 */ 3993 BUILD_BUG_ON(ZONE_NORMAL - ZONE_DMA32 != 1); 3994 if (nr_online_nodes > 1 && !populated_zone(--zone)) 3995 return alloc_flags; 3996 3997 alloc_flags |= ALLOC_NOFRAGMENT; 3998 #endif /* CONFIG_ZONE_DMA32 */ 3999 return alloc_flags; 4000 } 4001 4002 /* Must be called after current_gfp_context() which can change gfp_mask */ 4003 static inline unsigned int gfp_to_alloc_flags_cma(gfp_t gfp_mask, 4004 unsigned int alloc_flags) 4005 { 4006 #ifdef CONFIG_CMA 4007 if (gfp_migratetype(gfp_mask) == MIGRATE_MOVABLE) 4008 alloc_flags |= ALLOC_CMA; 4009 #endif 4010 return alloc_flags; 4011 } 4012 4013 /* 4014 * get_page_from_freelist goes through the zonelist trying to allocate 4015 * a page. 4016 */ 4017 static struct page * 4018 get_page_from_freelist(gfp_t gfp_mask, unsigned int order, int alloc_flags, 4019 const struct alloc_context *ac) 4020 { 4021 struct zoneref *z; 4022 struct zone *zone; 4023 struct pglist_data *last_pgdat_dirty_limit = NULL; 4024 bool no_fallback; 4025 4026 retry: 4027 /* 4028 * Scan zonelist, looking for a zone with enough free. 4029 * See also __cpuset_node_allowed() comment in kernel/cpuset.c. 4030 */ 4031 no_fallback = alloc_flags & ALLOC_NOFRAGMENT; 4032 z = ac->preferred_zoneref; 4033 for_next_zone_zonelist_nodemask(zone, z, ac->highest_zoneidx, 4034 ac->nodemask) { 4035 struct page *page; 4036 unsigned long mark; 4037 4038 if (cpusets_enabled() && 4039 (alloc_flags & ALLOC_CPUSET) && 4040 !__cpuset_zone_allowed(zone, gfp_mask)) 4041 continue; 4042 /* 4043 * When allocating a page cache page for writing, we 4044 * want to get it from a node that is within its dirty 4045 * limit, such that no single node holds more than its 4046 * proportional share of globally allowed dirty pages. 4047 * The dirty limits take into account the node's 4048 * lowmem reserves and high watermark so that kswapd 4049 * should be able to balance it without having to 4050 * write pages from its LRU list. 4051 * 4052 * XXX: For now, allow allocations to potentially 4053 * exceed the per-node dirty limit in the slowpath 4054 * (spread_dirty_pages unset) before going into reclaim, 4055 * which is important when on a NUMA setup the allowed 4056 * nodes are together not big enough to reach the 4057 * global limit. The proper fix for these situations 4058 * will require awareness of nodes in the 4059 * dirty-throttling and the flusher threads. 4060 */ 4061 if (ac->spread_dirty_pages) { 4062 if (last_pgdat_dirty_limit == zone->zone_pgdat) 4063 continue; 4064 4065 if (!node_dirty_ok(zone->zone_pgdat)) { 4066 last_pgdat_dirty_limit = zone->zone_pgdat; 4067 continue; 4068 } 4069 } 4070 4071 if (no_fallback && nr_online_nodes > 1 && 4072 zone != ac->preferred_zoneref->zone) { 4073 int local_nid; 4074 4075 /* 4076 * If moving to a remote node, retry but allow 4077 * fragmenting fallbacks. Locality is more important 4078 * than fragmentation avoidance. 4079 */ 4080 local_nid = zone_to_nid(ac->preferred_zoneref->zone); 4081 if (zone_to_nid(zone) != local_nid) { 4082 alloc_flags &= ~ALLOC_NOFRAGMENT; 4083 goto retry; 4084 } 4085 } 4086 4087 mark = wmark_pages(zone, alloc_flags & ALLOC_WMARK_MASK); 4088 if (!zone_watermark_fast(zone, order, mark, 4089 ac->highest_zoneidx, alloc_flags, 4090 gfp_mask)) { 4091 int ret; 4092 4093 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 4094 /* 4095 * Watermark failed for this zone, but see if we can 4096 * grow this zone if it contains deferred pages. 4097 */ 4098 if (static_branch_unlikely(&deferred_pages)) { 4099 if (_deferred_grow_zone(zone, order)) 4100 goto try_this_zone; 4101 } 4102 #endif 4103 /* Checked here to keep the fast path fast */ 4104 BUILD_BUG_ON(ALLOC_NO_WATERMARKS < NR_WMARK); 4105 if (alloc_flags & ALLOC_NO_WATERMARKS) 4106 goto try_this_zone; 4107 4108 if (!node_reclaim_enabled() || 4109 !zone_allows_reclaim(ac->preferred_zoneref->zone, zone)) 4110 continue; 4111 4112 ret = node_reclaim(zone->zone_pgdat, gfp_mask, order); 4113 switch (ret) { 4114 case NODE_RECLAIM_NOSCAN: 4115 /* did not scan */ 4116 continue; 4117 case NODE_RECLAIM_FULL: 4118 /* scanned but unreclaimable */ 4119 continue; 4120 default: 4121 /* did we reclaim enough */ 4122 if (zone_watermark_ok(zone, order, mark, 4123 ac->highest_zoneidx, alloc_flags)) 4124 goto try_this_zone; 4125 4126 continue; 4127 } 4128 } 4129 4130 try_this_zone: 4131 page = rmqueue(ac->preferred_zoneref->zone, zone, order, 4132 gfp_mask, alloc_flags, ac->migratetype); 4133 if (page) { 4134 prep_new_page(page, order, gfp_mask, alloc_flags); 4135 4136 /* 4137 * If this is a high-order atomic allocation then check 4138 * if the pageblock should be reserved for the future 4139 */ 4140 if (unlikely(order && (alloc_flags & ALLOC_HARDER))) 4141 reserve_highatomic_pageblock(page, zone, order); 4142 4143 return page; 4144 } else { 4145 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 4146 /* Try again if zone has deferred pages */ 4147 if (static_branch_unlikely(&deferred_pages)) { 4148 if (_deferred_grow_zone(zone, order)) 4149 goto try_this_zone; 4150 } 4151 #endif 4152 } 4153 } 4154 4155 /* 4156 * It's possible on a UMA machine to get through all zones that are 4157 * fragmented. If avoiding fragmentation, reset and try again. 4158 */ 4159 if (no_fallback) { 4160 alloc_flags &= ~ALLOC_NOFRAGMENT; 4161 goto retry; 4162 } 4163 4164 return NULL; 4165 } 4166 4167 static void warn_alloc_show_mem(gfp_t gfp_mask, nodemask_t *nodemask) 4168 { 4169 unsigned int filter = SHOW_MEM_FILTER_NODES; 4170 4171 /* 4172 * This documents exceptions given to allocations in certain 4173 * contexts that are allowed to allocate outside current's set 4174 * of allowed nodes. 4175 */ 4176 if (!(gfp_mask & __GFP_NOMEMALLOC)) 4177 if (tsk_is_oom_victim(current) || 4178 (current->flags & (PF_MEMALLOC | PF_EXITING))) 4179 filter &= ~SHOW_MEM_FILTER_NODES; 4180 if (!in_task() || !(gfp_mask & __GFP_DIRECT_RECLAIM)) 4181 filter &= ~SHOW_MEM_FILTER_NODES; 4182 4183 show_mem(filter, nodemask); 4184 } 4185 4186 void warn_alloc(gfp_t gfp_mask, nodemask_t *nodemask, const char *fmt, ...) 4187 { 4188 struct va_format vaf; 4189 va_list args; 4190 static DEFINE_RATELIMIT_STATE(nopage_rs, 10*HZ, 1); 4191 4192 if ((gfp_mask & __GFP_NOWARN) || 4193 !__ratelimit(&nopage_rs) || 4194 ((gfp_mask & __GFP_DMA) && !has_managed_dma())) 4195 return; 4196 4197 va_start(args, fmt); 4198 vaf.fmt = fmt; 4199 vaf.va = &args; 4200 pr_warn("%s: %pV, mode:%#x(%pGg), nodemask=%*pbl", 4201 current->comm, &vaf, gfp_mask, &gfp_mask, 4202 nodemask_pr_args(nodemask)); 4203 va_end(args); 4204 4205 cpuset_print_current_mems_allowed(); 4206 pr_cont("\n"); 4207 dump_stack(); 4208 warn_alloc_show_mem(gfp_mask, nodemask); 4209 } 4210 4211 static inline struct page * 4212 __alloc_pages_cpuset_fallback(gfp_t gfp_mask, unsigned int order, 4213 unsigned int alloc_flags, 4214 const struct alloc_context *ac) 4215 { 4216 struct page *page; 4217 4218 page = get_page_from_freelist(gfp_mask, order, 4219 alloc_flags|ALLOC_CPUSET, ac); 4220 /* 4221 * fallback to ignore cpuset restriction if our nodes 4222 * are depleted 4223 */ 4224 if (!page) 4225 page = get_page_from_freelist(gfp_mask, order, 4226 alloc_flags, ac); 4227 4228 return page; 4229 } 4230 4231 static inline struct page * 4232 __alloc_pages_may_oom(gfp_t gfp_mask, unsigned int order, 4233 const struct alloc_context *ac, unsigned long *did_some_progress) 4234 { 4235 struct oom_control oc = { 4236 .zonelist = ac->zonelist, 4237 .nodemask = ac->nodemask, 4238 .memcg = NULL, 4239 .gfp_mask = gfp_mask, 4240 .order = order, 4241 }; 4242 struct page *page; 4243 4244 *did_some_progress = 0; 4245 4246 /* 4247 * Acquire the oom lock. If that fails, somebody else is 4248 * making progress for us. 4249 */ 4250 if (!mutex_trylock(&oom_lock)) { 4251 *did_some_progress = 1; 4252 schedule_timeout_uninterruptible(1); 4253 return NULL; 4254 } 4255 4256 /* 4257 * Go through the zonelist yet one more time, keep very high watermark 4258 * here, this is only to catch a parallel oom killing, we must fail if 4259 * we're still under heavy pressure. But make sure that this reclaim 4260 * attempt shall not depend on __GFP_DIRECT_RECLAIM && !__GFP_NORETRY 4261 * allocation which will never fail due to oom_lock already held. 4262 */ 4263 page = get_page_from_freelist((gfp_mask | __GFP_HARDWALL) & 4264 ~__GFP_DIRECT_RECLAIM, order, 4265 ALLOC_WMARK_HIGH|ALLOC_CPUSET, ac); 4266 if (page) 4267 goto out; 4268 4269 /* Coredumps can quickly deplete all memory reserves */ 4270 if (current->flags & PF_DUMPCORE) 4271 goto out; 4272 /* The OOM killer will not help higher order allocs */ 4273 if (order > PAGE_ALLOC_COSTLY_ORDER) 4274 goto out; 4275 /* 4276 * We have already exhausted all our reclaim opportunities without any 4277 * success so it is time to admit defeat. We will skip the OOM killer 4278 * because it is very likely that the caller has a more reasonable 4279 * fallback than shooting a random task. 4280 * 4281 * The OOM killer may not free memory on a specific node. 4282 */ 4283 if (gfp_mask & (__GFP_RETRY_MAYFAIL | __GFP_THISNODE)) 4284 goto out; 4285 /* The OOM killer does not needlessly kill tasks for lowmem */ 4286 if (ac->highest_zoneidx < ZONE_NORMAL) 4287 goto out; 4288 if (pm_suspended_storage()) 4289 goto out; 4290 /* 4291 * XXX: GFP_NOFS allocations should rather fail than rely on 4292 * other request to make a forward progress. 4293 * We are in an unfortunate situation where out_of_memory cannot 4294 * do much for this context but let's try it to at least get 4295 * access to memory reserved if the current task is killed (see 4296 * out_of_memory). Once filesystems are ready to handle allocation 4297 * failures more gracefully we should just bail out here. 4298 */ 4299 4300 /* Exhausted what can be done so it's blame time */ 4301 if (out_of_memory(&oc) || WARN_ON_ONCE(gfp_mask & __GFP_NOFAIL)) { 4302 *did_some_progress = 1; 4303 4304 /* 4305 * Help non-failing allocations by giving them access to memory 4306 * reserves 4307 */ 4308 if (gfp_mask & __GFP_NOFAIL) 4309 page = __alloc_pages_cpuset_fallback(gfp_mask, order, 4310 ALLOC_NO_WATERMARKS, ac); 4311 } 4312 out: 4313 mutex_unlock(&oom_lock); 4314 return page; 4315 } 4316 4317 /* 4318 * Maximum number of compaction retries with a progress before OOM 4319 * killer is consider as the only way to move forward. 4320 */ 4321 #define MAX_COMPACT_RETRIES 16 4322 4323 #ifdef CONFIG_COMPACTION 4324 /* Try memory compaction for high-order allocations before reclaim */ 4325 static struct page * 4326 __alloc_pages_direct_compact(gfp_t gfp_mask, unsigned int order, 4327 unsigned int alloc_flags, const struct alloc_context *ac, 4328 enum compact_priority prio, enum compact_result *compact_result) 4329 { 4330 struct page *page = NULL; 4331 unsigned long pflags; 4332 unsigned int noreclaim_flag; 4333 4334 if (!order) 4335 return NULL; 4336 4337 psi_memstall_enter(&pflags); 4338 delayacct_compact_start(); 4339 noreclaim_flag = memalloc_noreclaim_save(); 4340 4341 *compact_result = try_to_compact_pages(gfp_mask, order, alloc_flags, ac, 4342 prio, &page); 4343 4344 memalloc_noreclaim_restore(noreclaim_flag); 4345 psi_memstall_leave(&pflags); 4346 delayacct_compact_end(); 4347 4348 if (*compact_result == COMPACT_SKIPPED) 4349 return NULL; 4350 /* 4351 * At least in one zone compaction wasn't deferred or skipped, so let's 4352 * count a compaction stall 4353 */ 4354 count_vm_event(COMPACTSTALL); 4355 4356 /* Prep a captured page if available */ 4357 if (page) 4358 prep_new_page(page, order, gfp_mask, alloc_flags); 4359 4360 /* Try get a page from the freelist if available */ 4361 if (!page) 4362 page = get_page_from_freelist(gfp_mask, order, alloc_flags, ac); 4363 4364 if (page) { 4365 struct zone *zone = page_zone(page); 4366 4367 zone->compact_blockskip_flush = false; 4368 compaction_defer_reset(zone, order, true); 4369 count_vm_event(COMPACTSUCCESS); 4370 return page; 4371 } 4372 4373 /* 4374 * It's bad if compaction run occurs and fails. The most likely reason 4375 * is that pages exist, but not enough to satisfy watermarks. 4376 */ 4377 count_vm_event(COMPACTFAIL); 4378 4379 cond_resched(); 4380 4381 return NULL; 4382 } 4383 4384 static inline bool 4385 should_compact_retry(struct alloc_context *ac, int order, int alloc_flags, 4386 enum compact_result compact_result, 4387 enum compact_priority *compact_priority, 4388 int *compaction_retries) 4389 { 4390 int max_retries = MAX_COMPACT_RETRIES; 4391 int min_priority; 4392 bool ret = false; 4393 int retries = *compaction_retries; 4394 enum compact_priority priority = *compact_priority; 4395 4396 if (!order) 4397 return false; 4398 4399 if (fatal_signal_pending(current)) 4400 return false; 4401 4402 if (compaction_made_progress(compact_result)) 4403 (*compaction_retries)++; 4404 4405 /* 4406 * compaction considers all the zone as desperately out of memory 4407 * so it doesn't really make much sense to retry except when the 4408 * failure could be caused by insufficient priority 4409 */ 4410 if (compaction_failed(compact_result)) 4411 goto check_priority; 4412 4413 /* 4414 * compaction was skipped because there are not enough order-0 pages 4415 * to work with, so we retry only if it looks like reclaim can help. 4416 */ 4417 if (compaction_needs_reclaim(compact_result)) { 4418 ret = compaction_zonelist_suitable(ac, order, alloc_flags); 4419 goto out; 4420 } 4421 4422 /* 4423 * make sure the compaction wasn't deferred or didn't bail out early 4424 * due to locks contention before we declare that we should give up. 4425 * But the next retry should use a higher priority if allowed, so 4426 * we don't just keep bailing out endlessly. 4427 */ 4428 if (compaction_withdrawn(compact_result)) { 4429 goto check_priority; 4430 } 4431 4432 /* 4433 * !costly requests are much more important than __GFP_RETRY_MAYFAIL 4434 * costly ones because they are de facto nofail and invoke OOM 4435 * killer to move on while costly can fail and users are ready 4436 * to cope with that. 1/4 retries is rather arbitrary but we 4437 * would need much more detailed feedback from compaction to 4438 * make a better decision. 4439 */ 4440 if (order > PAGE_ALLOC_COSTLY_ORDER) 4441 max_retries /= 4; 4442 if (*compaction_retries <= max_retries) { 4443 ret = true; 4444 goto out; 4445 } 4446 4447 /* 4448 * Make sure there are attempts at the highest priority if we exhausted 4449 * all retries or failed at the lower priorities. 4450 */ 4451 check_priority: 4452 min_priority = (order > PAGE_ALLOC_COSTLY_ORDER) ? 4453 MIN_COMPACT_COSTLY_PRIORITY : MIN_COMPACT_PRIORITY; 4454 4455 if (*compact_priority > min_priority) { 4456 (*compact_priority)--; 4457 *compaction_retries = 0; 4458 ret = true; 4459 } 4460 out: 4461 trace_compact_retry(order, priority, compact_result, retries, max_retries, ret); 4462 return ret; 4463 } 4464 #else 4465 static inline struct page * 4466 __alloc_pages_direct_compact(gfp_t gfp_mask, unsigned int order, 4467 unsigned int alloc_flags, const struct alloc_context *ac, 4468 enum compact_priority prio, enum compact_result *compact_result) 4469 { 4470 *compact_result = COMPACT_SKIPPED; 4471 return NULL; 4472 } 4473 4474 static inline bool 4475 should_compact_retry(struct alloc_context *ac, unsigned int order, int alloc_flags, 4476 enum compact_result compact_result, 4477 enum compact_priority *compact_priority, 4478 int *compaction_retries) 4479 { 4480 struct zone *zone; 4481 struct zoneref *z; 4482 4483 if (!order || order > PAGE_ALLOC_COSTLY_ORDER) 4484 return false; 4485 4486 /* 4487 * There are setups with compaction disabled which would prefer to loop 4488 * inside the allocator rather than hit the oom killer prematurely. 4489 * Let's give them a good hope and keep retrying while the order-0 4490 * watermarks are OK. 4491 */ 4492 for_each_zone_zonelist_nodemask(zone, z, ac->zonelist, 4493 ac->highest_zoneidx, ac->nodemask) { 4494 if (zone_watermark_ok(zone, 0, min_wmark_pages(zone), 4495 ac->highest_zoneidx, alloc_flags)) 4496 return true; 4497 } 4498 return false; 4499 } 4500 #endif /* CONFIG_COMPACTION */ 4501 4502 #ifdef CONFIG_LOCKDEP 4503 static struct lockdep_map __fs_reclaim_map = 4504 STATIC_LOCKDEP_MAP_INIT("fs_reclaim", &__fs_reclaim_map); 4505 4506 static bool __need_reclaim(gfp_t gfp_mask) 4507 { 4508 /* no reclaim without waiting on it */ 4509 if (!(gfp_mask & __GFP_DIRECT_RECLAIM)) 4510 return false; 4511 4512 /* this guy won't enter reclaim */ 4513 if (current->flags & PF_MEMALLOC) 4514 return false; 4515 4516 if (gfp_mask & __GFP_NOLOCKDEP) 4517 return false; 4518 4519 return true; 4520 } 4521 4522 void __fs_reclaim_acquire(unsigned long ip) 4523 { 4524 lock_acquire_exclusive(&__fs_reclaim_map, 0, 0, NULL, ip); 4525 } 4526 4527 void __fs_reclaim_release(unsigned long ip) 4528 { 4529 lock_release(&__fs_reclaim_map, ip); 4530 } 4531 4532 void fs_reclaim_acquire(gfp_t gfp_mask) 4533 { 4534 gfp_mask = current_gfp_context(gfp_mask); 4535 4536 if (__need_reclaim(gfp_mask)) { 4537 if (gfp_mask & __GFP_FS) 4538 __fs_reclaim_acquire(_RET_IP_); 4539 4540 #ifdef CONFIG_MMU_NOTIFIER 4541 lock_map_acquire(&__mmu_notifier_invalidate_range_start_map); 4542 lock_map_release(&__mmu_notifier_invalidate_range_start_map); 4543 #endif 4544 4545 } 4546 } 4547 EXPORT_SYMBOL_GPL(fs_reclaim_acquire); 4548 4549 void fs_reclaim_release(gfp_t gfp_mask) 4550 { 4551 gfp_mask = current_gfp_context(gfp_mask); 4552 4553 if (__need_reclaim(gfp_mask)) { 4554 if (gfp_mask & __GFP_FS) 4555 __fs_reclaim_release(_RET_IP_); 4556 } 4557 } 4558 EXPORT_SYMBOL_GPL(fs_reclaim_release); 4559 #endif 4560 4561 /* Perform direct synchronous page reclaim */ 4562 static unsigned long 4563 __perform_reclaim(gfp_t gfp_mask, unsigned int order, 4564 const struct alloc_context *ac) 4565 { 4566 unsigned int noreclaim_flag; 4567 unsigned long progress; 4568 4569 cond_resched(); 4570 4571 /* We now go into synchronous reclaim */ 4572 cpuset_memory_pressure_bump(); 4573 fs_reclaim_acquire(gfp_mask); 4574 noreclaim_flag = memalloc_noreclaim_save(); 4575 4576 progress = try_to_free_pages(ac->zonelist, order, gfp_mask, 4577 ac->nodemask); 4578 4579 memalloc_noreclaim_restore(noreclaim_flag); 4580 fs_reclaim_release(gfp_mask); 4581 4582 cond_resched(); 4583 4584 return progress; 4585 } 4586 4587 /* The really slow allocator path where we enter direct reclaim */ 4588 static inline struct page * 4589 __alloc_pages_direct_reclaim(gfp_t gfp_mask, unsigned int order, 4590 unsigned int alloc_flags, const struct alloc_context *ac, 4591 unsigned long *did_some_progress) 4592 { 4593 struct page *page = NULL; 4594 unsigned long pflags; 4595 bool drained = false; 4596 4597 psi_memstall_enter(&pflags); 4598 *did_some_progress = __perform_reclaim(gfp_mask, order, ac); 4599 if (unlikely(!(*did_some_progress))) 4600 goto out; 4601 4602 retry: 4603 page = get_page_from_freelist(gfp_mask, order, alloc_flags, ac); 4604 4605 /* 4606 * If an allocation failed after direct reclaim, it could be because 4607 * pages are pinned on the per-cpu lists or in high alloc reserves. 4608 * Shrink them and try again 4609 */ 4610 if (!page && !drained) { 4611 unreserve_highatomic_pageblock(ac, false); 4612 drain_all_pages(NULL); 4613 drained = true; 4614 goto retry; 4615 } 4616 out: 4617 psi_memstall_leave(&pflags); 4618 4619 return page; 4620 } 4621 4622 static void wake_all_kswapds(unsigned int order, gfp_t gfp_mask, 4623 const struct alloc_context *ac) 4624 { 4625 struct zoneref *z; 4626 struct zone *zone; 4627 pg_data_t *last_pgdat = NULL; 4628 enum zone_type highest_zoneidx = ac->highest_zoneidx; 4629 4630 for_each_zone_zonelist_nodemask(zone, z, ac->zonelist, highest_zoneidx, 4631 ac->nodemask) { 4632 if (last_pgdat != zone->zone_pgdat) 4633 wakeup_kswapd(zone, gfp_mask, order, highest_zoneidx); 4634 last_pgdat = zone->zone_pgdat; 4635 } 4636 } 4637 4638 static inline unsigned int 4639 gfp_to_alloc_flags(gfp_t gfp_mask) 4640 { 4641 unsigned int alloc_flags = ALLOC_WMARK_MIN | ALLOC_CPUSET; 4642 4643 /* 4644 * __GFP_HIGH is assumed to be the same as ALLOC_HIGH 4645 * and __GFP_KSWAPD_RECLAIM is assumed to be the same as ALLOC_KSWAPD 4646 * to save two branches. 4647 */ 4648 BUILD_BUG_ON(__GFP_HIGH != (__force gfp_t) ALLOC_HIGH); 4649 BUILD_BUG_ON(__GFP_KSWAPD_RECLAIM != (__force gfp_t) ALLOC_KSWAPD); 4650 4651 /* 4652 * The caller may dip into page reserves a bit more if the caller 4653 * cannot run direct reclaim, or if the caller has realtime scheduling 4654 * policy or is asking for __GFP_HIGH memory. GFP_ATOMIC requests will 4655 * set both ALLOC_HARDER (__GFP_ATOMIC) and ALLOC_HIGH (__GFP_HIGH). 4656 */ 4657 alloc_flags |= (__force int) 4658 (gfp_mask & (__GFP_HIGH | __GFP_KSWAPD_RECLAIM)); 4659 4660 if (gfp_mask & __GFP_ATOMIC) { 4661 /* 4662 * Not worth trying to allocate harder for __GFP_NOMEMALLOC even 4663 * if it can't schedule. 4664 */ 4665 if (!(gfp_mask & __GFP_NOMEMALLOC)) 4666 alloc_flags |= ALLOC_HARDER; 4667 /* 4668 * Ignore cpuset mems for GFP_ATOMIC rather than fail, see the 4669 * comment for __cpuset_node_allowed(). 4670 */ 4671 alloc_flags &= ~ALLOC_CPUSET; 4672 } else if (unlikely(rt_task(current)) && in_task()) 4673 alloc_flags |= ALLOC_HARDER; 4674 4675 alloc_flags = gfp_to_alloc_flags_cma(gfp_mask, alloc_flags); 4676 4677 return alloc_flags; 4678 } 4679 4680 static bool oom_reserves_allowed(struct task_struct *tsk) 4681 { 4682 if (!tsk_is_oom_victim(tsk)) 4683 return false; 4684 4685 /* 4686 * !MMU doesn't have oom reaper so give access to memory reserves 4687 * only to the thread with TIF_MEMDIE set 4688 */ 4689 if (!IS_ENABLED(CONFIG_MMU) && !test_thread_flag(TIF_MEMDIE)) 4690 return false; 4691 4692 return true; 4693 } 4694 4695 /* 4696 * Distinguish requests which really need access to full memory 4697 * reserves from oom victims which can live with a portion of it 4698 */ 4699 static inline int __gfp_pfmemalloc_flags(gfp_t gfp_mask) 4700 { 4701 if (unlikely(gfp_mask & __GFP_NOMEMALLOC)) 4702 return 0; 4703 if (gfp_mask & __GFP_MEMALLOC) 4704 return ALLOC_NO_WATERMARKS; 4705 if (in_serving_softirq() && (current->flags & PF_MEMALLOC)) 4706 return ALLOC_NO_WATERMARKS; 4707 if (!in_interrupt()) { 4708 if (current->flags & PF_MEMALLOC) 4709 return ALLOC_NO_WATERMARKS; 4710 else if (oom_reserves_allowed(current)) 4711 return ALLOC_OOM; 4712 } 4713 4714 return 0; 4715 } 4716 4717 bool gfp_pfmemalloc_allowed(gfp_t gfp_mask) 4718 { 4719 return !!__gfp_pfmemalloc_flags(gfp_mask); 4720 } 4721 4722 /* 4723 * Checks whether it makes sense to retry the reclaim to make a forward progress 4724 * for the given allocation request. 4725 * 4726 * We give up when we either have tried MAX_RECLAIM_RETRIES in a row 4727 * without success, or when we couldn't even meet the watermark if we 4728 * reclaimed all remaining pages on the LRU lists. 4729 * 4730 * Returns true if a retry is viable or false to enter the oom path. 4731 */ 4732 static inline bool 4733 should_reclaim_retry(gfp_t gfp_mask, unsigned order, 4734 struct alloc_context *ac, int alloc_flags, 4735 bool did_some_progress, int *no_progress_loops) 4736 { 4737 struct zone *zone; 4738 struct zoneref *z; 4739 bool ret = false; 4740 4741 /* 4742 * Costly allocations might have made a progress but this doesn't mean 4743 * their order will become available due to high fragmentation so 4744 * always increment the no progress counter for them 4745 */ 4746 if (did_some_progress && order <= PAGE_ALLOC_COSTLY_ORDER) 4747 *no_progress_loops = 0; 4748 else 4749 (*no_progress_loops)++; 4750 4751 /* 4752 * Make sure we converge to OOM if we cannot make any progress 4753 * several times in the row. 4754 */ 4755 if (*no_progress_loops > MAX_RECLAIM_RETRIES) { 4756 /* Before OOM, exhaust highatomic_reserve */ 4757 return unreserve_highatomic_pageblock(ac, true); 4758 } 4759 4760 /* 4761 * Keep reclaiming pages while there is a chance this will lead 4762 * somewhere. If none of the target zones can satisfy our allocation 4763 * request even if all reclaimable pages are considered then we are 4764 * screwed and have to go OOM. 4765 */ 4766 for_each_zone_zonelist_nodemask(zone, z, ac->zonelist, 4767 ac->highest_zoneidx, ac->nodemask) { 4768 unsigned long available; 4769 unsigned long reclaimable; 4770 unsigned long min_wmark = min_wmark_pages(zone); 4771 bool wmark; 4772 4773 available = reclaimable = zone_reclaimable_pages(zone); 4774 available += zone_page_state_snapshot(zone, NR_FREE_PAGES); 4775 4776 /* 4777 * Would the allocation succeed if we reclaimed all 4778 * reclaimable pages? 4779 */ 4780 wmark = __zone_watermark_ok(zone, order, min_wmark, 4781 ac->highest_zoneidx, alloc_flags, available); 4782 trace_reclaim_retry_zone(z, order, reclaimable, 4783 available, min_wmark, *no_progress_loops, wmark); 4784 if (wmark) { 4785 ret = true; 4786 break; 4787 } 4788 } 4789 4790 /* 4791 * Memory allocation/reclaim might be called from a WQ context and the 4792 * current implementation of the WQ concurrency control doesn't 4793 * recognize that a particular WQ is congested if the worker thread is 4794 * looping without ever sleeping. Therefore we have to do a short sleep 4795 * here rather than calling cond_resched(). 4796 */ 4797 if (current->flags & PF_WQ_WORKER) 4798 schedule_timeout_uninterruptible(1); 4799 else 4800 cond_resched(); 4801 return ret; 4802 } 4803 4804 static inline bool 4805 check_retry_cpuset(int cpuset_mems_cookie, struct alloc_context *ac) 4806 { 4807 /* 4808 * It's possible that cpuset's mems_allowed and the nodemask from 4809 * mempolicy don't intersect. This should be normally dealt with by 4810 * policy_nodemask(), but it's possible to race with cpuset update in 4811 * such a way the check therein was true, and then it became false 4812 * before we got our cpuset_mems_cookie here. 4813 * This assumes that for all allocations, ac->nodemask can come only 4814 * from MPOL_BIND mempolicy (whose documented semantics is to be ignored 4815 * when it does not intersect with the cpuset restrictions) or the 4816 * caller can deal with a violated nodemask. 4817 */ 4818 if (cpusets_enabled() && ac->nodemask && 4819 !cpuset_nodemask_valid_mems_allowed(ac->nodemask)) { 4820 ac->nodemask = NULL; 4821 return true; 4822 } 4823 4824 /* 4825 * When updating a task's mems_allowed or mempolicy nodemask, it is 4826 * possible to race with parallel threads in such a way that our 4827 * allocation can fail while the mask is being updated. If we are about 4828 * to fail, check if the cpuset changed during allocation and if so, 4829 * retry. 4830 */ 4831 if (read_mems_allowed_retry(cpuset_mems_cookie)) 4832 return true; 4833 4834 return false; 4835 } 4836 4837 static inline struct page * 4838 __alloc_pages_slowpath(gfp_t gfp_mask, unsigned int order, 4839 struct alloc_context *ac) 4840 { 4841 bool can_direct_reclaim = gfp_mask & __GFP_DIRECT_RECLAIM; 4842 const bool costly_order = order > PAGE_ALLOC_COSTLY_ORDER; 4843 struct page *page = NULL; 4844 unsigned int alloc_flags; 4845 unsigned long did_some_progress; 4846 enum compact_priority compact_priority; 4847 enum compact_result compact_result; 4848 int compaction_retries; 4849 int no_progress_loops; 4850 unsigned int cpuset_mems_cookie; 4851 int reserve_flags; 4852 4853 /* 4854 * We also sanity check to catch abuse of atomic reserves being used by 4855 * callers that are not in atomic context. 4856 */ 4857 if (WARN_ON_ONCE((gfp_mask & (__GFP_ATOMIC|__GFP_DIRECT_RECLAIM)) == 4858 (__GFP_ATOMIC|__GFP_DIRECT_RECLAIM))) 4859 gfp_mask &= ~__GFP_ATOMIC; 4860 4861 retry_cpuset: 4862 compaction_retries = 0; 4863 no_progress_loops = 0; 4864 compact_priority = DEF_COMPACT_PRIORITY; 4865 cpuset_mems_cookie = read_mems_allowed_begin(); 4866 4867 /* 4868 * The fast path uses conservative alloc_flags to succeed only until 4869 * kswapd needs to be woken up, and to avoid the cost of setting up 4870 * alloc_flags precisely. So we do that now. 4871 */ 4872 alloc_flags = gfp_to_alloc_flags(gfp_mask); 4873 4874 /* 4875 * We need to recalculate the starting point for the zonelist iterator 4876 * because we might have used different nodemask in the fast path, or 4877 * there was a cpuset modification and we are retrying - otherwise we 4878 * could end up iterating over non-eligible zones endlessly. 4879 */ 4880 ac->preferred_zoneref = first_zones_zonelist(ac->zonelist, 4881 ac->highest_zoneidx, ac->nodemask); 4882 if (!ac->preferred_zoneref->zone) 4883 goto nopage; 4884 4885 /* 4886 * Check for insane configurations where the cpuset doesn't contain 4887 * any suitable zone to satisfy the request - e.g. non-movable 4888 * GFP_HIGHUSER allocations from MOVABLE nodes only. 4889 */ 4890 if (cpusets_insane_config() && (gfp_mask & __GFP_HARDWALL)) { 4891 struct zoneref *z = first_zones_zonelist(ac->zonelist, 4892 ac->highest_zoneidx, 4893 &cpuset_current_mems_allowed); 4894 if (!z->zone) 4895 goto nopage; 4896 } 4897 4898 if (alloc_flags & ALLOC_KSWAPD) 4899 wake_all_kswapds(order, gfp_mask, ac); 4900 4901 /* 4902 * The adjusted alloc_flags might result in immediate success, so try 4903 * that first 4904 */ 4905 page = get_page_from_freelist(gfp_mask, order, alloc_flags, ac); 4906 if (page) 4907 goto got_pg; 4908 4909 /* 4910 * For costly allocations, try direct compaction first, as it's likely 4911 * that we have enough base pages and don't need to reclaim. For non- 4912 * movable high-order allocations, do that as well, as compaction will 4913 * try prevent permanent fragmentation by migrating from blocks of the 4914 * same migratetype. 4915 * Don't try this for allocations that are allowed to ignore 4916 * watermarks, as the ALLOC_NO_WATERMARKS attempt didn't yet happen. 4917 */ 4918 if (can_direct_reclaim && 4919 (costly_order || 4920 (order > 0 && ac->migratetype != MIGRATE_MOVABLE)) 4921 && !gfp_pfmemalloc_allowed(gfp_mask)) { 4922 page = __alloc_pages_direct_compact(gfp_mask, order, 4923 alloc_flags, ac, 4924 INIT_COMPACT_PRIORITY, 4925 &compact_result); 4926 if (page) 4927 goto got_pg; 4928 4929 /* 4930 * Checks for costly allocations with __GFP_NORETRY, which 4931 * includes some THP page fault allocations 4932 */ 4933 if (costly_order && (gfp_mask & __GFP_NORETRY)) { 4934 /* 4935 * If allocating entire pageblock(s) and compaction 4936 * failed because all zones are below low watermarks 4937 * or is prohibited because it recently failed at this 4938 * order, fail immediately unless the allocator has 4939 * requested compaction and reclaim retry. 4940 * 4941 * Reclaim is 4942 * - potentially very expensive because zones are far 4943 * below their low watermarks or this is part of very 4944 * bursty high order allocations, 4945 * - not guaranteed to help because isolate_freepages() 4946 * may not iterate over freed pages as part of its 4947 * linear scan, and 4948 * - unlikely to make entire pageblocks free on its 4949 * own. 4950 */ 4951 if (compact_result == COMPACT_SKIPPED || 4952 compact_result == COMPACT_DEFERRED) 4953 goto nopage; 4954 4955 /* 4956 * Looks like reclaim/compaction is worth trying, but 4957 * sync compaction could be very expensive, so keep 4958 * using async compaction. 4959 */ 4960 compact_priority = INIT_COMPACT_PRIORITY; 4961 } 4962 } 4963 4964 retry: 4965 /* Ensure kswapd doesn't accidentally go to sleep as long as we loop */ 4966 if (alloc_flags & ALLOC_KSWAPD) 4967 wake_all_kswapds(order, gfp_mask, ac); 4968 4969 reserve_flags = __gfp_pfmemalloc_flags(gfp_mask); 4970 if (reserve_flags) 4971 alloc_flags = gfp_to_alloc_flags_cma(gfp_mask, reserve_flags); 4972 4973 /* 4974 * Reset the nodemask and zonelist iterators if memory policies can be 4975 * ignored. These allocations are high priority and system rather than 4976 * user oriented. 4977 */ 4978 if (!(alloc_flags & ALLOC_CPUSET) || reserve_flags) { 4979 ac->nodemask = NULL; 4980 ac->preferred_zoneref = first_zones_zonelist(ac->zonelist, 4981 ac->highest_zoneidx, ac->nodemask); 4982 } 4983 4984 /* Attempt with potentially adjusted zonelist and alloc_flags */ 4985 page = get_page_from_freelist(gfp_mask, order, alloc_flags, ac); 4986 if (page) 4987 goto got_pg; 4988 4989 /* Caller is not willing to reclaim, we can't balance anything */ 4990 if (!can_direct_reclaim) 4991 goto nopage; 4992 4993 /* Avoid recursion of direct reclaim */ 4994 if (current->flags & PF_MEMALLOC) 4995 goto nopage; 4996 4997 /* Try direct reclaim and then allocating */ 4998 page = __alloc_pages_direct_reclaim(gfp_mask, order, alloc_flags, ac, 4999 &did_some_progress); 5000 if (page) 5001 goto got_pg; 5002 5003 /* Try direct compaction and then allocating */ 5004 page = __alloc_pages_direct_compact(gfp_mask, order, alloc_flags, ac, 5005 compact_priority, &compact_result); 5006 if (page) 5007 goto got_pg; 5008 5009 /* Do not loop if specifically requested */ 5010 if (gfp_mask & __GFP_NORETRY) 5011 goto nopage; 5012 5013 /* 5014 * Do not retry costly high order allocations unless they are 5015 * __GFP_RETRY_MAYFAIL 5016 */ 5017 if (costly_order && !(gfp_mask & __GFP_RETRY_MAYFAIL)) 5018 goto nopage; 5019 5020 if (should_reclaim_retry(gfp_mask, order, ac, alloc_flags, 5021 did_some_progress > 0, &no_progress_loops)) 5022 goto retry; 5023 5024 /* 5025 * It doesn't make any sense to retry for the compaction if the order-0 5026 * reclaim is not able to make any progress because the current 5027 * implementation of the compaction depends on the sufficient amount 5028 * of free memory (see __compaction_suitable) 5029 */ 5030 if (did_some_progress > 0 && 5031 should_compact_retry(ac, order, alloc_flags, 5032 compact_result, &compact_priority, 5033 &compaction_retries)) 5034 goto retry; 5035 5036 5037 /* Deal with possible cpuset update races before we start OOM killing */ 5038 if (check_retry_cpuset(cpuset_mems_cookie, ac)) 5039 goto retry_cpuset; 5040 5041 /* Reclaim has failed us, start killing things */ 5042 page = __alloc_pages_may_oom(gfp_mask, order, ac, &did_some_progress); 5043 if (page) 5044 goto got_pg; 5045 5046 /* Avoid allocations with no watermarks from looping endlessly */ 5047 if (tsk_is_oom_victim(current) && 5048 (alloc_flags & ALLOC_OOM || 5049 (gfp_mask & __GFP_NOMEMALLOC))) 5050 goto nopage; 5051 5052 /* Retry as long as the OOM killer is making progress */ 5053 if (did_some_progress) { 5054 no_progress_loops = 0; 5055 goto retry; 5056 } 5057 5058 nopage: 5059 /* Deal with possible cpuset update races before we fail */ 5060 if (check_retry_cpuset(cpuset_mems_cookie, ac)) 5061 goto retry_cpuset; 5062 5063 /* 5064 * Make sure that __GFP_NOFAIL request doesn't leak out and make sure 5065 * we always retry 5066 */ 5067 if (gfp_mask & __GFP_NOFAIL) { 5068 /* 5069 * All existing users of the __GFP_NOFAIL are blockable, so warn 5070 * of any new users that actually require GFP_NOWAIT 5071 */ 5072 if (WARN_ON_ONCE(!can_direct_reclaim)) 5073 goto fail; 5074 5075 /* 5076 * PF_MEMALLOC request from this context is rather bizarre 5077 * because we cannot reclaim anything and only can loop waiting 5078 * for somebody to do a work for us 5079 */ 5080 WARN_ON_ONCE(current->flags & PF_MEMALLOC); 5081 5082 /* 5083 * non failing costly orders are a hard requirement which we 5084 * are not prepared for much so let's warn about these users 5085 * so that we can identify them and convert them to something 5086 * else. 5087 */ 5088 WARN_ON_ONCE(order > PAGE_ALLOC_COSTLY_ORDER); 5089 5090 /* 5091 * Help non-failing allocations by giving them access to memory 5092 * reserves but do not use ALLOC_NO_WATERMARKS because this 5093 * could deplete whole memory reserves which would just make 5094 * the situation worse 5095 */ 5096 page = __alloc_pages_cpuset_fallback(gfp_mask, order, ALLOC_HARDER, ac); 5097 if (page) 5098 goto got_pg; 5099 5100 cond_resched(); 5101 goto retry; 5102 } 5103 fail: 5104 warn_alloc(gfp_mask, ac->nodemask, 5105 "page allocation failure: order:%u", order); 5106 got_pg: 5107 return page; 5108 } 5109 5110 static inline bool prepare_alloc_pages(gfp_t gfp_mask, unsigned int order, 5111 int preferred_nid, nodemask_t *nodemask, 5112 struct alloc_context *ac, gfp_t *alloc_gfp, 5113 unsigned int *alloc_flags) 5114 { 5115 ac->highest_zoneidx = gfp_zone(gfp_mask); 5116 ac->zonelist = node_zonelist(preferred_nid, gfp_mask); 5117 ac->nodemask = nodemask; 5118 ac->migratetype = gfp_migratetype(gfp_mask); 5119 5120 if (cpusets_enabled()) { 5121 *alloc_gfp |= __GFP_HARDWALL; 5122 /* 5123 * When we are in the interrupt context, it is irrelevant 5124 * to the current task context. It means that any node ok. 5125 */ 5126 if (in_task() && !ac->nodemask) 5127 ac->nodemask = &cpuset_current_mems_allowed; 5128 else 5129 *alloc_flags |= ALLOC_CPUSET; 5130 } 5131 5132 fs_reclaim_acquire(gfp_mask); 5133 fs_reclaim_release(gfp_mask); 5134 5135 might_sleep_if(gfp_mask & __GFP_DIRECT_RECLAIM); 5136 5137 if (should_fail_alloc_page(gfp_mask, order)) 5138 return false; 5139 5140 *alloc_flags = gfp_to_alloc_flags_cma(gfp_mask, *alloc_flags); 5141 5142 /* Dirty zone balancing only done in the fast path */ 5143 ac->spread_dirty_pages = (gfp_mask & __GFP_WRITE); 5144 5145 /* 5146 * The preferred zone is used for statistics but crucially it is 5147 * also used as the starting point for the zonelist iterator. It 5148 * may get reset for allocations that ignore memory policies. 5149 */ 5150 ac->preferred_zoneref = first_zones_zonelist(ac->zonelist, 5151 ac->highest_zoneidx, ac->nodemask); 5152 5153 return true; 5154 } 5155 5156 /* 5157 * __alloc_pages_bulk - Allocate a number of order-0 pages to a list or array 5158 * @gfp: GFP flags for the allocation 5159 * @preferred_nid: The preferred NUMA node ID to allocate from 5160 * @nodemask: Set of nodes to allocate from, may be NULL 5161 * @nr_pages: The number of pages desired on the list or array 5162 * @page_list: Optional list to store the allocated pages 5163 * @page_array: Optional array to store the pages 5164 * 5165 * This is a batched version of the page allocator that attempts to 5166 * allocate nr_pages quickly. Pages are added to page_list if page_list 5167 * is not NULL, otherwise it is assumed that the page_array is valid. 5168 * 5169 * For lists, nr_pages is the number of pages that should be allocated. 5170 * 5171 * For arrays, only NULL elements are populated with pages and nr_pages 5172 * is the maximum number of pages that will be stored in the array. 5173 * 5174 * Returns the number of pages on the list or array. 5175 */ 5176 unsigned long __alloc_pages_bulk(gfp_t gfp, int preferred_nid, 5177 nodemask_t *nodemask, int nr_pages, 5178 struct list_head *page_list, 5179 struct page **page_array) 5180 { 5181 struct page *page; 5182 unsigned long flags; 5183 struct zone *zone; 5184 struct zoneref *z; 5185 struct per_cpu_pages *pcp; 5186 struct list_head *pcp_list; 5187 struct alloc_context ac; 5188 gfp_t alloc_gfp; 5189 unsigned int alloc_flags = ALLOC_WMARK_LOW; 5190 int nr_populated = 0, nr_account = 0; 5191 5192 /* 5193 * Skip populated array elements to determine if any pages need 5194 * to be allocated before disabling IRQs. 5195 */ 5196 while (page_array && nr_populated < nr_pages && page_array[nr_populated]) 5197 nr_populated++; 5198 5199 /* No pages requested? */ 5200 if (unlikely(nr_pages <= 0)) 5201 goto out; 5202 5203 /* Already populated array? */ 5204 if (unlikely(page_array && nr_pages - nr_populated == 0)) 5205 goto out; 5206 5207 /* Bulk allocator does not support memcg accounting. */ 5208 if (memcg_kmem_enabled() && (gfp & __GFP_ACCOUNT)) 5209 goto failed; 5210 5211 /* Use the single page allocator for one page. */ 5212 if (nr_pages - nr_populated == 1) 5213 goto failed; 5214 5215 #ifdef CONFIG_PAGE_OWNER 5216 /* 5217 * PAGE_OWNER may recurse into the allocator to allocate space to 5218 * save the stack with pagesets.lock held. Releasing/reacquiring 5219 * removes much of the performance benefit of bulk allocation so 5220 * force the caller to allocate one page at a time as it'll have 5221 * similar performance to added complexity to the bulk allocator. 5222 */ 5223 if (static_branch_unlikely(&page_owner_inited)) 5224 goto failed; 5225 #endif 5226 5227 /* May set ALLOC_NOFRAGMENT, fragmentation will return 1 page. */ 5228 gfp &= gfp_allowed_mask; 5229 alloc_gfp = gfp; 5230 if (!prepare_alloc_pages(gfp, 0, preferred_nid, nodemask, &ac, &alloc_gfp, &alloc_flags)) 5231 goto out; 5232 gfp = alloc_gfp; 5233 5234 /* Find an allowed local zone that meets the low watermark. */ 5235 for_each_zone_zonelist_nodemask(zone, z, ac.zonelist, ac.highest_zoneidx, ac.nodemask) { 5236 unsigned long mark; 5237 5238 if (cpusets_enabled() && (alloc_flags & ALLOC_CPUSET) && 5239 !__cpuset_zone_allowed(zone, gfp)) { 5240 continue; 5241 } 5242 5243 if (nr_online_nodes > 1 && zone != ac.preferred_zoneref->zone && 5244 zone_to_nid(zone) != zone_to_nid(ac.preferred_zoneref->zone)) { 5245 goto failed; 5246 } 5247 5248 mark = wmark_pages(zone, alloc_flags & ALLOC_WMARK_MASK) + nr_pages; 5249 if (zone_watermark_fast(zone, 0, mark, 5250 zonelist_zone_idx(ac.preferred_zoneref), 5251 alloc_flags, gfp)) { 5252 break; 5253 } 5254 } 5255 5256 /* 5257 * If there are no allowed local zones that meets the watermarks then 5258 * try to allocate a single page and reclaim if necessary. 5259 */ 5260 if (unlikely(!zone)) 5261 goto failed; 5262 5263 /* Attempt the batch allocation */ 5264 local_lock_irqsave(&pagesets.lock, flags); 5265 pcp = this_cpu_ptr(zone->per_cpu_pageset); 5266 pcp_list = &pcp->lists[order_to_pindex(ac.migratetype, 0)]; 5267 5268 while (nr_populated < nr_pages) { 5269 5270 /* Skip existing pages */ 5271 if (page_array && page_array[nr_populated]) { 5272 nr_populated++; 5273 continue; 5274 } 5275 5276 page = __rmqueue_pcplist(zone, 0, ac.migratetype, alloc_flags, 5277 pcp, pcp_list); 5278 if (unlikely(!page)) { 5279 /* Try and get at least one page */ 5280 if (!nr_populated) 5281 goto failed_irq; 5282 break; 5283 } 5284 nr_account++; 5285 5286 prep_new_page(page, 0, gfp, 0); 5287 if (page_list) 5288 list_add(&page->lru, page_list); 5289 else 5290 page_array[nr_populated] = page; 5291 nr_populated++; 5292 } 5293 5294 local_unlock_irqrestore(&pagesets.lock, flags); 5295 5296 __count_zid_vm_events(PGALLOC, zone_idx(zone), nr_account); 5297 zone_statistics(ac.preferred_zoneref->zone, zone, nr_account); 5298 5299 out: 5300 return nr_populated; 5301 5302 failed_irq: 5303 local_unlock_irqrestore(&pagesets.lock, flags); 5304 5305 failed: 5306 page = __alloc_pages(gfp, 0, preferred_nid, nodemask); 5307 if (page) { 5308 if (page_list) 5309 list_add(&page->lru, page_list); 5310 else 5311 page_array[nr_populated] = page; 5312 nr_populated++; 5313 } 5314 5315 goto out; 5316 } 5317 EXPORT_SYMBOL_GPL(__alloc_pages_bulk); 5318 5319 /* 5320 * This is the 'heart' of the zoned buddy allocator. 5321 */ 5322 struct page *__alloc_pages(gfp_t gfp, unsigned int order, int preferred_nid, 5323 nodemask_t *nodemask) 5324 { 5325 struct page *page; 5326 unsigned int alloc_flags = ALLOC_WMARK_LOW; 5327 gfp_t alloc_gfp; /* The gfp_t that was actually used for allocation */ 5328 struct alloc_context ac = { }; 5329 5330 /* 5331 * There are several places where we assume that the order value is sane 5332 * so bail out early if the request is out of bound. 5333 */ 5334 if (unlikely(order >= MAX_ORDER)) { 5335 WARN_ON_ONCE(!(gfp & __GFP_NOWARN)); 5336 return NULL; 5337 } 5338 5339 gfp &= gfp_allowed_mask; 5340 /* 5341 * Apply scoped allocation constraints. This is mainly about GFP_NOFS 5342 * resp. GFP_NOIO which has to be inherited for all allocation requests 5343 * from a particular context which has been marked by 5344 * memalloc_no{fs,io}_{save,restore}. And PF_MEMALLOC_PIN which ensures 5345 * movable zones are not used during allocation. 5346 */ 5347 gfp = current_gfp_context(gfp); 5348 alloc_gfp = gfp; 5349 if (!prepare_alloc_pages(gfp, order, preferred_nid, nodemask, &ac, 5350 &alloc_gfp, &alloc_flags)) 5351 return NULL; 5352 5353 /* 5354 * Forbid the first pass from falling back to types that fragment 5355 * memory until all local zones are considered. 5356 */ 5357 alloc_flags |= alloc_flags_nofragment(ac.preferred_zoneref->zone, gfp); 5358 5359 /* First allocation attempt */ 5360 page = get_page_from_freelist(alloc_gfp, order, alloc_flags, &ac); 5361 if (likely(page)) 5362 goto out; 5363 5364 alloc_gfp = gfp; 5365 ac.spread_dirty_pages = false; 5366 5367 /* 5368 * Restore the original nodemask if it was potentially replaced with 5369 * &cpuset_current_mems_allowed to optimize the fast-path attempt. 5370 */ 5371 ac.nodemask = nodemask; 5372 5373 page = __alloc_pages_slowpath(alloc_gfp, order, &ac); 5374 5375 out: 5376 if (memcg_kmem_enabled() && (gfp & __GFP_ACCOUNT) && page && 5377 unlikely(__memcg_kmem_charge_page(page, gfp, order) != 0)) { 5378 __free_pages(page, order); 5379 page = NULL; 5380 } 5381 5382 trace_mm_page_alloc(page, order, alloc_gfp, ac.migratetype); 5383 5384 return page; 5385 } 5386 EXPORT_SYMBOL(__alloc_pages); 5387 5388 struct folio *__folio_alloc(gfp_t gfp, unsigned int order, int preferred_nid, 5389 nodemask_t *nodemask) 5390 { 5391 struct page *page = __alloc_pages(gfp | __GFP_COMP, order, 5392 preferred_nid, nodemask); 5393 5394 if (page && order > 1) 5395 prep_transhuge_page(page); 5396 return (struct folio *)page; 5397 } 5398 EXPORT_SYMBOL(__folio_alloc); 5399 5400 /* 5401 * Common helper functions. Never use with __GFP_HIGHMEM because the returned 5402 * address cannot represent highmem pages. Use alloc_pages and then kmap if 5403 * you need to access high mem. 5404 */ 5405 unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order) 5406 { 5407 struct page *page; 5408 5409 page = alloc_pages(gfp_mask & ~__GFP_HIGHMEM, order); 5410 if (!page) 5411 return 0; 5412 return (unsigned long) page_address(page); 5413 } 5414 EXPORT_SYMBOL(__get_free_pages); 5415 5416 unsigned long get_zeroed_page(gfp_t gfp_mask) 5417 { 5418 return __get_free_pages(gfp_mask | __GFP_ZERO, 0); 5419 } 5420 EXPORT_SYMBOL(get_zeroed_page); 5421 5422 /** 5423 * __free_pages - Free pages allocated with alloc_pages(). 5424 * @page: The page pointer returned from alloc_pages(). 5425 * @order: The order of the allocation. 5426 * 5427 * This function can free multi-page allocations that are not compound 5428 * pages. It does not check that the @order passed in matches that of 5429 * the allocation, so it is easy to leak memory. Freeing more memory 5430 * than was allocated will probably emit a warning. 5431 * 5432 * If the last reference to this page is speculative, it will be released 5433 * by put_page() which only frees the first page of a non-compound 5434 * allocation. To prevent the remaining pages from being leaked, we free 5435 * the subsequent pages here. If you want to use the page's reference 5436 * count to decide when to free the allocation, you should allocate a 5437 * compound page, and use put_page() instead of __free_pages(). 5438 * 5439 * Context: May be called in interrupt context or while holding a normal 5440 * spinlock, but not in NMI context or while holding a raw spinlock. 5441 */ 5442 void __free_pages(struct page *page, unsigned int order) 5443 { 5444 if (put_page_testzero(page)) 5445 free_the_page(page, order); 5446 else if (!PageHead(page)) 5447 while (order-- > 0) 5448 free_the_page(page + (1 << order), order); 5449 } 5450 EXPORT_SYMBOL(__free_pages); 5451 5452 void free_pages(unsigned long addr, unsigned int order) 5453 { 5454 if (addr != 0) { 5455 VM_BUG_ON(!virt_addr_valid((void *)addr)); 5456 __free_pages(virt_to_page((void *)addr), order); 5457 } 5458 } 5459 5460 EXPORT_SYMBOL(free_pages); 5461 5462 /* 5463 * Page Fragment: 5464 * An arbitrary-length arbitrary-offset area of memory which resides 5465 * within a 0 or higher order page. Multiple fragments within that page 5466 * are individually refcounted, in the page's reference counter. 5467 * 5468 * The page_frag functions below provide a simple allocation framework for 5469 * page fragments. This is used by the network stack and network device 5470 * drivers to provide a backing region of memory for use as either an 5471 * sk_buff->head, or to be used in the "frags" portion of skb_shared_info. 5472 */ 5473 static struct page *__page_frag_cache_refill(struct page_frag_cache *nc, 5474 gfp_t gfp_mask) 5475 { 5476 struct page *page = NULL; 5477 gfp_t gfp = gfp_mask; 5478 5479 #if (PAGE_SIZE < PAGE_FRAG_CACHE_MAX_SIZE) 5480 gfp_mask |= __GFP_COMP | __GFP_NOWARN | __GFP_NORETRY | 5481 __GFP_NOMEMALLOC; 5482 page = alloc_pages_node(NUMA_NO_NODE, gfp_mask, 5483 PAGE_FRAG_CACHE_MAX_ORDER); 5484 nc->size = page ? PAGE_FRAG_CACHE_MAX_SIZE : PAGE_SIZE; 5485 #endif 5486 if (unlikely(!page)) 5487 page = alloc_pages_node(NUMA_NO_NODE, gfp, 0); 5488 5489 nc->va = page ? page_address(page) : NULL; 5490 5491 return page; 5492 } 5493 5494 void __page_frag_cache_drain(struct page *page, unsigned int count) 5495 { 5496 VM_BUG_ON_PAGE(page_ref_count(page) == 0, page); 5497 5498 if (page_ref_sub_and_test(page, count)) 5499 free_the_page(page, compound_order(page)); 5500 } 5501 EXPORT_SYMBOL(__page_frag_cache_drain); 5502 5503 void *page_frag_alloc_align(struct page_frag_cache *nc, 5504 unsigned int fragsz, gfp_t gfp_mask, 5505 unsigned int align_mask) 5506 { 5507 unsigned int size = PAGE_SIZE; 5508 struct page *page; 5509 int offset; 5510 5511 if (unlikely(!nc->va)) { 5512 refill: 5513 page = __page_frag_cache_refill(nc, gfp_mask); 5514 if (!page) 5515 return NULL; 5516 5517 #if (PAGE_SIZE < PAGE_FRAG_CACHE_MAX_SIZE) 5518 /* if size can vary use size else just use PAGE_SIZE */ 5519 size = nc->size; 5520 #endif 5521 /* Even if we own the page, we do not use atomic_set(). 5522 * This would break get_page_unless_zero() users. 5523 */ 5524 page_ref_add(page, PAGE_FRAG_CACHE_MAX_SIZE); 5525 5526 /* reset page count bias and offset to start of new frag */ 5527 nc->pfmemalloc = page_is_pfmemalloc(page); 5528 nc->pagecnt_bias = PAGE_FRAG_CACHE_MAX_SIZE + 1; 5529 nc->offset = size; 5530 } 5531 5532 offset = nc->offset - fragsz; 5533 if (unlikely(offset < 0)) { 5534 page = virt_to_page(nc->va); 5535 5536 if (!page_ref_sub_and_test(page, nc->pagecnt_bias)) 5537 goto refill; 5538 5539 if (unlikely(nc->pfmemalloc)) { 5540 free_the_page(page, compound_order(page)); 5541 goto refill; 5542 } 5543 5544 #if (PAGE_SIZE < PAGE_FRAG_CACHE_MAX_SIZE) 5545 /* if size can vary use size else just use PAGE_SIZE */ 5546 size = nc->size; 5547 #endif 5548 /* OK, page count is 0, we can safely set it */ 5549 set_page_count(page, PAGE_FRAG_CACHE_MAX_SIZE + 1); 5550 5551 /* reset page count bias and offset to start of new frag */ 5552 nc->pagecnt_bias = PAGE_FRAG_CACHE_MAX_SIZE + 1; 5553 offset = size - fragsz; 5554 } 5555 5556 nc->pagecnt_bias--; 5557 offset &= align_mask; 5558 nc->offset = offset; 5559 5560 return nc->va + offset; 5561 } 5562 EXPORT_SYMBOL(page_frag_alloc_align); 5563 5564 /* 5565 * Frees a page fragment allocated out of either a compound or order 0 page. 5566 */ 5567 void page_frag_free(void *addr) 5568 { 5569 struct page *page = virt_to_head_page(addr); 5570 5571 if (unlikely(put_page_testzero(page))) 5572 free_the_page(page, compound_order(page)); 5573 } 5574 EXPORT_SYMBOL(page_frag_free); 5575 5576 static void *make_alloc_exact(unsigned long addr, unsigned int order, 5577 size_t size) 5578 { 5579 if (addr) { 5580 unsigned long alloc_end = addr + (PAGE_SIZE << order); 5581 unsigned long used = addr + PAGE_ALIGN(size); 5582 5583 split_page(virt_to_page((void *)addr), order); 5584 while (used < alloc_end) { 5585 free_page(used); 5586 used += PAGE_SIZE; 5587 } 5588 } 5589 return (void *)addr; 5590 } 5591 5592 /** 5593 * alloc_pages_exact - allocate an exact number physically-contiguous pages. 5594 * @size: the number of bytes to allocate 5595 * @gfp_mask: GFP flags for the allocation, must not contain __GFP_COMP 5596 * 5597 * This function is similar to alloc_pages(), except that it allocates the 5598 * minimum number of pages to satisfy the request. alloc_pages() can only 5599 * allocate memory in power-of-two pages. 5600 * 5601 * This function is also limited by MAX_ORDER. 5602 * 5603 * Memory allocated by this function must be released by free_pages_exact(). 5604 * 5605 * Return: pointer to the allocated area or %NULL in case of error. 5606 */ 5607 void *alloc_pages_exact(size_t size, gfp_t gfp_mask) 5608 { 5609 unsigned int order = get_order(size); 5610 unsigned long addr; 5611 5612 if (WARN_ON_ONCE(gfp_mask & (__GFP_COMP | __GFP_HIGHMEM))) 5613 gfp_mask &= ~(__GFP_COMP | __GFP_HIGHMEM); 5614 5615 addr = __get_free_pages(gfp_mask, order); 5616 return make_alloc_exact(addr, order, size); 5617 } 5618 EXPORT_SYMBOL(alloc_pages_exact); 5619 5620 /** 5621 * alloc_pages_exact_nid - allocate an exact number of physically-contiguous 5622 * pages on a node. 5623 * @nid: the preferred node ID where memory should be allocated 5624 * @size: the number of bytes to allocate 5625 * @gfp_mask: GFP flags for the allocation, must not contain __GFP_COMP 5626 * 5627 * Like alloc_pages_exact(), but try to allocate on node nid first before falling 5628 * back. 5629 * 5630 * Return: pointer to the allocated area or %NULL in case of error. 5631 */ 5632 void * __meminit alloc_pages_exact_nid(int nid, size_t size, gfp_t gfp_mask) 5633 { 5634 unsigned int order = get_order(size); 5635 struct page *p; 5636 5637 if (WARN_ON_ONCE(gfp_mask & (__GFP_COMP | __GFP_HIGHMEM))) 5638 gfp_mask &= ~(__GFP_COMP | __GFP_HIGHMEM); 5639 5640 p = alloc_pages_node(nid, gfp_mask, order); 5641 if (!p) 5642 return NULL; 5643 return make_alloc_exact((unsigned long)page_address(p), order, size); 5644 } 5645 5646 /** 5647 * free_pages_exact - release memory allocated via alloc_pages_exact() 5648 * @virt: the value returned by alloc_pages_exact. 5649 * @size: size of allocation, same value as passed to alloc_pages_exact(). 5650 * 5651 * Release the memory allocated by a previous call to alloc_pages_exact. 5652 */ 5653 void free_pages_exact(void *virt, size_t size) 5654 { 5655 unsigned long addr = (unsigned long)virt; 5656 unsigned long end = addr + PAGE_ALIGN(size); 5657 5658 while (addr < end) { 5659 free_page(addr); 5660 addr += PAGE_SIZE; 5661 } 5662 } 5663 EXPORT_SYMBOL(free_pages_exact); 5664 5665 /** 5666 * nr_free_zone_pages - count number of pages beyond high watermark 5667 * @offset: The zone index of the highest zone 5668 * 5669 * nr_free_zone_pages() counts the number of pages which are beyond the 5670 * high watermark within all zones at or below a given zone index. For each 5671 * zone, the number of pages is calculated as: 5672 * 5673 * nr_free_zone_pages = managed_pages - high_pages 5674 * 5675 * Return: number of pages beyond high watermark. 5676 */ 5677 static unsigned long nr_free_zone_pages(int offset) 5678 { 5679 struct zoneref *z; 5680 struct zone *zone; 5681 5682 /* Just pick one node, since fallback list is circular */ 5683 unsigned long sum = 0; 5684 5685 struct zonelist *zonelist = node_zonelist(numa_node_id(), GFP_KERNEL); 5686 5687 for_each_zone_zonelist(zone, z, zonelist, offset) { 5688 unsigned long size = zone_managed_pages(zone); 5689 unsigned long high = high_wmark_pages(zone); 5690 if (size > high) 5691 sum += size - high; 5692 } 5693 5694 return sum; 5695 } 5696 5697 /** 5698 * nr_free_buffer_pages - count number of pages beyond high watermark 5699 * 5700 * nr_free_buffer_pages() counts the number of pages which are beyond the high 5701 * watermark within ZONE_DMA and ZONE_NORMAL. 5702 * 5703 * Return: number of pages beyond high watermark within ZONE_DMA and 5704 * ZONE_NORMAL. 5705 */ 5706 unsigned long nr_free_buffer_pages(void) 5707 { 5708 return nr_free_zone_pages(gfp_zone(GFP_USER)); 5709 } 5710 EXPORT_SYMBOL_GPL(nr_free_buffer_pages); 5711 5712 static inline void show_node(struct zone *zone) 5713 { 5714 if (IS_ENABLED(CONFIG_NUMA)) 5715 printk("Node %d ", zone_to_nid(zone)); 5716 } 5717 5718 long si_mem_available(void) 5719 { 5720 long available; 5721 unsigned long pagecache; 5722 unsigned long wmark_low = 0; 5723 unsigned long pages[NR_LRU_LISTS]; 5724 unsigned long reclaimable; 5725 struct zone *zone; 5726 int lru; 5727 5728 for (lru = LRU_BASE; lru < NR_LRU_LISTS; lru++) 5729 pages[lru] = global_node_page_state(NR_LRU_BASE + lru); 5730 5731 for_each_zone(zone) 5732 wmark_low += low_wmark_pages(zone); 5733 5734 /* 5735 * Estimate the amount of memory available for userspace allocations, 5736 * without causing swapping. 5737 */ 5738 available = global_zone_page_state(NR_FREE_PAGES) - totalreserve_pages; 5739 5740 /* 5741 * Not all the page cache can be freed, otherwise the system will 5742 * start swapping. Assume at least half of the page cache, or the 5743 * low watermark worth of cache, needs to stay. 5744 */ 5745 pagecache = pages[LRU_ACTIVE_FILE] + pages[LRU_INACTIVE_FILE]; 5746 pagecache -= min(pagecache / 2, wmark_low); 5747 available += pagecache; 5748 5749 /* 5750 * Part of the reclaimable slab and other kernel memory consists of 5751 * items that are in use, and cannot be freed. Cap this estimate at the 5752 * low watermark. 5753 */ 5754 reclaimable = global_node_page_state_pages(NR_SLAB_RECLAIMABLE_B) + 5755 global_node_page_state(NR_KERNEL_MISC_RECLAIMABLE); 5756 available += reclaimable - min(reclaimable / 2, wmark_low); 5757 5758 if (available < 0) 5759 available = 0; 5760 return available; 5761 } 5762 EXPORT_SYMBOL_GPL(si_mem_available); 5763 5764 void si_meminfo(struct sysinfo *val) 5765 { 5766 val->totalram = totalram_pages(); 5767 val->sharedram = global_node_page_state(NR_SHMEM); 5768 val->freeram = global_zone_page_state(NR_FREE_PAGES); 5769 val->bufferram = nr_blockdev_pages(); 5770 val->totalhigh = totalhigh_pages(); 5771 val->freehigh = nr_free_highpages(); 5772 val->mem_unit = PAGE_SIZE; 5773 } 5774 5775 EXPORT_SYMBOL(si_meminfo); 5776 5777 #ifdef CONFIG_NUMA 5778 void si_meminfo_node(struct sysinfo *val, int nid) 5779 { 5780 int zone_type; /* needs to be signed */ 5781 unsigned long managed_pages = 0; 5782 unsigned long managed_highpages = 0; 5783 unsigned long free_highpages = 0; 5784 pg_data_t *pgdat = NODE_DATA(nid); 5785 5786 for (zone_type = 0; zone_type < MAX_NR_ZONES; zone_type++) 5787 managed_pages += zone_managed_pages(&pgdat->node_zones[zone_type]); 5788 val->totalram = managed_pages; 5789 val->sharedram = node_page_state(pgdat, NR_SHMEM); 5790 val->freeram = sum_zone_node_page_state(nid, NR_FREE_PAGES); 5791 #ifdef CONFIG_HIGHMEM 5792 for (zone_type = 0; zone_type < MAX_NR_ZONES; zone_type++) { 5793 struct zone *zone = &pgdat->node_zones[zone_type]; 5794 5795 if (is_highmem(zone)) { 5796 managed_highpages += zone_managed_pages(zone); 5797 free_highpages += zone_page_state(zone, NR_FREE_PAGES); 5798 } 5799 } 5800 val->totalhigh = managed_highpages; 5801 val->freehigh = free_highpages; 5802 #else 5803 val->totalhigh = managed_highpages; 5804 val->freehigh = free_highpages; 5805 #endif 5806 val->mem_unit = PAGE_SIZE; 5807 } 5808 #endif 5809 5810 /* 5811 * Determine whether the node should be displayed or not, depending on whether 5812 * SHOW_MEM_FILTER_NODES was passed to show_free_areas(). 5813 */ 5814 static bool show_mem_node_skip(unsigned int flags, int nid, nodemask_t *nodemask) 5815 { 5816 if (!(flags & SHOW_MEM_FILTER_NODES)) 5817 return false; 5818 5819 /* 5820 * no node mask - aka implicit memory numa policy. Do not bother with 5821 * the synchronization - read_mems_allowed_begin - because we do not 5822 * have to be precise here. 5823 */ 5824 if (!nodemask) 5825 nodemask = &cpuset_current_mems_allowed; 5826 5827 return !node_isset(nid, *nodemask); 5828 } 5829 5830 #define K(x) ((x) << (PAGE_SHIFT-10)) 5831 5832 static void show_migration_types(unsigned char type) 5833 { 5834 static const char types[MIGRATE_TYPES] = { 5835 [MIGRATE_UNMOVABLE] = 'U', 5836 [MIGRATE_MOVABLE] = 'M', 5837 [MIGRATE_RECLAIMABLE] = 'E', 5838 [MIGRATE_HIGHATOMIC] = 'H', 5839 #ifdef CONFIG_CMA 5840 [MIGRATE_CMA] = 'C', 5841 #endif 5842 #ifdef CONFIG_MEMORY_ISOLATION 5843 [MIGRATE_ISOLATE] = 'I', 5844 #endif 5845 }; 5846 char tmp[MIGRATE_TYPES + 1]; 5847 char *p = tmp; 5848 int i; 5849 5850 for (i = 0; i < MIGRATE_TYPES; i++) { 5851 if (type & (1 << i)) 5852 *p++ = types[i]; 5853 } 5854 5855 *p = '\0'; 5856 printk(KERN_CONT "(%s) ", tmp); 5857 } 5858 5859 /* 5860 * Show free area list (used inside shift_scroll-lock stuff) 5861 * We also calculate the percentage fragmentation. We do this by counting the 5862 * memory on each free list with the exception of the first item on the list. 5863 * 5864 * Bits in @filter: 5865 * SHOW_MEM_FILTER_NODES: suppress nodes that are not allowed by current's 5866 * cpuset. 5867 */ 5868 void show_free_areas(unsigned int filter, nodemask_t *nodemask) 5869 { 5870 unsigned long free_pcp = 0; 5871 int cpu; 5872 struct zone *zone; 5873 pg_data_t *pgdat; 5874 5875 for_each_populated_zone(zone) { 5876 if (show_mem_node_skip(filter, zone_to_nid(zone), nodemask)) 5877 continue; 5878 5879 for_each_online_cpu(cpu) 5880 free_pcp += per_cpu_ptr(zone->per_cpu_pageset, cpu)->count; 5881 } 5882 5883 printk("active_anon:%lu inactive_anon:%lu isolated_anon:%lu\n" 5884 " active_file:%lu inactive_file:%lu isolated_file:%lu\n" 5885 " unevictable:%lu dirty:%lu writeback:%lu\n" 5886 " slab_reclaimable:%lu slab_unreclaimable:%lu\n" 5887 " mapped:%lu shmem:%lu pagetables:%lu bounce:%lu\n" 5888 " kernel_misc_reclaimable:%lu\n" 5889 " free:%lu free_pcp:%lu free_cma:%lu\n", 5890 global_node_page_state(NR_ACTIVE_ANON), 5891 global_node_page_state(NR_INACTIVE_ANON), 5892 global_node_page_state(NR_ISOLATED_ANON), 5893 global_node_page_state(NR_ACTIVE_FILE), 5894 global_node_page_state(NR_INACTIVE_FILE), 5895 global_node_page_state(NR_ISOLATED_FILE), 5896 global_node_page_state(NR_UNEVICTABLE), 5897 global_node_page_state(NR_FILE_DIRTY), 5898 global_node_page_state(NR_WRITEBACK), 5899 global_node_page_state_pages(NR_SLAB_RECLAIMABLE_B), 5900 global_node_page_state_pages(NR_SLAB_UNRECLAIMABLE_B), 5901 global_node_page_state(NR_FILE_MAPPED), 5902 global_node_page_state(NR_SHMEM), 5903 global_node_page_state(NR_PAGETABLE), 5904 global_zone_page_state(NR_BOUNCE), 5905 global_node_page_state(NR_KERNEL_MISC_RECLAIMABLE), 5906 global_zone_page_state(NR_FREE_PAGES), 5907 free_pcp, 5908 global_zone_page_state(NR_FREE_CMA_PAGES)); 5909 5910 for_each_online_pgdat(pgdat) { 5911 if (show_mem_node_skip(filter, pgdat->node_id, nodemask)) 5912 continue; 5913 5914 printk("Node %d" 5915 " active_anon:%lukB" 5916 " inactive_anon:%lukB" 5917 " active_file:%lukB" 5918 " inactive_file:%lukB" 5919 " unevictable:%lukB" 5920 " isolated(anon):%lukB" 5921 " isolated(file):%lukB" 5922 " mapped:%lukB" 5923 " dirty:%lukB" 5924 " writeback:%lukB" 5925 " shmem:%lukB" 5926 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 5927 " shmem_thp: %lukB" 5928 " shmem_pmdmapped: %lukB" 5929 " anon_thp: %lukB" 5930 #endif 5931 " writeback_tmp:%lukB" 5932 " kernel_stack:%lukB" 5933 #ifdef CONFIG_SHADOW_CALL_STACK 5934 " shadow_call_stack:%lukB" 5935 #endif 5936 " pagetables:%lukB" 5937 " all_unreclaimable? %s" 5938 "\n", 5939 pgdat->node_id, 5940 K(node_page_state(pgdat, NR_ACTIVE_ANON)), 5941 K(node_page_state(pgdat, NR_INACTIVE_ANON)), 5942 K(node_page_state(pgdat, NR_ACTIVE_FILE)), 5943 K(node_page_state(pgdat, NR_INACTIVE_FILE)), 5944 K(node_page_state(pgdat, NR_UNEVICTABLE)), 5945 K(node_page_state(pgdat, NR_ISOLATED_ANON)), 5946 K(node_page_state(pgdat, NR_ISOLATED_FILE)), 5947 K(node_page_state(pgdat, NR_FILE_MAPPED)), 5948 K(node_page_state(pgdat, NR_FILE_DIRTY)), 5949 K(node_page_state(pgdat, NR_WRITEBACK)), 5950 K(node_page_state(pgdat, NR_SHMEM)), 5951 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 5952 K(node_page_state(pgdat, NR_SHMEM_THPS)), 5953 K(node_page_state(pgdat, NR_SHMEM_PMDMAPPED)), 5954 K(node_page_state(pgdat, NR_ANON_THPS)), 5955 #endif 5956 K(node_page_state(pgdat, NR_WRITEBACK_TEMP)), 5957 node_page_state(pgdat, NR_KERNEL_STACK_KB), 5958 #ifdef CONFIG_SHADOW_CALL_STACK 5959 node_page_state(pgdat, NR_KERNEL_SCS_KB), 5960 #endif 5961 K(node_page_state(pgdat, NR_PAGETABLE)), 5962 pgdat->kswapd_failures >= MAX_RECLAIM_RETRIES ? 5963 "yes" : "no"); 5964 } 5965 5966 for_each_populated_zone(zone) { 5967 int i; 5968 5969 if (show_mem_node_skip(filter, zone_to_nid(zone), nodemask)) 5970 continue; 5971 5972 free_pcp = 0; 5973 for_each_online_cpu(cpu) 5974 free_pcp += per_cpu_ptr(zone->per_cpu_pageset, cpu)->count; 5975 5976 show_node(zone); 5977 printk(KERN_CONT 5978 "%s" 5979 " free:%lukB" 5980 " boost:%lukB" 5981 " min:%lukB" 5982 " low:%lukB" 5983 " high:%lukB" 5984 " reserved_highatomic:%luKB" 5985 " active_anon:%lukB" 5986 " inactive_anon:%lukB" 5987 " active_file:%lukB" 5988 " inactive_file:%lukB" 5989 " unevictable:%lukB" 5990 " writepending:%lukB" 5991 " present:%lukB" 5992 " managed:%lukB" 5993 " mlocked:%lukB" 5994 " bounce:%lukB" 5995 " free_pcp:%lukB" 5996 " local_pcp:%ukB" 5997 " free_cma:%lukB" 5998 "\n", 5999 zone->name, 6000 K(zone_page_state(zone, NR_FREE_PAGES)), 6001 K(zone->watermark_boost), 6002 K(min_wmark_pages(zone)), 6003 K(low_wmark_pages(zone)), 6004 K(high_wmark_pages(zone)), 6005 K(zone->nr_reserved_highatomic), 6006 K(zone_page_state(zone, NR_ZONE_ACTIVE_ANON)), 6007 K(zone_page_state(zone, NR_ZONE_INACTIVE_ANON)), 6008 K(zone_page_state(zone, NR_ZONE_ACTIVE_FILE)), 6009 K(zone_page_state(zone, NR_ZONE_INACTIVE_FILE)), 6010 K(zone_page_state(zone, NR_ZONE_UNEVICTABLE)), 6011 K(zone_page_state(zone, NR_ZONE_WRITE_PENDING)), 6012 K(zone->present_pages), 6013 K(zone_managed_pages(zone)), 6014 K(zone_page_state(zone, NR_MLOCK)), 6015 K(zone_page_state(zone, NR_BOUNCE)), 6016 K(free_pcp), 6017 K(this_cpu_read(zone->per_cpu_pageset->count)), 6018 K(zone_page_state(zone, NR_FREE_CMA_PAGES))); 6019 printk("lowmem_reserve[]:"); 6020 for (i = 0; i < MAX_NR_ZONES; i++) 6021 printk(KERN_CONT " %ld", zone->lowmem_reserve[i]); 6022 printk(KERN_CONT "\n"); 6023 } 6024 6025 for_each_populated_zone(zone) { 6026 unsigned int order; 6027 unsigned long nr[MAX_ORDER], flags, total = 0; 6028 unsigned char types[MAX_ORDER]; 6029 6030 if (show_mem_node_skip(filter, zone_to_nid(zone), nodemask)) 6031 continue; 6032 show_node(zone); 6033 printk(KERN_CONT "%s: ", zone->name); 6034 6035 spin_lock_irqsave(&zone->lock, flags); 6036 for (order = 0; order < MAX_ORDER; order++) { 6037 struct free_area *area = &zone->free_area[order]; 6038 int type; 6039 6040 nr[order] = area->nr_free; 6041 total += nr[order] << order; 6042 6043 types[order] = 0; 6044 for (type = 0; type < MIGRATE_TYPES; type++) { 6045 if (!free_area_empty(area, type)) 6046 types[order] |= 1 << type; 6047 } 6048 } 6049 spin_unlock_irqrestore(&zone->lock, flags); 6050 for (order = 0; order < MAX_ORDER; order++) { 6051 printk(KERN_CONT "%lu*%lukB ", 6052 nr[order], K(1UL) << order); 6053 if (nr[order]) 6054 show_migration_types(types[order]); 6055 } 6056 printk(KERN_CONT "= %lukB\n", K(total)); 6057 } 6058 6059 hugetlb_show_meminfo(); 6060 6061 printk("%ld total pagecache pages\n", global_node_page_state(NR_FILE_PAGES)); 6062 6063 show_swap_cache_info(); 6064 } 6065 6066 static void zoneref_set_zone(struct zone *zone, struct zoneref *zoneref) 6067 { 6068 zoneref->zone = zone; 6069 zoneref->zone_idx = zone_idx(zone); 6070 } 6071 6072 /* 6073 * Builds allocation fallback zone lists. 6074 * 6075 * Add all populated zones of a node to the zonelist. 6076 */ 6077 static int build_zonerefs_node(pg_data_t *pgdat, struct zoneref *zonerefs) 6078 { 6079 struct zone *zone; 6080 enum zone_type zone_type = MAX_NR_ZONES; 6081 int nr_zones = 0; 6082 6083 do { 6084 zone_type--; 6085 zone = pgdat->node_zones + zone_type; 6086 if (populated_zone(zone)) { 6087 zoneref_set_zone(zone, &zonerefs[nr_zones++]); 6088 check_highest_zone(zone_type); 6089 } 6090 } while (zone_type); 6091 6092 return nr_zones; 6093 } 6094 6095 #ifdef CONFIG_NUMA 6096 6097 static int __parse_numa_zonelist_order(char *s) 6098 { 6099 /* 6100 * We used to support different zonelists modes but they turned 6101 * out to be just not useful. Let's keep the warning in place 6102 * if somebody still use the cmd line parameter so that we do 6103 * not fail it silently 6104 */ 6105 if (!(*s == 'd' || *s == 'D' || *s == 'n' || *s == 'N')) { 6106 pr_warn("Ignoring unsupported numa_zonelist_order value: %s\n", s); 6107 return -EINVAL; 6108 } 6109 return 0; 6110 } 6111 6112 char numa_zonelist_order[] = "Node"; 6113 6114 /* 6115 * sysctl handler for numa_zonelist_order 6116 */ 6117 int numa_zonelist_order_handler(struct ctl_table *table, int write, 6118 void *buffer, size_t *length, loff_t *ppos) 6119 { 6120 if (write) 6121 return __parse_numa_zonelist_order(buffer); 6122 return proc_dostring(table, write, buffer, length, ppos); 6123 } 6124 6125 6126 static int node_load[MAX_NUMNODES]; 6127 6128 /** 6129 * find_next_best_node - find the next node that should appear in a given node's fallback list 6130 * @node: node whose fallback list we're appending 6131 * @used_node_mask: nodemask_t of already used nodes 6132 * 6133 * We use a number of factors to determine which is the next node that should 6134 * appear on a given node's fallback list. The node should not have appeared 6135 * already in @node's fallback list, and it should be the next closest node 6136 * according to the distance array (which contains arbitrary distance values 6137 * from each node to each node in the system), and should also prefer nodes 6138 * with no CPUs, since presumably they'll have very little allocation pressure 6139 * on them otherwise. 6140 * 6141 * Return: node id of the found node or %NUMA_NO_NODE if no node is found. 6142 */ 6143 int find_next_best_node(int node, nodemask_t *used_node_mask) 6144 { 6145 int n, val; 6146 int min_val = INT_MAX; 6147 int best_node = NUMA_NO_NODE; 6148 6149 /* Use the local node if we haven't already */ 6150 if (!node_isset(node, *used_node_mask)) { 6151 node_set(node, *used_node_mask); 6152 return node; 6153 } 6154 6155 for_each_node_state(n, N_MEMORY) { 6156 6157 /* Don't want a node to appear more than once */ 6158 if (node_isset(n, *used_node_mask)) 6159 continue; 6160 6161 /* Use the distance array to find the distance */ 6162 val = node_distance(node, n); 6163 6164 /* Penalize nodes under us ("prefer the next node") */ 6165 val += (n < node); 6166 6167 /* Give preference to headless and unused nodes */ 6168 if (!cpumask_empty(cpumask_of_node(n))) 6169 val += PENALTY_FOR_NODE_WITH_CPUS; 6170 6171 /* Slight preference for less loaded node */ 6172 val *= MAX_NUMNODES; 6173 val += node_load[n]; 6174 6175 if (val < min_val) { 6176 min_val = val; 6177 best_node = n; 6178 } 6179 } 6180 6181 if (best_node >= 0) 6182 node_set(best_node, *used_node_mask); 6183 6184 return best_node; 6185 } 6186 6187 6188 /* 6189 * Build zonelists ordered by node and zones within node. 6190 * This results in maximum locality--normal zone overflows into local 6191 * DMA zone, if any--but risks exhausting DMA zone. 6192 */ 6193 static void build_zonelists_in_node_order(pg_data_t *pgdat, int *node_order, 6194 unsigned nr_nodes) 6195 { 6196 struct zoneref *zonerefs; 6197 int i; 6198 6199 zonerefs = pgdat->node_zonelists[ZONELIST_FALLBACK]._zonerefs; 6200 6201 for (i = 0; i < nr_nodes; i++) { 6202 int nr_zones; 6203 6204 pg_data_t *node = NODE_DATA(node_order[i]); 6205 6206 nr_zones = build_zonerefs_node(node, zonerefs); 6207 zonerefs += nr_zones; 6208 } 6209 zonerefs->zone = NULL; 6210 zonerefs->zone_idx = 0; 6211 } 6212 6213 /* 6214 * Build gfp_thisnode zonelists 6215 */ 6216 static void build_thisnode_zonelists(pg_data_t *pgdat) 6217 { 6218 struct zoneref *zonerefs; 6219 int nr_zones; 6220 6221 zonerefs = pgdat->node_zonelists[ZONELIST_NOFALLBACK]._zonerefs; 6222 nr_zones = build_zonerefs_node(pgdat, zonerefs); 6223 zonerefs += nr_zones; 6224 zonerefs->zone = NULL; 6225 zonerefs->zone_idx = 0; 6226 } 6227 6228 /* 6229 * Build zonelists ordered by zone and nodes within zones. 6230 * This results in conserving DMA zone[s] until all Normal memory is 6231 * exhausted, but results in overflowing to remote node while memory 6232 * may still exist in local DMA zone. 6233 */ 6234 6235 static void build_zonelists(pg_data_t *pgdat) 6236 { 6237 static int node_order[MAX_NUMNODES]; 6238 int node, nr_nodes = 0; 6239 nodemask_t used_mask = NODE_MASK_NONE; 6240 int local_node, prev_node; 6241 6242 /* NUMA-aware ordering of nodes */ 6243 local_node = pgdat->node_id; 6244 prev_node = local_node; 6245 6246 memset(node_order, 0, sizeof(node_order)); 6247 while ((node = find_next_best_node(local_node, &used_mask)) >= 0) { 6248 /* 6249 * We don't want to pressure a particular node. 6250 * So adding penalty to the first node in same 6251 * distance group to make it round-robin. 6252 */ 6253 if (node_distance(local_node, node) != 6254 node_distance(local_node, prev_node)) 6255 node_load[node] += 1; 6256 6257 node_order[nr_nodes++] = node; 6258 prev_node = node; 6259 } 6260 6261 build_zonelists_in_node_order(pgdat, node_order, nr_nodes); 6262 build_thisnode_zonelists(pgdat); 6263 pr_info("Fallback order for Node %d: ", local_node); 6264 for (node = 0; node < nr_nodes; node++) 6265 pr_cont("%d ", node_order[node]); 6266 pr_cont("\n"); 6267 } 6268 6269 #ifdef CONFIG_HAVE_MEMORYLESS_NODES 6270 /* 6271 * Return node id of node used for "local" allocations. 6272 * I.e., first node id of first zone in arg node's generic zonelist. 6273 * Used for initializing percpu 'numa_mem', which is used primarily 6274 * for kernel allocations, so use GFP_KERNEL flags to locate zonelist. 6275 */ 6276 int local_memory_node(int node) 6277 { 6278 struct zoneref *z; 6279 6280 z = first_zones_zonelist(node_zonelist(node, GFP_KERNEL), 6281 gfp_zone(GFP_KERNEL), 6282 NULL); 6283 return zone_to_nid(z->zone); 6284 } 6285 #endif 6286 6287 static void setup_min_unmapped_ratio(void); 6288 static void setup_min_slab_ratio(void); 6289 #else /* CONFIG_NUMA */ 6290 6291 static void build_zonelists(pg_data_t *pgdat) 6292 { 6293 int node, local_node; 6294 struct zoneref *zonerefs; 6295 int nr_zones; 6296 6297 local_node = pgdat->node_id; 6298 6299 zonerefs = pgdat->node_zonelists[ZONELIST_FALLBACK]._zonerefs; 6300 nr_zones = build_zonerefs_node(pgdat, zonerefs); 6301 zonerefs += nr_zones; 6302 6303 /* 6304 * Now we build the zonelist so that it contains the zones 6305 * of all the other nodes. 6306 * We don't want to pressure a particular node, so when 6307 * building the zones for node N, we make sure that the 6308 * zones coming right after the local ones are those from 6309 * node N+1 (modulo N) 6310 */ 6311 for (node = local_node + 1; node < MAX_NUMNODES; node++) { 6312 if (!node_online(node)) 6313 continue; 6314 nr_zones = build_zonerefs_node(NODE_DATA(node), zonerefs); 6315 zonerefs += nr_zones; 6316 } 6317 for (node = 0; node < local_node; node++) { 6318 if (!node_online(node)) 6319 continue; 6320 nr_zones = build_zonerefs_node(NODE_DATA(node), zonerefs); 6321 zonerefs += nr_zones; 6322 } 6323 6324 zonerefs->zone = NULL; 6325 zonerefs->zone_idx = 0; 6326 } 6327 6328 #endif /* CONFIG_NUMA */ 6329 6330 /* 6331 * Boot pageset table. One per cpu which is going to be used for all 6332 * zones and all nodes. The parameters will be set in such a way 6333 * that an item put on a list will immediately be handed over to 6334 * the buddy list. This is safe since pageset manipulation is done 6335 * with interrupts disabled. 6336 * 6337 * The boot_pagesets must be kept even after bootup is complete for 6338 * unused processors and/or zones. They do play a role for bootstrapping 6339 * hotplugged processors. 6340 * 6341 * zoneinfo_show() and maybe other functions do 6342 * not check if the processor is online before following the pageset pointer. 6343 * Other parts of the kernel may not check if the zone is available. 6344 */ 6345 static void per_cpu_pages_init(struct per_cpu_pages *pcp, struct per_cpu_zonestat *pzstats); 6346 /* These effectively disable the pcplists in the boot pageset completely */ 6347 #define BOOT_PAGESET_HIGH 0 6348 #define BOOT_PAGESET_BATCH 1 6349 static DEFINE_PER_CPU(struct per_cpu_pages, boot_pageset); 6350 static DEFINE_PER_CPU(struct per_cpu_zonestat, boot_zonestats); 6351 DEFINE_PER_CPU(struct per_cpu_nodestat, boot_nodestats); 6352 6353 static void __build_all_zonelists(void *data) 6354 { 6355 int nid; 6356 int __maybe_unused cpu; 6357 pg_data_t *self = data; 6358 static DEFINE_SPINLOCK(lock); 6359 6360 spin_lock(&lock); 6361 6362 #ifdef CONFIG_NUMA 6363 memset(node_load, 0, sizeof(node_load)); 6364 #endif 6365 6366 /* 6367 * This node is hotadded and no memory is yet present. So just 6368 * building zonelists is fine - no need to touch other nodes. 6369 */ 6370 if (self && !node_online(self->node_id)) { 6371 build_zonelists(self); 6372 } else { 6373 /* 6374 * All possible nodes have pgdat preallocated 6375 * in free_area_init 6376 */ 6377 for_each_node(nid) { 6378 pg_data_t *pgdat = NODE_DATA(nid); 6379 6380 build_zonelists(pgdat); 6381 } 6382 6383 #ifdef CONFIG_HAVE_MEMORYLESS_NODES 6384 /* 6385 * We now know the "local memory node" for each node-- 6386 * i.e., the node of the first zone in the generic zonelist. 6387 * Set up numa_mem percpu variable for on-line cpus. During 6388 * boot, only the boot cpu should be on-line; we'll init the 6389 * secondary cpus' numa_mem as they come on-line. During 6390 * node/memory hotplug, we'll fixup all on-line cpus. 6391 */ 6392 for_each_online_cpu(cpu) 6393 set_cpu_numa_mem(cpu, local_memory_node(cpu_to_node(cpu))); 6394 #endif 6395 } 6396 6397 spin_unlock(&lock); 6398 } 6399 6400 static noinline void __init 6401 build_all_zonelists_init(void) 6402 { 6403 int cpu; 6404 6405 __build_all_zonelists(NULL); 6406 6407 /* 6408 * Initialize the boot_pagesets that are going to be used 6409 * for bootstrapping processors. The real pagesets for 6410 * each zone will be allocated later when the per cpu 6411 * allocator is available. 6412 * 6413 * boot_pagesets are used also for bootstrapping offline 6414 * cpus if the system is already booted because the pagesets 6415 * are needed to initialize allocators on a specific cpu too. 6416 * F.e. the percpu allocator needs the page allocator which 6417 * needs the percpu allocator in order to allocate its pagesets 6418 * (a chicken-egg dilemma). 6419 */ 6420 for_each_possible_cpu(cpu) 6421 per_cpu_pages_init(&per_cpu(boot_pageset, cpu), &per_cpu(boot_zonestats, cpu)); 6422 6423 mminit_verify_zonelist(); 6424 cpuset_init_current_mems_allowed(); 6425 } 6426 6427 /* 6428 * unless system_state == SYSTEM_BOOTING. 6429 * 6430 * __ref due to call of __init annotated helper build_all_zonelists_init 6431 * [protected by SYSTEM_BOOTING]. 6432 */ 6433 void __ref build_all_zonelists(pg_data_t *pgdat) 6434 { 6435 unsigned long vm_total_pages; 6436 6437 if (system_state == SYSTEM_BOOTING) { 6438 build_all_zonelists_init(); 6439 } else { 6440 __build_all_zonelists(pgdat); 6441 /* cpuset refresh routine should be here */ 6442 } 6443 /* Get the number of free pages beyond high watermark in all zones. */ 6444 vm_total_pages = nr_free_zone_pages(gfp_zone(GFP_HIGHUSER_MOVABLE)); 6445 /* 6446 * Disable grouping by mobility if the number of pages in the 6447 * system is too low to allow the mechanism to work. It would be 6448 * more accurate, but expensive to check per-zone. This check is 6449 * made on memory-hotadd so a system can start with mobility 6450 * disabled and enable it later 6451 */ 6452 if (vm_total_pages < (pageblock_nr_pages * MIGRATE_TYPES)) 6453 page_group_by_mobility_disabled = 1; 6454 else 6455 page_group_by_mobility_disabled = 0; 6456 6457 pr_info("Built %u zonelists, mobility grouping %s. Total pages: %ld\n", 6458 nr_online_nodes, 6459 page_group_by_mobility_disabled ? "off" : "on", 6460 vm_total_pages); 6461 #ifdef CONFIG_NUMA 6462 pr_info("Policy zone: %s\n", zone_names[policy_zone]); 6463 #endif 6464 } 6465 6466 /* If zone is ZONE_MOVABLE but memory is mirrored, it is an overlapped init */ 6467 static bool __meminit 6468 overlap_memmap_init(unsigned long zone, unsigned long *pfn) 6469 { 6470 static struct memblock_region *r; 6471 6472 if (mirrored_kernelcore && zone == ZONE_MOVABLE) { 6473 if (!r || *pfn >= memblock_region_memory_end_pfn(r)) { 6474 for_each_mem_region(r) { 6475 if (*pfn < memblock_region_memory_end_pfn(r)) 6476 break; 6477 } 6478 } 6479 if (*pfn >= memblock_region_memory_base_pfn(r) && 6480 memblock_is_mirror(r)) { 6481 *pfn = memblock_region_memory_end_pfn(r); 6482 return true; 6483 } 6484 } 6485 return false; 6486 } 6487 6488 /* 6489 * Initially all pages are reserved - free ones are freed 6490 * up by memblock_free_all() once the early boot process is 6491 * done. Non-atomic initialization, single-pass. 6492 * 6493 * All aligned pageblocks are initialized to the specified migratetype 6494 * (usually MIGRATE_MOVABLE). Besides setting the migratetype, no related 6495 * zone stats (e.g., nr_isolate_pageblock) are touched. 6496 */ 6497 void __meminit memmap_init_range(unsigned long size, int nid, unsigned long zone, 6498 unsigned long start_pfn, unsigned long zone_end_pfn, 6499 enum meminit_context context, 6500 struct vmem_altmap *altmap, int migratetype) 6501 { 6502 unsigned long pfn, end_pfn = start_pfn + size; 6503 struct page *page; 6504 6505 if (highest_memmap_pfn < end_pfn - 1) 6506 highest_memmap_pfn = end_pfn - 1; 6507 6508 #ifdef CONFIG_ZONE_DEVICE 6509 /* 6510 * Honor reservation requested by the driver for this ZONE_DEVICE 6511 * memory. We limit the total number of pages to initialize to just 6512 * those that might contain the memory mapping. We will defer the 6513 * ZONE_DEVICE page initialization until after we have released 6514 * the hotplug lock. 6515 */ 6516 if (zone == ZONE_DEVICE) { 6517 if (!altmap) 6518 return; 6519 6520 if (start_pfn == altmap->base_pfn) 6521 start_pfn += altmap->reserve; 6522 end_pfn = altmap->base_pfn + vmem_altmap_offset(altmap); 6523 } 6524 #endif 6525 6526 for (pfn = start_pfn; pfn < end_pfn; ) { 6527 /* 6528 * There can be holes in boot-time mem_map[]s handed to this 6529 * function. They do not exist on hotplugged memory. 6530 */ 6531 if (context == MEMINIT_EARLY) { 6532 if (overlap_memmap_init(zone, &pfn)) 6533 continue; 6534 if (defer_init(nid, pfn, zone_end_pfn)) 6535 break; 6536 } 6537 6538 page = pfn_to_page(pfn); 6539 __init_single_page(page, pfn, zone, nid); 6540 if (context == MEMINIT_HOTPLUG) 6541 __SetPageReserved(page); 6542 6543 /* 6544 * Usually, we want to mark the pageblock MIGRATE_MOVABLE, 6545 * such that unmovable allocations won't be scattered all 6546 * over the place during system boot. 6547 */ 6548 if (IS_ALIGNED(pfn, pageblock_nr_pages)) { 6549 set_pageblock_migratetype(page, migratetype); 6550 cond_resched(); 6551 } 6552 pfn++; 6553 } 6554 } 6555 6556 #ifdef CONFIG_ZONE_DEVICE 6557 static void __ref __init_zone_device_page(struct page *page, unsigned long pfn, 6558 unsigned long zone_idx, int nid, 6559 struct dev_pagemap *pgmap) 6560 { 6561 6562 __init_single_page(page, pfn, zone_idx, nid); 6563 6564 /* 6565 * Mark page reserved as it will need to wait for onlining 6566 * phase for it to be fully associated with a zone. 6567 * 6568 * We can use the non-atomic __set_bit operation for setting 6569 * the flag as we are still initializing the pages. 6570 */ 6571 __SetPageReserved(page); 6572 6573 /* 6574 * ZONE_DEVICE pages union ->lru with a ->pgmap back pointer 6575 * and zone_device_data. It is a bug if a ZONE_DEVICE page is 6576 * ever freed or placed on a driver-private list. 6577 */ 6578 page->pgmap = pgmap; 6579 page->zone_device_data = NULL; 6580 6581 /* 6582 * Mark the block movable so that blocks are reserved for 6583 * movable at startup. This will force kernel allocations 6584 * to reserve their blocks rather than leaking throughout 6585 * the address space during boot when many long-lived 6586 * kernel allocations are made. 6587 * 6588 * Please note that MEMINIT_HOTPLUG path doesn't clear memmap 6589 * because this is done early in section_activate() 6590 */ 6591 if (IS_ALIGNED(pfn, pageblock_nr_pages)) { 6592 set_pageblock_migratetype(page, MIGRATE_MOVABLE); 6593 cond_resched(); 6594 } 6595 } 6596 6597 static void __ref memmap_init_compound(struct page *head, 6598 unsigned long head_pfn, 6599 unsigned long zone_idx, int nid, 6600 struct dev_pagemap *pgmap, 6601 unsigned long nr_pages) 6602 { 6603 unsigned long pfn, end_pfn = head_pfn + nr_pages; 6604 unsigned int order = pgmap->vmemmap_shift; 6605 6606 __SetPageHead(head); 6607 for (pfn = head_pfn + 1; pfn < end_pfn; pfn++) { 6608 struct page *page = pfn_to_page(pfn); 6609 6610 __init_zone_device_page(page, pfn, zone_idx, nid, pgmap); 6611 prep_compound_tail(head, pfn - head_pfn); 6612 set_page_count(page, 0); 6613 6614 /* 6615 * The first tail page stores compound_mapcount_ptr() and 6616 * compound_order() and the second tail page stores 6617 * compound_pincount_ptr(). Call prep_compound_head() after 6618 * the first and second tail pages have been initialized to 6619 * not have the data overwritten. 6620 */ 6621 if (pfn == head_pfn + 2) 6622 prep_compound_head(head, order); 6623 } 6624 } 6625 6626 void __ref memmap_init_zone_device(struct zone *zone, 6627 unsigned long start_pfn, 6628 unsigned long nr_pages, 6629 struct dev_pagemap *pgmap) 6630 { 6631 unsigned long pfn, end_pfn = start_pfn + nr_pages; 6632 struct pglist_data *pgdat = zone->zone_pgdat; 6633 struct vmem_altmap *altmap = pgmap_altmap(pgmap); 6634 unsigned int pfns_per_compound = pgmap_vmemmap_nr(pgmap); 6635 unsigned long zone_idx = zone_idx(zone); 6636 unsigned long start = jiffies; 6637 int nid = pgdat->node_id; 6638 6639 if (WARN_ON_ONCE(!pgmap || zone_idx(zone) != ZONE_DEVICE)) 6640 return; 6641 6642 /* 6643 * The call to memmap_init should have already taken care 6644 * of the pages reserved for the memmap, so we can just jump to 6645 * the end of that region and start processing the device pages. 6646 */ 6647 if (altmap) { 6648 start_pfn = altmap->base_pfn + vmem_altmap_offset(altmap); 6649 nr_pages = end_pfn - start_pfn; 6650 } 6651 6652 for (pfn = start_pfn; pfn < end_pfn; pfn += pfns_per_compound) { 6653 struct page *page = pfn_to_page(pfn); 6654 6655 __init_zone_device_page(page, pfn, zone_idx, nid, pgmap); 6656 6657 if (pfns_per_compound == 1) 6658 continue; 6659 6660 memmap_init_compound(page, pfn, zone_idx, nid, pgmap, 6661 pfns_per_compound); 6662 } 6663 6664 pr_info("%s initialised %lu pages in %ums\n", __func__, 6665 nr_pages, jiffies_to_msecs(jiffies - start)); 6666 } 6667 6668 #endif 6669 static void __meminit zone_init_free_lists(struct zone *zone) 6670 { 6671 unsigned int order, t; 6672 for_each_migratetype_order(order, t) { 6673 INIT_LIST_HEAD(&zone->free_area[order].free_list[t]); 6674 zone->free_area[order].nr_free = 0; 6675 } 6676 } 6677 6678 /* 6679 * Only struct pages that correspond to ranges defined by memblock.memory 6680 * are zeroed and initialized by going through __init_single_page() during 6681 * memmap_init_zone_range(). 6682 * 6683 * But, there could be struct pages that correspond to holes in 6684 * memblock.memory. This can happen because of the following reasons: 6685 * - physical memory bank size is not necessarily the exact multiple of the 6686 * arbitrary section size 6687 * - early reserved memory may not be listed in memblock.memory 6688 * - memory layouts defined with memmap= kernel parameter may not align 6689 * nicely with memmap sections 6690 * 6691 * Explicitly initialize those struct pages so that: 6692 * - PG_Reserved is set 6693 * - zone and node links point to zone and node that span the page if the 6694 * hole is in the middle of a zone 6695 * - zone and node links point to adjacent zone/node if the hole falls on 6696 * the zone boundary; the pages in such holes will be prepended to the 6697 * zone/node above the hole except for the trailing pages in the last 6698 * section that will be appended to the zone/node below. 6699 */ 6700 static void __init init_unavailable_range(unsigned long spfn, 6701 unsigned long epfn, 6702 int zone, int node) 6703 { 6704 unsigned long pfn; 6705 u64 pgcnt = 0; 6706 6707 for (pfn = spfn; pfn < epfn; pfn++) { 6708 if (!pfn_valid(ALIGN_DOWN(pfn, pageblock_nr_pages))) { 6709 pfn = ALIGN_DOWN(pfn, pageblock_nr_pages) 6710 + pageblock_nr_pages - 1; 6711 continue; 6712 } 6713 __init_single_page(pfn_to_page(pfn), pfn, zone, node); 6714 __SetPageReserved(pfn_to_page(pfn)); 6715 pgcnt++; 6716 } 6717 6718 if (pgcnt) 6719 pr_info("On node %d, zone %s: %lld pages in unavailable ranges", 6720 node, zone_names[zone], pgcnt); 6721 } 6722 6723 static void __init memmap_init_zone_range(struct zone *zone, 6724 unsigned long start_pfn, 6725 unsigned long end_pfn, 6726 unsigned long *hole_pfn) 6727 { 6728 unsigned long zone_start_pfn = zone->zone_start_pfn; 6729 unsigned long zone_end_pfn = zone_start_pfn + zone->spanned_pages; 6730 int nid = zone_to_nid(zone), zone_id = zone_idx(zone); 6731 6732 start_pfn = clamp(start_pfn, zone_start_pfn, zone_end_pfn); 6733 end_pfn = clamp(end_pfn, zone_start_pfn, zone_end_pfn); 6734 6735 if (start_pfn >= end_pfn) 6736 return; 6737 6738 memmap_init_range(end_pfn - start_pfn, nid, zone_id, start_pfn, 6739 zone_end_pfn, MEMINIT_EARLY, NULL, MIGRATE_MOVABLE); 6740 6741 if (*hole_pfn < start_pfn) 6742 init_unavailable_range(*hole_pfn, start_pfn, zone_id, nid); 6743 6744 *hole_pfn = end_pfn; 6745 } 6746 6747 static void __init memmap_init(void) 6748 { 6749 unsigned long start_pfn, end_pfn; 6750 unsigned long hole_pfn = 0; 6751 int i, j, zone_id = 0, nid; 6752 6753 for_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn, &nid) { 6754 struct pglist_data *node = NODE_DATA(nid); 6755 6756 for (j = 0; j < MAX_NR_ZONES; j++) { 6757 struct zone *zone = node->node_zones + j; 6758 6759 if (!populated_zone(zone)) 6760 continue; 6761 6762 memmap_init_zone_range(zone, start_pfn, end_pfn, 6763 &hole_pfn); 6764 zone_id = j; 6765 } 6766 } 6767 6768 #ifdef CONFIG_SPARSEMEM 6769 /* 6770 * Initialize the memory map for hole in the range [memory_end, 6771 * section_end]. 6772 * Append the pages in this hole to the highest zone in the last 6773 * node. 6774 * The call to init_unavailable_range() is outside the ifdef to 6775 * silence the compiler warining about zone_id set but not used; 6776 * for FLATMEM it is a nop anyway 6777 */ 6778 end_pfn = round_up(end_pfn, PAGES_PER_SECTION); 6779 if (hole_pfn < end_pfn) 6780 #endif 6781 init_unavailable_range(hole_pfn, end_pfn, zone_id, nid); 6782 } 6783 6784 void __init *memmap_alloc(phys_addr_t size, phys_addr_t align, 6785 phys_addr_t min_addr, int nid, bool exact_nid) 6786 { 6787 void *ptr; 6788 6789 if (exact_nid) 6790 ptr = memblock_alloc_exact_nid_raw(size, align, min_addr, 6791 MEMBLOCK_ALLOC_ACCESSIBLE, 6792 nid); 6793 else 6794 ptr = memblock_alloc_try_nid_raw(size, align, min_addr, 6795 MEMBLOCK_ALLOC_ACCESSIBLE, 6796 nid); 6797 6798 if (ptr && size > 0) 6799 page_init_poison(ptr, size); 6800 6801 return ptr; 6802 } 6803 6804 static int zone_batchsize(struct zone *zone) 6805 { 6806 #ifdef CONFIG_MMU 6807 int batch; 6808 6809 /* 6810 * The number of pages to batch allocate is either ~0.1% 6811 * of the zone or 1MB, whichever is smaller. The batch 6812 * size is striking a balance between allocation latency 6813 * and zone lock contention. 6814 */ 6815 batch = min(zone_managed_pages(zone) >> 10, (1024 * 1024) / PAGE_SIZE); 6816 batch /= 4; /* We effectively *= 4 below */ 6817 if (batch < 1) 6818 batch = 1; 6819 6820 /* 6821 * Clamp the batch to a 2^n - 1 value. Having a power 6822 * of 2 value was found to be more likely to have 6823 * suboptimal cache aliasing properties in some cases. 6824 * 6825 * For example if 2 tasks are alternately allocating 6826 * batches of pages, one task can end up with a lot 6827 * of pages of one half of the possible page colors 6828 * and the other with pages of the other colors. 6829 */ 6830 batch = rounddown_pow_of_two(batch + batch/2) - 1; 6831 6832 return batch; 6833 6834 #else 6835 /* The deferral and batching of frees should be suppressed under NOMMU 6836 * conditions. 6837 * 6838 * The problem is that NOMMU needs to be able to allocate large chunks 6839 * of contiguous memory as there's no hardware page translation to 6840 * assemble apparent contiguous memory from discontiguous pages. 6841 * 6842 * Queueing large contiguous runs of pages for batching, however, 6843 * causes the pages to actually be freed in smaller chunks. As there 6844 * can be a significant delay between the individual batches being 6845 * recycled, this leads to the once large chunks of space being 6846 * fragmented and becoming unavailable for high-order allocations. 6847 */ 6848 return 0; 6849 #endif 6850 } 6851 6852 static int zone_highsize(struct zone *zone, int batch, int cpu_online) 6853 { 6854 #ifdef CONFIG_MMU 6855 int high; 6856 int nr_split_cpus; 6857 unsigned long total_pages; 6858 6859 if (!percpu_pagelist_high_fraction) { 6860 /* 6861 * By default, the high value of the pcp is based on the zone 6862 * low watermark so that if they are full then background 6863 * reclaim will not be started prematurely. 6864 */ 6865 total_pages = low_wmark_pages(zone); 6866 } else { 6867 /* 6868 * If percpu_pagelist_high_fraction is configured, the high 6869 * value is based on a fraction of the managed pages in the 6870 * zone. 6871 */ 6872 total_pages = zone_managed_pages(zone) / percpu_pagelist_high_fraction; 6873 } 6874 6875 /* 6876 * Split the high value across all online CPUs local to the zone. Note 6877 * that early in boot that CPUs may not be online yet and that during 6878 * CPU hotplug that the cpumask is not yet updated when a CPU is being 6879 * onlined. For memory nodes that have no CPUs, split pcp->high across 6880 * all online CPUs to mitigate the risk that reclaim is triggered 6881 * prematurely due to pages stored on pcp lists. 6882 */ 6883 nr_split_cpus = cpumask_weight(cpumask_of_node(zone_to_nid(zone))) + cpu_online; 6884 if (!nr_split_cpus) 6885 nr_split_cpus = num_online_cpus(); 6886 high = total_pages / nr_split_cpus; 6887 6888 /* 6889 * Ensure high is at least batch*4. The multiple is based on the 6890 * historical relationship between high and batch. 6891 */ 6892 high = max(high, batch << 2); 6893 6894 return high; 6895 #else 6896 return 0; 6897 #endif 6898 } 6899 6900 /* 6901 * pcp->high and pcp->batch values are related and generally batch is lower 6902 * than high. They are also related to pcp->count such that count is lower 6903 * than high, and as soon as it reaches high, the pcplist is flushed. 6904 * 6905 * However, guaranteeing these relations at all times would require e.g. write 6906 * barriers here but also careful usage of read barriers at the read side, and 6907 * thus be prone to error and bad for performance. Thus the update only prevents 6908 * store tearing. Any new users of pcp->batch and pcp->high should ensure they 6909 * can cope with those fields changing asynchronously, and fully trust only the 6910 * pcp->count field on the local CPU with interrupts disabled. 6911 * 6912 * mutex_is_locked(&pcp_batch_high_lock) required when calling this function 6913 * outside of boot time (or some other assurance that no concurrent updaters 6914 * exist). 6915 */ 6916 static void pageset_update(struct per_cpu_pages *pcp, unsigned long high, 6917 unsigned long batch) 6918 { 6919 WRITE_ONCE(pcp->batch, batch); 6920 WRITE_ONCE(pcp->high, high); 6921 } 6922 6923 static void per_cpu_pages_init(struct per_cpu_pages *pcp, struct per_cpu_zonestat *pzstats) 6924 { 6925 int pindex; 6926 6927 memset(pcp, 0, sizeof(*pcp)); 6928 memset(pzstats, 0, sizeof(*pzstats)); 6929 6930 for (pindex = 0; pindex < NR_PCP_LISTS; pindex++) 6931 INIT_LIST_HEAD(&pcp->lists[pindex]); 6932 6933 /* 6934 * Set batch and high values safe for a boot pageset. A true percpu 6935 * pageset's initialization will update them subsequently. Here we don't 6936 * need to be as careful as pageset_update() as nobody can access the 6937 * pageset yet. 6938 */ 6939 pcp->high = BOOT_PAGESET_HIGH; 6940 pcp->batch = BOOT_PAGESET_BATCH; 6941 pcp->free_factor = 0; 6942 } 6943 6944 static void __zone_set_pageset_high_and_batch(struct zone *zone, unsigned long high, 6945 unsigned long batch) 6946 { 6947 struct per_cpu_pages *pcp; 6948 int cpu; 6949 6950 for_each_possible_cpu(cpu) { 6951 pcp = per_cpu_ptr(zone->per_cpu_pageset, cpu); 6952 pageset_update(pcp, high, batch); 6953 } 6954 } 6955 6956 /* 6957 * Calculate and set new high and batch values for all per-cpu pagesets of a 6958 * zone based on the zone's size. 6959 */ 6960 static void zone_set_pageset_high_and_batch(struct zone *zone, int cpu_online) 6961 { 6962 int new_high, new_batch; 6963 6964 new_batch = max(1, zone_batchsize(zone)); 6965 new_high = zone_highsize(zone, new_batch, cpu_online); 6966 6967 if (zone->pageset_high == new_high && 6968 zone->pageset_batch == new_batch) 6969 return; 6970 6971 zone->pageset_high = new_high; 6972 zone->pageset_batch = new_batch; 6973 6974 __zone_set_pageset_high_and_batch(zone, new_high, new_batch); 6975 } 6976 6977 void __meminit setup_zone_pageset(struct zone *zone) 6978 { 6979 int cpu; 6980 6981 /* Size may be 0 on !SMP && !NUMA */ 6982 if (sizeof(struct per_cpu_zonestat) > 0) 6983 zone->per_cpu_zonestats = alloc_percpu(struct per_cpu_zonestat); 6984 6985 zone->per_cpu_pageset = alloc_percpu(struct per_cpu_pages); 6986 for_each_possible_cpu(cpu) { 6987 struct per_cpu_pages *pcp; 6988 struct per_cpu_zonestat *pzstats; 6989 6990 pcp = per_cpu_ptr(zone->per_cpu_pageset, cpu); 6991 pzstats = per_cpu_ptr(zone->per_cpu_zonestats, cpu); 6992 per_cpu_pages_init(pcp, pzstats); 6993 } 6994 6995 zone_set_pageset_high_and_batch(zone, 0); 6996 } 6997 6998 /* 6999 * Allocate per cpu pagesets and initialize them. 7000 * Before this call only boot pagesets were available. 7001 */ 7002 void __init setup_per_cpu_pageset(void) 7003 { 7004 struct pglist_data *pgdat; 7005 struct zone *zone; 7006 int __maybe_unused cpu; 7007 7008 for_each_populated_zone(zone) 7009 setup_zone_pageset(zone); 7010 7011 #ifdef CONFIG_NUMA 7012 /* 7013 * Unpopulated zones continue using the boot pagesets. 7014 * The numa stats for these pagesets need to be reset. 7015 * Otherwise, they will end up skewing the stats of 7016 * the nodes these zones are associated with. 7017 */ 7018 for_each_possible_cpu(cpu) { 7019 struct per_cpu_zonestat *pzstats = &per_cpu(boot_zonestats, cpu); 7020 memset(pzstats->vm_numa_event, 0, 7021 sizeof(pzstats->vm_numa_event)); 7022 } 7023 #endif 7024 7025 for_each_online_pgdat(pgdat) 7026 pgdat->per_cpu_nodestats = 7027 alloc_percpu(struct per_cpu_nodestat); 7028 } 7029 7030 static __meminit void zone_pcp_init(struct zone *zone) 7031 { 7032 /* 7033 * per cpu subsystem is not up at this point. The following code 7034 * relies on the ability of the linker to provide the 7035 * offset of a (static) per cpu variable into the per cpu area. 7036 */ 7037 zone->per_cpu_pageset = &boot_pageset; 7038 zone->per_cpu_zonestats = &boot_zonestats; 7039 zone->pageset_high = BOOT_PAGESET_HIGH; 7040 zone->pageset_batch = BOOT_PAGESET_BATCH; 7041 7042 if (populated_zone(zone)) 7043 pr_debug(" %s zone: %lu pages, LIFO batch:%u\n", zone->name, 7044 zone->present_pages, zone_batchsize(zone)); 7045 } 7046 7047 void __meminit init_currently_empty_zone(struct zone *zone, 7048 unsigned long zone_start_pfn, 7049 unsigned long size) 7050 { 7051 struct pglist_data *pgdat = zone->zone_pgdat; 7052 int zone_idx = zone_idx(zone) + 1; 7053 7054 if (zone_idx > pgdat->nr_zones) 7055 pgdat->nr_zones = zone_idx; 7056 7057 zone->zone_start_pfn = zone_start_pfn; 7058 7059 mminit_dprintk(MMINIT_TRACE, "memmap_init", 7060 "Initialising map node %d zone %lu pfns %lu -> %lu\n", 7061 pgdat->node_id, 7062 (unsigned long)zone_idx(zone), 7063 zone_start_pfn, (zone_start_pfn + size)); 7064 7065 zone_init_free_lists(zone); 7066 zone->initialized = 1; 7067 } 7068 7069 /** 7070 * get_pfn_range_for_nid - Return the start and end page frames for a node 7071 * @nid: The nid to return the range for. If MAX_NUMNODES, the min and max PFN are returned. 7072 * @start_pfn: Passed by reference. On return, it will have the node start_pfn. 7073 * @end_pfn: Passed by reference. On return, it will have the node end_pfn. 7074 * 7075 * It returns the start and end page frame of a node based on information 7076 * provided by memblock_set_node(). If called for a node 7077 * with no available memory, a warning is printed and the start and end 7078 * PFNs will be 0. 7079 */ 7080 void __init get_pfn_range_for_nid(unsigned int nid, 7081 unsigned long *start_pfn, unsigned long *end_pfn) 7082 { 7083 unsigned long this_start_pfn, this_end_pfn; 7084 int i; 7085 7086 *start_pfn = -1UL; 7087 *end_pfn = 0; 7088 7089 for_each_mem_pfn_range(i, nid, &this_start_pfn, &this_end_pfn, NULL) { 7090 *start_pfn = min(*start_pfn, this_start_pfn); 7091 *end_pfn = max(*end_pfn, this_end_pfn); 7092 } 7093 7094 if (*start_pfn == -1UL) 7095 *start_pfn = 0; 7096 } 7097 7098 /* 7099 * This finds a zone that can be used for ZONE_MOVABLE pages. The 7100 * assumption is made that zones within a node are ordered in monotonic 7101 * increasing memory addresses so that the "highest" populated zone is used 7102 */ 7103 static void __init find_usable_zone_for_movable(void) 7104 { 7105 int zone_index; 7106 for (zone_index = MAX_NR_ZONES - 1; zone_index >= 0; zone_index--) { 7107 if (zone_index == ZONE_MOVABLE) 7108 continue; 7109 7110 if (arch_zone_highest_possible_pfn[zone_index] > 7111 arch_zone_lowest_possible_pfn[zone_index]) 7112 break; 7113 } 7114 7115 VM_BUG_ON(zone_index == -1); 7116 movable_zone = zone_index; 7117 } 7118 7119 /* 7120 * The zone ranges provided by the architecture do not include ZONE_MOVABLE 7121 * because it is sized independent of architecture. Unlike the other zones, 7122 * the starting point for ZONE_MOVABLE is not fixed. It may be different 7123 * in each node depending on the size of each node and how evenly kernelcore 7124 * is distributed. This helper function adjusts the zone ranges 7125 * provided by the architecture for a given node by using the end of the 7126 * highest usable zone for ZONE_MOVABLE. This preserves the assumption that 7127 * zones within a node are in order of monotonic increases memory addresses 7128 */ 7129 static void __init adjust_zone_range_for_zone_movable(int nid, 7130 unsigned long zone_type, 7131 unsigned long node_start_pfn, 7132 unsigned long node_end_pfn, 7133 unsigned long *zone_start_pfn, 7134 unsigned long *zone_end_pfn) 7135 { 7136 /* Only adjust if ZONE_MOVABLE is on this node */ 7137 if (zone_movable_pfn[nid]) { 7138 /* Size ZONE_MOVABLE */ 7139 if (zone_type == ZONE_MOVABLE) { 7140 *zone_start_pfn = zone_movable_pfn[nid]; 7141 *zone_end_pfn = min(node_end_pfn, 7142 arch_zone_highest_possible_pfn[movable_zone]); 7143 7144 /* Adjust for ZONE_MOVABLE starting within this range */ 7145 } else if (!mirrored_kernelcore && 7146 *zone_start_pfn < zone_movable_pfn[nid] && 7147 *zone_end_pfn > zone_movable_pfn[nid]) { 7148 *zone_end_pfn = zone_movable_pfn[nid]; 7149 7150 /* Check if this whole range is within ZONE_MOVABLE */ 7151 } else if (*zone_start_pfn >= zone_movable_pfn[nid]) 7152 *zone_start_pfn = *zone_end_pfn; 7153 } 7154 } 7155 7156 /* 7157 * Return the number of pages a zone spans in a node, including holes 7158 * present_pages = zone_spanned_pages_in_node() - zone_absent_pages_in_node() 7159 */ 7160 static unsigned long __init zone_spanned_pages_in_node(int nid, 7161 unsigned long zone_type, 7162 unsigned long node_start_pfn, 7163 unsigned long node_end_pfn, 7164 unsigned long *zone_start_pfn, 7165 unsigned long *zone_end_pfn) 7166 { 7167 unsigned long zone_low = arch_zone_lowest_possible_pfn[zone_type]; 7168 unsigned long zone_high = arch_zone_highest_possible_pfn[zone_type]; 7169 /* When hotadd a new node from cpu_up(), the node should be empty */ 7170 if (!node_start_pfn && !node_end_pfn) 7171 return 0; 7172 7173 /* Get the start and end of the zone */ 7174 *zone_start_pfn = clamp(node_start_pfn, zone_low, zone_high); 7175 *zone_end_pfn = clamp(node_end_pfn, zone_low, zone_high); 7176 adjust_zone_range_for_zone_movable(nid, zone_type, 7177 node_start_pfn, node_end_pfn, 7178 zone_start_pfn, zone_end_pfn); 7179 7180 /* Check that this node has pages within the zone's required range */ 7181 if (*zone_end_pfn < node_start_pfn || *zone_start_pfn > node_end_pfn) 7182 return 0; 7183 7184 /* Move the zone boundaries inside the node if necessary */ 7185 *zone_end_pfn = min(*zone_end_pfn, node_end_pfn); 7186 *zone_start_pfn = max(*zone_start_pfn, node_start_pfn); 7187 7188 /* Return the spanned pages */ 7189 return *zone_end_pfn - *zone_start_pfn; 7190 } 7191 7192 /* 7193 * Return the number of holes in a range on a node. If nid is MAX_NUMNODES, 7194 * then all holes in the requested range will be accounted for. 7195 */ 7196 unsigned long __init __absent_pages_in_range(int nid, 7197 unsigned long range_start_pfn, 7198 unsigned long range_end_pfn) 7199 { 7200 unsigned long nr_absent = range_end_pfn - range_start_pfn; 7201 unsigned long start_pfn, end_pfn; 7202 int i; 7203 7204 for_each_mem_pfn_range(i, nid, &start_pfn, &end_pfn, NULL) { 7205 start_pfn = clamp(start_pfn, range_start_pfn, range_end_pfn); 7206 end_pfn = clamp(end_pfn, range_start_pfn, range_end_pfn); 7207 nr_absent -= end_pfn - start_pfn; 7208 } 7209 return nr_absent; 7210 } 7211 7212 /** 7213 * absent_pages_in_range - Return number of page frames in holes within a range 7214 * @start_pfn: The start PFN to start searching for holes 7215 * @end_pfn: The end PFN to stop searching for holes 7216 * 7217 * Return: the number of pages frames in memory holes within a range. 7218 */ 7219 unsigned long __init absent_pages_in_range(unsigned long start_pfn, 7220 unsigned long end_pfn) 7221 { 7222 return __absent_pages_in_range(MAX_NUMNODES, start_pfn, end_pfn); 7223 } 7224 7225 /* Return the number of page frames in holes in a zone on a node */ 7226 static unsigned long __init zone_absent_pages_in_node(int nid, 7227 unsigned long zone_type, 7228 unsigned long node_start_pfn, 7229 unsigned long node_end_pfn) 7230 { 7231 unsigned long zone_low = arch_zone_lowest_possible_pfn[zone_type]; 7232 unsigned long zone_high = arch_zone_highest_possible_pfn[zone_type]; 7233 unsigned long zone_start_pfn, zone_end_pfn; 7234 unsigned long nr_absent; 7235 7236 /* When hotadd a new node from cpu_up(), the node should be empty */ 7237 if (!node_start_pfn && !node_end_pfn) 7238 return 0; 7239 7240 zone_start_pfn = clamp(node_start_pfn, zone_low, zone_high); 7241 zone_end_pfn = clamp(node_end_pfn, zone_low, zone_high); 7242 7243 adjust_zone_range_for_zone_movable(nid, zone_type, 7244 node_start_pfn, node_end_pfn, 7245 &zone_start_pfn, &zone_end_pfn); 7246 nr_absent = __absent_pages_in_range(nid, zone_start_pfn, zone_end_pfn); 7247 7248 /* 7249 * ZONE_MOVABLE handling. 7250 * Treat pages to be ZONE_MOVABLE in ZONE_NORMAL as absent pages 7251 * and vice versa. 7252 */ 7253 if (mirrored_kernelcore && zone_movable_pfn[nid]) { 7254 unsigned long start_pfn, end_pfn; 7255 struct memblock_region *r; 7256 7257 for_each_mem_region(r) { 7258 start_pfn = clamp(memblock_region_memory_base_pfn(r), 7259 zone_start_pfn, zone_end_pfn); 7260 end_pfn = clamp(memblock_region_memory_end_pfn(r), 7261 zone_start_pfn, zone_end_pfn); 7262 7263 if (zone_type == ZONE_MOVABLE && 7264 memblock_is_mirror(r)) 7265 nr_absent += end_pfn - start_pfn; 7266 7267 if (zone_type == ZONE_NORMAL && 7268 !memblock_is_mirror(r)) 7269 nr_absent += end_pfn - start_pfn; 7270 } 7271 } 7272 7273 return nr_absent; 7274 } 7275 7276 static void __init calculate_node_totalpages(struct pglist_data *pgdat, 7277 unsigned long node_start_pfn, 7278 unsigned long node_end_pfn) 7279 { 7280 unsigned long realtotalpages = 0, totalpages = 0; 7281 enum zone_type i; 7282 7283 for (i = 0; i < MAX_NR_ZONES; i++) { 7284 struct zone *zone = pgdat->node_zones + i; 7285 unsigned long zone_start_pfn, zone_end_pfn; 7286 unsigned long spanned, absent; 7287 unsigned long size, real_size; 7288 7289 spanned = zone_spanned_pages_in_node(pgdat->node_id, i, 7290 node_start_pfn, 7291 node_end_pfn, 7292 &zone_start_pfn, 7293 &zone_end_pfn); 7294 absent = zone_absent_pages_in_node(pgdat->node_id, i, 7295 node_start_pfn, 7296 node_end_pfn); 7297 7298 size = spanned; 7299 real_size = size - absent; 7300 7301 if (size) 7302 zone->zone_start_pfn = zone_start_pfn; 7303 else 7304 zone->zone_start_pfn = 0; 7305 zone->spanned_pages = size; 7306 zone->present_pages = real_size; 7307 #if defined(CONFIG_MEMORY_HOTPLUG) 7308 zone->present_early_pages = real_size; 7309 #endif 7310 7311 totalpages += size; 7312 realtotalpages += real_size; 7313 } 7314 7315 pgdat->node_spanned_pages = totalpages; 7316 pgdat->node_present_pages = realtotalpages; 7317 pr_debug("On node %d totalpages: %lu\n", pgdat->node_id, realtotalpages); 7318 } 7319 7320 #ifndef CONFIG_SPARSEMEM 7321 /* 7322 * Calculate the size of the zone->blockflags rounded to an unsigned long 7323 * Start by making sure zonesize is a multiple of pageblock_order by rounding 7324 * up. Then use 1 NR_PAGEBLOCK_BITS worth of bits per pageblock, finally 7325 * round what is now in bits to nearest long in bits, then return it in 7326 * bytes. 7327 */ 7328 static unsigned long __init usemap_size(unsigned long zone_start_pfn, unsigned long zonesize) 7329 { 7330 unsigned long usemapsize; 7331 7332 zonesize += zone_start_pfn & (pageblock_nr_pages-1); 7333 usemapsize = roundup(zonesize, pageblock_nr_pages); 7334 usemapsize = usemapsize >> pageblock_order; 7335 usemapsize *= NR_PAGEBLOCK_BITS; 7336 usemapsize = roundup(usemapsize, 8 * sizeof(unsigned long)); 7337 7338 return usemapsize / 8; 7339 } 7340 7341 static void __ref setup_usemap(struct zone *zone) 7342 { 7343 unsigned long usemapsize = usemap_size(zone->zone_start_pfn, 7344 zone->spanned_pages); 7345 zone->pageblock_flags = NULL; 7346 if (usemapsize) { 7347 zone->pageblock_flags = 7348 memblock_alloc_node(usemapsize, SMP_CACHE_BYTES, 7349 zone_to_nid(zone)); 7350 if (!zone->pageblock_flags) 7351 panic("Failed to allocate %ld bytes for zone %s pageblock flags on node %d\n", 7352 usemapsize, zone->name, zone_to_nid(zone)); 7353 } 7354 } 7355 #else 7356 static inline void setup_usemap(struct zone *zone) {} 7357 #endif /* CONFIG_SPARSEMEM */ 7358 7359 #ifdef CONFIG_HUGETLB_PAGE_SIZE_VARIABLE 7360 7361 /* Initialise the number of pages represented by NR_PAGEBLOCK_BITS */ 7362 void __init set_pageblock_order(void) 7363 { 7364 unsigned int order = MAX_ORDER - 1; 7365 7366 /* Check that pageblock_nr_pages has not already been setup */ 7367 if (pageblock_order) 7368 return; 7369 7370 /* Don't let pageblocks exceed the maximum allocation granularity. */ 7371 if (HPAGE_SHIFT > PAGE_SHIFT && HUGETLB_PAGE_ORDER < order) 7372 order = HUGETLB_PAGE_ORDER; 7373 7374 /* 7375 * Assume the largest contiguous order of interest is a huge page. 7376 * This value may be variable depending on boot parameters on IA64 and 7377 * powerpc. 7378 */ 7379 pageblock_order = order; 7380 } 7381 #else /* CONFIG_HUGETLB_PAGE_SIZE_VARIABLE */ 7382 7383 /* 7384 * When CONFIG_HUGETLB_PAGE_SIZE_VARIABLE is not set, set_pageblock_order() 7385 * is unused as pageblock_order is set at compile-time. See 7386 * include/linux/pageblock-flags.h for the values of pageblock_order based on 7387 * the kernel config 7388 */ 7389 void __init set_pageblock_order(void) 7390 { 7391 } 7392 7393 #endif /* CONFIG_HUGETLB_PAGE_SIZE_VARIABLE */ 7394 7395 static unsigned long __init calc_memmap_size(unsigned long spanned_pages, 7396 unsigned long present_pages) 7397 { 7398 unsigned long pages = spanned_pages; 7399 7400 /* 7401 * Provide a more accurate estimation if there are holes within 7402 * the zone and SPARSEMEM is in use. If there are holes within the 7403 * zone, each populated memory region may cost us one or two extra 7404 * memmap pages due to alignment because memmap pages for each 7405 * populated regions may not be naturally aligned on page boundary. 7406 * So the (present_pages >> 4) heuristic is a tradeoff for that. 7407 */ 7408 if (spanned_pages > present_pages + (present_pages >> 4) && 7409 IS_ENABLED(CONFIG_SPARSEMEM)) 7410 pages = present_pages; 7411 7412 return PAGE_ALIGN(pages * sizeof(struct page)) >> PAGE_SHIFT; 7413 } 7414 7415 #ifdef CONFIG_TRANSPARENT_HUGEPAGE 7416 static void pgdat_init_split_queue(struct pglist_data *pgdat) 7417 { 7418 struct deferred_split *ds_queue = &pgdat->deferred_split_queue; 7419 7420 spin_lock_init(&ds_queue->split_queue_lock); 7421 INIT_LIST_HEAD(&ds_queue->split_queue); 7422 ds_queue->split_queue_len = 0; 7423 } 7424 #else 7425 static void pgdat_init_split_queue(struct pglist_data *pgdat) {} 7426 #endif 7427 7428 #ifdef CONFIG_COMPACTION 7429 static void pgdat_init_kcompactd(struct pglist_data *pgdat) 7430 { 7431 init_waitqueue_head(&pgdat->kcompactd_wait); 7432 } 7433 #else 7434 static void pgdat_init_kcompactd(struct pglist_data *pgdat) {} 7435 #endif 7436 7437 static void __meminit pgdat_init_internals(struct pglist_data *pgdat) 7438 { 7439 int i; 7440 7441 pgdat_resize_init(pgdat); 7442 7443 pgdat_init_split_queue(pgdat); 7444 pgdat_init_kcompactd(pgdat); 7445 7446 init_waitqueue_head(&pgdat->kswapd_wait); 7447 init_waitqueue_head(&pgdat->pfmemalloc_wait); 7448 7449 for (i = 0; i < NR_VMSCAN_THROTTLE; i++) 7450 init_waitqueue_head(&pgdat->reclaim_wait[i]); 7451 7452 pgdat_page_ext_init(pgdat); 7453 lruvec_init(&pgdat->__lruvec); 7454 } 7455 7456 static void __meminit zone_init_internals(struct zone *zone, enum zone_type idx, int nid, 7457 unsigned long remaining_pages) 7458 { 7459 atomic_long_set(&zone->managed_pages, remaining_pages); 7460 zone_set_nid(zone, nid); 7461 zone->name = zone_names[idx]; 7462 zone->zone_pgdat = NODE_DATA(nid); 7463 spin_lock_init(&zone->lock); 7464 zone_seqlock_init(zone); 7465 zone_pcp_init(zone); 7466 } 7467 7468 /* 7469 * Set up the zone data structures 7470 * - init pgdat internals 7471 * - init all zones belonging to this node 7472 * 7473 * NOTE: this function is only called during memory hotplug 7474 */ 7475 #ifdef CONFIG_MEMORY_HOTPLUG 7476 void __ref free_area_init_core_hotplug(struct pglist_data *pgdat) 7477 { 7478 int nid = pgdat->node_id; 7479 enum zone_type z; 7480 int cpu; 7481 7482 pgdat_init_internals(pgdat); 7483 7484 if (pgdat->per_cpu_nodestats == &boot_nodestats) 7485 pgdat->per_cpu_nodestats = alloc_percpu(struct per_cpu_nodestat); 7486 7487 /* 7488 * Reset the nr_zones, order and highest_zoneidx before reuse. 7489 * Note that kswapd will init kswapd_highest_zoneidx properly 7490 * when it starts in the near future. 7491 */ 7492 pgdat->nr_zones = 0; 7493 pgdat->kswapd_order = 0; 7494 pgdat->kswapd_highest_zoneidx = 0; 7495 pgdat->node_start_pfn = 0; 7496 for_each_online_cpu(cpu) { 7497 struct per_cpu_nodestat *p; 7498 7499 p = per_cpu_ptr(pgdat->per_cpu_nodestats, cpu); 7500 memset(p, 0, sizeof(*p)); 7501 } 7502 7503 for (z = 0; z < MAX_NR_ZONES; z++) 7504 zone_init_internals(&pgdat->node_zones[z], z, nid, 0); 7505 } 7506 #endif 7507 7508 /* 7509 * Set up the zone data structures: 7510 * - mark all pages reserved 7511 * - mark all memory queues empty 7512 * - clear the memory bitmaps 7513 * 7514 * NOTE: pgdat should get zeroed by caller. 7515 * NOTE: this function is only called during early init. 7516 */ 7517 static void __init free_area_init_core(struct pglist_data *pgdat) 7518 { 7519 enum zone_type j; 7520 int nid = pgdat->node_id; 7521 7522 pgdat_init_internals(pgdat); 7523 pgdat->per_cpu_nodestats = &boot_nodestats; 7524 7525 for (j = 0; j < MAX_NR_ZONES; j++) { 7526 struct zone *zone = pgdat->node_zones + j; 7527 unsigned long size, freesize, memmap_pages; 7528 7529 size = zone->spanned_pages; 7530 freesize = zone->present_pages; 7531 7532 /* 7533 * Adjust freesize so that it accounts for how much memory 7534 * is used by this zone for memmap. This affects the watermark 7535 * and per-cpu initialisations 7536 */ 7537 memmap_pages = calc_memmap_size(size, freesize); 7538 if (!is_highmem_idx(j)) { 7539 if (freesize >= memmap_pages) { 7540 freesize -= memmap_pages; 7541 if (memmap_pages) 7542 pr_debug(" %s zone: %lu pages used for memmap\n", 7543 zone_names[j], memmap_pages); 7544 } else 7545 pr_warn(" %s zone: %lu memmap pages exceeds freesize %lu\n", 7546 zone_names[j], memmap_pages, freesize); 7547 } 7548 7549 /* Account for reserved pages */ 7550 if (j == 0 && freesize > dma_reserve) { 7551 freesize -= dma_reserve; 7552 pr_debug(" %s zone: %lu pages reserved\n", zone_names[0], dma_reserve); 7553 } 7554 7555 if (!is_highmem_idx(j)) 7556 nr_kernel_pages += freesize; 7557 /* Charge for highmem memmap if there are enough kernel pages */ 7558 else if (nr_kernel_pages > memmap_pages * 2) 7559 nr_kernel_pages -= memmap_pages; 7560 nr_all_pages += freesize; 7561 7562 /* 7563 * Set an approximate value for lowmem here, it will be adjusted 7564 * when the bootmem allocator frees pages into the buddy system. 7565 * And all highmem pages will be managed by the buddy system. 7566 */ 7567 zone_init_internals(zone, j, nid, freesize); 7568 7569 if (!size) 7570 continue; 7571 7572 set_pageblock_order(); 7573 setup_usemap(zone); 7574 init_currently_empty_zone(zone, zone->zone_start_pfn, size); 7575 } 7576 } 7577 7578 #ifdef CONFIG_FLATMEM 7579 static void __init alloc_node_mem_map(struct pglist_data *pgdat) 7580 { 7581 unsigned long __maybe_unused start = 0; 7582 unsigned long __maybe_unused offset = 0; 7583 7584 /* Skip empty nodes */ 7585 if (!pgdat->node_spanned_pages) 7586 return; 7587 7588 start = pgdat->node_start_pfn & ~(MAX_ORDER_NR_PAGES - 1); 7589 offset = pgdat->node_start_pfn - start; 7590 /* ia64 gets its own node_mem_map, before this, without bootmem */ 7591 if (!pgdat->node_mem_map) { 7592 unsigned long size, end; 7593 struct page *map; 7594 7595 /* 7596 * The zone's endpoints aren't required to be MAX_ORDER 7597 * aligned but the node_mem_map endpoints must be in order 7598 * for the buddy allocator to function correctly. 7599 */ 7600 end = pgdat_end_pfn(pgdat); 7601 end = ALIGN(end, MAX_ORDER_NR_PAGES); 7602 size = (end - start) * sizeof(struct page); 7603 map = memmap_alloc(size, SMP_CACHE_BYTES, MEMBLOCK_LOW_LIMIT, 7604 pgdat->node_id, false); 7605 if (!map) 7606 panic("Failed to allocate %ld bytes for node %d memory map\n", 7607 size, pgdat->node_id); 7608 pgdat->node_mem_map = map + offset; 7609 } 7610 pr_debug("%s: node %d, pgdat %08lx, node_mem_map %08lx\n", 7611 __func__, pgdat->node_id, (unsigned long)pgdat, 7612 (unsigned long)pgdat->node_mem_map); 7613 #ifndef CONFIG_NUMA 7614 /* 7615 * With no DISCONTIG, the global mem_map is just set as node 0's 7616 */ 7617 if (pgdat == NODE_DATA(0)) { 7618 mem_map = NODE_DATA(0)->node_mem_map; 7619 if (page_to_pfn(mem_map) != pgdat->node_start_pfn) 7620 mem_map -= offset; 7621 } 7622 #endif 7623 } 7624 #else 7625 static inline void alloc_node_mem_map(struct pglist_data *pgdat) { } 7626 #endif /* CONFIG_FLATMEM */ 7627 7628 #ifdef CONFIG_DEFERRED_STRUCT_PAGE_INIT 7629 static inline void pgdat_set_deferred_range(pg_data_t *pgdat) 7630 { 7631 pgdat->first_deferred_pfn = ULONG_MAX; 7632 } 7633 #else 7634 static inline void pgdat_set_deferred_range(pg_data_t *pgdat) {} 7635 #endif 7636 7637 static void __init free_area_init_node(int nid) 7638 { 7639 pg_data_t *pgdat = NODE_DATA(nid); 7640 unsigned long start_pfn = 0; 7641 unsigned long end_pfn = 0; 7642 7643 /* pg_data_t should be reset to zero when it's allocated */ 7644 WARN_ON(pgdat->nr_zones || pgdat->kswapd_highest_zoneidx); 7645 7646 get_pfn_range_for_nid(nid, &start_pfn, &end_pfn); 7647 7648 pgdat->node_id = nid; 7649 pgdat->node_start_pfn = start_pfn; 7650 pgdat->per_cpu_nodestats = NULL; 7651 7652 if (start_pfn != end_pfn) { 7653 pr_info("Initmem setup node %d [mem %#018Lx-%#018Lx]\n", nid, 7654 (u64)start_pfn << PAGE_SHIFT, 7655 end_pfn ? ((u64)end_pfn << PAGE_SHIFT) - 1 : 0); 7656 } else { 7657 pr_info("Initmem setup node %d as memoryless\n", nid); 7658 } 7659 7660 calculate_node_totalpages(pgdat, start_pfn, end_pfn); 7661 7662 alloc_node_mem_map(pgdat); 7663 pgdat_set_deferred_range(pgdat); 7664 7665 free_area_init_core(pgdat); 7666 } 7667 7668 static void __init free_area_init_memoryless_node(int nid) 7669 { 7670 free_area_init_node(nid); 7671 } 7672 7673 #if MAX_NUMNODES > 1 7674 /* 7675 * Figure out the number of possible node ids. 7676 */ 7677 void __init setup_nr_node_ids(void) 7678 { 7679 unsigned int highest; 7680 7681 highest = find_last_bit(node_possible_map.bits, MAX_NUMNODES); 7682 nr_node_ids = highest + 1; 7683 } 7684 #endif 7685 7686 /** 7687 * node_map_pfn_alignment - determine the maximum internode alignment 7688 * 7689 * This function should be called after node map is populated and sorted. 7690 * It calculates the maximum power of two alignment which can distinguish 7691 * all the nodes. 7692 * 7693 * For example, if all nodes are 1GiB and aligned to 1GiB, the return value 7694 * would indicate 1GiB alignment with (1 << (30 - PAGE_SHIFT)). If the 7695 * nodes are shifted by 256MiB, 256MiB. Note that if only the last node is 7696 * shifted, 1GiB is enough and this function will indicate so. 7697 * 7698 * This is used to test whether pfn -> nid mapping of the chosen memory 7699 * model has fine enough granularity to avoid incorrect mapping for the 7700 * populated node map. 7701 * 7702 * Return: the determined alignment in pfn's. 0 if there is no alignment 7703 * requirement (single node). 7704 */ 7705 unsigned long __init node_map_pfn_alignment(void) 7706 { 7707 unsigned long accl_mask = 0, last_end = 0; 7708 unsigned long start, end, mask; 7709 int last_nid = NUMA_NO_NODE; 7710 int i, nid; 7711 7712 for_each_mem_pfn_range(i, MAX_NUMNODES, &start, &end, &nid) { 7713 if (!start || last_nid < 0 || last_nid == nid) { 7714 last_nid = nid; 7715 last_end = end; 7716 continue; 7717 } 7718 7719 /* 7720 * Start with a mask granular enough to pin-point to the 7721 * start pfn and tick off bits one-by-one until it becomes 7722 * too coarse to separate the current node from the last. 7723 */ 7724 mask = ~((1 << __ffs(start)) - 1); 7725 while (mask && last_end <= (start & (mask << 1))) 7726 mask <<= 1; 7727 7728 /* accumulate all internode masks */ 7729 accl_mask |= mask; 7730 } 7731 7732 /* convert mask to number of pages */ 7733 return ~accl_mask + 1; 7734 } 7735 7736 /** 7737 * find_min_pfn_with_active_regions - Find the minimum PFN registered 7738 * 7739 * Return: the minimum PFN based on information provided via 7740 * memblock_set_node(). 7741 */ 7742 unsigned long __init find_min_pfn_with_active_regions(void) 7743 { 7744 return PHYS_PFN(memblock_start_of_DRAM()); 7745 } 7746 7747 /* 7748 * early_calculate_totalpages() 7749 * Sum pages in active regions for movable zone. 7750 * Populate N_MEMORY for calculating usable_nodes. 7751 */ 7752 static unsigned long __init early_calculate_totalpages(void) 7753 { 7754 unsigned long totalpages = 0; 7755 unsigned long start_pfn, end_pfn; 7756 int i, nid; 7757 7758 for_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn, &nid) { 7759 unsigned long pages = end_pfn - start_pfn; 7760 7761 totalpages += pages; 7762 if (pages) 7763 node_set_state(nid, N_MEMORY); 7764 } 7765 return totalpages; 7766 } 7767 7768 /* 7769 * Find the PFN the Movable zone begins in each node. Kernel memory 7770 * is spread evenly between nodes as long as the nodes have enough 7771 * memory. When they don't, some nodes will have more kernelcore than 7772 * others 7773 */ 7774 static void __init find_zone_movable_pfns_for_nodes(void) 7775 { 7776 int i, nid; 7777 unsigned long usable_startpfn; 7778 unsigned long kernelcore_node, kernelcore_remaining; 7779 /* save the state before borrow the nodemask */ 7780 nodemask_t saved_node_state = node_states[N_MEMORY]; 7781 unsigned long totalpages = early_calculate_totalpages(); 7782 int usable_nodes = nodes_weight(node_states[N_MEMORY]); 7783 struct memblock_region *r; 7784 7785 /* Need to find movable_zone earlier when movable_node is specified. */ 7786 find_usable_zone_for_movable(); 7787 7788 /* 7789 * If movable_node is specified, ignore kernelcore and movablecore 7790 * options. 7791 */ 7792 if (movable_node_is_enabled()) { 7793 for_each_mem_region(r) { 7794 if (!memblock_is_hotpluggable(r)) 7795 continue; 7796 7797 nid = memblock_get_region_node(r); 7798 7799 usable_startpfn = PFN_DOWN(r->base); 7800 zone_movable_pfn[nid] = zone_movable_pfn[nid] ? 7801 min(usable_startpfn, zone_movable_pfn[nid]) : 7802 usable_startpfn; 7803 } 7804 7805 goto out2; 7806 } 7807 7808 /* 7809 * If kernelcore=mirror is specified, ignore movablecore option 7810 */ 7811 if (mirrored_kernelcore) { 7812 bool mem_below_4gb_not_mirrored = false; 7813 7814 for_each_mem_region(r) { 7815 if (memblock_is_mirror(r)) 7816 continue; 7817 7818 nid = memblock_get_region_node(r); 7819 7820 usable_startpfn = memblock_region_memory_base_pfn(r); 7821 7822 if (usable_startpfn < 0x100000) { 7823 mem_below_4gb_not_mirrored = true; 7824 continue; 7825 } 7826 7827 zone_movable_pfn[nid] = zone_movable_pfn[nid] ? 7828 min(usable_startpfn, zone_movable_pfn[nid]) : 7829 usable_startpfn; 7830 } 7831 7832 if (mem_below_4gb_not_mirrored) 7833 pr_warn("This configuration results in unmirrored kernel memory.\n"); 7834 7835 goto out2; 7836 } 7837 7838 /* 7839 * If kernelcore=nn% or movablecore=nn% was specified, calculate the 7840 * amount of necessary memory. 7841 */ 7842 if (required_kernelcore_percent) 7843 required_kernelcore = (totalpages * 100 * required_kernelcore_percent) / 7844 10000UL; 7845 if (required_movablecore_percent) 7846 required_movablecore = (totalpages * 100 * required_movablecore_percent) / 7847 10000UL; 7848 7849 /* 7850 * If movablecore= was specified, calculate what size of 7851 * kernelcore that corresponds so that memory usable for 7852 * any allocation type is evenly spread. If both kernelcore 7853 * and movablecore are specified, then the value of kernelcore 7854 * will be used for required_kernelcore if it's greater than 7855 * what movablecore would have allowed. 7856 */ 7857 if (required_movablecore) { 7858 unsigned long corepages; 7859 7860 /* 7861 * Round-up so that ZONE_MOVABLE is at least as large as what 7862 * was requested by the user 7863 */ 7864 required_movablecore = 7865 roundup(required_movablecore, MAX_ORDER_NR_PAGES); 7866 required_movablecore = min(totalpages, required_movablecore); 7867 corepages = totalpages - required_movablecore; 7868 7869 required_kernelcore = max(required_kernelcore, corepages); 7870 } 7871 7872 /* 7873 * If kernelcore was not specified or kernelcore size is larger 7874 * than totalpages, there is no ZONE_MOVABLE. 7875 */ 7876 if (!required_kernelcore || required_kernelcore >= totalpages) 7877 goto out; 7878 7879 /* usable_startpfn is the lowest possible pfn ZONE_MOVABLE can be at */ 7880 usable_startpfn = arch_zone_lowest_possible_pfn[movable_zone]; 7881 7882 restart: 7883 /* Spread kernelcore memory as evenly as possible throughout nodes */ 7884 kernelcore_node = required_kernelcore / usable_nodes; 7885 for_each_node_state(nid, N_MEMORY) { 7886 unsigned long start_pfn, end_pfn; 7887 7888 /* 7889 * Recalculate kernelcore_node if the division per node 7890 * now exceeds what is necessary to satisfy the requested 7891 * amount of memory for the kernel 7892 */ 7893 if (required_kernelcore < kernelcore_node) 7894 kernelcore_node = required_kernelcore / usable_nodes; 7895 7896 /* 7897 * As the map is walked, we track how much memory is usable 7898 * by the kernel using kernelcore_remaining. When it is 7899 * 0, the rest of the node is usable by ZONE_MOVABLE 7900 */ 7901 kernelcore_remaining = kernelcore_node; 7902 7903 /* Go through each range of PFNs within this node */ 7904 for_each_mem_pfn_range(i, nid, &start_pfn, &end_pfn, NULL) { 7905 unsigned long size_pages; 7906 7907 start_pfn = max(start_pfn, zone_movable_pfn[nid]); 7908 if (start_pfn >= end_pfn) 7909 continue; 7910 7911 /* Account for what is only usable for kernelcore */ 7912 if (start_pfn < usable_startpfn) { 7913 unsigned long kernel_pages; 7914 kernel_pages = min(end_pfn, usable_startpfn) 7915 - start_pfn; 7916 7917 kernelcore_remaining -= min(kernel_pages, 7918 kernelcore_remaining); 7919 required_kernelcore -= min(kernel_pages, 7920 required_kernelcore); 7921 7922 /* Continue if range is now fully accounted */ 7923 if (end_pfn <= usable_startpfn) { 7924 7925 /* 7926 * Push zone_movable_pfn to the end so 7927 * that if we have to rebalance 7928 * kernelcore across nodes, we will 7929 * not double account here 7930 */ 7931 zone_movable_pfn[nid] = end_pfn; 7932 continue; 7933 } 7934 start_pfn = usable_startpfn; 7935 } 7936 7937 /* 7938 * The usable PFN range for ZONE_MOVABLE is from 7939 * start_pfn->end_pfn. Calculate size_pages as the 7940 * number of pages used as kernelcore 7941 */ 7942 size_pages = end_pfn - start_pfn; 7943 if (size_pages > kernelcore_remaining) 7944 size_pages = kernelcore_remaining; 7945 zone_movable_pfn[nid] = start_pfn + size_pages; 7946 7947 /* 7948 * Some kernelcore has been met, update counts and 7949 * break if the kernelcore for this node has been 7950 * satisfied 7951 */ 7952 required_kernelcore -= min(required_kernelcore, 7953 size_pages); 7954 kernelcore_remaining -= size_pages; 7955 if (!kernelcore_remaining) 7956 break; 7957 } 7958 } 7959 7960 /* 7961 * If there is still required_kernelcore, we do another pass with one 7962 * less node in the count. This will push zone_movable_pfn[nid] further 7963 * along on the nodes that still have memory until kernelcore is 7964 * satisfied 7965 */ 7966 usable_nodes--; 7967 if (usable_nodes && required_kernelcore > usable_nodes) 7968 goto restart; 7969 7970 out2: 7971 /* Align start of ZONE_MOVABLE on all nids to MAX_ORDER_NR_PAGES */ 7972 for (nid = 0; nid < MAX_NUMNODES; nid++) { 7973 unsigned long start_pfn, end_pfn; 7974 7975 zone_movable_pfn[nid] = 7976 roundup(zone_movable_pfn[nid], MAX_ORDER_NR_PAGES); 7977 7978 get_pfn_range_for_nid(nid, &start_pfn, &end_pfn); 7979 if (zone_movable_pfn[nid] >= end_pfn) 7980 zone_movable_pfn[nid] = 0; 7981 } 7982 7983 out: 7984 /* restore the node_state */ 7985 node_states[N_MEMORY] = saved_node_state; 7986 } 7987 7988 /* Any regular or high memory on that node ? */ 7989 static void check_for_memory(pg_data_t *pgdat, int nid) 7990 { 7991 enum zone_type zone_type; 7992 7993 for (zone_type = 0; zone_type <= ZONE_MOVABLE - 1; zone_type++) { 7994 struct zone *zone = &pgdat->node_zones[zone_type]; 7995 if (populated_zone(zone)) { 7996 if (IS_ENABLED(CONFIG_HIGHMEM)) 7997 node_set_state(nid, N_HIGH_MEMORY); 7998 if (zone_type <= ZONE_NORMAL) 7999 node_set_state(nid, N_NORMAL_MEMORY); 8000 break; 8001 } 8002 } 8003 } 8004 8005 /* 8006 * Some architectures, e.g. ARC may have ZONE_HIGHMEM below ZONE_NORMAL. For 8007 * such cases we allow max_zone_pfn sorted in the descending order 8008 */ 8009 bool __weak arch_has_descending_max_zone_pfns(void) 8010 { 8011 return false; 8012 } 8013 8014 /** 8015 * free_area_init - Initialise all pg_data_t and zone data 8016 * @max_zone_pfn: an array of max PFNs for each zone 8017 * 8018 * This will call free_area_init_node() for each active node in the system. 8019 * Using the page ranges provided by memblock_set_node(), the size of each 8020 * zone in each node and their holes is calculated. If the maximum PFN 8021 * between two adjacent zones match, it is assumed that the zone is empty. 8022 * For example, if arch_max_dma_pfn == arch_max_dma32_pfn, it is assumed 8023 * that arch_max_dma32_pfn has no pages. It is also assumed that a zone 8024 * starts where the previous one ended. For example, ZONE_DMA32 starts 8025 * at arch_max_dma_pfn. 8026 */ 8027 void __init free_area_init(unsigned long *max_zone_pfn) 8028 { 8029 unsigned long start_pfn, end_pfn; 8030 int i, nid, zone; 8031 bool descending; 8032 8033 /* Record where the zone boundaries are */ 8034 memset(arch_zone_lowest_possible_pfn, 0, 8035 sizeof(arch_zone_lowest_possible_pfn)); 8036 memset(arch_zone_highest_possible_pfn, 0, 8037 sizeof(arch_zone_highest_possible_pfn)); 8038 8039 start_pfn = find_min_pfn_with_active_regions(); 8040 descending = arch_has_descending_max_zone_pfns(); 8041 8042 for (i = 0; i < MAX_NR_ZONES; i++) { 8043 if (descending) 8044 zone = MAX_NR_ZONES - i - 1; 8045 else 8046 zone = i; 8047 8048 if (zone == ZONE_MOVABLE) 8049 continue; 8050 8051 end_pfn = max(max_zone_pfn[zone], start_pfn); 8052 arch_zone_lowest_possible_pfn[zone] = start_pfn; 8053 arch_zone_highest_possible_pfn[zone] = end_pfn; 8054 8055 start_pfn = end_pfn; 8056 } 8057 8058 /* Find the PFNs that ZONE_MOVABLE begins at in each node */ 8059 memset(zone_movable_pfn, 0, sizeof(zone_movable_pfn)); 8060 find_zone_movable_pfns_for_nodes(); 8061 8062 /* Print out the zone ranges */ 8063 pr_info("Zone ranges:\n"); 8064 for (i = 0; i < MAX_NR_ZONES; i++) { 8065 if (i == ZONE_MOVABLE) 8066 continue; 8067 pr_info(" %-8s ", zone_names[i]); 8068 if (arch_zone_lowest_possible_pfn[i] == 8069 arch_zone_highest_possible_pfn[i]) 8070 pr_cont("empty\n"); 8071 else 8072 pr_cont("[mem %#018Lx-%#018Lx]\n", 8073 (u64)arch_zone_lowest_possible_pfn[i] 8074 << PAGE_SHIFT, 8075 ((u64)arch_zone_highest_possible_pfn[i] 8076 << PAGE_SHIFT) - 1); 8077 } 8078 8079 /* Print out the PFNs ZONE_MOVABLE begins at in each node */ 8080 pr_info("Movable zone start for each node\n"); 8081 for (i = 0; i < MAX_NUMNODES; i++) { 8082 if (zone_movable_pfn[i]) 8083 pr_info(" Node %d: %#018Lx\n", i, 8084 (u64)zone_movable_pfn[i] << PAGE_SHIFT); 8085 } 8086 8087 /* 8088 * Print out the early node map, and initialize the 8089 * subsection-map relative to active online memory ranges to 8090 * enable future "sub-section" extensions of the memory map. 8091 */ 8092 pr_info("Early memory node ranges\n"); 8093 for_each_mem_pfn_range(i, MAX_NUMNODES, &start_pfn, &end_pfn, &nid) { 8094 pr_info(" node %3d: [mem %#018Lx-%#018Lx]\n", nid, 8095 (u64)start_pfn << PAGE_SHIFT, 8096 ((u64)end_pfn << PAGE_SHIFT) - 1); 8097 subsection_map_init(start_pfn, end_pfn - start_pfn); 8098 } 8099 8100 /* Initialise every node */ 8101 mminit_verify_pageflags_layout(); 8102 setup_nr_node_ids(); 8103 for_each_node(nid) { 8104 pg_data_t *pgdat; 8105 8106 if (!node_online(nid)) { 8107 pr_info("Initializing node %d as memoryless\n", nid); 8108 8109 /* Allocator not initialized yet */ 8110 pgdat = arch_alloc_nodedata(nid); 8111 if (!pgdat) { 8112 pr_err("Cannot allocate %zuB for node %d.\n", 8113 sizeof(*pgdat), nid); 8114 continue; 8115 } 8116 arch_refresh_nodedata(nid, pgdat); 8117 free_area_init_memoryless_node(nid); 8118 8119 /* 8120 * We do not want to confuse userspace by sysfs 8121 * files/directories for node without any memory 8122 * attached to it, so this node is not marked as 8123 * N_MEMORY and not marked online so that no sysfs 8124 * hierarchy will be created via register_one_node for 8125 * it. The pgdat will get fully initialized by 8126 * hotadd_init_pgdat() when memory is hotplugged into 8127 * this node. 8128 */ 8129 continue; 8130 } 8131 8132 pgdat = NODE_DATA(nid); 8133 free_area_init_node(nid); 8134 8135 /* Any memory on that node */ 8136 if (pgdat->node_present_pages) 8137 node_set_state(nid, N_MEMORY); 8138 check_for_memory(pgdat, nid); 8139 } 8140 8141 memmap_init(); 8142 } 8143 8144 static int __init cmdline_parse_core(char *p, unsigned long *core, 8145 unsigned long *percent) 8146 { 8147 unsigned long long coremem; 8148 char *endptr; 8149 8150 if (!p) 8151 return -EINVAL; 8152 8153 /* Value may be a percentage of total memory, otherwise bytes */ 8154 coremem = simple_strtoull(p, &endptr, 0); 8155 if (*endptr == '%') { 8156 /* Paranoid check for percent values greater than 100 */ 8157 WARN_ON(coremem > 100); 8158 8159 *percent = coremem; 8160 } else { 8161 coremem = memparse(p, &p); 8162 /* Paranoid check that UL is enough for the coremem value */ 8163 WARN_ON((coremem >> PAGE_SHIFT) > ULONG_MAX); 8164 8165 *core = coremem >> PAGE_SHIFT; 8166 *percent = 0UL; 8167 } 8168 return 0; 8169 } 8170 8171 /* 8172 * kernelcore=size sets the amount of memory for use for allocations that 8173 * cannot be reclaimed or migrated. 8174 */ 8175 static int __init cmdline_parse_kernelcore(char *p) 8176 { 8177 /* parse kernelcore=mirror */ 8178 if (parse_option_str(p, "mirror")) { 8179 mirrored_kernelcore = true; 8180 return 0; 8181 } 8182 8183 return cmdline_parse_core(p, &required_kernelcore, 8184 &required_kernelcore_percent); 8185 } 8186 8187 /* 8188 * movablecore=size sets the amount of memory for use for allocations that 8189 * can be reclaimed or migrated. 8190 */ 8191 static int __init cmdline_parse_movablecore(char *p) 8192 { 8193 return cmdline_parse_core(p, &required_movablecore, 8194 &required_movablecore_percent); 8195 } 8196 8197 early_param("kernelcore", cmdline_parse_kernelcore); 8198 early_param("movablecore", cmdline_parse_movablecore); 8199 8200 void adjust_managed_page_count(struct page *page, long count) 8201 { 8202 atomic_long_add(count, &page_zone(page)->managed_pages); 8203 totalram_pages_add(count); 8204 #ifdef CONFIG_HIGHMEM 8205 if (PageHighMem(page)) 8206 totalhigh_pages_add(count); 8207 #endif 8208 } 8209 EXPORT_SYMBOL(adjust_managed_page_count); 8210 8211 unsigned long free_reserved_area(void *start, void *end, int poison, const char *s) 8212 { 8213 void *pos; 8214 unsigned long pages = 0; 8215 8216 start = (void *)PAGE_ALIGN((unsigned long)start); 8217 end = (void *)((unsigned long)end & PAGE_MASK); 8218 for (pos = start; pos < end; pos += PAGE_SIZE, pages++) { 8219 struct page *page = virt_to_page(pos); 8220 void *direct_map_addr; 8221 8222 /* 8223 * 'direct_map_addr' might be different from 'pos' 8224 * because some architectures' virt_to_page() 8225 * work with aliases. Getting the direct map 8226 * address ensures that we get a _writeable_ 8227 * alias for the memset(). 8228 */ 8229 direct_map_addr = page_address(page); 8230 /* 8231 * Perform a kasan-unchecked memset() since this memory 8232 * has not been initialized. 8233 */ 8234 direct_map_addr = kasan_reset_tag(direct_map_addr); 8235 if ((unsigned int)poison <= 0xFF) 8236 memset(direct_map_addr, poison, PAGE_SIZE); 8237 8238 free_reserved_page(page); 8239 } 8240 8241 if (pages && s) 8242 pr_info("Freeing %s memory: %ldK\n", s, K(pages)); 8243 8244 return pages; 8245 } 8246 8247 void __init mem_init_print_info(void) 8248 { 8249 unsigned long physpages, codesize, datasize, rosize, bss_size; 8250 unsigned long init_code_size, init_data_size; 8251 8252 physpages = get_num_physpages(); 8253 codesize = _etext - _stext; 8254 datasize = _edata - _sdata; 8255 rosize = __end_rodata - __start_rodata; 8256 bss_size = __bss_stop - __bss_start; 8257 init_data_size = __init_end - __init_begin; 8258 init_code_size = _einittext - _sinittext; 8259 8260 /* 8261 * Detect special cases and adjust section sizes accordingly: 8262 * 1) .init.* may be embedded into .data sections 8263 * 2) .init.text.* may be out of [__init_begin, __init_end], 8264 * please refer to arch/tile/kernel/vmlinux.lds.S. 8265 * 3) .rodata.* may be embedded into .text or .data sections. 8266 */ 8267 #define adj_init_size(start, end, size, pos, adj) \ 8268 do { \ 8269 if (&start[0] <= &pos[0] && &pos[0] < &end[0] && size > adj) \ 8270 size -= adj; \ 8271 } while (0) 8272 8273 adj_init_size(__init_begin, __init_end, init_data_size, 8274 _sinittext, init_code_size); 8275 adj_init_size(_stext, _etext, codesize, _sinittext, init_code_size); 8276 adj_init_size(_sdata, _edata, datasize, __init_begin, init_data_size); 8277 adj_init_size(_stext, _etext, codesize, __start_rodata, rosize); 8278 adj_init_size(_sdata, _edata, datasize, __start_rodata, rosize); 8279 8280 #undef adj_init_size 8281 8282 pr_info("Memory: %luK/%luK available (%luK kernel code, %luK rwdata, %luK rodata, %luK init, %luK bss, %luK reserved, %luK cma-reserved" 8283 #ifdef CONFIG_HIGHMEM 8284 ", %luK highmem" 8285 #endif 8286 ")\n", 8287 K(nr_free_pages()), K(physpages), 8288 codesize >> 10, datasize >> 10, rosize >> 10, 8289 (init_data_size + init_code_size) >> 10, bss_size >> 10, 8290 K(physpages - totalram_pages() - totalcma_pages), 8291 K(totalcma_pages) 8292 #ifdef CONFIG_HIGHMEM 8293 , K(totalhigh_pages()) 8294 #endif 8295 ); 8296 } 8297 8298 /** 8299 * set_dma_reserve - set the specified number of pages reserved in the first zone 8300 * @new_dma_reserve: The number of pages to mark reserved 8301 * 8302 * The per-cpu batchsize and zone watermarks are determined by managed_pages. 8303 * In the DMA zone, a significant percentage may be consumed by kernel image 8304 * and other unfreeable allocations which can skew the watermarks badly. This 8305 * function may optionally be used to account for unfreeable pages in the 8306 * first zone (e.g., ZONE_DMA). The effect will be lower watermarks and 8307 * smaller per-cpu batchsize. 8308 */ 8309 void __init set_dma_reserve(unsigned long new_dma_reserve) 8310 { 8311 dma_reserve = new_dma_reserve; 8312 } 8313 8314 static int page_alloc_cpu_dead(unsigned int cpu) 8315 { 8316 struct zone *zone; 8317 8318 lru_add_drain_cpu(cpu); 8319 mlock_page_drain_remote(cpu); 8320 drain_pages(cpu); 8321 8322 /* 8323 * Spill the event counters of the dead processor 8324 * into the current processors event counters. 8325 * This artificially elevates the count of the current 8326 * processor. 8327 */ 8328 vm_events_fold_cpu(cpu); 8329 8330 /* 8331 * Zero the differential counters of the dead processor 8332 * so that the vm statistics are consistent. 8333 * 8334 * This is only okay since the processor is dead and cannot 8335 * race with what we are doing. 8336 */ 8337 cpu_vm_stats_fold(cpu); 8338 8339 for_each_populated_zone(zone) 8340 zone_pcp_update(zone, 0); 8341 8342 return 0; 8343 } 8344 8345 static int page_alloc_cpu_online(unsigned int cpu) 8346 { 8347 struct zone *zone; 8348 8349 for_each_populated_zone(zone) 8350 zone_pcp_update(zone, 1); 8351 return 0; 8352 } 8353 8354 #ifdef CONFIG_NUMA 8355 int hashdist = HASHDIST_DEFAULT; 8356 8357 static int __init set_hashdist(char *str) 8358 { 8359 if (!str) 8360 return 0; 8361 hashdist = simple_strtoul(str, &str, 0); 8362 return 1; 8363 } 8364 __setup("hashdist=", set_hashdist); 8365 #endif 8366 8367 void __init page_alloc_init(void) 8368 { 8369 int ret; 8370 8371 #ifdef CONFIG_NUMA 8372 if (num_node_state(N_MEMORY) == 1) 8373 hashdist = 0; 8374 #endif 8375 8376 ret = cpuhp_setup_state_nocalls(CPUHP_PAGE_ALLOC, 8377 "mm/page_alloc:pcp", 8378 page_alloc_cpu_online, 8379 page_alloc_cpu_dead); 8380 WARN_ON(ret < 0); 8381 } 8382 8383 /* 8384 * calculate_totalreserve_pages - called when sysctl_lowmem_reserve_ratio 8385 * or min_free_kbytes changes. 8386 */ 8387 static void calculate_totalreserve_pages(void) 8388 { 8389 struct pglist_data *pgdat; 8390 unsigned long reserve_pages = 0; 8391 enum zone_type i, j; 8392 8393 for_each_online_pgdat(pgdat) { 8394 8395 pgdat->totalreserve_pages = 0; 8396 8397 for (i = 0; i < MAX_NR_ZONES; i++) { 8398 struct zone *zone = pgdat->node_zones + i; 8399 long max = 0; 8400 unsigned long managed_pages = zone_managed_pages(zone); 8401 8402 /* Find valid and maximum lowmem_reserve in the zone */ 8403 for (j = i; j < MAX_NR_ZONES; j++) { 8404 if (zone->lowmem_reserve[j] > max) 8405 max = zone->lowmem_reserve[j]; 8406 } 8407 8408 /* we treat the high watermark as reserved pages. */ 8409 max += high_wmark_pages(zone); 8410 8411 if (max > managed_pages) 8412 max = managed_pages; 8413 8414 pgdat->totalreserve_pages += max; 8415 8416 reserve_pages += max; 8417 } 8418 } 8419 totalreserve_pages = reserve_pages; 8420 } 8421 8422 /* 8423 * setup_per_zone_lowmem_reserve - called whenever 8424 * sysctl_lowmem_reserve_ratio changes. Ensures that each zone 8425 * has a correct pages reserved value, so an adequate number of 8426 * pages are left in the zone after a successful __alloc_pages(). 8427 */ 8428 static void setup_per_zone_lowmem_reserve(void) 8429 { 8430 struct pglist_data *pgdat; 8431 enum zone_type i, j; 8432 8433 for_each_online_pgdat(pgdat) { 8434 for (i = 0; i < MAX_NR_ZONES - 1; i++) { 8435 struct zone *zone = &pgdat->node_zones[i]; 8436 int ratio = sysctl_lowmem_reserve_ratio[i]; 8437 bool clear = !ratio || !zone_managed_pages(zone); 8438 unsigned long managed_pages = 0; 8439 8440 for (j = i + 1; j < MAX_NR_ZONES; j++) { 8441 struct zone *upper_zone = &pgdat->node_zones[j]; 8442 8443 managed_pages += zone_managed_pages(upper_zone); 8444 8445 if (clear) 8446 zone->lowmem_reserve[j] = 0; 8447 else 8448 zone->lowmem_reserve[j] = managed_pages / ratio; 8449 } 8450 } 8451 } 8452 8453 /* update totalreserve_pages */ 8454 calculate_totalreserve_pages(); 8455 } 8456 8457 static void __setup_per_zone_wmarks(void) 8458 { 8459 unsigned long pages_min = min_free_kbytes >> (PAGE_SHIFT - 10); 8460 unsigned long lowmem_pages = 0; 8461 struct zone *zone; 8462 unsigned long flags; 8463 8464 /* Calculate total number of !ZONE_HIGHMEM pages */ 8465 for_each_zone(zone) { 8466 if (!is_highmem(zone)) 8467 lowmem_pages += zone_managed_pages(zone); 8468 } 8469 8470 for_each_zone(zone) { 8471 u64 tmp; 8472 8473 spin_lock_irqsave(&zone->lock, flags); 8474 tmp = (u64)pages_min * zone_managed_pages(zone); 8475 do_div(tmp, lowmem_pages); 8476 if (is_highmem(zone)) { 8477 /* 8478 * __GFP_HIGH and PF_MEMALLOC allocations usually don't 8479 * need highmem pages, so cap pages_min to a small 8480 * value here. 8481 * 8482 * The WMARK_HIGH-WMARK_LOW and (WMARK_LOW-WMARK_MIN) 8483 * deltas control async page reclaim, and so should 8484 * not be capped for highmem. 8485 */ 8486 unsigned long min_pages; 8487 8488 min_pages = zone_managed_pages(zone) / 1024; 8489 min_pages = clamp(min_pages, SWAP_CLUSTER_MAX, 128UL); 8490 zone->_watermark[WMARK_MIN] = min_pages; 8491 } else { 8492 /* 8493 * If it's a lowmem zone, reserve a number of pages 8494 * proportionate to the zone's size. 8495 */ 8496 zone->_watermark[WMARK_MIN] = tmp; 8497 } 8498 8499 /* 8500 * Set the kswapd watermarks distance according to the 8501 * scale factor in proportion to available memory, but 8502 * ensure a minimum size on small systems. 8503 */ 8504 tmp = max_t(u64, tmp >> 2, 8505 mult_frac(zone_managed_pages(zone), 8506 watermark_scale_factor, 10000)); 8507 8508 zone->watermark_boost = 0; 8509 zone->_watermark[WMARK_LOW] = min_wmark_pages(zone) + tmp; 8510 zone->_watermark[WMARK_HIGH] = low_wmark_pages(zone) + tmp; 8511 zone->_watermark[WMARK_PROMO] = high_wmark_pages(zone) + tmp; 8512 8513 spin_unlock_irqrestore(&zone->lock, flags); 8514 } 8515 8516 /* update totalreserve_pages */ 8517 calculate_totalreserve_pages(); 8518 } 8519 8520 /** 8521 * setup_per_zone_wmarks - called when min_free_kbytes changes 8522 * or when memory is hot-{added|removed} 8523 * 8524 * Ensures that the watermark[min,low,high] values for each zone are set 8525 * correctly with respect to min_free_kbytes. 8526 */ 8527 void setup_per_zone_wmarks(void) 8528 { 8529 struct zone *zone; 8530 static DEFINE_SPINLOCK(lock); 8531 8532 spin_lock(&lock); 8533 __setup_per_zone_wmarks(); 8534 spin_unlock(&lock); 8535 8536 /* 8537 * The watermark size have changed so update the pcpu batch 8538 * and high limits or the limits may be inappropriate. 8539 */ 8540 for_each_zone(zone) 8541 zone_pcp_update(zone, 0); 8542 } 8543 8544 /* 8545 * Initialise min_free_kbytes. 8546 * 8547 * For small machines we want it small (128k min). For large machines 8548 * we want it large (256MB max). But it is not linear, because network 8549 * bandwidth does not increase linearly with machine size. We use 8550 * 8551 * min_free_kbytes = 4 * sqrt(lowmem_kbytes), for better accuracy: 8552 * min_free_kbytes = sqrt(lowmem_kbytes * 16) 8553 * 8554 * which yields 8555 * 8556 * 16MB: 512k 8557 * 32MB: 724k 8558 * 64MB: 1024k 8559 * 128MB: 1448k 8560 * 256MB: 2048k 8561 * 512MB: 2896k 8562 * 1024MB: 4096k 8563 * 2048MB: 5792k 8564 * 4096MB: 8192k 8565 * 8192MB: 11584k 8566 * 16384MB: 16384k 8567 */ 8568 void calculate_min_free_kbytes(void) 8569 { 8570 unsigned long lowmem_kbytes; 8571 int new_min_free_kbytes; 8572 8573 lowmem_kbytes = nr_free_buffer_pages() * (PAGE_SIZE >> 10); 8574 new_min_free_kbytes = int_sqrt(lowmem_kbytes * 16); 8575 8576 if (new_min_free_kbytes > user_min_free_kbytes) 8577 min_free_kbytes = clamp(new_min_free_kbytes, 128, 262144); 8578 else 8579 pr_warn("min_free_kbytes is not updated to %d because user defined value %d is preferred\n", 8580 new_min_free_kbytes, user_min_free_kbytes); 8581 8582 } 8583 8584 int __meminit init_per_zone_wmark_min(void) 8585 { 8586 calculate_min_free_kbytes(); 8587 setup_per_zone_wmarks(); 8588 refresh_zone_stat_thresholds(); 8589 setup_per_zone_lowmem_reserve(); 8590 8591 #ifdef CONFIG_NUMA 8592 setup_min_unmapped_ratio(); 8593 setup_min_slab_ratio(); 8594 #endif 8595 8596 khugepaged_min_free_kbytes_update(); 8597 8598 return 0; 8599 } 8600 postcore_initcall(init_per_zone_wmark_min) 8601 8602 /* 8603 * min_free_kbytes_sysctl_handler - just a wrapper around proc_dointvec() so 8604 * that we can call two helper functions whenever min_free_kbytes 8605 * changes. 8606 */ 8607 int min_free_kbytes_sysctl_handler(struct ctl_table *table, int write, 8608 void *buffer, size_t *length, loff_t *ppos) 8609 { 8610 int rc; 8611 8612 rc = proc_dointvec_minmax(table, write, buffer, length, ppos); 8613 if (rc) 8614 return rc; 8615 8616 if (write) { 8617 user_min_free_kbytes = min_free_kbytes; 8618 setup_per_zone_wmarks(); 8619 } 8620 return 0; 8621 } 8622 8623 int watermark_scale_factor_sysctl_handler(struct ctl_table *table, int write, 8624 void *buffer, size_t *length, loff_t *ppos) 8625 { 8626 int rc; 8627 8628 rc = proc_dointvec_minmax(table, write, buffer, length, ppos); 8629 if (rc) 8630 return rc; 8631 8632 if (write) 8633 setup_per_zone_wmarks(); 8634 8635 return 0; 8636 } 8637 8638 #ifdef CONFIG_NUMA 8639 static void setup_min_unmapped_ratio(void) 8640 { 8641 pg_data_t *pgdat; 8642 struct zone *zone; 8643 8644 for_each_online_pgdat(pgdat) 8645 pgdat->min_unmapped_pages = 0; 8646 8647 for_each_zone(zone) 8648 zone->zone_pgdat->min_unmapped_pages += (zone_managed_pages(zone) * 8649 sysctl_min_unmapped_ratio) / 100; 8650 } 8651 8652 8653 int sysctl_min_unmapped_ratio_sysctl_handler(struct ctl_table *table, int write, 8654 void *buffer, size_t *length, loff_t *ppos) 8655 { 8656 int rc; 8657 8658 rc = proc_dointvec_minmax(table, write, buffer, length, ppos); 8659 if (rc) 8660 return rc; 8661 8662 setup_min_unmapped_ratio(); 8663 8664 return 0; 8665 } 8666 8667 static void setup_min_slab_ratio(void) 8668 { 8669 pg_data_t *pgdat; 8670 struct zone *zone; 8671 8672 for_each_online_pgdat(pgdat) 8673 pgdat->min_slab_pages = 0; 8674 8675 for_each_zone(zone) 8676 zone->zone_pgdat->min_slab_pages += (zone_managed_pages(zone) * 8677 sysctl_min_slab_ratio) / 100; 8678 } 8679 8680 int sysctl_min_slab_ratio_sysctl_handler(struct ctl_table *table, int write, 8681 void *buffer, size_t *length, loff_t *ppos) 8682 { 8683 int rc; 8684 8685 rc = proc_dointvec_minmax(table, write, buffer, length, ppos); 8686 if (rc) 8687 return rc; 8688 8689 setup_min_slab_ratio(); 8690 8691 return 0; 8692 } 8693 #endif 8694 8695 /* 8696 * lowmem_reserve_ratio_sysctl_handler - just a wrapper around 8697 * proc_dointvec() so that we can call setup_per_zone_lowmem_reserve() 8698 * whenever sysctl_lowmem_reserve_ratio changes. 8699 * 8700 * The reserve ratio obviously has absolutely no relation with the 8701 * minimum watermarks. The lowmem reserve ratio can only make sense 8702 * if in function of the boot time zone sizes. 8703 */ 8704 int lowmem_reserve_ratio_sysctl_handler(struct ctl_table *table, int write, 8705 void *buffer, size_t *length, loff_t *ppos) 8706 { 8707 int i; 8708 8709 proc_dointvec_minmax(table, write, buffer, length, ppos); 8710 8711 for (i = 0; i < MAX_NR_ZONES; i++) { 8712 if (sysctl_lowmem_reserve_ratio[i] < 1) 8713 sysctl_lowmem_reserve_ratio[i] = 0; 8714 } 8715 8716 setup_per_zone_lowmem_reserve(); 8717 return 0; 8718 } 8719 8720 /* 8721 * percpu_pagelist_high_fraction - changes the pcp->high for each zone on each 8722 * cpu. It is the fraction of total pages in each zone that a hot per cpu 8723 * pagelist can have before it gets flushed back to buddy allocator. 8724 */ 8725 int percpu_pagelist_high_fraction_sysctl_handler(struct ctl_table *table, 8726 int write, void *buffer, size_t *length, loff_t *ppos) 8727 { 8728 struct zone *zone; 8729 int old_percpu_pagelist_high_fraction; 8730 int ret; 8731 8732 mutex_lock(&pcp_batch_high_lock); 8733 old_percpu_pagelist_high_fraction = percpu_pagelist_high_fraction; 8734 8735 ret = proc_dointvec_minmax(table, write, buffer, length, ppos); 8736 if (!write || ret < 0) 8737 goto out; 8738 8739 /* Sanity checking to avoid pcp imbalance */ 8740 if (percpu_pagelist_high_fraction && 8741 percpu_pagelist_high_fraction < MIN_PERCPU_PAGELIST_HIGH_FRACTION) { 8742 percpu_pagelist_high_fraction = old_percpu_pagelist_high_fraction; 8743 ret = -EINVAL; 8744 goto out; 8745 } 8746 8747 /* No change? */ 8748 if (percpu_pagelist_high_fraction == old_percpu_pagelist_high_fraction) 8749 goto out; 8750 8751 for_each_populated_zone(zone) 8752 zone_set_pageset_high_and_batch(zone, 0); 8753 out: 8754 mutex_unlock(&pcp_batch_high_lock); 8755 return ret; 8756 } 8757 8758 #ifndef __HAVE_ARCH_RESERVED_KERNEL_PAGES 8759 /* 8760 * Returns the number of pages that arch has reserved but 8761 * is not known to alloc_large_system_hash(). 8762 */ 8763 static unsigned long __init arch_reserved_kernel_pages(void) 8764 { 8765 return 0; 8766 } 8767 #endif 8768 8769 /* 8770 * Adaptive scale is meant to reduce sizes of hash tables on large memory 8771 * machines. As memory size is increased the scale is also increased but at 8772 * slower pace. Starting from ADAPT_SCALE_BASE (64G), every time memory 8773 * quadruples the scale is increased by one, which means the size of hash table 8774 * only doubles, instead of quadrupling as well. 8775 * Because 32-bit systems cannot have large physical memory, where this scaling 8776 * makes sense, it is disabled on such platforms. 8777 */ 8778 #if __BITS_PER_LONG > 32 8779 #define ADAPT_SCALE_BASE (64ul << 30) 8780 #define ADAPT_SCALE_SHIFT 2 8781 #define ADAPT_SCALE_NPAGES (ADAPT_SCALE_BASE >> PAGE_SHIFT) 8782 #endif 8783 8784 /* 8785 * allocate a large system hash table from bootmem 8786 * - it is assumed that the hash table must contain an exact power-of-2 8787 * quantity of entries 8788 * - limit is the number of hash buckets, not the total allocation size 8789 */ 8790 void *__init alloc_large_system_hash(const char *tablename, 8791 unsigned long bucketsize, 8792 unsigned long numentries, 8793 int scale, 8794 int flags, 8795 unsigned int *_hash_shift, 8796 unsigned int *_hash_mask, 8797 unsigned long low_limit, 8798 unsigned long high_limit) 8799 { 8800 unsigned long long max = high_limit; 8801 unsigned long log2qty, size; 8802 void *table = NULL; 8803 gfp_t gfp_flags; 8804 bool virt; 8805 bool huge; 8806 8807 /* allow the kernel cmdline to have a say */ 8808 if (!numentries) { 8809 /* round applicable memory size up to nearest megabyte */ 8810 numentries = nr_kernel_pages; 8811 numentries -= arch_reserved_kernel_pages(); 8812 8813 /* It isn't necessary when PAGE_SIZE >= 1MB */ 8814 if (PAGE_SHIFT < 20) 8815 numentries = round_up(numentries, (1<<20)/PAGE_SIZE); 8816 8817 #if __BITS_PER_LONG > 32 8818 if (!high_limit) { 8819 unsigned long adapt; 8820 8821 for (adapt = ADAPT_SCALE_NPAGES; adapt < numentries; 8822 adapt <<= ADAPT_SCALE_SHIFT) 8823 scale++; 8824 } 8825 #endif 8826 8827 /* limit to 1 bucket per 2^scale bytes of low memory */ 8828 if (scale > PAGE_SHIFT) 8829 numentries >>= (scale - PAGE_SHIFT); 8830 else 8831 numentries <<= (PAGE_SHIFT - scale); 8832 8833 /* Make sure we've got at least a 0-order allocation.. */ 8834 if (unlikely(flags & HASH_SMALL)) { 8835 /* Makes no sense without HASH_EARLY */ 8836 WARN_ON(!(flags & HASH_EARLY)); 8837 if (!(numentries >> *_hash_shift)) { 8838 numentries = 1UL << *_hash_shift; 8839 BUG_ON(!numentries); 8840 } 8841 } else if (unlikely((numentries * bucketsize) < PAGE_SIZE)) 8842 numentries = PAGE_SIZE / bucketsize; 8843 } 8844 numentries = roundup_pow_of_two(numentries); 8845 8846 /* limit allocation size to 1/16 total memory by default */ 8847 if (max == 0) { 8848 max = ((unsigned long long)nr_all_pages << PAGE_SHIFT) >> 4; 8849 do_div(max, bucketsize); 8850 } 8851 max = min(max, 0x80000000ULL); 8852 8853 if (numentries < low_limit) 8854 numentries = low_limit; 8855 if (numentries > max) 8856 numentries = max; 8857 8858 log2qty = ilog2(numentries); 8859 8860 gfp_flags = (flags & HASH_ZERO) ? GFP_ATOMIC | __GFP_ZERO : GFP_ATOMIC; 8861 do { 8862 virt = false; 8863 size = bucketsize << log2qty; 8864 if (flags & HASH_EARLY) { 8865 if (flags & HASH_ZERO) 8866 table = memblock_alloc(size, SMP_CACHE_BYTES); 8867 else 8868 table = memblock_alloc_raw(size, 8869 SMP_CACHE_BYTES); 8870 } else if (get_order(size) >= MAX_ORDER || hashdist) { 8871 table = vmalloc_huge(size, gfp_flags); 8872 virt = true; 8873 if (table) 8874 huge = is_vm_area_hugepages(table); 8875 } else { 8876 /* 8877 * If bucketsize is not a power-of-two, we may free 8878 * some pages at the end of hash table which 8879 * alloc_pages_exact() automatically does 8880 */ 8881 table = alloc_pages_exact(size, gfp_flags); 8882 kmemleak_alloc(table, size, 1, gfp_flags); 8883 } 8884 } while (!table && size > PAGE_SIZE && --log2qty); 8885 8886 if (!table) 8887 panic("Failed to allocate %s hash table\n", tablename); 8888 8889 pr_info("%s hash table entries: %ld (order: %d, %lu bytes, %s)\n", 8890 tablename, 1UL << log2qty, ilog2(size) - PAGE_SHIFT, size, 8891 virt ? (huge ? "vmalloc hugepage" : "vmalloc") : "linear"); 8892 8893 if (_hash_shift) 8894 *_hash_shift = log2qty; 8895 if (_hash_mask) 8896 *_hash_mask = (1 << log2qty) - 1; 8897 8898 return table; 8899 } 8900 8901 /* 8902 * This function checks whether pageblock includes unmovable pages or not. 8903 * 8904 * PageLRU check without isolation or lru_lock could race so that 8905 * MIGRATE_MOVABLE block might include unmovable pages. And __PageMovable 8906 * check without lock_page also may miss some movable non-lru pages at 8907 * race condition. So you can't expect this function should be exact. 8908 * 8909 * Returns a page without holding a reference. If the caller wants to 8910 * dereference that page (e.g., dumping), it has to make sure that it 8911 * cannot get removed (e.g., via memory unplug) concurrently. 8912 * 8913 */ 8914 struct page *has_unmovable_pages(struct zone *zone, struct page *page, 8915 int migratetype, int flags) 8916 { 8917 unsigned long iter = 0; 8918 unsigned long pfn = page_to_pfn(page); 8919 unsigned long offset = pfn % pageblock_nr_pages; 8920 8921 if (is_migrate_cma_page(page)) { 8922 /* 8923 * CMA allocations (alloc_contig_range) really need to mark 8924 * isolate CMA pageblocks even when they are not movable in fact 8925 * so consider them movable here. 8926 */ 8927 if (is_migrate_cma(migratetype)) 8928 return NULL; 8929 8930 return page; 8931 } 8932 8933 for (; iter < pageblock_nr_pages - offset; iter++) { 8934 page = pfn_to_page(pfn + iter); 8935 8936 /* 8937 * Both, bootmem allocations and memory holes are marked 8938 * PG_reserved and are unmovable. We can even have unmovable 8939 * allocations inside ZONE_MOVABLE, for example when 8940 * specifying "movablecore". 8941 */ 8942 if (PageReserved(page)) 8943 return page; 8944 8945 /* 8946 * If the zone is movable and we have ruled out all reserved 8947 * pages then it should be reasonably safe to assume the rest 8948 * is movable. 8949 */ 8950 if (zone_idx(zone) == ZONE_MOVABLE) 8951 continue; 8952 8953 /* 8954 * Hugepages are not in LRU lists, but they're movable. 8955 * THPs are on the LRU, but need to be counted as #small pages. 8956 * We need not scan over tail pages because we don't 8957 * handle each tail page individually in migration. 8958 */ 8959 if (PageHuge(page) || PageTransCompound(page)) { 8960 struct page *head = compound_head(page); 8961 unsigned int skip_pages; 8962 8963 if (PageHuge(page)) { 8964 if (!hugepage_migration_supported(page_hstate(head))) 8965 return page; 8966 } else if (!PageLRU(head) && !__PageMovable(head)) { 8967 return page; 8968 } 8969 8970 skip_pages = compound_nr(head) - (page - head); 8971 iter += skip_pages - 1; 8972 continue; 8973 } 8974 8975 /* 8976 * We can't use page_count without pin a page 8977 * because another CPU can free compound page. 8978 * This check already skips compound tails of THP 8979 * because their page->_refcount is zero at all time. 8980 */ 8981 if (!page_ref_count(page)) { 8982 if (PageBuddy(page)) 8983 iter += (1 << buddy_order(page)) - 1; 8984 continue; 8985 } 8986 8987 /* 8988 * The HWPoisoned page may be not in buddy system, and 8989 * page_count() is not 0. 8990 */ 8991 if ((flags & MEMORY_OFFLINE) && PageHWPoison(page)) 8992 continue; 8993 8994 /* 8995 * We treat all PageOffline() pages as movable when offlining 8996 * to give drivers a chance to decrement their reference count 8997 * in MEM_GOING_OFFLINE in order to indicate that these pages 8998 * can be offlined as there are no direct references anymore. 8999 * For actually unmovable PageOffline() where the driver does 9000 * not support this, we will fail later when trying to actually 9001 * move these pages that still have a reference count > 0. 9002 * (false negatives in this function only) 9003 */ 9004 if ((flags & MEMORY_OFFLINE) && PageOffline(page)) 9005 continue; 9006 9007 if (__PageMovable(page) || PageLRU(page)) 9008 continue; 9009 9010 /* 9011 * If there are RECLAIMABLE pages, we need to check 9012 * it. But now, memory offline itself doesn't call 9013 * shrink_node_slabs() and it still to be fixed. 9014 */ 9015 return page; 9016 } 9017 return NULL; 9018 } 9019 9020 #ifdef CONFIG_CONTIG_ALLOC 9021 static unsigned long pfn_max_align_down(unsigned long pfn) 9022 { 9023 return ALIGN_DOWN(pfn, MAX_ORDER_NR_PAGES); 9024 } 9025 9026 static unsigned long pfn_max_align_up(unsigned long pfn) 9027 { 9028 return ALIGN(pfn, MAX_ORDER_NR_PAGES); 9029 } 9030 9031 #if defined(CONFIG_DYNAMIC_DEBUG) || \ 9032 (defined(CONFIG_DYNAMIC_DEBUG_CORE) && defined(DYNAMIC_DEBUG_MODULE)) 9033 /* Usage: See admin-guide/dynamic-debug-howto.rst */ 9034 static void alloc_contig_dump_pages(struct list_head *page_list) 9035 { 9036 DEFINE_DYNAMIC_DEBUG_METADATA(descriptor, "migrate failure"); 9037 9038 if (DYNAMIC_DEBUG_BRANCH(descriptor)) { 9039 struct page *page; 9040 9041 dump_stack(); 9042 list_for_each_entry(page, page_list, lru) 9043 dump_page(page, "migration failure"); 9044 } 9045 } 9046 #else 9047 static inline void alloc_contig_dump_pages(struct list_head *page_list) 9048 { 9049 } 9050 #endif 9051 9052 /* [start, end) must belong to a single zone. */ 9053 static int __alloc_contig_migrate_range(struct compact_control *cc, 9054 unsigned long start, unsigned long end) 9055 { 9056 /* This function is based on compact_zone() from compaction.c. */ 9057 unsigned int nr_reclaimed; 9058 unsigned long pfn = start; 9059 unsigned int tries = 0; 9060 int ret = 0; 9061 struct migration_target_control mtc = { 9062 .nid = zone_to_nid(cc->zone), 9063 .gfp_mask = GFP_USER | __GFP_MOVABLE | __GFP_RETRY_MAYFAIL, 9064 }; 9065 9066 lru_cache_disable(); 9067 9068 while (pfn < end || !list_empty(&cc->migratepages)) { 9069 if (fatal_signal_pending(current)) { 9070 ret = -EINTR; 9071 break; 9072 } 9073 9074 if (list_empty(&cc->migratepages)) { 9075 cc->nr_migratepages = 0; 9076 ret = isolate_migratepages_range(cc, pfn, end); 9077 if (ret && ret != -EAGAIN) 9078 break; 9079 pfn = cc->migrate_pfn; 9080 tries = 0; 9081 } else if (++tries == 5) { 9082 ret = -EBUSY; 9083 break; 9084 } 9085 9086 nr_reclaimed = reclaim_clean_pages_from_list(cc->zone, 9087 &cc->migratepages); 9088 cc->nr_migratepages -= nr_reclaimed; 9089 9090 ret = migrate_pages(&cc->migratepages, alloc_migration_target, 9091 NULL, (unsigned long)&mtc, cc->mode, MR_CONTIG_RANGE, NULL); 9092 9093 /* 9094 * On -ENOMEM, migrate_pages() bails out right away. It is pointless 9095 * to retry again over this error, so do the same here. 9096 */ 9097 if (ret == -ENOMEM) 9098 break; 9099 } 9100 9101 lru_cache_enable(); 9102 if (ret < 0) { 9103 if (ret == -EBUSY) 9104 alloc_contig_dump_pages(&cc->migratepages); 9105 putback_movable_pages(&cc->migratepages); 9106 return ret; 9107 } 9108 return 0; 9109 } 9110 9111 /** 9112 * alloc_contig_range() -- tries to allocate given range of pages 9113 * @start: start PFN to allocate 9114 * @end: one-past-the-last PFN to allocate 9115 * @migratetype: migratetype of the underlying pageblocks (either 9116 * #MIGRATE_MOVABLE or #MIGRATE_CMA). All pageblocks 9117 * in range must have the same migratetype and it must 9118 * be either of the two. 9119 * @gfp_mask: GFP mask to use during compaction 9120 * 9121 * The PFN range does not have to be pageblock or MAX_ORDER_NR_PAGES 9122 * aligned. The PFN range must belong to a single zone. 9123 * 9124 * The first thing this routine does is attempt to MIGRATE_ISOLATE all 9125 * pageblocks in the range. Once isolated, the pageblocks should not 9126 * be modified by others. 9127 * 9128 * Return: zero on success or negative error code. On success all 9129 * pages which PFN is in [start, end) are allocated for the caller and 9130 * need to be freed with free_contig_range(). 9131 */ 9132 int alloc_contig_range(unsigned long start, unsigned long end, 9133 unsigned migratetype, gfp_t gfp_mask) 9134 { 9135 unsigned long outer_start, outer_end; 9136 unsigned int order; 9137 int ret = 0; 9138 9139 struct compact_control cc = { 9140 .nr_migratepages = 0, 9141 .order = -1, 9142 .zone = page_zone(pfn_to_page(start)), 9143 .mode = MIGRATE_SYNC, 9144 .ignore_skip_hint = true, 9145 .no_set_skip_hint = true, 9146 .gfp_mask = current_gfp_context(gfp_mask), 9147 .alloc_contig = true, 9148 }; 9149 INIT_LIST_HEAD(&cc.migratepages); 9150 9151 /* 9152 * What we do here is we mark all pageblocks in range as 9153 * MIGRATE_ISOLATE. Because pageblock and max order pages may 9154 * have different sizes, and due to the way page allocator 9155 * work, we align the range to biggest of the two pages so 9156 * that page allocator won't try to merge buddies from 9157 * different pageblocks and change MIGRATE_ISOLATE to some 9158 * other migration type. 9159 * 9160 * Once the pageblocks are marked as MIGRATE_ISOLATE, we 9161 * migrate the pages from an unaligned range (ie. pages that 9162 * we are interested in). This will put all the pages in 9163 * range back to page allocator as MIGRATE_ISOLATE. 9164 * 9165 * When this is done, we take the pages in range from page 9166 * allocator removing them from the buddy system. This way 9167 * page allocator will never consider using them. 9168 * 9169 * This lets us mark the pageblocks back as 9170 * MIGRATE_CMA/MIGRATE_MOVABLE so that free pages in the 9171 * aligned range but not in the unaligned, original range are 9172 * put back to page allocator so that buddy can use them. 9173 */ 9174 9175 ret = start_isolate_page_range(pfn_max_align_down(start), 9176 pfn_max_align_up(end), migratetype, 0); 9177 if (ret) 9178 return ret; 9179 9180 drain_all_pages(cc.zone); 9181 9182 /* 9183 * In case of -EBUSY, we'd like to know which page causes problem. 9184 * So, just fall through. test_pages_isolated() has a tracepoint 9185 * which will report the busy page. 9186 * 9187 * It is possible that busy pages could become available before 9188 * the call to test_pages_isolated, and the range will actually be 9189 * allocated. So, if we fall through be sure to clear ret so that 9190 * -EBUSY is not accidentally used or returned to caller. 9191 */ 9192 ret = __alloc_contig_migrate_range(&cc, start, end); 9193 if (ret && ret != -EBUSY) 9194 goto done; 9195 ret = 0; 9196 9197 /* 9198 * Pages from [start, end) are within a MAX_ORDER_NR_PAGES 9199 * aligned blocks that are marked as MIGRATE_ISOLATE. What's 9200 * more, all pages in [start, end) are free in page allocator. 9201 * What we are going to do is to allocate all pages from 9202 * [start, end) (that is remove them from page allocator). 9203 * 9204 * The only problem is that pages at the beginning and at the 9205 * end of interesting range may be not aligned with pages that 9206 * page allocator holds, ie. they can be part of higher order 9207 * pages. Because of this, we reserve the bigger range and 9208 * once this is done free the pages we are not interested in. 9209 * 9210 * We don't have to hold zone->lock here because the pages are 9211 * isolated thus they won't get removed from buddy. 9212 */ 9213 9214 order = 0; 9215 outer_start = start; 9216 while (!PageBuddy(pfn_to_page(outer_start))) { 9217 if (++order >= MAX_ORDER) { 9218 outer_start = start; 9219 break; 9220 } 9221 outer_start &= ~0UL << order; 9222 } 9223 9224 if (outer_start != start) { 9225 order = buddy_order(pfn_to_page(outer_start)); 9226 9227 /* 9228 * outer_start page could be small order buddy page and 9229 * it doesn't include start page. Adjust outer_start 9230 * in this case to report failed page properly 9231 * on tracepoint in test_pages_isolated() 9232 */ 9233 if (outer_start + (1UL << order) <= start) 9234 outer_start = start; 9235 } 9236 9237 /* Make sure the range is really isolated. */ 9238 if (test_pages_isolated(outer_start, end, 0)) { 9239 ret = -EBUSY; 9240 goto done; 9241 } 9242 9243 /* Grab isolated pages from freelists. */ 9244 outer_end = isolate_freepages_range(&cc, outer_start, end); 9245 if (!outer_end) { 9246 ret = -EBUSY; 9247 goto done; 9248 } 9249 9250 /* Free head and tail (if any) */ 9251 if (start != outer_start) 9252 free_contig_range(outer_start, start - outer_start); 9253 if (end != outer_end) 9254 free_contig_range(end, outer_end - end); 9255 9256 done: 9257 undo_isolate_page_range(pfn_max_align_down(start), 9258 pfn_max_align_up(end), migratetype); 9259 return ret; 9260 } 9261 EXPORT_SYMBOL(alloc_contig_range); 9262 9263 static int __alloc_contig_pages(unsigned long start_pfn, 9264 unsigned long nr_pages, gfp_t gfp_mask) 9265 { 9266 unsigned long end_pfn = start_pfn + nr_pages; 9267 9268 return alloc_contig_range(start_pfn, end_pfn, MIGRATE_MOVABLE, 9269 gfp_mask); 9270 } 9271 9272 static bool pfn_range_valid_contig(struct zone *z, unsigned long start_pfn, 9273 unsigned long nr_pages) 9274 { 9275 unsigned long i, end_pfn = start_pfn + nr_pages; 9276 struct page *page; 9277 9278 for (i = start_pfn; i < end_pfn; i++) { 9279 page = pfn_to_online_page(i); 9280 if (!page) 9281 return false; 9282 9283 if (page_zone(page) != z) 9284 return false; 9285 9286 if (PageReserved(page)) 9287 return false; 9288 } 9289 return true; 9290 } 9291 9292 static bool zone_spans_last_pfn(const struct zone *zone, 9293 unsigned long start_pfn, unsigned long nr_pages) 9294 { 9295 unsigned long last_pfn = start_pfn + nr_pages - 1; 9296 9297 return zone_spans_pfn(zone, last_pfn); 9298 } 9299 9300 /** 9301 * alloc_contig_pages() -- tries to find and allocate contiguous range of pages 9302 * @nr_pages: Number of contiguous pages to allocate 9303 * @gfp_mask: GFP mask to limit search and used during compaction 9304 * @nid: Target node 9305 * @nodemask: Mask for other possible nodes 9306 * 9307 * This routine is a wrapper around alloc_contig_range(). It scans over zones 9308 * on an applicable zonelist to find a contiguous pfn range which can then be 9309 * tried for allocation with alloc_contig_range(). This routine is intended 9310 * for allocation requests which can not be fulfilled with the buddy allocator. 9311 * 9312 * The allocated memory is always aligned to a page boundary. If nr_pages is a 9313 * power of two, then allocated range is also guaranteed to be aligned to same 9314 * nr_pages (e.g. 1GB request would be aligned to 1GB). 9315 * 9316 * Allocated pages can be freed with free_contig_range() or by manually calling 9317 * __free_page() on each allocated page. 9318 * 9319 * Return: pointer to contiguous pages on success, or NULL if not successful. 9320 */ 9321 struct page *alloc_contig_pages(unsigned long nr_pages, gfp_t gfp_mask, 9322 int nid, nodemask_t *nodemask) 9323 { 9324 unsigned long ret, pfn, flags; 9325 struct zonelist *zonelist; 9326 struct zone *zone; 9327 struct zoneref *z; 9328 9329 zonelist = node_zonelist(nid, gfp_mask); 9330 for_each_zone_zonelist_nodemask(zone, z, zonelist, 9331 gfp_zone(gfp_mask), nodemask) { 9332 spin_lock_irqsave(&zone->lock, flags); 9333 9334 pfn = ALIGN(zone->zone_start_pfn, nr_pages); 9335 while (zone_spans_last_pfn(zone, pfn, nr_pages)) { 9336 if (pfn_range_valid_contig(zone, pfn, nr_pages)) { 9337 /* 9338 * We release the zone lock here because 9339 * alloc_contig_range() will also lock the zone 9340 * at some point. If there's an allocation 9341 * spinning on this lock, it may win the race 9342 * and cause alloc_contig_range() to fail... 9343 */ 9344 spin_unlock_irqrestore(&zone->lock, flags); 9345 ret = __alloc_contig_pages(pfn, nr_pages, 9346 gfp_mask); 9347 if (!ret) 9348 return pfn_to_page(pfn); 9349 spin_lock_irqsave(&zone->lock, flags); 9350 } 9351 pfn += nr_pages; 9352 } 9353 spin_unlock_irqrestore(&zone->lock, flags); 9354 } 9355 return NULL; 9356 } 9357 #endif /* CONFIG_CONTIG_ALLOC */ 9358 9359 void free_contig_range(unsigned long pfn, unsigned long nr_pages) 9360 { 9361 unsigned long count = 0; 9362 9363 for (; nr_pages--; pfn++) { 9364 struct page *page = pfn_to_page(pfn); 9365 9366 count += page_count(page) != 1; 9367 __free_page(page); 9368 } 9369 WARN(count != 0, "%lu pages are still in use!\n", count); 9370 } 9371 EXPORT_SYMBOL(free_contig_range); 9372 9373 /* 9374 * The zone indicated has a new number of managed_pages; batch sizes and percpu 9375 * page high values need to be recalculated. 9376 */ 9377 void zone_pcp_update(struct zone *zone, int cpu_online) 9378 { 9379 mutex_lock(&pcp_batch_high_lock); 9380 zone_set_pageset_high_and_batch(zone, cpu_online); 9381 mutex_unlock(&pcp_batch_high_lock); 9382 } 9383 9384 /* 9385 * Effectively disable pcplists for the zone by setting the high limit to 0 9386 * and draining all cpus. A concurrent page freeing on another CPU that's about 9387 * to put the page on pcplist will either finish before the drain and the page 9388 * will be drained, or observe the new high limit and skip the pcplist. 9389 * 9390 * Must be paired with a call to zone_pcp_enable(). 9391 */ 9392 void zone_pcp_disable(struct zone *zone) 9393 { 9394 mutex_lock(&pcp_batch_high_lock); 9395 __zone_set_pageset_high_and_batch(zone, 0, 1); 9396 __drain_all_pages(zone, true); 9397 } 9398 9399 void zone_pcp_enable(struct zone *zone) 9400 { 9401 __zone_set_pageset_high_and_batch(zone, zone->pageset_high, zone->pageset_batch); 9402 mutex_unlock(&pcp_batch_high_lock); 9403 } 9404 9405 void zone_pcp_reset(struct zone *zone) 9406 { 9407 int cpu; 9408 struct per_cpu_zonestat *pzstats; 9409 9410 if (zone->per_cpu_pageset != &boot_pageset) { 9411 for_each_online_cpu(cpu) { 9412 pzstats = per_cpu_ptr(zone->per_cpu_zonestats, cpu); 9413 drain_zonestat(zone, pzstats); 9414 } 9415 free_percpu(zone->per_cpu_pageset); 9416 free_percpu(zone->per_cpu_zonestats); 9417 zone->per_cpu_pageset = &boot_pageset; 9418 zone->per_cpu_zonestats = &boot_zonestats; 9419 } 9420 } 9421 9422 #ifdef CONFIG_MEMORY_HOTREMOVE 9423 /* 9424 * All pages in the range must be in a single zone, must not contain holes, 9425 * must span full sections, and must be isolated before calling this function. 9426 */ 9427 void __offline_isolated_pages(unsigned long start_pfn, unsigned long end_pfn) 9428 { 9429 unsigned long pfn = start_pfn; 9430 struct page *page; 9431 struct zone *zone; 9432 unsigned int order; 9433 unsigned long flags; 9434 9435 offline_mem_sections(pfn, end_pfn); 9436 zone = page_zone(pfn_to_page(pfn)); 9437 spin_lock_irqsave(&zone->lock, flags); 9438 while (pfn < end_pfn) { 9439 page = pfn_to_page(pfn); 9440 /* 9441 * The HWPoisoned page may be not in buddy system, and 9442 * page_count() is not 0. 9443 */ 9444 if (unlikely(!PageBuddy(page) && PageHWPoison(page))) { 9445 pfn++; 9446 continue; 9447 } 9448 /* 9449 * At this point all remaining PageOffline() pages have a 9450 * reference count of 0 and can simply be skipped. 9451 */ 9452 if (PageOffline(page)) { 9453 BUG_ON(page_count(page)); 9454 BUG_ON(PageBuddy(page)); 9455 pfn++; 9456 continue; 9457 } 9458 9459 BUG_ON(page_count(page)); 9460 BUG_ON(!PageBuddy(page)); 9461 order = buddy_order(page); 9462 del_page_from_free_list(page, zone, order); 9463 pfn += (1 << order); 9464 } 9465 spin_unlock_irqrestore(&zone->lock, flags); 9466 } 9467 #endif 9468 9469 /* 9470 * This function returns a stable result only if called under zone lock. 9471 */ 9472 bool is_free_buddy_page(struct page *page) 9473 { 9474 unsigned long pfn = page_to_pfn(page); 9475 unsigned int order; 9476 9477 for (order = 0; order < MAX_ORDER; order++) { 9478 struct page *page_head = page - (pfn & ((1 << order) - 1)); 9479 9480 if (PageBuddy(page_head) && 9481 buddy_order_unsafe(page_head) >= order) 9482 break; 9483 } 9484 9485 return order < MAX_ORDER; 9486 } 9487 EXPORT_SYMBOL(is_free_buddy_page); 9488 9489 #ifdef CONFIG_MEMORY_FAILURE 9490 /* 9491 * Break down a higher-order page in sub-pages, and keep our target out of 9492 * buddy allocator. 9493 */ 9494 static void break_down_buddy_pages(struct zone *zone, struct page *page, 9495 struct page *target, int low, int high, 9496 int migratetype) 9497 { 9498 unsigned long size = 1 << high; 9499 struct page *current_buddy, *next_page; 9500 9501 while (high > low) { 9502 high--; 9503 size >>= 1; 9504 9505 if (target >= &page[size]) { 9506 next_page = page + size; 9507 current_buddy = page; 9508 } else { 9509 next_page = page; 9510 current_buddy = page + size; 9511 } 9512 9513 if (set_page_guard(zone, current_buddy, high, migratetype)) 9514 continue; 9515 9516 if (current_buddy != target) { 9517 add_to_free_list(current_buddy, zone, high, migratetype); 9518 set_buddy_order(current_buddy, high); 9519 page = next_page; 9520 } 9521 } 9522 } 9523 9524 /* 9525 * Take a page that will be marked as poisoned off the buddy allocator. 9526 */ 9527 bool take_page_off_buddy(struct page *page) 9528 { 9529 struct zone *zone = page_zone(page); 9530 unsigned long pfn = page_to_pfn(page); 9531 unsigned long flags; 9532 unsigned int order; 9533 bool ret = false; 9534 9535 spin_lock_irqsave(&zone->lock, flags); 9536 for (order = 0; order < MAX_ORDER; order++) { 9537 struct page *page_head = page - (pfn & ((1 << order) - 1)); 9538 int page_order = buddy_order(page_head); 9539 9540 if (PageBuddy(page_head) && page_order >= order) { 9541 unsigned long pfn_head = page_to_pfn(page_head); 9542 int migratetype = get_pfnblock_migratetype(page_head, 9543 pfn_head); 9544 9545 del_page_from_free_list(page_head, zone, page_order); 9546 break_down_buddy_pages(zone, page_head, page, 0, 9547 page_order, migratetype); 9548 SetPageHWPoisonTakenOff(page); 9549 if (!is_migrate_isolate(migratetype)) 9550 __mod_zone_freepage_state(zone, -1, migratetype); 9551 ret = true; 9552 break; 9553 } 9554 if (page_count(page_head) > 0) 9555 break; 9556 } 9557 spin_unlock_irqrestore(&zone->lock, flags); 9558 return ret; 9559 } 9560 9561 /* 9562 * Cancel takeoff done by take_page_off_buddy(). 9563 */ 9564 bool put_page_back_buddy(struct page *page) 9565 { 9566 struct zone *zone = page_zone(page); 9567 unsigned long pfn = page_to_pfn(page); 9568 unsigned long flags; 9569 int migratetype = get_pfnblock_migratetype(page, pfn); 9570 bool ret = false; 9571 9572 spin_lock_irqsave(&zone->lock, flags); 9573 if (put_page_testzero(page)) { 9574 ClearPageHWPoisonTakenOff(page); 9575 __free_one_page(page, pfn, zone, 0, migratetype, FPI_NONE); 9576 if (TestClearPageHWPoison(page)) { 9577 num_poisoned_pages_dec(); 9578 ret = true; 9579 } 9580 } 9581 spin_unlock_irqrestore(&zone->lock, flags); 9582 9583 return ret; 9584 } 9585 #endif 9586 9587 #ifdef CONFIG_ZONE_DMA 9588 bool has_managed_dma(void) 9589 { 9590 struct pglist_data *pgdat; 9591 9592 for_each_online_pgdat(pgdat) { 9593 struct zone *zone = &pgdat->node_zones[ZONE_DMA]; 9594 9595 if (managed_zone(zone)) 9596 return true; 9597 } 9598 return false; 9599 } 9600 #endif /* CONFIG_ZONE_DMA */ 9601