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 /fs/udf | |
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>
Diffstat (limited to 'fs/udf')
-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 | ||