diff options
author | NeilBrown <neilb@cse.unsw.edu.au> | 2005-09-09 19:23:41 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-09-09 19:39:09 -0400 |
commit | e5dcdd80a60627371f40797426273048630dc8ca (patch) | |
tree | 1621f68394ceaa4da86d89c6da3b93fd306415fc /drivers/md/linear.c | |
parent | 3ec67ac1a399d576d48b0736096bcce7721fe3cf (diff) |
[PATCH] md: fail IO request to md that require a barrier.
md does not yet support BIO_RW_BARRIER, so be honest about it and fail
(-EOPNOTSUPP) any such requests.
Signed-off-by: Neil Brown <neilb@cse.unsw.edu.au>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/md/linear.c')
-rw-r--r-- | drivers/md/linear.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/md/linear.c b/drivers/md/linear.c index 8d740013d74d..4991ba543368 100644 --- a/drivers/md/linear.c +++ b/drivers/md/linear.c | |||
@@ -238,6 +238,11 @@ static int linear_make_request (request_queue_t *q, struct bio *bio) | |||
238 | dev_info_t *tmp_dev; | 238 | dev_info_t *tmp_dev; |
239 | sector_t block; | 239 | sector_t block; |
240 | 240 | ||
241 | if (unlikely(bio_barrier(bio))) { | ||
242 | bio_endio(bio, bio->bi_size, -EOPNOTSUPP); | ||
243 | return 0; | ||
244 | } | ||
245 | |||
241 | if (bio_data_dir(bio)==WRITE) { | 246 | if (bio_data_dir(bio)==WRITE) { |
242 | disk_stat_inc(mddev->gendisk, writes); | 247 | disk_stat_inc(mddev->gendisk, writes); |
243 | disk_stat_add(mddev->gendisk, write_sectors, bio_sectors(bio)); | 248 | disk_stat_add(mddev->gendisk, write_sectors, bio_sectors(bio)); |