Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b8286239 authored by Kiyoshi Ueda's avatar Kiyoshi Ueda Committed by Jens Axboe
Browse files

blk_end_request: cleanup of request completion (take 4)



This patch merges complete_request() into end_that_request_last()
for cleanup.

complete_request() was introduced by earlier part of this patch-set,
not to break the existing users of end_that_request_last().

Since all users are converted to blk_end_request interfaces and
end_that_request_last() is no longer exported, the code can be
merged to end_that_request_last().

Cc: Boaz Harrosh <bharrosh@panasas.com>
Signed-off-by: default avatarKiyoshi Ueda <k-ueda@ct.jp.nec.com>
Signed-off-by: default avatarJun'ichi Nomura <j-nomura@ce.jp.nec.com>
Signed-off-by: default avatarJens Axboe <jens.axboe@oracle.com>
parent 5450d3e1
Loading
Loading
Loading
Loading
+14 −17
Original line number Diff line number Diff line
@@ -3638,6 +3638,12 @@ static void end_that_request_last(struct request *req, int error)
{
	struct gendisk *disk = req->rq_disk;

	if (blk_rq_tagged(req))
		blk_queue_end_tag(req->q, req);

	if (blk_queued_rq(req))
		blkdev_dequeue_request(req);

	if (unlikely(laptop_mode) && blk_fs_request(req))
		laptop_io_completion();

@@ -3655,11 +3661,16 @@ static void end_that_request_last(struct request *req, int error)
		disk_round_stats(disk);
		disk->in_flight--;
	}

	if (req->end_io)
		req->end_io(req, error);
	else
	else {
		if (blk_bidi_rq(req))
			__blk_put_request(req->next_rq->q, req->next_rq);

		__blk_put_request(req->q, req);
	}
}

static inline void __end_request(struct request *rq, int uptodate,
				 unsigned int nr_bytes)
@@ -3759,20 +3770,6 @@ void end_request(struct request *req, int uptodate)
}
EXPORT_SYMBOL(end_request);

static void complete_request(struct request *rq, int error)
{
	if (blk_rq_tagged(rq))
		blk_queue_end_tag(rq->q, rq);

	if (blk_queued_rq(rq))
		blkdev_dequeue_request(rq);

	if (blk_bidi_rq(rq) && !rq->end_io)
		__blk_put_request(rq->next_rq->q, rq->next_rq);

	end_that_request_last(rq, error);
}

/**
 * blk_end_io - Generic end_io function to complete a request.
 * @rq:           the request being processed
@@ -3815,7 +3812,7 @@ static int blk_end_io(struct request *rq, int error, int nr_bytes,
	add_disk_randomness(rq->rq_disk);

	spin_lock_irqsave(q->queue_lock, flags);
	complete_request(rq, error);
	end_that_request_last(rq, error);
	spin_unlock_irqrestore(q->queue_lock, flags);

	return 0;
@@ -3863,7 +3860,7 @@ int __blk_end_request(struct request *rq, int error, int nr_bytes)

	add_disk_randomness(rq->rq_disk);

	complete_request(rq, error);
	end_that_request_last(rq, error);

	return 0;
}