aboutsummaryrefslogtreecommitdiffstats
path: root/block/ll_rw_blk.c
diff options
context:
space:
mode:
Diffstat (limited to 'block/ll_rw_blk.c')
-rw-r--r--block/ll_rw_blk.c22
1 files changed, 7 insertions, 15 deletions
diff --git a/block/ll_rw_blk.c b/block/ll_rw_blk.c
index b1ea941f6dc3..e25b4cd2dcd1 100644
--- a/block/ll_rw_blk.c
+++ b/block/ll_rw_blk.c
@@ -2885,17 +2885,11 @@ static void init_request_from_bio(struct request *req, struct bio *bio)
2885static int __make_request(request_queue_t *q, struct bio *bio) 2885static int __make_request(request_queue_t *q, struct bio *bio)
2886{ 2886{
2887 struct request *req; 2887 struct request *req;
2888 int el_ret, rw, nr_sectors, cur_nr_sectors, barrier, err, sync; 2888 int el_ret, nr_sectors, barrier, err;
2889 unsigned short prio; 2889 const unsigned short prio = bio_prio(bio);
2890 sector_t sector; 2890 const int sync = bio_sync(bio);
2891 2891
2892 sector = bio->bi_sector;
2893 nr_sectors = bio_sectors(bio); 2892 nr_sectors = bio_sectors(bio);
2894 cur_nr_sectors = bio_cur_sectors(bio);
2895 prio = bio_prio(bio);
2896
2897 rw = bio_data_dir(bio);
2898 sync = bio_sync(bio);
2899 2893
2900 /* 2894 /*
2901 * low level driver can indicate that it wants pages above a 2895 * low level driver can indicate that it wants pages above a
@@ -2904,8 +2898,6 @@ static int __make_request(request_queue_t *q, struct bio *bio)
2904 */ 2898 */
2905 blk_queue_bounce(q, &bio); 2899 blk_queue_bounce(q, &bio);
2906 2900
2907 spin_lock_prefetch(q->queue_lock);
2908
2909 barrier = bio_barrier(bio); 2901 barrier = bio_barrier(bio);
2910 if (unlikely(barrier) && (q->next_ordered == QUEUE_ORDERED_NONE)) { 2902 if (unlikely(barrier) && (q->next_ordered == QUEUE_ORDERED_NONE)) {
2911 err = -EOPNOTSUPP; 2903 err = -EOPNOTSUPP;
@@ -2953,9 +2945,9 @@ static int __make_request(request_queue_t *q, struct bio *bio)
2953 * not touch req->buffer either... 2945 * not touch req->buffer either...
2954 */ 2946 */
2955 req->buffer = bio_data(bio); 2947 req->buffer = bio_data(bio);
2956 req->current_nr_sectors = cur_nr_sectors; 2948 req->current_nr_sectors = bio_cur_sectors(bio);
2957 req->hard_cur_sectors = cur_nr_sectors; 2949 req->hard_cur_sectors = req->current_nr_sectors;
2958 req->sector = req->hard_sector = sector; 2950 req->sector = req->hard_sector = bio->bi_sector;
2959 req->nr_sectors = req->hard_nr_sectors += nr_sectors; 2951 req->nr_sectors = req->hard_nr_sectors += nr_sectors;
2960 req->ioprio = ioprio_best(req->ioprio, prio); 2952 req->ioprio = ioprio_best(req->ioprio, prio);
2961 drive_stat_acct(req, nr_sectors, 0); 2953 drive_stat_acct(req, nr_sectors, 0);
@@ -2973,7 +2965,7 @@ get_rq:
2973 * Grab a free request. This is might sleep but can not fail. 2965 * Grab a free request. This is might sleep but can not fail.
2974 * Returns with the queue unlocked. 2966 * Returns with the queue unlocked.
2975 */ 2967 */
2976 req = get_request_wait(q, rw, bio); 2968 req = get_request_wait(q, bio_data_dir(bio), bio);
2977 2969
2978 /* 2970 /*
2979 * After dropping the lock and possibly sleeping here, our request 2971 * After dropping the lock and possibly sleeping here, our request