aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--block/blk-core.c128
-rw-r--r--include/linux/blkdev.h128
2 files changed, 130 insertions, 126 deletions
diff --git a/block/blk-core.c b/block/blk-core.c
index 93691d2ac5a0..a2d97de1a12c 100644
--- a/block/blk-core.c
+++ b/block/blk-core.c
@@ -2026,8 +2026,8 @@ static void blk_finish_request(struct request *req, int error)
2026 * %false - we are done with this request 2026 * %false - we are done with this request
2027 * %true - still buffers pending for this request 2027 * %true - still buffers pending for this request
2028 **/ 2028 **/
2029bool blk_end_bidi_request(struct request *rq, int error, 2029static bool blk_end_bidi_request(struct request *rq, int error,
2030 unsigned int nr_bytes, unsigned int bidi_bytes) 2030 unsigned int nr_bytes, unsigned int bidi_bytes)
2031{ 2031{
2032 struct request_queue *q = rq->q; 2032 struct request_queue *q = rq->q;
2033 unsigned long flags; 2033 unsigned long flags;
@@ -2041,7 +2041,6 @@ bool blk_end_bidi_request(struct request *rq, int error,
2041 2041
2042 return false; 2042 return false;
2043} 2043}
2044EXPORT_SYMBOL_GPL(blk_end_bidi_request);
2045 2044
2046/** 2045/**
2047 * __blk_end_bidi_request - Complete a bidi request with queue lock held 2046 * __blk_end_bidi_request - Complete a bidi request with queue lock held
@@ -2058,8 +2057,8 @@ EXPORT_SYMBOL_GPL(blk_end_bidi_request);
2058 * %false - we are done with this request 2057 * %false - we are done with this request
2059 * %true - still buffers pending for this request 2058 * %true - still buffers pending for this request
2060 **/ 2059 **/
2061bool __blk_end_bidi_request(struct request *rq, int error, 2060static bool __blk_end_bidi_request(struct request *rq, int error,
2062 unsigned int nr_bytes, unsigned int bidi_bytes) 2061 unsigned int nr_bytes, unsigned int bidi_bytes)
2063{ 2062{
2064 if (blk_update_bidi_request(rq, error, nr_bytes, bidi_bytes)) 2063 if (blk_update_bidi_request(rq, error, nr_bytes, bidi_bytes))
2065 return true; 2064 return true;
@@ -2068,7 +2067,124 @@ bool __blk_end_bidi_request(struct request *rq, int error,
2068 2067
2069 return false; 2068 return false;
2070} 2069}
2071EXPORT_SYMBOL_GPL(__blk_end_bidi_request); 2070
2071/**
2072 * blk_end_request - Helper function for drivers to complete the request.
2073 * @rq: the request being processed
2074 * @error: %0 for success, < %0 for error
2075 * @nr_bytes: number of bytes to complete
2076 *
2077 * Description:
2078 * Ends I/O on a number of bytes attached to @rq.
2079 * If @rq has leftover, sets it up for the next range of segments.
2080 *
2081 * Return:
2082 * %false - we are done with this request
2083 * %true - still buffers pending for this request
2084 **/
2085bool blk_end_request(struct request *rq, int error, unsigned int nr_bytes)
2086{
2087 return blk_end_bidi_request(rq, error, nr_bytes, 0);
2088}
2089EXPORT_SYMBOL_GPL(blk_end_request);
2090
2091/**
2092 * blk_end_request_all - Helper function for drives to finish the request.
2093 * @rq: the request to finish
2094 * @err: %0 for success, < %0 for error
2095 *
2096 * Description:
2097 * Completely finish @rq.
2098 */
2099void blk_end_request_all(struct request *rq, int error)
2100{
2101 bool pending;
2102 unsigned int bidi_bytes = 0;
2103
2104 if (unlikely(blk_bidi_rq(rq)))
2105 bidi_bytes = blk_rq_bytes(rq->next_rq);
2106
2107 pending = blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes);
2108 BUG_ON(pending);
2109}
2110EXPORT_SYMBOL_GPL(blk_end_request_all);
2111
2112/**
2113 * blk_end_request_cur - Helper function to finish the current request chunk.
2114 * @rq: the request to finish the current chunk for
2115 * @err: %0 for success, < %0 for error
2116 *
2117 * Description:
2118 * Complete the current consecutively mapped chunk from @rq.
2119 *
2120 * Return:
2121 * %false - we are done with this request
2122 * %true - still buffers pending for this request
2123 */
2124bool blk_end_request_cur(struct request *rq, int error)
2125{
2126 return blk_end_request(rq, error, blk_rq_cur_bytes(rq));
2127}
2128EXPORT_SYMBOL_GPL(blk_end_request_cur);
2129
2130/**
2131 * __blk_end_request - Helper function for drivers to complete the request.
2132 * @rq: the request being processed
2133 * @error: %0 for success, < %0 for error
2134 * @nr_bytes: number of bytes to complete
2135 *
2136 * Description:
2137 * Must be called with queue lock held unlike blk_end_request().
2138 *
2139 * Return:
2140 * %false - we are done with this request
2141 * %true - still buffers pending for this request
2142 **/
2143bool __blk_end_request(struct request *rq, int error, unsigned int nr_bytes)
2144{
2145 return __blk_end_bidi_request(rq, error, nr_bytes, 0);
2146}
2147EXPORT_SYMBOL_GPL(__blk_end_request);
2148
2149/**
2150 * __blk_end_request_all - Helper function for drives to finish the request.
2151 * @rq: the request to finish
2152 * @err: %0 for success, < %0 for error
2153 *
2154 * Description:
2155 * Completely finish @rq. Must be called with queue lock held.
2156 */
2157void __blk_end_request_all(struct request *rq, int error)
2158{
2159 bool pending;
2160 unsigned int bidi_bytes = 0;
2161
2162 if (unlikely(blk_bidi_rq(rq)))
2163 bidi_bytes = blk_rq_bytes(rq->next_rq);
2164
2165 pending = __blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes);
2166 BUG_ON(pending);
2167}
2168EXPORT_SYMBOL_GPL(__blk_end_request_all);
2169
2170/**
2171 * __blk_end_request_cur - Helper function to finish the current request chunk.
2172 * @rq: the request to finish the current chunk for
2173 * @err: %0 for success, < %0 for error
2174 *
2175 * Description:
2176 * Complete the current consecutively mapped chunk from @rq. Must
2177 * be called with queue lock held.
2178 *
2179 * Return:
2180 * %false - we are done with this request
2181 * %true - still buffers pending for this request
2182 */
2183bool __blk_end_request_cur(struct request *rq, int error)
2184{
2185 return __blk_end_request(rq, error, blk_rq_cur_bytes(rq));
2186}
2187EXPORT_SYMBOL_GPL(__blk_end_request_cur);
2072 2188
2073void blk_rq_bio_prep(struct request_queue *q, struct request *rq, 2189void blk_rq_bio_prep(struct request_queue *q, struct request *rq,
2074 struct bio *bio) 2190 struct bio *bio)
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h
index 1069f4483c6e..f9d60a78c08a 100644
--- a/include/linux/blkdev.h
+++ b/include/linux/blkdev.h
@@ -872,126 +872,14 @@ extern struct request *blk_fetch_request(struct request_queue *q);
872 */ 872 */
873extern bool blk_update_request(struct request *rq, int error, 873extern bool blk_update_request(struct request *rq, int error,
874 unsigned int nr_bytes); 874 unsigned int nr_bytes);
875extern bool blk_end_bidi_request(struct request *rq, int error, 875extern bool blk_end_request(struct request *rq, int error,
876 unsigned int nr_bytes, 876 unsigned int nr_bytes);
877 unsigned int bidi_bytes); 877extern void blk_end_request_all(struct request *rq, int error);
878extern bool __blk_end_bidi_request(struct request *rq, int error, 878extern bool blk_end_request_cur(struct request *rq, int error);
879 unsigned int nr_bytes, 879extern bool __blk_end_request(struct request *rq, int error,
880 unsigned int bidi_bytes); 880 unsigned int nr_bytes);
881 881extern void __blk_end_request_all(struct request *rq, int error);
882/** 882extern bool __blk_end_request_cur(struct request *rq, int error);
883 * blk_end_request - Helper function for drivers to complete the request.
884 * @rq: the request being processed
885 * @error: %0 for success, < %0 for error
886 * @nr_bytes: number of bytes to complete
887 *
888 * Description:
889 * Ends I/O on a number of bytes attached to @rq.
890 * If @rq has leftover, sets it up for the next range of segments.
891 *
892 * Return:
893 * %false - we are done with this request
894 * %true - still buffers pending for this request
895 **/
896static inline bool blk_end_request(struct request *rq, int error,
897 unsigned int nr_bytes)
898{
899 return blk_end_bidi_request(rq, error, nr_bytes, 0);
900}
901
902/**
903 * blk_end_request_all - Helper function for drives to finish the request.
904 * @rq: the request to finish
905 * @err: %0 for success, < %0 for error
906 *
907 * Description:
908 * Completely finish @rq.
909 */
910static inline void blk_end_request_all(struct request *rq, int error)
911{
912 bool pending;
913 unsigned int bidi_bytes = 0;
914
915 if (unlikely(blk_bidi_rq(rq)))
916 bidi_bytes = blk_rq_bytes(rq->next_rq);
917
918 pending = blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes);
919 BUG_ON(pending);
920}
921
922/**
923 * blk_end_request_cur - Helper function to finish the current request chunk.
924 * @rq: the request to finish the current chunk for
925 * @err: %0 for success, < %0 for error
926 *
927 * Description:
928 * Complete the current consecutively mapped chunk from @rq.
929 *
930 * Return:
931 * %false - we are done with this request
932 * %true - still buffers pending for this request
933 */
934static inline bool blk_end_request_cur(struct request *rq, int error)
935{
936 return blk_end_request(rq, error, blk_rq_cur_bytes(rq));
937}
938
939/**
940 * __blk_end_request - Helper function for drivers to complete the request.
941 * @rq: the request being processed
942 * @error: %0 for success, < %0 for error
943 * @nr_bytes: number of bytes to complete
944 *
945 * Description:
946 * Must be called with queue lock held unlike blk_end_request().
947 *
948 * Return:
949 * %false - we are done with this request
950 * %true - still buffers pending for this request
951 **/
952static inline bool __blk_end_request(struct request *rq, int error,
953 unsigned int nr_bytes)
954{
955 return __blk_end_bidi_request(rq, error, nr_bytes, 0);
956}
957
958/**
959 * __blk_end_request_all - Helper function for drives to finish the request.
960 * @rq: the request to finish
961 * @err: %0 for success, < %0 for error
962 *
963 * Description:
964 * Completely finish @rq. Must be called with queue lock held.
965 */
966static inline void __blk_end_request_all(struct request *rq, int error)
967{
968 bool pending;
969 unsigned int bidi_bytes = 0;
970
971 if (unlikely(blk_bidi_rq(rq)))
972 bidi_bytes = blk_rq_bytes(rq->next_rq);
973
974 pending = __blk_end_bidi_request(rq, error, blk_rq_bytes(rq), bidi_bytes);
975 BUG_ON(pending);
976}
977
978/**
979 * __blk_end_request_cur - Helper function to finish the current request chunk.
980 * @rq: the request to finish the current chunk for
981 * @err: %0 for success, < %0 for error
982 *
983 * Description:
984 * Complete the current consecutively mapped chunk from @rq. Must
985 * be called with queue lock held.
986 *
987 * Return:
988 * %false - we are done with this request
989 * %true - still buffers pending for this request
990 */
991static inline bool __blk_end_request_cur(struct request *rq, int error)
992{
993 return __blk_end_request(rq, error, blk_rq_cur_bytes(rq));
994}
995 883
996extern void blk_complete_request(struct request *); 884extern void blk_complete_request(struct request *);
997extern void __blk_complete_request(struct request *); 885extern void __blk_complete_request(struct request *);