提交 8cd9c297 编写于 作者: G Greg Kroah-Hartman

Staging: get cowloop to build properly

There has been some block api changes since the last
release of the cowloop code.  This patch updates the code to
properly build.

Cc: "H.J. Thomassen" <hjt@ATComputing.nl>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 dbda8325
...@@ -967,12 +967,12 @@ cowlo_request(request_queue_t *q) ...@@ -967,12 +967,12 @@ cowlo_request(request_queue_t *q)
DEBUGP(DCOW "cowloop - request function called....\n"); DEBUGP(DCOW "cowloop - request function called....\n");
while((req = elv_next_request(q)) != NULL) { while((req = blk_peek_request(q)) != NULL) {
DEBUGP(DCOW "cowloop - got next request\n"); DEBUGP(DCOW "cowloop - got next request\n");
if (! blk_fs_request(req)) { if (! blk_fs_request(req)) {
/* this is not a normal file system request */ /* this is not a normal file system request */
end_request(req, 0); __blk_end_request_cur(req, -EIO);
continue; continue;
} }
cowdev = req->rq_disk->private_data; cowdev = req->rq_disk->private_data;
...@@ -988,7 +988,7 @@ cowlo_request(request_queue_t *q) ...@@ -988,7 +988,7 @@ cowlo_request(request_queue_t *q)
*/ */
if (!cowdev->pid) { if (!cowdev->pid) {
printk(KERN_ERR"cowloop - no thread available\n"); printk(KERN_ERR"cowloop - no thread available\n");
end_request(req, 0); /* request failed */ __blk_end_request_cur(req, -EIO); /* request failed */
cowdev->iobusy = 0; cowdev->iobusy = 0;
continue; continue;
} }
...@@ -1058,7 +1058,7 @@ cowlo_daemon(struct cowloop_device *cowdev) ...@@ -1058,7 +1058,7 @@ cowlo_daemon(struct cowloop_device *cowdev)
*/ */
spin_lock_irq(&cowdev->rqlock); spin_lock_irq(&cowdev->rqlock);
end_request(cowdev->req, rv); __blk_end_request_cur(cowdev->req, rv);
cowdev->iobusy = 0; cowdev->iobusy = 0;
/* /*
...@@ -1090,8 +1090,8 @@ cowlo_do_request(struct request *req) ...@@ -1090,8 +1090,8 @@ cowlo_do_request(struct request *req)
/* /*
** calculate some variables which are needed later on ** calculate some variables which are needed later on
*/ */
len = req->current_nr_sectors << 9; len = blk_rq_cur_sectors(req) << 9;
offset = (loff_t) req->sector << 9; offset = (loff_t) blk_rq_pos(req) << 9;
DEBUGP(DCOW"cowloop - req cmd=%d offset=%lld len=%lu addr=%p\n", DEBUGP(DCOW"cowloop - req cmd=%d offset=%lld len=%lu addr=%p\n",
*(req->cmd), offset, len, req->buffer); *(req->cmd), offset, len, req->buffer);
...@@ -1918,7 +1918,7 @@ cowlo_openpair(char *rdof, char *cowf, int autorecover, int minor) ...@@ -1918,7 +1918,7 @@ cowlo_openpair(char *rdof, char *cowf, int autorecover, int minor)
return -EINVAL; return -EINVAL;
} }
blk_queue_hardsect_size(cowdev->rqueue, cowdev->blocksz); blk_queue_logical_block_size(cowdev->rqueue, cowdev->blocksz);
cowdev->gd->queue = cowdev->rqueue; cowdev->gd->queue = cowdev->rqueue;
/* /*
...@@ -2132,7 +2132,7 @@ cowlo_openrdo(struct cowloop_device *cowdev, char *rdof) ...@@ -2132,7 +2132,7 @@ cowlo_openrdo(struct cowloop_device *cowdev, char *rdof)
if (cowdev->belowq) if (cowdev->belowq)
cowdev->blocksz = cowdev->belowq->hardsect_size; cowdev->blocksz = queue_logical_block_size(cowdev->belowq);
if (cowdev->blocksz == 0) if (cowdev->blocksz == 0)
cowdev->blocksz = BLOCK_SIZE; /* default 2^10 */ cowdev->blocksz = BLOCK_SIZE; /* default 2^10 */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册