aboutsummaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorJens Axboe <jens.axboe@oracle.com>2007-11-02 08:49:08 +0100
committerJens Axboe <jens.axboe@oracle.com>2007-11-02 08:49:08 +0100
commit51fd77bd9f512ab6cc9df0733ba1caaab89eb957 (patch)
treefcc46ec04cad61a724eebffeabbecea197abbd89 /block
parent5ec140e600b7d6624c657f008833f0e71bd5ef48 (diff)
downloadkernel_samsung_smdk4412-51fd77bd9f512ab6cc9df0733ba1caaab89eb957.tar.gz
kernel_samsung_smdk4412-51fd77bd9f512ab6cc9df0733ba1caaab89eb957.tar.bz2
kernel_samsung_smdk4412-51fd77bd9f512ab6cc9df0733ba1caaab89eb957.zip
[BLOCK] Don't allow empty barriers to be passed down to queues that don't grok them
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
Diffstat (limited to 'block')
-rw-r--r--block/ll_rw_blk.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/block/ll_rw_blk.c b/block/ll_rw_blk.c
index 56f2646612e..3e4e8bfbe85 100644
--- a/block/ll_rw_blk.c
+++ b/block/ll_rw_blk.c
@@ -3221,6 +3221,7 @@ static inline void __generic_make_request(struct bio *bio)
sector_t old_sector;
int ret, nr_sectors = bio_sectors(bio);
dev_t old_dev;
+ int err = -EIO;
might_sleep();
@@ -3248,7 +3249,7 @@ static inline void __generic_make_request(struct bio *bio)
bdevname(bio->bi_bdev, b),
(long long) bio->bi_sector);
end_io:
- bio_endio(bio, -EIO);
+ bio_endio(bio, err);
break;
}
@@ -3283,6 +3284,10 @@ end_io:
if (bio_check_eod(bio, nr_sectors))
goto end_io;
+ if (bio_empty_barrier(bio) && !q->prepare_flush_fn) {
+ err = -EOPNOTSUPP;
+ goto end_io;
+ }
ret = q->make_request_fn(q, bio);
} while (ret);