io_uring/cmd: add cmd lazy tw wake helper
[linux-block.git] / include / linux / page_owner.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
48c96a36
JK
2#ifndef __LINUX_PAGE_OWNER_H
3#define __LINUX_PAGE_OWNER_H
4
7dd80b8a
VB
5#include <linux/jump_label.h>
6
48c96a36 7#ifdef CONFIG_PAGE_OWNER
7dd80b8a 8extern struct static_key_false page_owner_inited;
48c96a36
JK
9extern struct page_ext_operations page_owner_ops;
10
0093de69 11extern void __reset_page_owner(struct page *page, unsigned short order);
48c96a36 12extern void __set_page_owner(struct page *page,
0093de69 13 unsigned short order, gfp_t gfp_mask);
8fb156c9 14extern void __split_page_owner(struct page *page, unsigned int nr);
19138349 15extern void __folio_copy_owner(struct folio *newfolio, struct folio *old);
7cd12b4a 16extern void __set_page_owner_migrate_reason(struct page *page, int reason);
8bf6f451 17extern void __dump_page_owner(const struct page *page);
e2f612e6
JK
18extern void pagetypeinfo_showmixedcount_print(struct seq_file *m,
19 pg_data_t *pgdat, struct zone *zone);
48c96a36 20
0093de69 21static inline void reset_page_owner(struct page *page, unsigned short order)
48c96a36 22{
7dd80b8a
VB
23 if (static_branch_unlikely(&page_owner_inited))
24 __reset_page_owner(page, order);
48c96a36
JK
25}
26
27static inline void set_page_owner(struct page *page,
0093de69 28 unsigned short order, gfp_t gfp_mask)
48c96a36 29{
7dd80b8a
VB
30 if (static_branch_unlikely(&page_owner_inited))
31 __set_page_owner(page, order, gfp_mask);
48c96a36 32}
e2cfc911 33
8fb156c9 34static inline void split_page_owner(struct page *page, unsigned int nr)
e2cfc911 35{
7dd80b8a 36 if (static_branch_unlikely(&page_owner_inited))
8fb156c9 37 __split_page_owner(page, nr);
e2cfc911 38}
19138349 39static inline void folio_copy_owner(struct folio *newfolio, struct folio *old)
d435edca
VB
40{
41 if (static_branch_unlikely(&page_owner_inited))
19138349 42 __folio_copy_owner(newfolio, old);
d435edca 43}
7cd12b4a
VB
44static inline void set_page_owner_migrate_reason(struct page *page, int reason)
45{
46 if (static_branch_unlikely(&page_owner_inited))
47 __set_page_owner_migrate_reason(page, reason);
48}
8bf6f451 49static inline void dump_page_owner(const struct page *page)
4e462112
VB
50{
51 if (static_branch_unlikely(&page_owner_inited))
52 __dump_page_owner(page);
53}
48c96a36 54#else
0093de69 55static inline void reset_page_owner(struct page *page, unsigned short order)
48c96a36
JK
56{
57}
58static inline void set_page_owner(struct page *page,
59 unsigned int order, gfp_t gfp_mask)
60{
61}
a9627bc5 62static inline void split_page_owner(struct page *page,
0093de69 63 unsigned short order)
e2cfc911 64{
e2cfc911 65}
19138349 66static inline void folio_copy_owner(struct folio *newfolio, struct folio *folio)
d435edca
VB
67{
68}
7cd12b4a
VB
69static inline void set_page_owner_migrate_reason(struct page *page, int reason)
70{
71}
8bf6f451 72static inline void dump_page_owner(const struct page *page)
4e462112
VB
73{
74}
48c96a36
JK
75#endif /* CONFIG_PAGE_OWNER */
76#endif /* __LINUX_PAGE_OWNER_H */