diff options
Diffstat (limited to 'block/elevator.c')
| -rw-r--r-- | block/elevator.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/block/elevator.c b/block/elevator.c index ca861927ba41..6f2375339a99 100644 --- a/block/elevator.c +++ b/block/elevator.c | |||
| @@ -100,6 +100,14 @@ int elv_rq_merge_ok(struct request *rq, struct bio *bio) | |||
| 100 | if (bio_integrity(bio) != blk_integrity_rq(rq)) | 100 | if (bio_integrity(bio) != blk_integrity_rq(rq)) |
| 101 | return 0; | 101 | return 0; |
| 102 | 102 | ||
| 103 | /* | ||
| 104 | * Don't merge if failfast settings don't match | ||
| 105 | */ | ||
| 106 | if (bio_failfast_dev(bio) != blk_failfast_dev(rq) || | ||
| 107 | bio_failfast_transport(bio) != blk_failfast_transport(rq) || | ||
| 108 | bio_failfast_driver(bio) != blk_failfast_driver(rq)) | ||
| 109 | return 0; | ||
| 110 | |||
| 103 | if (!elv_iosched_allow_merge(rq, bio)) | 111 | if (!elv_iosched_allow_merge(rq, bio)) |
| 104 | return 0; | 112 | return 0; |
| 105 | 113 | ||
