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 /block/blk-settings.c | |
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 'block/blk-settings.c')
-rw-r--r-- | block/blk-settings.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/block/blk-settings.c b/block/blk-settings.c index 315b88c8cbbb..701859fb9647 100644 --- a/block/blk-settings.c +++ b/block/blk-settings.c | |||
@@ -792,6 +792,26 @@ void blk_queue_update_dma_alignment(struct request_queue *q, int mask) | |||
792 | } | 792 | } |
793 | EXPORT_SYMBOL(blk_queue_update_dma_alignment); | 793 | EXPORT_SYMBOL(blk_queue_update_dma_alignment); |
794 | 794 | ||
795 | /** | ||
796 | * blk_queue_flush - configure queue's cache flush capability | ||
797 | * @q: the request queue for the device | ||
798 | * @flush: 0, REQ_FLUSH or REQ_FLUSH | REQ_FUA | ||
799 | * | ||
800 | * Tell block layer cache flush capability of @q. If it supports | ||
801 | * flushing, REQ_FLUSH should be set. If it supports bypassing | ||
802 | * write cache for individual writes, REQ_FUA should be set. | ||
803 | */ | ||
804 | void blk_queue_flush(struct request_queue *q, unsigned int flush) | ||
805 | { | ||
806 | WARN_ON_ONCE(flush & ~(REQ_FLUSH | REQ_FUA)); | ||
807 | |||
808 | if (WARN_ON_ONCE(!(flush & REQ_FLUSH) && (flush & REQ_FUA))) | ||
809 | flush &= ~REQ_FUA; | ||
810 | |||
811 | q->flush_flags = flush & (REQ_FLUSH | REQ_FUA); | ||
812 | } | ||
813 | EXPORT_SYMBOL_GPL(blk_queue_flush); | ||
814 | |||
795 | static int __init blk_settings_init(void) | 815 | static int __init blk_settings_init(void) |
796 | { | 816 | { |
797 | blk_max_low_pfn = max_low_pfn - 1; | 817 | blk_max_low_pfn = max_low_pfn - 1; |