| .. | .. | 
|---|
| 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 */ | 
|---|