diff options
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/xen-blkback/blkback.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/drivers/block/xen-blkback/blkback.c b/drivers/block/xen-blkback/blkback.c index 4b97b86da926..da18046d0e07 100644 --- a/drivers/block/xen-blkback/blkback.c +++ b/drivers/block/xen-blkback/blkback.c | |||
@@ -285,8 +285,7 @@ static void free_persistent_gnts(struct xen_blkif *blkif, struct rb_root *root, | |||
285 | 285 | ||
286 | if (++segs_to_unmap == BLKIF_MAX_SEGMENTS_PER_REQUEST || | 286 | if (++segs_to_unmap == BLKIF_MAX_SEGMENTS_PER_REQUEST || |
287 | !rb_next(&persistent_gnt->node)) { | 287 | !rb_next(&persistent_gnt->node)) { |
288 | ret = gnttab_unmap_refs(unmap, NULL, pages, | 288 | ret = gnttab_unmap_refs(unmap, pages, segs_to_unmap); |
289 | segs_to_unmap); | ||
290 | BUG_ON(ret); | 289 | BUG_ON(ret); |
291 | put_free_pages(blkif, pages, segs_to_unmap); | 290 | put_free_pages(blkif, pages, segs_to_unmap); |
292 | segs_to_unmap = 0; | 291 | segs_to_unmap = 0; |
@@ -321,8 +320,7 @@ static void unmap_purged_grants(struct work_struct *work) | |||
321 | pages[segs_to_unmap] = persistent_gnt->page; | 320 | pages[segs_to_unmap] = persistent_gnt->page; |
322 | 321 | ||
323 | if (++segs_to_unmap == BLKIF_MAX_SEGMENTS_PER_REQUEST) { | 322 | if (++segs_to_unmap == BLKIF_MAX_SEGMENTS_PER_REQUEST) { |
324 | ret = gnttab_unmap_refs(unmap, NULL, pages, | 323 | ret = gnttab_unmap_refs(unmap, pages, segs_to_unmap); |
325 | segs_to_unmap); | ||
326 | BUG_ON(ret); | 324 | BUG_ON(ret); |
327 | put_free_pages(blkif, pages, segs_to_unmap); | 325 | put_free_pages(blkif, pages, segs_to_unmap); |
328 | segs_to_unmap = 0; | 326 | segs_to_unmap = 0; |
@@ -330,7 +328,7 @@ static void unmap_purged_grants(struct work_struct *work) | |||
330 | kfree(persistent_gnt); | 328 | kfree(persistent_gnt); |
331 | } | 329 | } |
332 | if (segs_to_unmap > 0) { | 330 | if (segs_to_unmap > 0) { |
333 | ret = gnttab_unmap_refs(unmap, NULL, pages, segs_to_unmap); | 331 | ret = gnttab_unmap_refs(unmap, pages, segs_to_unmap); |
334 | BUG_ON(ret); | 332 | BUG_ON(ret); |
335 | put_free_pages(blkif, pages, segs_to_unmap); | 333 | put_free_pages(blkif, pages, segs_to_unmap); |
336 | } | 334 | } |
@@ -670,15 +668,14 @@ static void xen_blkbk_unmap(struct xen_blkif *blkif, | |||
670 | GNTMAP_host_map, pages[i]->handle); | 668 | GNTMAP_host_map, pages[i]->handle); |
671 | pages[i]->handle = BLKBACK_INVALID_HANDLE; | 669 | pages[i]->handle = BLKBACK_INVALID_HANDLE; |
672 | if (++invcount == BLKIF_MAX_SEGMENTS_PER_REQUEST) { | 670 | if (++invcount == BLKIF_MAX_SEGMENTS_PER_REQUEST) { |
673 | ret = gnttab_unmap_refs(unmap, NULL, unmap_pages, | 671 | ret = gnttab_unmap_refs(unmap, unmap_pages, invcount); |
674 | invcount); | ||
675 | BUG_ON(ret); | 672 | BUG_ON(ret); |
676 | put_free_pages(blkif, unmap_pages, invcount); | 673 | put_free_pages(blkif, unmap_pages, invcount); |
677 | invcount = 0; | 674 | invcount = 0; |
678 | } | 675 | } |
679 | } | 676 | } |
680 | if (invcount) { | 677 | if (invcount) { |
681 | ret = gnttab_unmap_refs(unmap, NULL, unmap_pages, invcount); | 678 | ret = gnttab_unmap_refs(unmap, unmap_pages, invcount); |
682 | BUG_ON(ret); | 679 | BUG_ON(ret); |
683 | put_free_pages(blkif, unmap_pages, invcount); | 680 | put_free_pages(blkif, unmap_pages, invcount); |
684 | } | 681 | } |
@@ -740,7 +737,7 @@ again: | |||
740 | } | 737 | } |
741 | 738 | ||
742 | if (segs_to_map) { | 739 | if (segs_to_map) { |
743 | ret = gnttab_map_refs(map, NULL, pages_to_gnt, segs_to_map); | 740 | ret = gnttab_map_refs(map, pages_to_gnt, segs_to_map); |
744 | BUG_ON(ret); | 741 | BUG_ON(ret); |
745 | } | 742 | } |
746 | 743 | ||