提交 3bcddeac 编写于 作者: K Kiyoshi Ueda 提交者: Jens Axboe

blk_end_request: remove/unexport end_that_request_* (take 4)

This patch removes the following functions:
  o end_that_request_first()
  o end_that_request_chunk()
and stops exporting the functions below:
  o end_that_request_last()

Cc: Boaz Harrosh <bharrosh@panasas.com>
Signed-off-by: NKiyoshi Ueda <k-ueda@ct.jp.nec.com>
Signed-off-by: NJun'ichi Nomura <j-nomura@ce.jp.nec.com>
Signed-off-by: NJens Axboe <jens.axboe@oracle.com>
上级 610d8b0c
...@@ -3432,6 +3432,20 @@ static void blk_recalc_rq_sectors(struct request *rq, int nsect) ...@@ -3432,6 +3432,20 @@ static void blk_recalc_rq_sectors(struct request *rq, int nsect)
} }
} }
/**
* __end_that_request_first - end I/O on a request
* @req: the request being processed
* @uptodate: 1 for success, 0 for I/O error, < 0 for specific error
* @nr_bytes: number of bytes to complete
*
* Description:
* Ends I/O on a number of bytes attached to @req, and sets it up
* for the next range of segments (if any) in the cluster.
*
* Return:
* 0 - we are done with this request, call end_that_request_last()
* 1 - still buffers pending for this request
**/
static int __end_that_request_first(struct request *req, int uptodate, static int __end_that_request_first(struct request *req, int uptodate,
int nr_bytes) int nr_bytes)
{ {
...@@ -3548,49 +3562,6 @@ static int __end_that_request_first(struct request *req, int uptodate, ...@@ -3548,49 +3562,6 @@ static int __end_that_request_first(struct request *req, int uptodate,
return 1; return 1;
} }
/**
* end_that_request_first - end I/O on a request
* @req: the request being processed
* @uptodate: 1 for success, 0 for I/O error, < 0 for specific error
* @nr_sectors: number of sectors to end I/O on
*
* Description:
* Ends I/O on a number of sectors attached to @req, and sets it up
* for the next range of segments (if any) in the cluster.
*
* Return:
* 0 - we are done with this request, call end_that_request_last()
* 1 - still buffers pending for this request
**/
int end_that_request_first(struct request *req, int uptodate, int nr_sectors)
{
return __end_that_request_first(req, uptodate, nr_sectors << 9);
}
EXPORT_SYMBOL(end_that_request_first);
/**
* end_that_request_chunk - end I/O on a request
* @req: the request being processed
* @uptodate: 1 for success, 0 for I/O error, < 0 for specific error
* @nr_bytes: number of bytes to complete
*
* Description:
* Ends I/O on a number of bytes attached to @req, and sets it up
* for the next range of segments (if any). Like end_that_request_first(),
* but deals with bytes instead of sectors.
*
* Return:
* 0 - we are done with this request, call end_that_request_last()
* 1 - still buffers pending for this request
**/
int end_that_request_chunk(struct request *req, int uptodate, int nr_bytes)
{
return __end_that_request_first(req, uptodate, nr_bytes);
}
EXPORT_SYMBOL(end_that_request_chunk);
/* /*
* splice the completion data to a local structure and hand off to * splice the completion data to a local structure and hand off to
* process_completion_queue() to complete the requests * process_completion_queue() to complete the requests
...@@ -3670,7 +3641,7 @@ EXPORT_SYMBOL(blk_complete_request); ...@@ -3670,7 +3641,7 @@ EXPORT_SYMBOL(blk_complete_request);
/* /*
* queue lock must be held * queue lock must be held
*/ */
void end_that_request_last(struct request *req, int uptodate) static void end_that_request_last(struct request *req, int uptodate)
{ {
struct gendisk *disk = req->rq_disk; struct gendisk *disk = req->rq_disk;
int error; int error;
...@@ -3705,8 +3676,6 @@ void end_that_request_last(struct request *req, int uptodate) ...@@ -3705,8 +3676,6 @@ void end_that_request_last(struct request *req, int uptodate)
__blk_put_request(req->q, req); __blk_put_request(req->q, req);
} }
EXPORT_SYMBOL(end_that_request_last);
static inline void __end_request(struct request *rq, int uptodate, static inline void __end_request(struct request *rq, int uptodate,
unsigned int nr_bytes) unsigned int nr_bytes)
{ {
......
...@@ -718,21 +718,18 @@ static inline void blk_run_address_space(struct address_space *mapping) ...@@ -718,21 +718,18 @@ static inline void blk_run_address_space(struct address_space *mapping)
} }
/* /*
* end_request() and friends. Must be called with the request queue spinlock * blk_end_request() and friends.
* acquired. All functions called within end_request() _must_be_ atomic. * __blk_end_request() and end_request() must be called with
* the request queue spinlock acquired.
* *
* Several drivers define their own end_request and call * Several drivers define their own end_request and call
* end_that_request_first() and end_that_request_last() * blk_end_request() for parts of the original function.
* for parts of the original function. This prevents * This prevents code duplication in drivers.
* code duplication in drivers.
*/ */
extern int blk_end_request(struct request *rq, int error, int nr_bytes); extern int blk_end_request(struct request *rq, int error, int nr_bytes);
extern int __blk_end_request(struct request *rq, int error, int nr_bytes); extern int __blk_end_request(struct request *rq, int error, int nr_bytes);
extern int blk_end_bidi_request(struct request *rq, int error, int nr_bytes, extern int blk_end_bidi_request(struct request *rq, int error, int nr_bytes,
int bidi_bytes); int bidi_bytes);
extern int end_that_request_first(struct request *, int, int);
extern int end_that_request_chunk(struct request *, int, int);
extern void end_that_request_last(struct request *, int);
extern void end_request(struct request *, int); extern void end_request(struct request *, int);
extern void end_queued_request(struct request *, int); extern void end_queued_request(struct request *, int);
extern void end_dequeued_request(struct request *, int); extern void end_dequeued_request(struct request *, int);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册