aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2013-11-01 12:38:45 -0400
committerJens Axboe <axboe@kernel.dk>2013-11-08 11:10:29 -0500
commit6a5ec65b9acee39f9af4a15a81858d5fc07498d0 (patch)
treeeb86de09e70c7c76b432087e810ca9e282fbe266
parentfcd37eb3c1347193935d07a82b84dfc7d418dd05 (diff)
skd: cleanup the skd_*() function block wrapping
Just call the block functions directly, don't wrap them in skd helpers. With only one queueing model enabled, there's no point in doing that. Also kill the ->start_time and ->bio from the skd_request_context, we don't use those anymore. Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r--drivers/block/skd_main.c52
1 files changed, 15 insertions, 37 deletions
diff --git a/drivers/block/skd_main.c b/drivers/block/skd_main.c
index 49e1e8b48422..d404d7646d9c 100644
--- a/drivers/block/skd_main.c
+++ b/drivers/block/skd_main.c
@@ -214,8 +214,6 @@ struct skd_request_context {
214 u32 fitmsg_id; 214 u32 fitmsg_id;
215 215
216 struct request *req; 216 struct request *req;
217 struct bio *bio;
218 unsigned long start_time;
219 u8 flush_cmd; 217 u8 flush_cmd;
220 u8 discard_page; 218 u8 discard_page;
221 219
@@ -506,26 +504,6 @@ static void skd_log_skreq(struct skd_device *skdev,
506 * READ/WRITE REQUESTS 504 * READ/WRITE REQUESTS
507 ***************************************************************************** 505 *****************************************************************************
508 */ 506 */
509static void skd_stop_queue(struct skd_device *skdev)
510{
511 blk_stop_queue(skdev->queue);
512}
513
514static void skd_unstop_queue(struct skd_device *skdev)
515{
516 queue_flag_clear(QUEUE_FLAG_STOPPED, skdev->queue);
517}
518
519static void skd_start_queue(struct skd_device *skdev)
520{
521 blk_start_queue(skdev->queue);
522}
523
524static int skd_queue_stopped(struct skd_device *skdev)
525{
526 return blk_queue_stopped(skdev->queue);
527}
528
529static void skd_fail_all_pending(struct skd_device *skdev) 507static void skd_fail_all_pending(struct skd_device *skdev)
530{ 508{
531 struct request_queue *q = skdev->queue; 509 struct request_queue *q = skdev->queue;
@@ -634,14 +612,14 @@ static void skd_request_fn(struct request_queue *q)
634 return; 612 return;
635 } 613 }
636 614
637 if (skd_queue_stopped(skdev)) { 615 if (blk_queue_stopped(skdev->queue)) {
638 if (skdev->skmsg_free_list == NULL || 616 if (skdev->skmsg_free_list == NULL ||
639 skdev->skreq_free_list == NULL || 617 skdev->skreq_free_list == NULL ||
640 skdev->in_flight >= skdev->queue_low_water_mark) 618 skdev->in_flight >= skdev->queue_low_water_mark)
641 /* There is still some kind of shortage */ 619 /* There is still some kind of shortage */
642 return; 620 return;
643 621
644 skd_unstop_queue(skdev); 622 queue_flag_clear(QUEUE_FLAG_STOPPED, skdev->queue);
645 } 623 }
646 624
647 /* 625 /*
@@ -887,7 +865,7 @@ skip_sg:
887 * we are out of a resource. 865 * we are out of a resource.
888 */ 866 */
889 if (req) 867 if (req)
890 skd_stop_queue(skdev); 868 blk_stop_queue(skdev->queue);
891} 869}
892 870
893static void skd_end_request_blk(struct skd_device *skdev, 871static void skd_end_request_blk(struct skd_device *skdev,
@@ -1106,7 +1084,7 @@ static void skd_timer_tick(ulong arg)
1106 skdev->timer_countdown = SKD_DRAINING_TIMO; 1084 skdev->timer_countdown = SKD_DRAINING_TIMO;
1107 skdev->state = SKD_DRVR_STATE_DRAINING_TIMEOUT; 1085 skdev->state = SKD_DRVR_STATE_DRAINING_TIMEOUT;
1108 skdev->timo_slot = timo_slot; 1086 skdev->timo_slot = timo_slot;
1109 skd_stop_queue(skdev); 1087 blk_stop_queue(skdev->queue);
1110 1088
1111timer_func_out: 1089timer_func_out:
1112 mod_timer(&skdev->timer, (jiffies + HZ)); 1090 mod_timer(&skdev->timer, (jiffies + HZ));
@@ -1165,7 +1143,7 @@ static void skd_timer_tick_not_online(struct skd_device *skdev)
1165 1143
1166 /*start the queue so we can respond with error to requests */ 1144 /*start the queue so we can respond with error to requests */
1167 /* wakeup anyone waiting for startup complete */ 1145 /* wakeup anyone waiting for startup complete */
1168 skd_start_queue(skdev); 1146 blk_start_queue(skdev->queue);
1169 skdev->gendisk_on = -1; 1147 skdev->gendisk_on = -1;
1170 wake_up_interruptible(&skdev->waitq); 1148 wake_up_interruptible(&skdev->waitq);
1171 break; 1149 break;
@@ -1191,7 +1169,7 @@ static void skd_timer_tick_not_online(struct skd_device *skdev)
1191 pr_debug("%s:%s:%d Slot drained, starting queue.\n", 1169 pr_debug("%s:%s:%d Slot drained, starting queue.\n",
1192 skdev->name, __func__, __LINE__); 1170 skdev->name, __func__, __LINE__);
1193 skdev->state = SKD_DRVR_STATE_ONLINE; 1171 skdev->state = SKD_DRVR_STATE_ONLINE;
1194 skd_start_queue(skdev); 1172 blk_start_queue(skdev->queue);
1195 return; 1173 return;
1196 } 1174 }
1197 if (skdev->timer_countdown > 0) { 1175 if (skdev->timer_countdown > 0) {
@@ -1241,7 +1219,7 @@ static void skd_timer_tick_not_online(struct skd_device *skdev)
1241 1219
1242 /*start the queue so we can respond with error to requests */ 1220 /*start the queue so we can respond with error to requests */
1243 /* wakeup anyone waiting for startup complete */ 1221 /* wakeup anyone waiting for startup complete */
1244 skd_start_queue(skdev); 1222 blk_start_queue(skdev->queue);
1245 skdev->gendisk_on = -1; 1223 skdev->gendisk_on = -1;
1246 wake_up_interruptible(&skdev->waitq); 1224 wake_up_interruptible(&skdev->waitq);
1247 break; 1225 break;
@@ -3241,7 +3219,7 @@ static void skd_isr_fwstate(struct skd_device *skdev)
3241 */ 3219 */
3242 skdev->state = SKD_DRVR_STATE_BUSY_SANITIZE; 3220 skdev->state = SKD_DRVR_STATE_BUSY_SANITIZE;
3243 skdev->timer_countdown = SKD_TIMER_SECONDS(3); 3221 skdev->timer_countdown = SKD_TIMER_SECONDS(3);
3244 skd_start_queue(skdev); 3222 blk_start_queue(skdev->queue);
3245 break; 3223 break;
3246 case FIT_SR_DRIVE_BUSY_ERASE: 3224 case FIT_SR_DRIVE_BUSY_ERASE:
3247 skdev->state = SKD_DRVR_STATE_BUSY_ERASE; 3225 skdev->state = SKD_DRVR_STATE_BUSY_ERASE;
@@ -3276,7 +3254,7 @@ static void skd_isr_fwstate(struct skd_device *skdev)
3276 case FIT_SR_DRIVE_FAULT: 3254 case FIT_SR_DRIVE_FAULT:
3277 skd_drive_fault(skdev); 3255 skd_drive_fault(skdev);
3278 skd_recover_requests(skdev, 0); 3256 skd_recover_requests(skdev, 0);
3279 skd_start_queue(skdev); 3257 blk_start_queue(skdev->queue);
3280 break; 3258 break;
3281 3259
3282 /* PCIe bus returned all Fs? */ 3260 /* PCIe bus returned all Fs? */
@@ -3285,7 +3263,7 @@ static void skd_isr_fwstate(struct skd_device *skdev)
3285 skd_name(skdev), state, sense); 3263 skd_name(skdev), state, sense);
3286 skd_drive_disappeared(skdev); 3264 skd_drive_disappeared(skdev);
3287 skd_recover_requests(skdev, 0); 3265 skd_recover_requests(skdev, 0);
3288 skd_start_queue(skdev); 3266 blk_start_queue(skdev->queue);
3289 break; 3267 break;
3290 default: 3268 default:
3291 /* 3269 /*
@@ -3609,7 +3587,7 @@ static void skd_start_device(struct skd_device *skdev)
3609 /*start the queue so we can respond with error to requests */ 3587 /*start the queue so we can respond with error to requests */
3610 pr_debug("%s:%s:%d starting %s queue\n", 3588 pr_debug("%s:%s:%d starting %s queue\n",
3611 skdev->name, __func__, __LINE__, skdev->name); 3589 skdev->name, __func__, __LINE__, skdev->name);
3612 skd_start_queue(skdev); 3590 blk_start_queue(skdev->queue);
3613 skdev->gendisk_on = -1; 3591 skdev->gendisk_on = -1;
3614 wake_up_interruptible(&skdev->waitq); 3592 wake_up_interruptible(&skdev->waitq);
3615 break; 3593 break;
@@ -3621,7 +3599,7 @@ static void skd_start_device(struct skd_device *skdev)
3621 /*start the queue so we can respond with error to requests */ 3599 /*start the queue so we can respond with error to requests */
3622 pr_debug("%s:%s:%d starting %s queue to error-out reqs\n", 3600 pr_debug("%s:%s:%d starting %s queue to error-out reqs\n",
3623 skdev->name, __func__, __LINE__, skdev->name); 3601 skdev->name, __func__, __LINE__, skdev->name);
3624 skd_start_queue(skdev); 3602 blk_start_queue(skdev->queue);
3625 skdev->gendisk_on = -1; 3603 skdev->gendisk_on = -1;
3626 wake_up_interruptible(&skdev->waitq); 3604 wake_up_interruptible(&skdev->waitq);
3627 break; 3605 break;
@@ -3766,7 +3744,7 @@ static int skd_quiesce_dev(struct skd_device *skdev)
3766 case SKD_DRVR_STATE_BUSY_IMMINENT: 3744 case SKD_DRVR_STATE_BUSY_IMMINENT:
3767 pr_debug("%s:%s:%d stopping %s queue\n", 3745 pr_debug("%s:%s:%d stopping %s queue\n",
3768 skdev->name, __func__, __LINE__, skdev->name); 3746 skdev->name, __func__, __LINE__, skdev->name);
3769 skd_stop_queue(skdev); 3747 blk_stop_queue(skdev->queue);
3770 break; 3748 break;
3771 case SKD_DRVR_STATE_ONLINE: 3749 case SKD_DRVR_STATE_ONLINE:
3772 case SKD_DRVR_STATE_STOPPING: 3750 case SKD_DRVR_STATE_STOPPING:
@@ -3835,7 +3813,7 @@ static int skd_unquiesce_dev(struct skd_device *skdev)
3835 pr_debug("%s:%s:%d starting %s queue\n", 3813 pr_debug("%s:%s:%d starting %s queue\n",
3836 skdev->name, __func__, __LINE__, skdev->name); 3814 skdev->name, __func__, __LINE__, skdev->name);
3837 pr_info("(%s): STEC s1120 ONLINE\n", skd_name(skdev)); 3815 pr_info("(%s): STEC s1120 ONLINE\n", skd_name(skdev));
3838 skd_start_queue(skdev); 3816 blk_start_queue(skdev->queue);
3839 skdev->gendisk_on = 1; 3817 skdev->gendisk_on = 1;
3840 wake_up_interruptible(&skdev->waitq); 3818 wake_up_interruptible(&skdev->waitq);
3841 break; 3819 break;
@@ -4620,7 +4598,7 @@ static int skd_cons_disk(struct skd_device *skdev)
4620 spin_lock_irqsave(&skdev->lock, flags); 4598 spin_lock_irqsave(&skdev->lock, flags);
4621 pr_debug("%s:%s:%d stopping %s queue\n", 4599 pr_debug("%s:%s:%d stopping %s queue\n",
4622 skdev->name, __func__, __LINE__, skdev->name); 4600 skdev->name, __func__, __LINE__, skdev->name);
4623 skd_stop_queue(skdev); 4601 blk_stop_queue(skdev->queue);
4624 spin_unlock_irqrestore(&skdev->lock, flags); 4602 spin_unlock_irqrestore(&skdev->lock, flags);
4625 4603
4626err_out: 4604err_out: