blob: aa6d37f4dc22b86cbf4e3a04db59644e438e76b0 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _MM_PAGE_REPORTING_H
#define _MM_PAGE_REPORTING_H
#include <linux/mmzone.h>
#include <linux/pageblock-flags.h>
#include <linux/page-isolation.h>
#include <linux/jump_label.h>
#include <linux/slab.h>
#include <asm/pgtable.h>
#include <linux/scatterlist.h>
#define PAGE_REPORTING_MIN_ORDER pageblock_order
#ifdef CONFIG_PAGE_REPORTING
DECLARE_STATIC_KEY_FALSE(page_reporting_enabled);
void __page_reporting_notify(void);
static inline bool page_reported(struct page *page)
{
return static_branch_unlikely(&page_reporting_enabled) &&
PageReported(page);
}
/**
* page_reporting_notify_free - Free page notification to start page processing
*
* This function is meant to act as a screener for __page_reporting_notify
* which will determine if a give zone has crossed over the high-water mark
* that will justify us beginning page treatment. If we have crossed that
* threshold then it will start the process of pulling some pages and
* placing them in the batch list for treatment.
*/
static inline void page_reporting_notify_free(unsigned int order)
{
/* Called from hot path in __free_one_page() */
if (!static_branch_unlikely(&page_reporting_enabled))
return;
/* Determine if we have crossed reporting threshold */
if (order < PAGE_REPORTING_MIN_ORDER)
return;
/* This will add a few cycles, but should be called infrequently */
__page_reporting_notify();
}
#else /* CONFIG_PAGE_REPORTING */
#define page_reported(_page) false
static inline void page_reporting_notify_free(unsigned int order)
{
}
#endif /* CONFIG_PAGE_REPORTING */
#endif /*_MM_PAGE_REPORTING_H */