aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block/xen-blkfront.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/block/xen-blkfront.c')
-rw-r--r--drivers/block/xen-blkfront.c14
1 files changed, 6 insertions, 8 deletions
diff --git a/drivers/block/xen-blkfront.c b/drivers/block/xen-blkfront.c
index 3a318d8576c5..31c8a643d109 100644
--- a/drivers/block/xen-blkfront.c
+++ b/drivers/block/xen-blkfront.c
@@ -65,7 +65,7 @@ enum blkif_state {
65 65
66struct blk_shadow { 66struct blk_shadow {
67 struct blkif_request req; 67 struct blkif_request req;
68 unsigned long request; 68 struct request *request;
69 unsigned long frame[BLKIF_MAX_SEGMENTS_PER_REQUEST]; 69 unsigned long frame[BLKIF_MAX_SEGMENTS_PER_REQUEST];
70}; 70};
71 71
@@ -136,7 +136,7 @@ static void add_id_to_freelist(struct blkfront_info *info,
136 unsigned long id) 136 unsigned long id)
137{ 137{
138 info->shadow[id].req.id = info->shadow_free; 138 info->shadow[id].req.id = info->shadow_free;
139 info->shadow[id].request = 0; 139 info->shadow[id].request = NULL;
140 info->shadow_free = id; 140 info->shadow_free = id;
141} 141}
142 142
@@ -278,7 +278,7 @@ static int blkif_queue_request(struct request *req)
278 /* Fill out a communications ring structure. */ 278 /* Fill out a communications ring structure. */
279 ring_req = RING_GET_REQUEST(&info->ring, info->ring.req_prod_pvt); 279 ring_req = RING_GET_REQUEST(&info->ring, info->ring.req_prod_pvt);
280 id = get_id_from_freelist(info); 280 id = get_id_from_freelist(info);
281 info->shadow[id].request = (unsigned long)req; 281 info->shadow[id].request = req;
282 282
283 ring_req->id = id; 283 ring_req->id = id;
284 ring_req->sector_number = (blkif_sector_t)blk_rq_pos(req); 284 ring_req->sector_number = (blkif_sector_t)blk_rq_pos(req);
@@ -633,7 +633,7 @@ static irqreturn_t blkif_interrupt(int irq, void *dev_id)
633 633
634 bret = RING_GET_RESPONSE(&info->ring, i); 634 bret = RING_GET_RESPONSE(&info->ring, i);
635 id = bret->id; 635 id = bret->id;
636 req = (struct request *)info->shadow[id].request; 636 req = info->shadow[id].request;
637 637
638 blkif_completion(&info->shadow[id]); 638 blkif_completion(&info->shadow[id]);
639 639
@@ -898,7 +898,7 @@ static int blkif_recover(struct blkfront_info *info)
898 /* Stage 3: Find pending requests and requeue them. */ 898 /* Stage 3: Find pending requests and requeue them. */
899 for (i = 0; i < BLK_RING_SIZE; i++) { 899 for (i = 0; i < BLK_RING_SIZE; i++) {
900 /* Not in use? */ 900 /* Not in use? */
901 if (copy[i].request == 0) 901 if (!copy[i].request)
902 continue; 902 continue;
903 903
904 /* Grab a request slot and copy shadow state into it. */ 904 /* Grab a request slot and copy shadow state into it. */
@@ -915,9 +915,7 @@ static int blkif_recover(struct blkfront_info *info)
915 req->seg[j].gref, 915 req->seg[j].gref,
916 info->xbdev->otherend_id, 916 info->xbdev->otherend_id,
917 pfn_to_mfn(info->shadow[req->id].frame[j]), 917 pfn_to_mfn(info->shadow[req->id].frame[j]),
918 rq_data_dir( 918 rq_data_dir(info->shadow[req->id].request));
919 (struct request *)
920 info->shadow[req->id].request));
921 info->shadow[req->id].req = *req; 919 info->shadow[req->id].req = *req;
922 920
923 info->ring.req_prod_pvt++; 921 info->ring.req_prod_pvt++;