diff options
-rw-r--r-- | include/linux/swap.h | 2 | ||||
-rw-r--r-- | mm/filemap.c | 10 | ||||
-rw-r--r-- | mm/swap.c | 37 |
3 files changed, 19 insertions, 30 deletions
diff --git a/include/linux/swap.h b/include/linux/swap.h index 4286e7ac2b00..0b3377650c85 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h | |||
@@ -177,7 +177,7 @@ extern void activate_page(struct page *); | |||
177 | extern void mark_page_accessed(struct page *); | 177 | extern void mark_page_accessed(struct page *); |
178 | extern void lru_add_drain(void); | 178 | extern void lru_add_drain(void); |
179 | extern int lru_add_drain_all(void); | 179 | extern int lru_add_drain_all(void); |
180 | extern int rotate_reclaimable_page(struct page *page); | 180 | extern void rotate_reclaimable_page(struct page *page); |
181 | extern void swap_setup(void); | 181 | extern void swap_setup(void); |
182 | 182 | ||
183 | /* linux/mm/vmscan.c */ | 183 | /* linux/mm/vmscan.c */ |
diff --git a/mm/filemap.c b/mm/filemap.c index 07e9d9258b48..239d36163bbe 100644 --- a/mm/filemap.c +++ b/mm/filemap.c | |||
@@ -576,10 +576,12 @@ EXPORT_SYMBOL(unlock_page); | |||
576 | */ | 576 | */ |
577 | void end_page_writeback(struct page *page) | 577 | void end_page_writeback(struct page *page) |
578 | { | 578 | { |
579 | if (!TestClearPageReclaim(page) || rotate_reclaimable_page(page)) { | 579 | if (TestClearPageReclaim(page)) |
580 | if (!test_clear_page_writeback(page)) | 580 | rotate_reclaimable_page(page); |
581 | BUG(); | 581 | |
582 | } | 582 | if (!test_clear_page_writeback(page)) |
583 | BUG(); | ||
584 | |||
583 | smp_mb__after_clear_bit(); | 585 | smp_mb__after_clear_bit(); |
584 | wake_up_page(page, PG_writeback); | 586 | wake_up_page(page, PG_writeback); |
585 | } | 587 | } |
@@ -132,34 +132,21 @@ static void pagevec_move_tail(struct pagevec *pvec) | |||
132 | * Writeback is about to end against a page which has been marked for immediate | 132 | * Writeback is about to end against a page which has been marked for immediate |
133 | * reclaim. If it still appears to be reclaimable, move it to the tail of the | 133 | * reclaim. If it still appears to be reclaimable, move it to the tail of the |
134 | * inactive list. | 134 | * inactive list. |
135 | * | ||
136 | * Returns zero if it cleared PG_writeback. | ||
137 | */ | 135 | */ |
138 | int rotate_reclaimable_page(struct page *page) | 136 | void rotate_reclaimable_page(struct page *page) |
139 | { | 137 | { |
140 | struct pagevec *pvec; | 138 | if (!PageLocked(page) && !PageDirty(page) && !PageActive(page) && |
141 | unsigned long flags; | 139 | PageLRU(page)) { |
142 | 140 | struct pagevec *pvec; | |
143 | if (PageLocked(page)) | 141 | unsigned long flags; |
144 | return 1; | ||
145 | if (PageDirty(page)) | ||
146 | return 1; | ||
147 | if (PageActive(page)) | ||
148 | return 1; | ||
149 | if (!PageLRU(page)) | ||
150 | return 1; | ||
151 | |||
152 | page_cache_get(page); | ||
153 | local_irq_save(flags); | ||
154 | pvec = &__get_cpu_var(lru_rotate_pvecs); | ||
155 | if (!pagevec_add(pvec, page)) | ||
156 | pagevec_move_tail(pvec); | ||
157 | local_irq_restore(flags); | ||
158 | |||
159 | if (!test_clear_page_writeback(page)) | ||
160 | BUG(); | ||
161 | 142 | ||
162 | return 0; | 143 | page_cache_get(page); |
144 | local_irq_save(flags); | ||
145 | pvec = &__get_cpu_var(lru_rotate_pvecs); | ||
146 | if (!pagevec_add(pvec, page)) | ||
147 | pagevec_move_tail(pvec); | ||
148 | local_irq_restore(flags); | ||
149 | } | ||
163 | } | 150 | } |
164 | 151 | ||
165 | /* | 152 | /* |