block: change request end_io handler to pass back a return value
[platform/kernel/linux-starfive.git] / block / blk-flush.c
index 27705fc..53202ef 100644 (file)
@@ -217,7 +217,8 @@ static void blk_flush_complete_seq(struct request *rq,
        blk_kick_flush(q, fq, cmd_flags);
 }
 
-static void flush_end_io(struct request *flush_rq, blk_status_t error)
+static enum rq_end_io_ret flush_end_io(struct request *flush_rq,
+                                      blk_status_t error)
 {
        struct request_queue *q = flush_rq->q;
        struct list_head *running;
@@ -231,7 +232,7 @@ static void flush_end_io(struct request *flush_rq, blk_status_t error)
        if (!req_ref_put_and_test(flush_rq)) {
                fq->rq_status = error;
                spin_unlock_irqrestore(&fq->mq_flush_lock, flags);
-               return;
+               return RQ_END_IO_NONE;
        }
 
        blk_account_io_flush(flush_rq);
@@ -268,6 +269,7 @@ static void flush_end_io(struct request *flush_rq, blk_status_t error)
        }
 
        spin_unlock_irqrestore(&fq->mq_flush_lock, flags);
+       return RQ_END_IO_NONE;
 }
 
 bool is_flush_rq(struct request *rq)
@@ -353,7 +355,8 @@ static void blk_kick_flush(struct request_queue *q, struct blk_flush_queue *fq,
        blk_flush_queue_rq(flush_rq, false);
 }
 
-static void mq_flush_data_end_io(struct request *rq, blk_status_t error)
+static enum rq_end_io_ret mq_flush_data_end_io(struct request *rq,
+                                              blk_status_t error)
 {
        struct request_queue *q = rq->q;
        struct blk_mq_hw_ctx *hctx = rq->mq_hctx;
@@ -375,6 +378,7 @@ static void mq_flush_data_end_io(struct request *rq, blk_status_t error)
        spin_unlock_irqrestore(&fq->mq_flush_lock, flags);
 
        blk_mq_sched_restart(hctx);
+       return RQ_END_IO_NONE;
 }
 
 /**