diff options
Diffstat (limited to 'mm')
-rw-r--r-- | mm/cleancache.c | 19 | ||||
-rw-r--r-- | mm/filemap.c | 2 | ||||
-rw-r--r-- | mm/truncate.c | 10 |
3 files changed, 16 insertions, 15 deletions
diff --git a/mm/cleancache.c b/mm/cleancache.c index bcaae4c2a770..237c6e0feea0 100644 --- a/mm/cleancache.c +++ b/mm/cleancache.c | |||
@@ -19,7 +19,7 @@ | |||
19 | 19 | ||
20 | /* | 20 | /* |
21 | * This global enablement flag may be read thousands of times per second | 21 | * This global enablement flag may be read thousands of times per second |
22 | * by cleancache_get/put/flush even on systems where cleancache_ops | 22 | * by cleancache_get/put/invalidate even on systems where cleancache_ops |
23 | * is not claimed (e.g. cleancache is config'ed on but remains | 23 | * is not claimed (e.g. cleancache is config'ed on but remains |
24 | * disabled), so is preferred to the slower alternative: a function | 24 | * disabled), so is preferred to the slower alternative: a function |
25 | * call that checks a non-global. | 25 | * call that checks a non-global. |
@@ -148,10 +148,11 @@ void __cleancache_put_page(struct page *page) | |||
148 | EXPORT_SYMBOL(__cleancache_put_page); | 148 | EXPORT_SYMBOL(__cleancache_put_page); |
149 | 149 | ||
150 | /* | 150 | /* |
151 | * Flush any data from cleancache associated with the poolid and the | 151 | * Invalidate any data from cleancache associated with the poolid and the |
152 | * page's inode and page index so that a subsequent "get" will fail. | 152 | * page's inode and page index so that a subsequent "get" will fail. |
153 | */ | 153 | */ |
154 | void __cleancache_flush_page(struct address_space *mapping, struct page *page) | 154 | void __cleancache_invalidate_page(struct address_space *mapping, |
155 | struct page *page) | ||
155 | { | 156 | { |
156 | /* careful... page->mapping is NULL sometimes when this is called */ | 157 | /* careful... page->mapping is NULL sometimes when this is called */ |
157 | int pool_id = mapping->host->i_sb->cleancache_poolid; | 158 | int pool_id = mapping->host->i_sb->cleancache_poolid; |
@@ -165,14 +166,14 @@ void __cleancache_flush_page(struct address_space *mapping, struct page *page) | |||
165 | } | 166 | } |
166 | } | 167 | } |
167 | } | 168 | } |
168 | EXPORT_SYMBOL(__cleancache_flush_page); | 169 | EXPORT_SYMBOL(__cleancache_invalidate_page); |
169 | 170 | ||
170 | /* | 171 | /* |
171 | * Flush all data from cleancache associated with the poolid and the | 172 | * Invalidate all data from cleancache associated with the poolid and the |
172 | * mappings's inode so that all subsequent gets to this poolid/inode | 173 | * mappings's inode so that all subsequent gets to this poolid/inode |
173 | * will fail. | 174 | * will fail. |
174 | */ | 175 | */ |
175 | void __cleancache_flush_inode(struct address_space *mapping) | 176 | void __cleancache_invalidate_inode(struct address_space *mapping) |
176 | { | 177 | { |
177 | int pool_id = mapping->host->i_sb->cleancache_poolid; | 178 | int pool_id = mapping->host->i_sb->cleancache_poolid; |
178 | struct cleancache_filekey key = { .u.key = { 0 } }; | 179 | struct cleancache_filekey key = { .u.key = { 0 } }; |
@@ -180,14 +181,14 @@ void __cleancache_flush_inode(struct address_space *mapping) | |||
180 | if (pool_id >= 0 && cleancache_get_key(mapping->host, &key) >= 0) | 181 | if (pool_id >= 0 && cleancache_get_key(mapping->host, &key) >= 0) |
181 | (*cleancache_ops.flush_inode)(pool_id, key); | 182 | (*cleancache_ops.flush_inode)(pool_id, key); |
182 | } | 183 | } |
183 | EXPORT_SYMBOL(__cleancache_flush_inode); | 184 | EXPORT_SYMBOL(__cleancache_invalidate_inode); |
184 | 185 | ||
185 | /* | 186 | /* |
186 | * Called by any cleancache-enabled filesystem at time of unmount; | 187 | * Called by any cleancache-enabled filesystem at time of unmount; |
187 | * note that pool_id is surrendered and may be reutrned by a subsequent | 188 | * note that pool_id is surrendered and may be reutrned by a subsequent |
188 | * cleancache_init_fs or cleancache_init_shared_fs | 189 | * cleancache_init_fs or cleancache_init_shared_fs |
189 | */ | 190 | */ |
190 | void __cleancache_flush_fs(struct super_block *sb) | 191 | void __cleancache_invalidate_fs(struct super_block *sb) |
191 | { | 192 | { |
192 | if (sb->cleancache_poolid >= 0) { | 193 | if (sb->cleancache_poolid >= 0) { |
193 | int old_poolid = sb->cleancache_poolid; | 194 | int old_poolid = sb->cleancache_poolid; |
@@ -195,7 +196,7 @@ void __cleancache_flush_fs(struct super_block *sb) | |||
195 | (*cleancache_ops.flush_fs)(old_poolid); | 196 | (*cleancache_ops.flush_fs)(old_poolid); |
196 | } | 197 | } |
197 | } | 198 | } |
198 | EXPORT_SYMBOL(__cleancache_flush_fs); | 199 | EXPORT_SYMBOL(__cleancache_invalidate_fs); |
199 | 200 | ||
200 | #ifdef CONFIG_SYSFS | 201 | #ifdef CONFIG_SYSFS |
201 | 202 | ||
diff --git a/mm/filemap.c b/mm/filemap.c index a0701e6eec10..0aa3faa48219 100644 --- a/mm/filemap.c +++ b/mm/filemap.c | |||
@@ -123,7 +123,7 @@ void __delete_from_page_cache(struct page *page) | |||
123 | if (PageUptodate(page) && PageMappedToDisk(page)) | 123 | if (PageUptodate(page) && PageMappedToDisk(page)) |
124 | cleancache_put_page(page); | 124 | cleancache_put_page(page); |
125 | else | 125 | else |
126 | cleancache_flush_page(mapping, page); | 126 | cleancache_invalidate_page(mapping, page); |
127 | 127 | ||
128 | radix_tree_delete(&mapping->page_tree, page->index); | 128 | radix_tree_delete(&mapping->page_tree, page->index); |
129 | page->mapping = NULL; | 129 | page->mapping = NULL; |
diff --git a/mm/truncate.c b/mm/truncate.c index 632b15e29f74..b4d575c9a0ee 100644 --- a/mm/truncate.c +++ b/mm/truncate.c | |||
@@ -52,7 +52,7 @@ void do_invalidatepage(struct page *page, unsigned long offset) | |||
52 | static inline void truncate_partial_page(struct page *page, unsigned partial) | 52 | static inline void truncate_partial_page(struct page *page, unsigned partial) |
53 | { | 53 | { |
54 | zero_user_segment(page, partial, PAGE_CACHE_SIZE); | 54 | zero_user_segment(page, partial, PAGE_CACHE_SIZE); |
55 | cleancache_flush_page(page->mapping, page); | 55 | cleancache_invalidate_page(page->mapping, page); |
56 | if (page_has_private(page)) | 56 | if (page_has_private(page)) |
57 | do_invalidatepage(page, partial); | 57 | do_invalidatepage(page, partial); |
58 | } | 58 | } |
@@ -213,7 +213,7 @@ void truncate_inode_pages_range(struct address_space *mapping, | |||
213 | pgoff_t end; | 213 | pgoff_t end; |
214 | int i; | 214 | int i; |
215 | 215 | ||
216 | cleancache_flush_inode(mapping); | 216 | cleancache_invalidate_inode(mapping); |
217 | if (mapping->nrpages == 0) | 217 | if (mapping->nrpages == 0) |
218 | return; | 218 | return; |
219 | 219 | ||
@@ -292,7 +292,7 @@ void truncate_inode_pages_range(struct address_space *mapping, | |||
292 | mem_cgroup_uncharge_end(); | 292 | mem_cgroup_uncharge_end(); |
293 | index++; | 293 | index++; |
294 | } | 294 | } |
295 | cleancache_flush_inode(mapping); | 295 | cleancache_invalidate_inode(mapping); |
296 | } | 296 | } |
297 | EXPORT_SYMBOL(truncate_inode_pages_range); | 297 | EXPORT_SYMBOL(truncate_inode_pages_range); |
298 | 298 | ||
@@ -444,7 +444,7 @@ int invalidate_inode_pages2_range(struct address_space *mapping, | |||
444 | int ret2 = 0; | 444 | int ret2 = 0; |
445 | int did_range_unmap = 0; | 445 | int did_range_unmap = 0; |
446 | 446 | ||
447 | cleancache_flush_inode(mapping); | 447 | cleancache_invalidate_inode(mapping); |
448 | pagevec_init(&pvec, 0); | 448 | pagevec_init(&pvec, 0); |
449 | index = start; | 449 | index = start; |
450 | while (index <= end && pagevec_lookup(&pvec, mapping, index, | 450 | while (index <= end && pagevec_lookup(&pvec, mapping, index, |
@@ -500,7 +500,7 @@ int invalidate_inode_pages2_range(struct address_space *mapping, | |||
500 | cond_resched(); | 500 | cond_resched(); |
501 | index++; | 501 | index++; |
502 | } | 502 | } |
503 | cleancache_flush_inode(mapping); | 503 | cleancache_invalidate_inode(mapping); |
504 | return ret; | 504 | return ret; |
505 | } | 505 | } |
506 | EXPORT_SYMBOL_GPL(invalidate_inode_pages2_range); | 506 | EXPORT_SYMBOL_GPL(invalidate_inode_pages2_range); |