xref: /linux/include/trace/events/pagemap.h (revision e3b9f1e81de2083f359bacd2a94bf1c024f2ede0)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #undef TRACE_SYSTEM
3 #define TRACE_SYSTEM pagemap
4 
5 #if !defined(_TRACE_PAGEMAP_H) || defined(TRACE_HEADER_MULTI_READ)
6 #define _TRACE_PAGEMAP_H
7 
8 #include <linux/tracepoint.h>
9 #include <linux/mm.h>
10 
11 #define	PAGEMAP_MAPPED		0x0001u
12 #define PAGEMAP_ANONYMOUS	0x0002u
13 #define PAGEMAP_FILE		0x0004u
14 #define PAGEMAP_SWAPCACHE	0x0008u
15 #define PAGEMAP_SWAPBACKED	0x0010u
16 #define PAGEMAP_MAPPEDDISK	0x0020u
17 #define PAGEMAP_BUFFERS		0x0040u
18 
19 #define trace_pagemap_flags(page) ( \
20 	(PageAnon(page)		? PAGEMAP_ANONYMOUS  : PAGEMAP_FILE) | \
21 	(page_mapped(page)	? PAGEMAP_MAPPED     : 0) | \
22 	(PageSwapCache(page)	? PAGEMAP_SWAPCACHE  : 0) | \
23 	(PageSwapBacked(page)	? PAGEMAP_SWAPBACKED : 0) | \
24 	(PageMappedToDisk(page)	? PAGEMAP_MAPPEDDISK : 0) | \
25 	(page_has_private(page) ? PAGEMAP_BUFFERS    : 0) \
26 	)
27 
28 TRACE_EVENT(mm_lru_insertion,
29 
30 	TP_PROTO(
31 		struct page *page,
32 		int lru
33 	),
34 
35 	TP_ARGS(page, lru),
36 
37 	TP_STRUCT__entry(
38 		__field(struct page *,	page	)
39 		__field(unsigned long,	pfn	)
40 		__field(int,		lru	)
41 		__field(unsigned long,	flags	)
42 	),
43 
44 	TP_fast_assign(
45 		__entry->page	= page;
46 		__entry->pfn	= page_to_pfn(page);
47 		__entry->lru	= lru;
48 		__entry->flags	= trace_pagemap_flags(page);
49 	),
50 
51 	/* Flag format is based on page-types.c formatting for pagemap */
52 	TP_printk("page=%p pfn=%lu lru=%d flags=%s%s%s%s%s%s",
53 			__entry->page,
54 			__entry->pfn,
55 			__entry->lru,
56 			__entry->flags & PAGEMAP_MAPPED		? "M" : " ",
57 			__entry->flags & PAGEMAP_ANONYMOUS	? "a" : "f",
58 			__entry->flags & PAGEMAP_SWAPCACHE	? "s" : " ",
59 			__entry->flags & PAGEMAP_SWAPBACKED	? "b" : " ",
60 			__entry->flags & PAGEMAP_MAPPEDDISK	? "d" : " ",
61 			__entry->flags & PAGEMAP_BUFFERS	? "B" : " ")
62 );
63 
64 TRACE_EVENT(mm_lru_activate,
65 
66 	TP_PROTO(struct page *page),
67 
68 	TP_ARGS(page),
69 
70 	TP_STRUCT__entry(
71 		__field(struct page *,	page	)
72 		__field(unsigned long,	pfn	)
73 	),
74 
75 	TP_fast_assign(
76 		__entry->page	= page;
77 		__entry->pfn	= page_to_pfn(page);
78 	),
79 
80 	/* Flag format is based on page-types.c formatting for pagemap */
81 	TP_printk("page=%p pfn=%lu", __entry->page, __entry->pfn)
82 
83 );
84 
85 #endif /* _TRACE_PAGEMAP_H */
86 
87 /* This part must be outside protection */
88 #include <trace/define_trace.h>
89