101
102
103
104static void pagevec_move_tail(struct pagevec *pvec)
105{
106 int i;
107 int pgmoved = 0;
108 struct zone *zone = NULL;
109
110 for (i = 0; i < pagevec_count(pvec); i++) {
111 struct page *page = pvec->pages[i];
112 struct zone *pagezone = page_zone(page);
113
114 if (pagezone != zone) {
115 if (zone)
116 spin_unlock(&zone->lru_lock);
117 zone = pagezone;
118 spin_lock(&zone->lru_lock);
119 }
120 if (PageLRU(page) && !PageActive(page) && !PageUnevictable(page)) {
121 int lru = page_is_file_cache(page);
122 list_move_tail(&page->lru, &zone->lru[lru].list);
123 pgmoved++;
124 }
125 }
126 if (zone)
127 spin_unlock(&zone->lru_lock);
128 __count_vm_events(PGROTATED, pgmoved);
129 release_pages(pvec->pages, pvec->nr, pvec->cold);
130 pagevec_reinit(pvec);
131}
132
133
134
135
136
137
138void rotate_reclaimable_page(struct page *page)
139{
140 if (!PageLocked(page) && !PageDirty(page) && !PageActive(page) &&
141 !PageUnevictable(page) && PageLRU(page)) {