xen/netback: free already allocated memory on failure in xen_netbk_get_requests
Signed-off-by: Ian Campbell <ian.campbell@citrix.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7d5145d8eb
commit
4cc7c1cb7b
@ -978,7 +978,7 @@ static struct gnttab_copy *xen_netbk_get_requests(struct xen_netbk *netbk,
|
|||||||
pending_idx = netbk->pending_ring[index];
|
pending_idx = netbk->pending_ring[index];
|
||||||
page = xen_netbk_alloc_page(netbk, skb, pending_idx);
|
page = xen_netbk_alloc_page(netbk, skb, pending_idx);
|
||||||
if (!page)
|
if (!page)
|
||||||
return NULL;
|
goto err;
|
||||||
|
|
||||||
gop->source.u.ref = txp->gref;
|
gop->source.u.ref = txp->gref;
|
||||||
gop->source.domid = vif->domid;
|
gop->source.domid = vif->domid;
|
||||||
@ -1000,6 +1000,17 @@ static struct gnttab_copy *xen_netbk_get_requests(struct xen_netbk *netbk,
|
|||||||
}
|
}
|
||||||
|
|
||||||
return gop;
|
return gop;
|
||||||
|
err:
|
||||||
|
/* Unwind, freeing all pages and sending error responses. */
|
||||||
|
while (i-- > start) {
|
||||||
|
xen_netbk_idx_release(netbk, frag_get_pending_idx(&frags[i]),
|
||||||
|
XEN_NETIF_RSP_ERROR);
|
||||||
|
}
|
||||||
|
/* The head too, if necessary. */
|
||||||
|
if (start)
|
||||||
|
xen_netbk_idx_release(netbk, pending_idx, XEN_NETIF_RSP_ERROR);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xen_netbk_tx_check_gop(struct xen_netbk *netbk,
|
static int xen_netbk_tx_check_gop(struct xen_netbk *netbk,
|
||||||
|
Loading…
Reference in New Issue
Block a user