.. | .. |
---|
6 | 6 | #include <linux/page-flags.h> |
---|
7 | 7 | #include <linux/page_ext.h> |
---|
8 | 8 | |
---|
9 | | -#ifdef CONFIG_IDLE_PAGE_TRACKING |
---|
| 9 | +#ifdef CONFIG_PAGE_IDLE_FLAG |
---|
10 | 10 | |
---|
11 | 11 | #ifdef CONFIG_64BIT |
---|
12 | 12 | static inline bool page_is_young(struct page *page) |
---|
.. | .. |
---|
47 | 47 | |
---|
48 | 48 | static inline bool page_is_young(struct page *page) |
---|
49 | 49 | { |
---|
50 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 50 | + struct page_ext *page_ext = page_ext_get(page); |
---|
| 51 | + bool page_young; |
---|
51 | 52 | |
---|
52 | 53 | if (unlikely(!page_ext)) |
---|
53 | 54 | return false; |
---|
54 | 55 | |
---|
55 | | - return test_bit(PAGE_EXT_YOUNG, &page_ext->flags); |
---|
| 56 | + page_young = test_bit(PAGE_EXT_YOUNG, &page_ext->flags); |
---|
| 57 | + page_ext_put(page_ext); |
---|
| 58 | + |
---|
| 59 | + return page_young; |
---|
56 | 60 | } |
---|
57 | 61 | |
---|
58 | 62 | static inline void set_page_young(struct page *page) |
---|
59 | 63 | { |
---|
60 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 64 | + struct page_ext *page_ext = page_ext_get(page); |
---|
61 | 65 | |
---|
62 | 66 | if (unlikely(!page_ext)) |
---|
63 | 67 | return; |
---|
64 | 68 | |
---|
65 | 69 | set_bit(PAGE_EXT_YOUNG, &page_ext->flags); |
---|
| 70 | + page_ext_put(page_ext); |
---|
66 | 71 | } |
---|
67 | 72 | |
---|
68 | 73 | static inline bool test_and_clear_page_young(struct page *page) |
---|
69 | 74 | { |
---|
70 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 75 | + struct page_ext *page_ext = page_ext_get(page); |
---|
| 76 | + bool page_young; |
---|
71 | 77 | |
---|
72 | 78 | if (unlikely(!page_ext)) |
---|
73 | 79 | return false; |
---|
74 | 80 | |
---|
75 | | - return test_and_clear_bit(PAGE_EXT_YOUNG, &page_ext->flags); |
---|
| 81 | + page_young = test_and_clear_bit(PAGE_EXT_YOUNG, &page_ext->flags); |
---|
| 82 | + page_ext_put(page_ext); |
---|
| 83 | + |
---|
| 84 | + return page_young; |
---|
76 | 85 | } |
---|
77 | 86 | |
---|
78 | 87 | static inline bool page_is_idle(struct page *page) |
---|
79 | 88 | { |
---|
80 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 89 | + struct page_ext *page_ext = page_ext_get(page); |
---|
| 90 | + bool page_idle; |
---|
81 | 91 | |
---|
82 | 92 | if (unlikely(!page_ext)) |
---|
83 | 93 | return false; |
---|
84 | 94 | |
---|
85 | | - return test_bit(PAGE_EXT_IDLE, &page_ext->flags); |
---|
| 95 | + page_idle = test_bit(PAGE_EXT_IDLE, &page_ext->flags); |
---|
| 96 | + page_ext_put(page_ext); |
---|
| 97 | + |
---|
| 98 | + return page_idle; |
---|
86 | 99 | } |
---|
87 | 100 | |
---|
88 | 101 | static inline void set_page_idle(struct page *page) |
---|
89 | 102 | { |
---|
90 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 103 | + struct page_ext *page_ext = page_ext_get(page); |
---|
91 | 104 | |
---|
92 | 105 | if (unlikely(!page_ext)) |
---|
93 | 106 | return; |
---|
94 | 107 | |
---|
95 | 108 | set_bit(PAGE_EXT_IDLE, &page_ext->flags); |
---|
| 109 | + page_ext_put(page_ext); |
---|
96 | 110 | } |
---|
97 | 111 | |
---|
98 | 112 | static inline void clear_page_idle(struct page *page) |
---|
99 | 113 | { |
---|
100 | | - struct page_ext *page_ext = lookup_page_ext(page); |
---|
| 114 | + struct page_ext *page_ext = page_ext_get(page); |
---|
101 | 115 | |
---|
102 | 116 | if (unlikely(!page_ext)) |
---|
103 | 117 | return; |
---|
104 | 118 | |
---|
105 | 119 | clear_bit(PAGE_EXT_IDLE, &page_ext->flags); |
---|
| 120 | + page_ext_put(page_ext); |
---|
106 | 121 | } |
---|
107 | 122 | #endif /* CONFIG_64BIT */ |
---|
108 | 123 | |
---|
109 | | -#else /* !CONFIG_IDLE_PAGE_TRACKING */ |
---|
| 124 | +#else /* !CONFIG_PAGE_IDLE_FLAG */ |
---|
110 | 125 | |
---|
111 | 126 | static inline bool page_is_young(struct page *page) |
---|
112 | 127 | { |
---|
.. | .. |
---|
135 | 150 | { |
---|
136 | 151 | } |
---|
137 | 152 | |
---|
138 | | -#endif /* CONFIG_IDLE_PAGE_TRACKING */ |
---|
| 153 | +#endif /* CONFIG_PAGE_IDLE_FLAG */ |
---|
139 | 154 | |
---|
140 | 155 | #endif /* _LINUX_MM_PAGE_IDLE_H */ |
---|