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