debug_page_alloc.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/mm.h>
  3. #include <linux/page-isolation.h>
  4. unsigned int _debug_guardpage_minorder;
  5. bool _debug_pagealloc_enabled_early __read_mostly
  6. = IS_ENABLED(CONFIG_DEBUG_PAGEALLOC_ENABLE_DEFAULT);
  7. EXPORT_SYMBOL(_debug_pagealloc_enabled_early);
  8. DEFINE_STATIC_KEY_FALSE(_debug_pagealloc_enabled);
  9. EXPORT_SYMBOL(_debug_pagealloc_enabled);
  10. DEFINE_STATIC_KEY_FALSE(_debug_guardpage_enabled);
  11. static int __init early_debug_pagealloc(char *buf)
  12. {
  13. return kstrtobool(buf, &_debug_pagealloc_enabled_early);
  14. }
  15. early_param("debug_pagealloc", early_debug_pagealloc);
  16. static int __init debug_guardpage_minorder_setup(char *buf)
  17. {
  18. unsigned long res;
  19. if (kstrtoul(buf, 10, &res) < 0 || res > MAX_PAGE_ORDER / 2) {
  20. pr_err("Bad debug_guardpage_minorder value\n");
  21. return 0;
  22. }
  23. _debug_guardpage_minorder = res;
  24. pr_info("Setting debug_guardpage_minorder to %lu\n", res);
  25. return 0;
  26. }
  27. early_param("debug_guardpage_minorder", debug_guardpage_minorder_setup);
  28. bool __set_page_guard(struct zone *zone, struct page *page, unsigned int order)
  29. {
  30. if (order >= debug_guardpage_minorder())
  31. return false;
  32. __SetPageGuard(page);
  33. INIT_LIST_HEAD(&page->buddy_list);
  34. set_page_private(page, order);
  35. return true;
  36. }
  37. void __clear_page_guard(struct zone *zone, struct page *page, unsigned int order)
  38. {
  39. __ClearPageGuard(page);
  40. set_page_private(page, 0);
  41. }