diff options
author | Jens Axboe <axboe@suse.de> | 2006-07-06 10:18:05 +0200 |
---|---|---|
committer | Jens Axboe <axboe@suse.de> | 2006-07-06 10:18:05 +0200 |
commit | 1959d21232931dfa686769a21161413f10d6652f (patch) | |
tree | c311b9fce998ce66665bda261c470a6fb981aa5c /block | |
parent | [PATCH] blktrace: readahead support (diff) | |
download | linux-1959d21232931dfa686769a21161413f10d6652f.tar.xz linux-1959d21232931dfa686769a21161413f10d6652f.zip |
[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>
Diffstat (limited to 'block')
-rw-r--r-- | block/ll_rw_blk.c | 4 |
1 files changed, 2 insertions, 2 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); void blk_rq_bio_prep(request_queue_t *q, struct request *rq, struct bio *bio) { - /* first three bits are identical in rq->flags and bio->bi_rw */ - rq->flags |= (bio->bi_rw & 7); + /* first two bits are identical in rq->flags and bio->bi_rw */ + rq->flags |= (bio->bi_rw & 3); rq->nr_phys_segments = bio_phys_segments(q, bio); rq->nr_hw_segments = bio_hw_segments(q, bio); |