block: convert to dequeueing model (easy ones)
authorTejun Heo <tj@kernel.org>
Fri, 8 May 2009 02:54:15 +0000 (11:54 +0900)
committerJens Axboe <jens.axboe@oracle.com>
Mon, 11 May 2009 07:52:17 +0000 (09:52 +0200)
plat-omap/mailbox, floppy, viocd, mspro_block, i2o_block and
mmc/card/queue are already pretty close to dequeueing model and can be
converted with simple changes.  Convert them.

While at it,

* xen-blkfront: !fs check moved downwards to share dequeue call with
  normal path.

* mspro_block: __blk_end_request(..., blk_rq_cur_byte()) converted to
  __blk_end_request_cur()

* mmc/card/queue: loop of __blk_end_request() converted to
  __blk_end_request_all()

[ Impact: dequeue in-flight request ]

Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: Jeremy Fitzhardinge <jeremy@xensource.com>
Cc: Stephen Rothwell <sfr@canb.auug.org.au>
Cc: Alex Dubov <oakad@yahoo.com>
Cc: Markus Lidel <Markus.Lidel@shadowconnect.com>
Cc: Pierre Ossman <drzeus@drzeus.cx>
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
arch/arm/plat-omap/mailbox.c
drivers/block/floppy.c
drivers/block/xen-blkfront.c
drivers/cdrom/viocd.c
drivers/memstick/core/mspro_block.c
drivers/message/i2o/i2o_block.c
drivers/mmc/card/queue.c

index 538ba7541d3f6d2cff1fbf997b7b601ceee974b3..7a1f5c25fd17cff568e9c158dc2b96065d777b22 100644 (file)
@@ -198,6 +198,8 @@ static void mbox_tx_work(struct work_struct *work)
 
                spin_lock(q->queue_lock);
                rq = elv_next_request(q);
+               if (rq)
+                       blkdev_dequeue_request(rq);
                spin_unlock(q->queue_lock);
 
                if (!rq)
@@ -208,6 +210,9 @@ static void mbox_tx_work(struct work_struct *work)
                ret = __mbox_msg_send(mbox, tx_data->msg, tx_data->arg);
                if (ret) {
                        enable_mbox_irq(mbox, IRQ_TX);
+                       spin_lock(q->queue_lock);
+                       blk_requeue_request(q, rq);
+                       spin_unlock(q->queue_lock);
                        return;
                }
 
@@ -238,6 +243,8 @@ static void mbox_rx_work(struct work_struct *work)
        while (1) {
                spin_lock_irqsave(q->queue_lock, flags);
                rq = elv_next_request(q);
+               if (rq)
+                       blkdev_dequeue_request(rq);
                spin_unlock_irqrestore(q->queue_lock, flags);
                if (!rq)
                        break;
@@ -345,6 +352,8 @@ omap_mbox_read(struct device *dev, struct device_attribute *attr, char *buf)
        while (1) {
                spin_lock_irqsave(q->queue_lock, flags);
                rq = elv_next_request(q);
+               if (rq)
+                       blkdev_dequeue_request(rq);
                spin_unlock_irqrestore(q->queue_lock, flags);
 
                if (!rq)
index 1e27ed9208b459fde5c1bd66c372c321d4e093ba..e2c70d2085ae1e61abe001e1e319f8ac721a28a6 100644 (file)
@@ -931,7 +931,7 @@ static inline void unlock_fdc(void)
        del_timer(&fd_timeout);
        cont = NULL;
        clear_bit(0, &fdc_busy);
-       if (elv_next_request(floppy_queue))
+       if (current_req || elv_next_request(floppy_queue))
                do_fd_request(floppy_queue);
        spin_unlock_irqrestore(&floppy_lock, flags);
        wake_up(&fdc_wait);
@@ -2913,6 +2913,8 @@ static void redo_fd_request(void)
 
                        spin_lock_irq(floppy_queue->queue_lock);
                        req = elv_next_request(floppy_queue);
+                       if (req)
+                               blkdev_dequeue_request(req);
                        spin_unlock_irq(floppy_queue->queue_lock);
                        if (!req) {
                                do_floppy = NULL;
index 91fc56597e9b730363505c129e5c26f5a722bc06..66f834571b88c3a59ef4a37e7172715e19153860 100644 (file)
@@ -301,22 +301,23 @@ static void do_blkif_request(struct request_queue *rq)
 
        while ((req = elv_next_request(rq)) != NULL) {
                info = req->rq_disk->private_data;
-               if (!blk_fs_request(req)) {
-                       __blk_end_request_cur(req, -EIO);
-                       continue;
-               }
 
                if (RING_FULL(&info->ring))
                        goto wait;
 
+               blkdev_dequeue_request(req);
+
+               if (!blk_fs_request(req)) {
+                       __blk_end_request_all(req, -EIO);
+                       continue;
+               }
+
                pr_debug("do_blk_req %p: cmd %p, sec %lx, "
                         "(%u/%u) buffer:%p [%s]\n",
                         req, req->cmd, (unsigned long)blk_rq_pos(req),
                         blk_rq_cur_sectors(req), blk_rq_sectors(req),
                         req->buffer, rq_data_dir(req) ? "write" : "read");
 
-
-               blkdev_dequeue_request(req);
                if (blkif_queue_request(req)) {
                        blk_requeue_request(rq, req);
 wait:
index 6e190a93d8dfcdef433d60a651f001098d8eeb48..bbe9f08673475b4c3ac1733ae7f268f68216994f 100644 (file)
@@ -298,6 +298,8 @@ static void do_viocd_request(struct request_queue *q)
        struct request *req;
 
        while ((rwreq == 0) && ((req = elv_next_request(q)) != NULL)) {
+               blkdev_dequeue_request(req);
+
                if (!blk_fs_request(req))
                        __blk_end_request_all(req, -EIO);
                else if (send_request(req) < 0) {
index 93b2c61856566728255ec20be1e897a376c47108..58f5be8cd69e0e419a4b19cd7f918889612d5871 100644 (file)
@@ -672,8 +672,7 @@ try_again:
                                               msb->req_sg);
 
                if (!msb->seg_count) {
-                       chunk = __blk_end_request(msb->block_req, -ENOMEM,
-                                       blk_rq_cur_bytes(msb->block_req));
+                       chunk = __blk_end_request_cur(msb->block_req, -ENOMEM);
                        continue;
                }
 
@@ -711,6 +710,7 @@ try_again:
                dev_dbg(&card->dev, "issue end\n");
                return -EAGAIN;
        }
+       blkdev_dequeue_request(msb->block_req);
 
        dev_dbg(&card->dev, "trying again\n");
        chunk = 1;
@@ -825,8 +825,10 @@ static void mspro_block_submit_req(struct request_queue *q)
                return;
 
        if (msb->eject) {
-               while ((req = elv_next_request(q)) != NULL)
+               while ((req = elv_next_request(q)) != NULL) {
+                       blkdev_dequeue_request(req);
                        __blk_end_request_all(req, -ENODEV);
+               }
 
                return;
        }
index e153f5d5237de0250d2d0c307b53961a5d3da76c..8b5cbfc3ba97da40082d40b2f6ad824de542feb3 100644 (file)
@@ -916,8 +916,10 @@ static void i2o_block_request_fn(struct request_queue *q)
                                blk_stop_queue(q);
                                break;
                        }
-               } else
-                       __blk_end_request_cur(req, -EIO);
+               } else {
+                       blkdev_dequeue_request(req);
+                       __blk_end_request_all(req, -EIO);
+               }
        }
 };
 
index 7a72e75d5c674b94a66ab16073acb89e96a6d42b..4b70f1e28347cb96911ea4113d6d21f1bf684bbe 100644 (file)
@@ -54,8 +54,11 @@ static int mmc_queue_thread(void *d)
 
                spin_lock_irq(q->queue_lock);
                set_current_state(TASK_INTERRUPTIBLE);
-               if (!blk_queue_plugged(q))
+               if (!blk_queue_plugged(q)) {
                        req = elv_next_request(q);
+                       if (req)
+                               blkdev_dequeue_request(req);
+               }
                mq->req = req;
                spin_unlock_irq(q->queue_lock);
 
@@ -88,15 +91,12 @@ static void mmc_request(struct request_queue *q)
 {
        struct mmc_queue *mq = q->queuedata;
        struct request *req;
-       int ret;
 
        if (!mq) {
                printk(KERN_ERR "MMC: killing requests for dead queue\n");
                while ((req = elv_next_request(q)) != NULL) {
-                       do {
-                               ret = __blk_end_request(req, -EIO,
-                                                       blk_rq_cur_bytes(req));
-                       } while (ret);
+                       blkdev_dequeue_request(req);
+                       __blk_end_request_all(req, -EIO);
                }
                return;
        }