diff options
Diffstat (limited to 'block/blk-exec.c')
| -rw-r--r-- | block/blk-exec.c | 27 | 
1 files changed, 18 insertions, 9 deletions
diff --git a/block/blk-exec.c b/block/blk-exec.c index e7062139612..f4d27b12c90 100644 --- a/block/blk-exec.c +++ b/block/blk-exec.c @@ -5,6 +5,7 @@  #include <linux/module.h>  #include <linux/bio.h>  #include <linux/blkdev.h> +#include <linux/blk-mq.h>  #include <linux/sched/sysctl.h>  #include "blk.h" @@ -24,7 +25,6 @@ static void blk_end_sync_rq(struct request *rq, int error)  	struct completion *waiting = rq->end_io_data;  	rq->end_io_data = NULL; -	__blk_put_request(rq->q, rq);  	/*  	 * complete last, if this is a stack request the process (and thus @@ -59,6 +59,16 @@ void blk_execute_rq_nowait(struct request_queue *q, struct gendisk *bd_disk,  	rq->rq_disk = bd_disk;  	rq->end_io = done; + +	/* +	 * don't check dying flag for MQ because the request won't +	 * be resued after dying flag is set +	 */ +	if (q->mq_ops) { +		blk_mq_insert_request(rq, at_head, true, false); +		return; +	} +  	/*  	 * need to check this before __blk_run_queue(), because rq can  	 * be freed before that returns. @@ -68,9 +78,9 @@ void blk_execute_rq_nowait(struct request_queue *q, struct gendisk *bd_disk,  	spin_lock_irq(q->queue_lock);  	if (unlikely(blk_queue_dying(q))) { +		rq->cmd_flags |= REQ_QUIET;   		rq->errors = -ENXIO; -		if (rq->end_io) -			rq->end_io(rq, rq->errors); +		__blk_end_request_all(rq, rq->errors);  		spin_unlock_irq(q->queue_lock);  		return;  	} @@ -103,12 +113,6 @@ int blk_execute_rq(struct request_queue *q, struct gendisk *bd_disk,  	int err = 0;  	unsigned long hang_check; -	/* -	 * we need an extra reference to the request, so we can look at -	 * it after io completion -	 */ -	rq->ref_count++; -  	if (!rq->sense) {  		memset(sense, 0, sizeof(sense));  		rq->sense = sense; @@ -128,6 +132,11 @@ int blk_execute_rq(struct request_queue *q, struct gendisk *bd_disk,  	if (rq->errors)  		err = -EIO; +	if (rq->sense == sense)	{ +		rq->sense = NULL; +		rq->sense_len = 0; +	} +  	return err;  }  EXPORT_SYMBOL(blk_execute_rq);  | 
