diff options
-rw-r--r-- | block/blk-core.c | 128 | ||||
-rw-r--r-- | include/linux/blkdev.h | 128 |
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 | **/ |
2029 | bool blk_end_bidi_request(struct request *rq, int error, | 2029 | static 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 | } |
2044 | EXPORT_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 | **/ |
2061 | bool __blk_end_bidi_request(struct request *rq, int error, | 2060 | static 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 | } |
2071 | EXPORT_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 | **/ | ||
2085 | bool 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 | } | ||
2089 | EXPORT_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 | */ | ||
2099 | void 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 | } | ||
2110 | EXPORT_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 | */ | ||
2124 | bool blk_end_request_cur(struct request *rq, int error) | ||
2125 | { | ||
2126 | return blk_end_request(rq, error, blk_rq_cur_bytes(rq)); | ||
2127 | } | ||
2128 | EXPORT_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 | **/ | ||
2143 | bool __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 | } | ||
2147 | EXPORT_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 | */ | ||
2157 | void __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 | } | ||
2168 | EXPORT_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 | */ | ||
2183 | bool __blk_end_request_cur(struct request *rq, int error) | ||
2184 | { | ||
2185 | return __blk_end_request(rq, error, blk_rq_cur_bytes(rq)); | ||
2186 | } | ||
2187 | EXPORT_SYMBOL_GPL(__blk_end_request_cur); | ||
2072 | 2188 | ||
2073 | void blk_rq_bio_prep(struct request_queue *q, struct request *rq, | 2189 | void 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 | */ |
873 | extern bool blk_update_request(struct request *rq, int error, | 873 | extern bool blk_update_request(struct request *rq, int error, |
874 | unsigned int nr_bytes); | 874 | unsigned int nr_bytes); |
875 | extern bool blk_end_bidi_request(struct request *rq, int error, | 875 | extern bool blk_end_request(struct request *rq, int error, |
876 | unsigned int nr_bytes, | 876 | unsigned int nr_bytes); |
877 | unsigned int bidi_bytes); | 877 | extern void blk_end_request_all(struct request *rq, int error); |
878 | extern bool __blk_end_bidi_request(struct request *rq, int error, | 878 | extern bool blk_end_request_cur(struct request *rq, int error); |
879 | unsigned int nr_bytes, | 879 | extern bool __blk_end_request(struct request *rq, int error, |
880 | unsigned int bidi_bytes); | 880 | unsigned int nr_bytes); |
881 | 881 | extern void __blk_end_request_all(struct request *rq, int error); | |
882 | /** | 882 | extern 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 | **/ | ||
896 | static 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 | */ | ||
910 | static 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 | */ | ||
934 | static 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 | **/ | ||
952 | static 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 | */ | ||
966 | static 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 | */ | ||
991 | static 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 | ||
996 | extern void blk_complete_request(struct request *); | 884 | extern void blk_complete_request(struct request *); |
997 | extern void __blk_complete_request(struct request *); | 885 | extern void __blk_complete_request(struct request *); |