diff options
author | Jens Axboe <axboe@suse.de> | 2006-07-06 04:18:05 -0400 |
---|---|---|
committer | Jens Axboe <axboe@suse.de> | 2006-07-06 04:18:05 -0400 |
commit | 1959d21232931dfa686769a21161413f10d6652f (patch) | |
tree | c311b9fce998ce66665bda261c470a6fb981aa5c | |
parent | 40359ccb836866435b03a0cb57345002b587d875 (diff) |
[PATCH] Only the first two bits in bio->bi_rw and rq->flags match
Not three, as assumed. This causes the barrier bit to be needlessly set
for some IO.
Signed-off-by: Jens Axboe <axboe@suse.de>
-rw-r--r-- | block/ll_rw_blk.c | 4 | ||||
-rw-r--r-- | include/linux/blktrace_api.h | 2 |
2 files changed, 3 insertions, 3 deletions
diff --git a/block/ll_rw_blk.c b/block/ll_rw_blk.c index ab17c7224bb6..61d6b3c65b66 100644 --- a/block/ll_rw_blk.c +++ b/block/ll_rw_blk.c | |||
@@ -3491,8 +3491,8 @@ EXPORT_SYMBOL(end_request); | |||
3491 | 3491 | ||
3492 | void blk_rq_bio_prep(request_queue_t *q, struct request *rq, struct bio *bio) | 3492 | void blk_rq_bio_prep(request_queue_t *q, struct request *rq, struct bio *bio) |
3493 | { | 3493 | { |
3494 | /* first three bits are identical in rq->flags and bio->bi_rw */ | 3494 | /* first two bits are identical in rq->flags and bio->bi_rw */ |
3495 | rq->flags |= (bio->bi_rw & 7); | 3495 | rq->flags |= (bio->bi_rw & 3); |
3496 | 3496 | ||
3497 | rq->nr_phys_segments = bio_phys_segments(q, bio); | 3497 | rq->nr_phys_segments = bio_phys_segments(q, bio); |
3498 | rq->nr_hw_segments = bio_hw_segments(q, bio); | 3498 | rq->nr_hw_segments = bio_hw_segments(q, bio); |
diff --git a/include/linux/blktrace_api.h b/include/linux/blktrace_api.h index 2346a1db8561..7520cc1ff9e2 100644 --- a/include/linux/blktrace_api.h +++ b/include/linux/blktrace_api.h | |||
@@ -148,7 +148,7 @@ static inline void blk_add_trace_rq(struct request_queue *q, struct request *rq, | |||
148 | u32 what) | 148 | u32 what) |
149 | { | 149 | { |
150 | struct blk_trace *bt = q->blk_trace; | 150 | struct blk_trace *bt = q->blk_trace; |
151 | int rw = rq->flags & 0x07; | 151 | int rw = rq->flags & 0x03; |
152 | 152 | ||
153 | if (likely(!bt)) | 153 | if (likely(!bt)) |
154 | return; | 154 | return; |