diff options
| -rw-r--r-- | fs/nilfs2/super.c | 10 | ||||
| -rw-r--r-- | fs/nilfs2/the_nilfs.c | 7 |
2 files changed, 3 insertions, 14 deletions
diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c index 922263393c76..faa5078ff751 100644 --- a/fs/nilfs2/super.c +++ b/fs/nilfs2/super.c | |||
| @@ -178,17 +178,9 @@ static int nilfs_sync_super(struct nilfs_sb_info *sbi, int flag) | |||
| 178 | 178 | ||
| 179 | retry: | 179 | retry: |
| 180 | set_buffer_dirty(nilfs->ns_sbh[0]); | 180 | set_buffer_dirty(nilfs->ns_sbh[0]); |
| 181 | |||
| 182 | if (nilfs_test_opt(sbi, BARRIER)) { | 181 | if (nilfs_test_opt(sbi, BARRIER)) { |
| 183 | err = __sync_dirty_buffer(nilfs->ns_sbh[0], | 182 | err = __sync_dirty_buffer(nilfs->ns_sbh[0], |
| 184 | WRITE_SYNC | WRITE_BARRIER); | 183 | WRITE_SYNC | WRITE_FLUSH_FUA); |
| 185 | if (err == -EOPNOTSUPP) { | ||
| 186 | nilfs_warning(sbi->s_super, __func__, | ||
| 187 | "barrier-based sync failed. " | ||
| 188 | "disabling barriers\n"); | ||
| 189 | nilfs_clear_opt(sbi, BARRIER); | ||
| 190 | goto retry; | ||
| 191 | } | ||
| 192 | } else { | 184 | } else { |
| 193 | err = sync_dirty_buffer(nilfs->ns_sbh[0]); | 185 | err = sync_dirty_buffer(nilfs->ns_sbh[0]); |
| 194 | } | 186 | } |
diff --git a/fs/nilfs2/the_nilfs.c b/fs/nilfs2/the_nilfs.c index 4317f177ea7c..400b2caef4d8 100644 --- a/fs/nilfs2/the_nilfs.c +++ b/fs/nilfs2/the_nilfs.c | |||
| @@ -774,9 +774,7 @@ int nilfs_discard_segments(struct the_nilfs *nilfs, __u64 *segnump, | |||
| 774 | ret = blkdev_issue_discard(nilfs->ns_bdev, | 774 | ret = blkdev_issue_discard(nilfs->ns_bdev, |
| 775 | start * sects_per_block, | 775 | start * sects_per_block, |
| 776 | nblocks * sects_per_block, | 776 | nblocks * sects_per_block, |
| 777 | GFP_NOFS, | 777 | GFP_NOFS, BLKDEV_IFL_WAIT); |
| 778 | BLKDEV_IFL_WAIT | | ||
| 779 | BLKDEV_IFL_BARRIER); | ||
| 780 | if (ret < 0) | 778 | if (ret < 0) |
| 781 | return ret; | 779 | return ret; |
| 782 | nblocks = 0; | 780 | nblocks = 0; |
| @@ -786,8 +784,7 @@ int nilfs_discard_segments(struct the_nilfs *nilfs, __u64 *segnump, | |||
| 786 | ret = blkdev_issue_discard(nilfs->ns_bdev, | 784 | ret = blkdev_issue_discard(nilfs->ns_bdev, |
| 787 | start * sects_per_block, | 785 | start * sects_per_block, |
| 788 | nblocks * sects_per_block, | 786 | nblocks * sects_per_block, |
| 789 | GFP_NOFS, | 787 | GFP_NOFS, BLKDEV_IFL_WAIT); |
| 790 | BLKDEV_IFL_WAIT | BLKDEV_IFL_BARRIER); | ||
| 791 | return ret; | 788 | return ret; |
| 792 | } | 789 | } |
| 793 | 790 | ||
