diff options
author | Andi Kleen <andi@firstfloor.org> | 2009-09-16 05:50:13 -0400 |
---|---|---|
committer | Andi Kleen <ak@linux.intel.com> | 2009-09-16 05:50:13 -0400 |
commit | 257187362123f15d9d1e09918cf87cebbea4e786 (patch) | |
tree | 92b768ad3f2afeda13a2acadc6d5766090ebcc60 /mm | |
parent | 83f786680aec8d030184f7ced1a0a3dd8ac81764 (diff) |
HWPOISON: Define a new error_remove_page address space op for async truncation
Truncating metadata pages is not safe right now before
we haven't audited all file systems.
To enable truncation only for data address space define
a new address_space callback error_remove_page.
This is used for memory_failure.c memory error handling.
This can be then set to truncate_inode_page()
This patch just defines the new operation and adds documentation.
Callers and users come in followon patches.
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/truncate.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/mm/truncate.c b/mm/truncate.c index ea132f7ea2d..a17b3977cfd 100644 --- a/mm/truncate.c +++ b/mm/truncate.c | |||
@@ -147,6 +147,23 @@ int truncate_inode_page(struct address_space *mapping, struct page *page) | |||
147 | } | 147 | } |
148 | 148 | ||
149 | /* | 149 | /* |
150 | * Used to get rid of pages on hardware memory corruption. | ||
151 | */ | ||
152 | int generic_error_remove_page(struct address_space *mapping, struct page *page) | ||
153 | { | ||
154 | if (!mapping) | ||
155 | return -EINVAL; | ||
156 | /* | ||
157 | * Only punch for normal data pages for now. | ||
158 | * Handling other types like directories would need more auditing. | ||
159 | */ | ||
160 | if (!S_ISREG(mapping->host->i_mode)) | ||
161 | return -EIO; | ||
162 | return truncate_inode_page(mapping, page); | ||
163 | } | ||
164 | EXPORT_SYMBOL(generic_error_remove_page); | ||
165 | |||
166 | /* | ||
150 | * Safely invalidate one page from its pagecache mapping. | 167 | * Safely invalidate one page from its pagecache mapping. |
151 | * It only drops clean, unused pages. The page must be locked. | 168 | * It only drops clean, unused pages. The page must be locked. |
152 | * | 169 | * |