diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-10-22 20:07:18 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-10-22 20:07:18 -0400 |
commit | a2887097f25cd38cadfc11d10769e2b349fb5eca (patch) | |
tree | cd4adcb305365d6ba9acd2c02d4eb9d0125c6f8d /fs/nilfs2 | |
parent | 8abfc6e7a45eb74e51904bbae676fae008b11366 (diff) | |
parent | 005a1d15f5a6b2bb4ada80349513effbf22b4588 (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.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 9f4913f78408..f3b75206e956 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 ba7c10c917fc..d27715103376 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 | ||