diff options
author | Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp> | 2009-04-06 22:01:38 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-04-07 11:31:15 -0400 |
commit | f30bf3e40f80ef50c17f55271deae3abc03e793e (patch) | |
tree | 2e6d69611d1443688c1a79c5e5aed60cf38672e7 /fs/nilfs2/segment.h | |
parent | 9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453 (diff) |
nilfs2: fix missed-sync issue for do_sync_mapping_range()
Chris Mason pointed out that there is a missed sync issue in
nilfs_writepages():
On Wed, 17 Dec 2008 21:52:55 -0500, Chris Mason wrote:
> It looks like nilfs_writepage ignores WB_SYNC_NONE, which is used by
> do_sync_mapping_range().
where WB_SYNC_NONE in do_sync_mapping_range() was replaced with
WB_SYNC_ALL by Nick's patch (commit:
ee53a891f47444c53318b98dac947ede963db400).
This fixes the problem by letting nilfs_writepages() write out the log of
file data within the range if sync_mode is WB_SYNC_ALL.
This involves removal of nilfs_file_aio_write() which was previously
needed to ensure O_SYNC sync writes.
Cc: Chris Mason <chris.mason@oracle.com>
Signed-off-by: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/nilfs2/segment.h')
-rw-r--r-- | fs/nilfs2/segment.h | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/fs/nilfs2/segment.h b/fs/nilfs2/segment.h index 615654b8c329..2dd39da9f386 100644 --- a/fs/nilfs2/segment.h +++ b/fs/nilfs2/segment.h | |||
@@ -93,6 +93,9 @@ struct nilfs_segsum_pointer { | |||
93 | * @sc_active_segments: List of active segments that were already written out | 93 | * @sc_active_segments: List of active segments that were already written out |
94 | * @sc_cleaning_segments: List of segments to be freed through construction | 94 | * @sc_cleaning_segments: List of segments to be freed through construction |
95 | * @sc_copied_buffers: List of copied buffers (buffer heads) to freeze data | 95 | * @sc_copied_buffers: List of copied buffers (buffer heads) to freeze data |
96 | * @sc_dsync_inode: inode whose data pages are written for a sync operation | ||
97 | * @sc_dsync_start: start byte offset of data pages | ||
98 | * @sc_dsync_end: end byte offset of data pages (inclusive) | ||
96 | * @sc_segbufs: List of segment buffers | 99 | * @sc_segbufs: List of segment buffers |
97 | * @sc_segbuf_nblocks: Number of available blocks in segment buffers. | 100 | * @sc_segbuf_nblocks: Number of available blocks in segment buffers. |
98 | * @sc_curseg: Current segment buffer | 101 | * @sc_curseg: Current segment buffer |
@@ -134,6 +137,10 @@ struct nilfs_sc_info { | |||
134 | struct list_head sc_cleaning_segments; | 137 | struct list_head sc_cleaning_segments; |
135 | struct list_head sc_copied_buffers; | 138 | struct list_head sc_copied_buffers; |
136 | 139 | ||
140 | struct nilfs_inode_info *sc_dsync_inode; | ||
141 | loff_t sc_dsync_start; | ||
142 | loff_t sc_dsync_end; | ||
143 | |||
137 | /* Segment buffers */ | 144 | /* Segment buffers */ |
138 | struct list_head sc_segbufs; | 145 | struct list_head sc_segbufs; |
139 | unsigned long sc_segbuf_nblocks; | 146 | unsigned long sc_segbuf_nblocks; |
@@ -221,8 +228,8 @@ extern void nilfs_destroy_transaction_cache(void); | |||
221 | extern void nilfs_relax_pressure_in_lock(struct super_block *); | 228 | extern void nilfs_relax_pressure_in_lock(struct super_block *); |
222 | 229 | ||
223 | extern int nilfs_construct_segment(struct super_block *); | 230 | extern int nilfs_construct_segment(struct super_block *); |
224 | extern int nilfs_construct_dsync_segment(struct super_block *, | 231 | extern int nilfs_construct_dsync_segment(struct super_block *, struct inode *, |
225 | struct inode *); | 232 | loff_t, loff_t); |
226 | extern void nilfs_flush_segment(struct super_block *, ino_t); | 233 | extern void nilfs_flush_segment(struct super_block *, ino_t); |
227 | extern int nilfs_clean_segments(struct super_block *, void __user *); | 234 | extern int nilfs_clean_segments(struct super_block *, void __user *); |
228 | 235 | ||