diff options
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/md/dm-mpath.c | 2 | ||||
| -rw-r--r-- | drivers/md/multipath.c | 4 | ||||
| -rw-r--r-- | drivers/s390/block/dasd_diag.c | 2 | ||||
| -rw-r--r-- | drivers/s390/block/dasd_eckd.c | 2 | ||||
| -rw-r--r-- | drivers/s390/block/dasd_fba.c | 2 | ||||
| -rw-r--r-- | drivers/scsi/device_handler/scsi_dh_alua.c | 3 | ||||
| -rw-r--r-- | drivers/scsi/device_handler/scsi_dh_emc.c | 3 | ||||
| -rw-r--r-- | drivers/scsi/device_handler/scsi_dh_hp_sw.c | 6 | ||||
| -rw-r--r-- | drivers/scsi/device_handler/scsi_dh_rdac.c | 3 | ||||
| -rw-r--r-- | drivers/scsi/scsi_transport_spi.c | 4 | 
10 files changed, 19 insertions, 12 deletions
diff --git a/drivers/md/dm-mpath.c b/drivers/md/dm-mpath.c index 103304c1e3b..9bf3460c554 100644 --- a/drivers/md/dm-mpath.c +++ b/drivers/md/dm-mpath.c @@ -849,7 +849,7 @@ static int multipath_map(struct dm_target *ti, struct bio *bio,  	dm_bio_record(&mpio->details, bio);  	map_context->ptr = mpio; -	bio->bi_rw |= (1 << BIO_RW_FAILFAST); +	bio->bi_rw |= (1 << BIO_RW_FAILFAST_TRANSPORT);  	r = map_io(m, bio, mpio, 0);  	if (r < 0 || r == DM_MAPIO_REQUEUE)  		mempool_free(mpio, m->mpio_pool); diff --git a/drivers/md/multipath.c b/drivers/md/multipath.c index 8bb8794129b..7ae33ebaf7e 100644 --- a/drivers/md/multipath.c +++ b/drivers/md/multipath.c @@ -176,7 +176,7 @@ static int multipath_make_request (struct request_queue *q, struct bio * bio)  	mp_bh->bio = *bio;  	mp_bh->bio.bi_sector += multipath->rdev->data_offset;  	mp_bh->bio.bi_bdev = multipath->rdev->bdev; -	mp_bh->bio.bi_rw |= (1 << BIO_RW_FAILFAST); +	mp_bh->bio.bi_rw |= (1 << BIO_RW_FAILFAST_TRANSPORT);  	mp_bh->bio.bi_end_io = multipath_end_request;  	mp_bh->bio.bi_private = mp_bh;  	generic_make_request(&mp_bh->bio); @@ -402,7 +402,7 @@ static void multipathd (mddev_t *mddev)  			*bio = *(mp_bh->master_bio);  			bio->bi_sector += conf->multipaths[mp_bh->path].rdev->data_offset;  			bio->bi_bdev = conf->multipaths[mp_bh->path].rdev->bdev; -			bio->bi_rw |= (1 << BIO_RW_FAILFAST); +			bio->bi_rw |= (1 << BIO_RW_FAILFAST_TRANSPORT);  			bio->bi_end_io = multipath_end_request;  			bio->bi_private = mp_bh;  			generic_make_request(bio); diff --git a/drivers/s390/block/dasd_diag.c b/drivers/s390/block/dasd_diag.c index 85fcb437105..7844461a995 100644 --- a/drivers/s390/block/dasd_diag.c +++ b/drivers/s390/block/dasd_diag.c @@ -544,7 +544,7 @@ static struct dasd_ccw_req *dasd_diag_build_cp(struct dasd_device *memdev,  	}  	cqr->retries = DIAG_MAX_RETRIES;  	cqr->buildclk = get_clock(); -	if (req->cmd_flags & REQ_FAILFAST) +	if (blk_noretry_request(req))  		set_bit(DASD_CQR_FLAGS_FAILFAST, &cqr->flags);  	cqr->startdev = memdev;  	cqr->memdev = memdev; diff --git a/drivers/s390/block/dasd_eckd.c b/drivers/s390/block/dasd_eckd.c index 49f9d221e23..2e60d5f968c 100644 --- a/drivers/s390/block/dasd_eckd.c +++ b/drivers/s390/block/dasd_eckd.c @@ -1700,7 +1700,7 @@ static struct dasd_ccw_req *dasd_eckd_build_cp(struct dasd_device *startdev,  			recid++;  		}  	} -	if (req->cmd_flags & REQ_FAILFAST) +	if (blk_noretry_request(req))  		set_bit(DASD_CQR_FLAGS_FAILFAST, &cqr->flags);  	cqr->startdev = startdev;  	cqr->memdev = startdev; diff --git a/drivers/s390/block/dasd_fba.c b/drivers/s390/block/dasd_fba.c index 93d9b6452a9..7d442aeff3d 100644 --- a/drivers/s390/block/dasd_fba.c +++ b/drivers/s390/block/dasd_fba.c @@ -355,7 +355,7 @@ static struct dasd_ccw_req *dasd_fba_build_cp(struct dasd_device * memdev,  			recid++;  		}  	} -	if (req->cmd_flags & REQ_FAILFAST) +	if (blk_noretry_request(req))  		set_bit(DASD_CQR_FLAGS_FAILFAST, &cqr->flags);  	cqr->startdev = memdev;  	cqr->memdev = memdev; diff --git a/drivers/scsi/device_handler/scsi_dh_alua.c b/drivers/scsi/device_handler/scsi_dh_alua.c index 708e475896b..cb8aa3b58c2 100644 --- a/drivers/scsi/device_handler/scsi_dh_alua.c +++ b/drivers/scsi/device_handler/scsi_dh_alua.c @@ -109,7 +109,8 @@ static struct request *get_alua_req(struct scsi_device *sdev,  	}  	rq->cmd_type = REQ_TYPE_BLOCK_PC; -	rq->cmd_flags |= REQ_FAILFAST | REQ_NOMERGE; +	rq->cmd_flags |= REQ_FAILFAST_DEV | REQ_FAILFAST_TRANSPORT | +			 REQ_FAILFAST_DRIVER | REQ_NOMERGE;  	rq->retries = ALUA_FAILOVER_RETRIES;  	rq->timeout = ALUA_FAILOVER_TIMEOUT; diff --git a/drivers/scsi/device_handler/scsi_dh_emc.c b/drivers/scsi/device_handler/scsi_dh_emc.c index 8f45570a8a0..0e572d2c5b0 100644 --- a/drivers/scsi/device_handler/scsi_dh_emc.c +++ b/drivers/scsi/device_handler/scsi_dh_emc.c @@ -303,7 +303,8 @@ static struct request *get_req(struct scsi_device *sdev, int cmd,  	rq->cmd[4] = len;  	rq->cmd_type = REQ_TYPE_BLOCK_PC; -	rq->cmd_flags |= REQ_FAILFAST; +	rq->cmd_flags |= REQ_FAILFAST_DEV | REQ_FAILFAST_TRANSPORT | +			 REQ_FAILFAST_DRIVER;  	rq->timeout = CLARIION_TIMEOUT;  	rq->retries = CLARIION_RETRIES; diff --git a/drivers/scsi/device_handler/scsi_dh_hp_sw.c b/drivers/scsi/device_handler/scsi_dh_hp_sw.c index 5e93c88ad66..9aec4ca64e5 100644 --- a/drivers/scsi/device_handler/scsi_dh_hp_sw.c +++ b/drivers/scsi/device_handler/scsi_dh_hp_sw.c @@ -112,7 +112,8 @@ static int hp_sw_tur(struct scsi_device *sdev, struct hp_sw_dh_data *h)  		return SCSI_DH_RES_TEMP_UNAVAIL;  	req->cmd_type = REQ_TYPE_BLOCK_PC; -	req->cmd_flags |= REQ_FAILFAST; +	req->cmd_flags |= REQ_FAILFAST_DEV | REQ_FAILFAST_TRANSPORT | +			  REQ_FAILFAST_DRIVER;  	req->cmd_len = COMMAND_SIZE(TEST_UNIT_READY);  	req->cmd[0] = TEST_UNIT_READY;  	req->timeout = HP_SW_TIMEOUT; @@ -204,7 +205,8 @@ static int hp_sw_start_stop(struct scsi_device *sdev, struct hp_sw_dh_data *h)  		return SCSI_DH_RES_TEMP_UNAVAIL;  	req->cmd_type = REQ_TYPE_BLOCK_PC; -	req->cmd_flags |= REQ_FAILFAST; +	req->cmd_flags |= REQ_FAILFAST_DEV | REQ_FAILFAST_TRANSPORT | +			  REQ_FAILFAST_DRIVER;  	req->cmd_len = COMMAND_SIZE(START_STOP);  	req->cmd[0] = START_STOP;  	req->cmd[4] = 1;	/* Start spin cycle */ diff --git a/drivers/scsi/device_handler/scsi_dh_rdac.c b/drivers/scsi/device_handler/scsi_dh_rdac.c index 50bf95f3b5c..a43c3ed4df2 100644 --- a/drivers/scsi/device_handler/scsi_dh_rdac.c +++ b/drivers/scsi/device_handler/scsi_dh_rdac.c @@ -226,7 +226,8 @@ static struct request *get_rdac_req(struct scsi_device *sdev,  	}  	rq->cmd_type = REQ_TYPE_BLOCK_PC; -	rq->cmd_flags |= REQ_FAILFAST | REQ_NOMERGE; +	rq->cmd_flags |= REQ_FAILFAST_DEV | REQ_FAILFAST_TRANSPORT | +			 REQ_FAILFAST_DRIVER;  	rq->retries = RDAC_RETRIES;  	rq->timeout = RDAC_TIMEOUT; diff --git a/drivers/scsi/scsi_transport_spi.c b/drivers/scsi/scsi_transport_spi.c index b29360ed0bd..7c2d28924d2 100644 --- a/drivers/scsi/scsi_transport_spi.c +++ b/drivers/scsi/scsi_transport_spi.c @@ -109,7 +109,9 @@ static int spi_execute(struct scsi_device *sdev, const void *cmd,  	for(i = 0; i < DV_RETRIES; i++) {  		result = scsi_execute(sdev, cmd, dir, buffer, bufflen,  				      sense, DV_TIMEOUT, /* retries */ 1, -				      REQ_FAILFAST); +				      REQ_FAILFAST_DEV | +				      REQ_FAILFAST_TRANSPORT | +				      REQ_FAILFAST_DRIVER);  		if (result & DRIVER_SENSE) {  			struct scsi_sense_hdr sshdr_tmp;  			if (!sshdr)  |