Skip to content

Commit e7b4c07

Browse files
committed
xen/blkback: simplify free_persistent_gnts() interface
The interface of free_persistent_gnts() can be simplified, as there is only a single caller of free_persistent_gnts() and the 2nd and 3rd parameters are easily obtainable via the ring pointer, which is passed as the first parameter anyway. Signed-off-by: Juergen Gross <jgross@suse.com> Acked-by: Roger Pau Monné <roger.pau@citrix.com> Signed-off-by: Juergen Gross <jgross@suse.com>
1 parent 656f3c1 commit e7b4c07

File tree

1 file changed

+10
-10
lines changed

1 file changed

+10
-10
lines changed

drivers/block/xen-blkback/blkback.c

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -239,16 +239,19 @@ static void put_persistent_gnt(struct xen_blkif_ring *ring,
239239
atomic_dec(&ring->persistent_gnt_in_use);
240240
}
241241

242-
static void free_persistent_gnts(struct xen_blkif_ring *ring, struct rb_root *root,
243-
unsigned int num)
242+
static void free_persistent_gnts(struct xen_blkif_ring *ring)
244243
{
244+
struct rb_root *root = &ring->persistent_gnts;
245245
struct gnttab_unmap_grant_ref unmap[BLKIF_MAX_SEGMENTS_PER_REQUEST];
246246
struct page *pages[BLKIF_MAX_SEGMENTS_PER_REQUEST];
247247
struct persistent_gnt *persistent_gnt;
248248
struct rb_node *n;
249249
int segs_to_unmap = 0;
250250
struct gntab_unmap_queue_data unmap_data;
251251

252+
if (RB_EMPTY_ROOT(root))
253+
return;
254+
252255
unmap_data.pages = pages;
253256
unmap_data.unmap_ops = unmap;
254257
unmap_data.kunmap_ops = NULL;
@@ -277,9 +280,11 @@ static void free_persistent_gnts(struct xen_blkif_ring *ring, struct rb_root *ro
277280

278281
rb_erase(&persistent_gnt->node, root);
279282
kfree(persistent_gnt);
280-
num--;
283+
ring->persistent_gnt_c--;
281284
}
282-
BUG_ON(num != 0);
285+
286+
BUG_ON(!RB_EMPTY_ROOT(&ring->persistent_gnts));
287+
BUG_ON(ring->persistent_gnt_c != 0);
283288
}
284289

285290
void xen_blkbk_unmap_purged_grants(struct work_struct *work)
@@ -631,12 +636,7 @@ int xen_blkif_schedule(void *arg)
631636
void xen_blkbk_free_caches(struct xen_blkif_ring *ring)
632637
{
633638
/* Free all persistent grant pages */
634-
if (!RB_EMPTY_ROOT(&ring->persistent_gnts))
635-
free_persistent_gnts(ring, &ring->persistent_gnts,
636-
ring->persistent_gnt_c);
637-
638-
BUG_ON(!RB_EMPTY_ROOT(&ring->persistent_gnts));
639-
ring->persistent_gnt_c = 0;
639+
free_persistent_gnts(ring);
640640

641641
/* Since we are shutting down remove all pages from the buffer */
642642
gnttab_page_cache_shrink(&ring->free_pages, 0 /* All */);

0 commit comments

Comments
 (0)