提交 11475975 编写于 作者: R Ryusuke Konishi 提交者: Linus Torvalds

nilfs2: flush disk caches in syncing

There are two cases that the cache flush is needed to avoid data loss
against unexpected hang or power failure.  One is sync file function (i.e.
 nilfs_sync_file) and another is checkpointing ioctl.

This issues a cache flush request to device for such cases if barrier
mount option is enabled, and makes sure data really is on persistent
storage on their completion.
Signed-off-by: NRyusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 a1d49449
...@@ -37,6 +37,7 @@ int nilfs_sync_file(struct file *file, loff_t start, loff_t end, int datasync) ...@@ -37,6 +37,7 @@ int nilfs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
* This function should be implemented when the writeback function * This function should be implemented when the writeback function
* will be implemented. * will be implemented.
*/ */
struct the_nilfs *nilfs;
struct inode *inode = file->f_mapping->host; struct inode *inode = file->f_mapping->host;
int err; int err;
...@@ -45,18 +46,21 @@ int nilfs_sync_file(struct file *file, loff_t start, loff_t end, int datasync) ...@@ -45,18 +46,21 @@ int nilfs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
return err; return err;
mutex_lock(&inode->i_mutex); mutex_lock(&inode->i_mutex);
if (!nilfs_inode_dirty(inode)) { if (nilfs_inode_dirty(inode)) {
mutex_unlock(&inode->i_mutex);
return 0;
}
if (datasync) if (datasync)
err = nilfs_construct_dsync_segment(inode->i_sb, inode, 0, err = nilfs_construct_dsync_segment(inode->i_sb, inode,
LLONG_MAX); 0, LLONG_MAX);
else else
err = nilfs_construct_segment(inode->i_sb); err = nilfs_construct_segment(inode->i_sb);
}
mutex_unlock(&inode->i_mutex); mutex_unlock(&inode->i_mutex);
nilfs = inode->i_sb->s_fs_info;
if (!err && nilfs_test_opt(nilfs, BARRIER)) {
err = blkdev_issue_flush(inode->i_sb->s_bdev, GFP_KERNEL, NULL);
if (err != -EIO)
err = 0;
}
return err; return err;
} }
......
...@@ -692,8 +692,14 @@ static int nilfs_ioctl_sync(struct inode *inode, struct file *filp, ...@@ -692,8 +692,14 @@ static int nilfs_ioctl_sync(struct inode *inode, struct file *filp,
if (ret < 0) if (ret < 0)
return ret; return ret;
if (argp != NULL) {
nilfs = inode->i_sb->s_fs_info; nilfs = inode->i_sb->s_fs_info;
if (nilfs_test_opt(nilfs, BARRIER)) {
ret = blkdev_issue_flush(inode->i_sb->s_bdev, GFP_KERNEL, NULL);
if (ret == -EIO)
return ret;
}
if (argp != NULL) {
down_read(&nilfs->ns_segctor_sem); down_read(&nilfs->ns_segctor_sem);
cno = nilfs->ns_cno - 1; cno = nilfs->ns_cno - 1;
up_read(&nilfs->ns_segctor_sem); up_read(&nilfs->ns_segctor_sem);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册