diff options
Diffstat (limited to 'fs/fscache/page.c')
| -rw-r--r-- | fs/fscache/page.c | 44 | 
1 files changed, 44 insertions, 0 deletions
| diff --git a/fs/fscache/page.c b/fs/fscache/page.c index a2a5d19ece6..2f343b4d7a7 100644 --- a/fs/fscache/page.c +++ b/fs/fscache/page.c @@ -954,3 +954,47 @@ void fscache_mark_pages_cached(struct fscache_retrieval *op,  	pagevec_reinit(pagevec);  }  EXPORT_SYMBOL(fscache_mark_pages_cached); + +/* + * Uncache all the pages in an inode that are marked PG_fscache, assuming them + * to be associated with the given cookie. + */ +void __fscache_uncache_all_inode_pages(struct fscache_cookie *cookie, +				       struct inode *inode) +{ +	struct address_space *mapping = inode->i_mapping; +	struct pagevec pvec; +	pgoff_t next; +	int i; + +	_enter("%p,%p", cookie, inode); + +	if (!mapping || mapping->nrpages == 0) { +		_leave(" [no pages]"); +		return; +	} + +	pagevec_init(&pvec, 0); +	next = 0; +	while (next <= (loff_t)-1 && +	       pagevec_lookup(&pvec, mapping, next, PAGEVEC_SIZE) +	       ) { +		for (i = 0; i < pagevec_count(&pvec); i++) { +			struct page *page = pvec.pages[i]; +			pgoff_t page_index = page->index; + +			ASSERTCMP(page_index, >=, next); +			next = page_index + 1; + +			if (PageFsCache(page)) { +				__fscache_wait_on_page_write(cookie, page); +				__fscache_uncache_page(cookie, page); +			} +		} +		pagevec_release(&pvec); +		cond_resched(); +	} + +	_leave(""); +} +EXPORT_SYMBOL(__fscache_uncache_all_inode_pages); | 
