diff options
| author | Nick Piggin <npiggin@suse.de> | 2007-10-16 04:25:20 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-16 12:42:57 -0400 |
| commit | be021ee41a8b65d181fe22799de6be62adf72efb (patch) | |
| tree | d02e79ac30c6b03ea361bc425a566a402a8db0c0 | |
| parent | 82b9d1d0da8046088b0f505f92a97d12d9804613 (diff) | |
udf: convert to new aops
Convert udf to new aops. Also seem to have fixed pagecache corruption in
udf_adinicb_commit_write -- page was marked uptodate when it is not. Also,
fixed the silly setup where prepare_write was doing a kmap to be used in
commit_write: just do kmap_atomic in write_end. Use libfs helpers to make
this easier.
Signed-off-by: Nick Piggin <npiggin@suse.de>
Cc: <bfennema@falcon.csc.calpoly.edu>
Cc: Jan Kara <jack@ucw.cz>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
| -rw-r--r-- | fs/udf/file.c | 35 | ||||
| -rw-r--r-- | fs/udf/inode.c | 13 |
2 files changed, 22 insertions, 26 deletions
diff --git a/fs/udf/file.c b/fs/udf/file.c index 5d7a4ea27753..7c7a1b39d56c 100644 --- a/fs/udf/file.c +++ b/fs/udf/file.c | |||
| @@ -76,36 +76,29 @@ static int udf_adinicb_writepage(struct page *page, struct writeback_control *wb | |||
| 76 | return 0; | 76 | return 0; |
| 77 | } | 77 | } |
| 78 | 78 | ||
| 79 | static int udf_adinicb_prepare_write(struct file *file, struct page *page, | 79 | static int udf_adinicb_write_end(struct file *file, |
| 80 | unsigned offset, unsigned to) | 80 | struct address_space *mapping, |
| 81 | loff_t pos, unsigned len, unsigned copied, | ||
| 82 | struct page *page, void *fsdata) | ||
| 81 | { | 83 | { |
| 82 | kmap(page); | 84 | struct inode *inode = mapping->host; |
| 83 | return 0; | 85 | unsigned offset = pos & (PAGE_CACHE_SIZE - 1); |
| 84 | } | 86 | char *kaddr; |
| 85 | |||
| 86 | static int udf_adinicb_commit_write(struct file *file, struct page *page, | ||
| 87 | unsigned offset, unsigned to) | ||
| 88 | { | ||
| 89 | struct inode *inode = page->mapping->host; | ||
| 90 | char *kaddr = page_address(page); | ||
| 91 | 87 | ||
| 88 | kaddr = kmap_atomic(page, KM_USER0); | ||
| 92 | memcpy(UDF_I_DATA(inode) + UDF_I_LENEATTR(inode) + offset, | 89 | memcpy(UDF_I_DATA(inode) + UDF_I_LENEATTR(inode) + offset, |
| 93 | kaddr + offset, to - offset); | 90 | kaddr + offset, copied); |
| 94 | mark_inode_dirty(inode); | 91 | kunmap_atomic(kaddr, KM_USER0); |
| 95 | SetPageUptodate(page); | 92 | |
| 96 | kunmap(page); | 93 | return simple_write_end(file, mapping, pos, len, copied, page, fsdata); |
| 97 | /* only one page here */ | ||
| 98 | if (to > inode->i_size) | ||
| 99 | inode->i_size = to; | ||
| 100 | return 0; | ||
| 101 | } | 94 | } |
| 102 | 95 | ||
| 103 | const struct address_space_operations udf_adinicb_aops = { | 96 | const struct address_space_operations udf_adinicb_aops = { |
| 104 | .readpage = udf_adinicb_readpage, | 97 | .readpage = udf_adinicb_readpage, |
| 105 | .writepage = udf_adinicb_writepage, | 98 | .writepage = udf_adinicb_writepage, |
| 106 | .sync_page = block_sync_page, | 99 | .sync_page = block_sync_page, |
| 107 | .prepare_write = udf_adinicb_prepare_write, | 100 | .write_begin = simple_write_begin, |
| 108 | .commit_write = udf_adinicb_commit_write, | 101 | .write_end = udf_adinicb_write_end, |
| 109 | }; | 102 | }; |
| 110 | 103 | ||
| 111 | static ssize_t udf_file_aio_write(struct kiocb *iocb, const struct iovec *iov, | 104 | static ssize_t udf_file_aio_write(struct kiocb *iocb, const struct iovec *iov, |
diff --git a/fs/udf/inode.c b/fs/udf/inode.c index 1652b2c665bb..6ff8151984cf 100644 --- a/fs/udf/inode.c +++ b/fs/udf/inode.c | |||
| @@ -133,10 +133,13 @@ static int udf_readpage(struct file *file, struct page *page) | |||
| 133 | return block_read_full_page(page, udf_get_block); | 133 | return block_read_full_page(page, udf_get_block); |
| 134 | } | 134 | } |
| 135 | 135 | ||
| 136 | static int udf_prepare_write(struct file *file, struct page *page, | 136 | static int udf_write_begin(struct file *file, struct address_space *mapping, |
| 137 | unsigned from, unsigned to) | 137 | loff_t pos, unsigned len, unsigned flags, |
| 138 | struct page **pagep, void **fsdata) | ||
| 138 | { | 139 | { |
| 139 | return block_prepare_write(page, from, to, udf_get_block); | 140 | *pagep = NULL; |
| 141 | return block_write_begin(file, mapping, pos, len, flags, pagep, fsdata, | ||
| 142 | udf_get_block); | ||
| 140 | } | 143 | } |
| 141 | 144 | ||
| 142 | static sector_t udf_bmap(struct address_space *mapping, sector_t block) | 145 | static sector_t udf_bmap(struct address_space *mapping, sector_t block) |
| @@ -148,8 +151,8 @@ const struct address_space_operations udf_aops = { | |||
| 148 | .readpage = udf_readpage, | 151 | .readpage = udf_readpage, |
| 149 | .writepage = udf_writepage, | 152 | .writepage = udf_writepage, |
| 150 | .sync_page = block_sync_page, | 153 | .sync_page = block_sync_page, |
| 151 | .prepare_write = udf_prepare_write, | 154 | .write_begin = udf_write_begin, |
| 152 | .commit_write = generic_commit_write, | 155 | .write_end = generic_write_end, |
| 153 | .bmap = udf_bmap, | 156 | .bmap = udf_bmap, |
| 154 | }; | 157 | }; |
| 155 | 158 | ||
