mg_disk: fix queue hang / infinite retry on !fs requests
authorTejun Heo <tj@kernel.org>
Fri, 8 May 2009 02:54:00 +0000 (11:54 +0900)
committerJens Axboe <jens.axboe@oracle.com>
Mon, 11 May 2009 07:52:14 +0000 (09:52 +0200)
Both request functions in mg_disk simply return when they encounter a
!fs request, which means the request will never be cleared from the
queue causing queue hang and indefinite retry of the request.  Fix it.

While at it, flatten condition checks and add unlikely to !fs tests.

[ Impact: fix possible queue hang / infinite retry of !fs requests ]

Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: unsik Kim <donari75@gmail.com>
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
drivers/block/mg_disk.c

index 826c3492b9fe2b9bb3e6aee2a309052373754717..be323880f24ab914ebaedcd2383afbe1efc1b1d9 100644 (file)
@@ -672,16 +672,16 @@ static void mg_request_poll(struct request_queue *q)
 
        while ((req = elv_next_request(q)) != NULL) {
                host = req->rq_disk->private_data;
-               if (blk_fs_request(req)) {
-                       switch (rq_data_dir(req)) {
-                       case READ:
-                               mg_read(req);
-                               break;
-                       case WRITE:
-                               mg_write(req);
-                               break;
-                       }
+
+               if (unlikely(!blk_fs_request(req))) {
+                       __blk_end_request_cur(req, -EIO);
+                       continue;
                }
+
+               if (rq_data_dir(req) == READ)
+                       mg_read(req);
+               else
+                       mg_write(req);
        }
 }
 
@@ -766,8 +766,10 @@ static void mg_request(struct request_queue *q)
                        continue;
                }
 
-               if (!blk_fs_request(req))
-                       return;
+               if (unlikely(!blk_fs_request(req))) {
+                       __blk_end_request_cur(req, -EIO);
+                       continue;
+               }
 
                if (!mg_issue_req(req, host, sect_num, sect_cnt))
                        return;