1 /* SPDX-License-Identifier: GPL-2.0 */ 1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _MM_PAGE_REPORTING_H 2 #ifndef _MM_PAGE_REPORTING_H 3 #define _MM_PAGE_REPORTING_H 3 #define _MM_PAGE_REPORTING_H 4 4 5 #include <linux/mmzone.h> 5 #include <linux/mmzone.h> 6 #include <linux/pageblock-flags.h> 6 #include <linux/pageblock-flags.h> 7 #include <linux/page-isolation.h> 7 #include <linux/page-isolation.h> 8 #include <linux/jump_label.h> 8 #include <linux/jump_label.h> 9 #include <linux/slab.h> 9 #include <linux/slab.h> 10 #include <linux/pgtable.h> 10 #include <linux/pgtable.h> 11 #include <linux/scatterlist.h> 11 #include <linux/scatterlist.h> 12 12 13 #ifdef CONFIG_PAGE_REPORTING 13 #ifdef CONFIG_PAGE_REPORTING 14 DECLARE_STATIC_KEY_FALSE(page_reporting_enable 14 DECLARE_STATIC_KEY_FALSE(page_reporting_enabled); 15 extern unsigned int page_reporting_order; 15 extern unsigned int page_reporting_order; 16 void __page_reporting_notify(void); 16 void __page_reporting_notify(void); 17 17 18 static inline bool page_reported(struct page * 18 static inline bool page_reported(struct page *page) 19 { 19 { 20 return static_branch_unlikely(&page_re 20 return static_branch_unlikely(&page_reporting_enabled) && 21 PageReported(page); 21 PageReported(page); 22 } 22 } 23 23 24 /** 24 /** 25 * page_reporting_notify_free - Free page noti 25 * page_reporting_notify_free - Free page notification to start page processing 26 * 26 * 27 * This function is meant to act as a screener 27 * This function is meant to act as a screener for __page_reporting_notify 28 * which will determine if a give zone has cro 28 * which will determine if a give zone has crossed over the high-water mark 29 * that will justify us beginning page treatme 29 * that will justify us beginning page treatment. If we have crossed that 30 * threshold then it will start the process of 30 * threshold then it will start the process of pulling some pages and 31 * placing them in the batch list for treatmen 31 * placing them in the batch list for treatment. 32 */ 32 */ 33 static inline void page_reporting_notify_free( 33 static inline void page_reporting_notify_free(unsigned int order) 34 { 34 { 35 /* Called from hot path in __free_one_ 35 /* Called from hot path in __free_one_page() */ 36 if (!static_branch_unlikely(&page_repo 36 if (!static_branch_unlikely(&page_reporting_enabled)) 37 return; 37 return; 38 38 39 /* Determine if we have crossed report 39 /* Determine if we have crossed reporting threshold */ 40 if (order < page_reporting_order) 40 if (order < page_reporting_order) 41 return; 41 return; 42 42 43 /* This will add a few cycles, but sho 43 /* This will add a few cycles, but should be called infrequently */ 44 __page_reporting_notify(); 44 __page_reporting_notify(); 45 } 45 } 46 #else /* CONFIG_PAGE_REPORTING */ 46 #else /* CONFIG_PAGE_REPORTING */ 47 #define page_reported(_page) false 47 #define page_reported(_page) false 48 48 49 static inline void page_reporting_notify_free( 49 static inline void page_reporting_notify_free(unsigned int order) 50 { 50 { 51 } 51 } 52 #endif /* CONFIG_PAGE_REPORTING */ 52 #endif /* CONFIG_PAGE_REPORTING */ 53 #endif /*_MM_PAGE_REPORTING_H */ 53 #endif /*_MM_PAGE_REPORTING_H */ 54 54
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.