aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nilfs2
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2010-10-22 20:07:18 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2010-10-22 20:07:18 -0400
commita2887097f25cd38cadfc11d10769e2b349fb5eca (patch)
treecd4adcb305365d6ba9acd2c02d4eb9d0125c6f8d /fs/nilfs2
parent8abfc6e7a45eb74e51904bbae676fae008b11366 (diff)
parent005a1d15f5a6b2bb4ada80349513effbf22b4588 (diff)
Merge branch 'for-2.6.37/barrier' of git://git.kernel.dk/linux-2.6-block
* 'for-2.6.37/barrier' of git://git.kernel.dk/linux-2.6-block: (46 commits) xen-blkfront: disable barrier/flush write support Added blk-lib.c and blk-barrier.c was renamed to blk-flush.c block: remove BLKDEV_IFL_WAIT aic7xxx_old: removed unused 'req' variable block: remove the BH_Eopnotsupp flag block: remove the BLKDEV_IFL_BARRIER flag block: remove the WRITE_BARRIER flag swap: do not send discards as barriers fat: do not send discards as barriers ext4: do not send discards as barriers jbd2: replace barriers with explicit flush / FUA usage jbd2: Modify ASYNC_COMMIT code to not rely on queue draining on barrier jbd: replace barriers with explicit flush / FUA usage nilfs2: replace barriers with explicit flush / FUA usage reiserfs: replace barriers with explicit flush / FUA usage gfs2: replace barriers with explicit flush / FUA usage btrfs: replace barriers with explicit flush / FUA usage xfs: replace barriers with explicit flush / FUA usage block: pass gfp_mask and flags to sb_issue_discard dm: convey that all flushes are processed as empty ...
Diffstat (limited to 'fs/nilfs2')
-rw-r--r--fs/nilfs2/super.c10
-rw-r--r--fs/nilfs2/the_nilfs.c7
2 files changed, 3 insertions, 14 deletions
diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c
index 9f4913f7840..f3b75206e95 100644
--- a/fs/nilfs2/super.c
+++ b/fs/nilfs2/super.c
@@ -177,17 +177,9 @@ static int nilfs_sync_super(struct nilfs_sb_info *sbi, int flag)
177 177
178 retry: 178 retry:
179 set_buffer_dirty(nilfs->ns_sbh[0]); 179 set_buffer_dirty(nilfs->ns_sbh[0]);
180
181 if (nilfs_test_opt(sbi, BARRIER)) { 180 if (nilfs_test_opt(sbi, BARRIER)) {
182 err = __sync_dirty_buffer(nilfs->ns_sbh[0], 181 err = __sync_dirty_buffer(nilfs->ns_sbh[0],
183 WRITE_SYNC | WRITE_BARRIER); 182 WRITE_SYNC | WRITE_FLUSH_FUA);
184 if (err == -EOPNOTSUPP) {
185 nilfs_warning(sbi->s_super, __func__,
186 "barrier-based sync failed. "
187 "disabling barriers\n");
188 nilfs_clear_opt(sbi, BARRIER);
189 goto retry;
190 }
191 } else { 183 } else {
192 err = sync_dirty_buffer(nilfs->ns_sbh[0]); 184 err = sync_dirty_buffer(nilfs->ns_sbh[0]);
193 } 185 }
diff --git a/fs/nilfs2/the_nilfs.c b/fs/nilfs2/the_nilfs.c
index ba7c10c917f..d2771510337 100644
--- a/fs/nilfs2/the_nilfs.c
+++ b/fs/nilfs2/the_nilfs.c
@@ -775,9 +775,7 @@ int nilfs_discard_segments(struct the_nilfs *nilfs, __u64 *segnump,
775 ret = blkdev_issue_discard(nilfs->ns_bdev, 775 ret = blkdev_issue_discard(nilfs->ns_bdev,
776 start * sects_per_block, 776 start * sects_per_block,
777 nblocks * sects_per_block, 777 nblocks * sects_per_block,
778 GFP_NOFS, 778 GFP_NOFS, 0);
779 BLKDEV_IFL_WAIT |
780 BLKDEV_IFL_BARRIER);
781 if (ret < 0) 779 if (ret < 0)
782 return ret; 780 return ret;
783 nblocks = 0; 781 nblocks = 0;
@@ -787,8 +785,7 @@ int nilfs_discard_segments(struct the_nilfs *nilfs, __u64 *segnump,
787 ret = blkdev_issue_discard(nilfs->ns_bdev, 785 ret = blkdev_issue_discard(nilfs->ns_bdev,
788 start * sects_per_block, 786 start * sects_per_block,
789 nblocks * sects_per_block, 787 nblocks * sects_per_block,
790 GFP_NOFS, 788 GFP_NOFS, 0);
791 BLKDEV_IFL_WAIT | BLKDEV_IFL_BARRIER);
792 return ret; 789 return ret;
793} 790}
794 791