xen: remove other open-coded use of libxengnttab
Now that helpers are available in xen_backend, use them throughout all Xen PV backends. Signed-off-by: Paul Durrant <paul.durrant@citrix.com> Acked-by: Anthony Perard <anthony.perard@citrix.com> Signed-off-by: Stefano Stabellini <sstabellini@kernel.org>
This commit is contained in:
parent
5ee1d99913
commit
58560f2ae7
@ -331,12 +331,12 @@ static int xen_9pfs_free(struct XenDevice *xendev)
|
|||||||
|
|
||||||
for (i = 0; i < xen_9pdev->num_rings; i++) {
|
for (i = 0; i < xen_9pdev->num_rings; i++) {
|
||||||
if (xen_9pdev->rings[i].data != NULL) {
|
if (xen_9pdev->rings[i].data != NULL) {
|
||||||
xengnttab_unmap(xen_9pdev->xendev.gnttabdev,
|
xen_be_unmap_grant_refs(&xen_9pdev->xendev,
|
||||||
xen_9pdev->rings[i].data,
|
xen_9pdev->rings[i].data,
|
||||||
(1 << xen_9pdev->rings[i].ring_order));
|
(1 << xen_9pdev->rings[i].ring_order));
|
||||||
}
|
}
|
||||||
if (xen_9pdev->rings[i].intf != NULL) {
|
if (xen_9pdev->rings[i].intf != NULL) {
|
||||||
xengnttab_unmap(xen_9pdev->xendev.gnttabdev,
|
xen_be_unmap_grant_refs(&xen_9pdev->xendev,
|
||||||
xen_9pdev->rings[i].intf,
|
xen_9pdev->rings[i].intf,
|
||||||
1);
|
1);
|
||||||
}
|
}
|
||||||
@ -390,9 +390,8 @@ static int xen_9pfs_connect(struct XenDevice *xendev)
|
|||||||
}
|
}
|
||||||
g_free(str);
|
g_free(str);
|
||||||
|
|
||||||
xen_9pdev->rings[i].intf = xengnttab_map_grant_ref(
|
xen_9pdev->rings[i].intf =
|
||||||
xen_9pdev->xendev.gnttabdev,
|
xen_be_map_grant_ref(&xen_9pdev->xendev,
|
||||||
xen_9pdev->xendev.dom,
|
|
||||||
xen_9pdev->rings[i].ref,
|
xen_9pdev->rings[i].ref,
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
if (!xen_9pdev->rings[i].intf) {
|
if (!xen_9pdev->rings[i].intf) {
|
||||||
@ -403,11 +402,10 @@ static int xen_9pfs_connect(struct XenDevice *xendev)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
xen_9pdev->rings[i].ring_order = ring_order;
|
xen_9pdev->rings[i].ring_order = ring_order;
|
||||||
xen_9pdev->rings[i].data = xengnttab_map_domain_grant_refs(
|
xen_9pdev->rings[i].data =
|
||||||
xen_9pdev->xendev.gnttabdev,
|
xen_be_map_grant_refs(&xen_9pdev->xendev,
|
||||||
(1 << ring_order),
|
|
||||||
xen_9pdev->xendev.dom,
|
|
||||||
xen_9pdev->rings[i].intf->ref,
|
xen_9pdev->rings[i].intf->ref,
|
||||||
|
(1 << ring_order),
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
if (!xen_9pdev->rings[i].data) {
|
if (!xen_9pdev->rings[i].data) {
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -236,8 +236,7 @@ static int con_initialise(struct XenDevice *xendev)
|
|||||||
PROT_READ | PROT_WRITE,
|
PROT_READ | PROT_WRITE,
|
||||||
1, &mfn, NULL);
|
1, &mfn, NULL);
|
||||||
} else {
|
} else {
|
||||||
con->sring = xengnttab_map_grant_ref(xendev->gnttabdev, con->xendev.dom,
|
con->sring = xen_be_map_grant_ref(xendev, con->ring_ref,
|
||||||
con->ring_ref,
|
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
}
|
}
|
||||||
if (!con->sring)
|
if (!con->sring)
|
||||||
@ -267,7 +266,7 @@ static void con_disconnect(struct XenDevice *xendev)
|
|||||||
if (!xendev->dev) {
|
if (!xendev->dev) {
|
||||||
xenforeignmemory_unmap(xen_fmem, con->sring, 1);
|
xenforeignmemory_unmap(xen_fmem, con->sring, 1);
|
||||||
} else {
|
} else {
|
||||||
xengnttab_unmap(xendev->gnttabdev, con->sring, 1);
|
xen_be_unmap_grant_ref(xendev, con->sring);
|
||||||
}
|
}
|
||||||
con->sring = NULL;
|
con->sring = NULL;
|
||||||
}
|
}
|
||||||
|
@ -160,9 +160,8 @@ static void net_tx_packets(struct XenNetDev *netdev)
|
|||||||
(txreq.flags & NETTXF_more_data) ? " more_data" : "",
|
(txreq.flags & NETTXF_more_data) ? " more_data" : "",
|
||||||
(txreq.flags & NETTXF_extra_info) ? " extra_info" : "");
|
(txreq.flags & NETTXF_extra_info) ? " extra_info" : "");
|
||||||
|
|
||||||
page = xengnttab_map_grant_ref(netdev->xendev.gnttabdev,
|
page = xen_be_map_grant_ref(&netdev->xendev, txreq.gref,
|
||||||
netdev->xendev.dom,
|
PROT_READ);
|
||||||
txreq.gref, PROT_READ);
|
|
||||||
if (page == NULL) {
|
if (page == NULL) {
|
||||||
xen_pv_printf(&netdev->xendev, 0,
|
xen_pv_printf(&netdev->xendev, 0,
|
||||||
"error: tx gref dereference failed (%d)\n",
|
"error: tx gref dereference failed (%d)\n",
|
||||||
@ -183,7 +182,7 @@ static void net_tx_packets(struct XenNetDev *netdev)
|
|||||||
qemu_send_packet(qemu_get_queue(netdev->nic),
|
qemu_send_packet(qemu_get_queue(netdev->nic),
|
||||||
page + txreq.offset, txreq.size);
|
page + txreq.offset, txreq.size);
|
||||||
}
|
}
|
||||||
xengnttab_unmap(netdev->xendev.gnttabdev, page, 1);
|
xen_be_unmap_grant_ref(&netdev->xendev, page);
|
||||||
net_tx_response(netdev, &txreq, NETIF_RSP_OKAY);
|
net_tx_response(netdev, &txreq, NETIF_RSP_OKAY);
|
||||||
}
|
}
|
||||||
if (!netdev->tx_work) {
|
if (!netdev->tx_work) {
|
||||||
@ -254,9 +253,7 @@ static ssize_t net_rx_packet(NetClientState *nc, const uint8_t *buf, size_t size
|
|||||||
memcpy(&rxreq, RING_GET_REQUEST(&netdev->rx_ring, rc), sizeof(rxreq));
|
memcpy(&rxreq, RING_GET_REQUEST(&netdev->rx_ring, rc), sizeof(rxreq));
|
||||||
netdev->rx_ring.req_cons = ++rc;
|
netdev->rx_ring.req_cons = ++rc;
|
||||||
|
|
||||||
page = xengnttab_map_grant_ref(netdev->xendev.gnttabdev,
|
page = xen_be_map_grant_ref(&netdev->xendev, rxreq.gref, PROT_WRITE);
|
||||||
netdev->xendev.dom,
|
|
||||||
rxreq.gref, PROT_WRITE);
|
|
||||||
if (page == NULL) {
|
if (page == NULL) {
|
||||||
xen_pv_printf(&netdev->xendev, 0,
|
xen_pv_printf(&netdev->xendev, 0,
|
||||||
"error: rx gref dereference failed (%d)\n",
|
"error: rx gref dereference failed (%d)\n",
|
||||||
@ -265,7 +262,7 @@ static ssize_t net_rx_packet(NetClientState *nc, const uint8_t *buf, size_t size
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
memcpy(page + NET_IP_ALIGN, buf, size);
|
memcpy(page + NET_IP_ALIGN, buf, size);
|
||||||
xengnttab_unmap(netdev->xendev.gnttabdev, page, 1);
|
xen_be_unmap_grant_ref(&netdev->xendev, page);
|
||||||
net_rx_response(netdev, &rxreq, NETIF_RSP_OKAY, NET_IP_ALIGN, size, 0);
|
net_rx_response(netdev, &rxreq, NETIF_RSP_OKAY, NET_IP_ALIGN, size, 0);
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
@ -338,19 +335,17 @@ static int net_connect(struct XenDevice *xendev)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
netdev->txs = xengnttab_map_grant_ref(netdev->xendev.gnttabdev,
|
netdev->txs = xen_be_map_grant_ref(&netdev->xendev,
|
||||||
netdev->xendev.dom,
|
|
||||||
netdev->tx_ring_ref,
|
netdev->tx_ring_ref,
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
if (!netdev->txs) {
|
if (!netdev->txs) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
netdev->rxs = xengnttab_map_grant_ref(netdev->xendev.gnttabdev,
|
netdev->rxs = xen_be_map_grant_ref(&netdev->xendev,
|
||||||
netdev->xendev.dom,
|
|
||||||
netdev->rx_ring_ref,
|
netdev->rx_ring_ref,
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
if (!netdev->rxs) {
|
if (!netdev->rxs) {
|
||||||
xengnttab_unmap(netdev->xendev.gnttabdev, netdev->txs, 1);
|
xen_be_unmap_grant_ref(&netdev->xendev, netdev->txs);
|
||||||
netdev->txs = NULL;
|
netdev->txs = NULL;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -375,11 +370,11 @@ static void net_disconnect(struct XenDevice *xendev)
|
|||||||
xen_pv_unbind_evtchn(&netdev->xendev);
|
xen_pv_unbind_evtchn(&netdev->xendev);
|
||||||
|
|
||||||
if (netdev->txs) {
|
if (netdev->txs) {
|
||||||
xengnttab_unmap(netdev->xendev.gnttabdev, netdev->txs, 1);
|
xen_be_unmap_grant_ref(&netdev->xendev, netdev->txs);
|
||||||
netdev->txs = NULL;
|
netdev->txs = NULL;
|
||||||
}
|
}
|
||||||
if (netdev->rxs) {
|
if (netdev->rxs) {
|
||||||
xengnttab_unmap(netdev->xendev.gnttabdev, netdev->rxs, 1);
|
xen_be_unmap_grant_ref(&netdev->xendev, netdev->rxs);
|
||||||
netdev->rxs = NULL;
|
netdev->rxs = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -173,8 +173,9 @@ static int usbback_gnttab_map(struct usbback_req *usbback_req)
|
|||||||
for (i = 0; i < usbback_req->nr_buffer_segs; i++) {
|
for (i = 0; i < usbback_req->nr_buffer_segs; i++) {
|
||||||
ref[i] = usbback_req->req.seg[i].gref;
|
ref[i] = usbback_req->req.seg[i].gref;
|
||||||
}
|
}
|
||||||
usbback_req->buffer = xengnttab_map_domain_grant_refs(xendev->gnttabdev,
|
usbback_req->buffer =
|
||||||
usbback_req->nr_buffer_segs, xendev->dom, ref, prot);
|
xen_be_map_grant_refs(xendev, ref, usbback_req->nr_buffer_segs,
|
||||||
|
prot);
|
||||||
|
|
||||||
if (!usbback_req->buffer) {
|
if (!usbback_req->buffer) {
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
@ -206,8 +207,9 @@ static int usbback_gnttab_map(struct usbback_req *usbback_req)
|
|||||||
for (i = 0; i < usbback_req->nr_extra_segs; i++) {
|
for (i = 0; i < usbback_req->nr_extra_segs; i++) {
|
||||||
ref[i] = usbback_req->req.seg[i + usbback_req->req.nr_buffer_segs].gref;
|
ref[i] = usbback_req->req.seg[i + usbback_req->req.nr_buffer_segs].gref;
|
||||||
}
|
}
|
||||||
usbback_req->isoc_buffer = xengnttab_map_domain_grant_refs(
|
usbback_req->isoc_buffer =
|
||||||
xendev->gnttabdev, usbback_req->nr_extra_segs, xendev->dom, ref, prot);
|
xen_be_map_grant_refs(xendev, ref, usbback_req->nr_extra_segs,
|
||||||
|
prot);
|
||||||
|
|
||||||
if (!usbback_req->isoc_buffer) {
|
if (!usbback_req->isoc_buffer) {
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
@ -291,13 +293,13 @@ static void usbback_do_response(struct usbback_req *usbback_req, int32_t status,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (usbback_req->buffer) {
|
if (usbback_req->buffer) {
|
||||||
xengnttab_unmap(xendev->gnttabdev, usbback_req->buffer,
|
xen_be_unmap_grant_refs(xendev, usbback_req->buffer,
|
||||||
usbback_req->nr_buffer_segs);
|
usbback_req->nr_buffer_segs);
|
||||||
usbback_req->buffer = NULL;
|
usbback_req->buffer = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (usbback_req->isoc_buffer) {
|
if (usbback_req->isoc_buffer) {
|
||||||
xengnttab_unmap(xendev->gnttabdev, usbback_req->isoc_buffer,
|
xen_be_unmap_grant_refs(xendev, usbback_req->isoc_buffer,
|
||||||
usbback_req->nr_extra_segs);
|
usbback_req->nr_extra_segs);
|
||||||
usbback_req->isoc_buffer = NULL;
|
usbback_req->isoc_buffer = NULL;
|
||||||
}
|
}
|
||||||
@ -834,11 +836,11 @@ static void usbback_disconnect(struct XenDevice *xendev)
|
|||||||
xen_pv_unbind_evtchn(xendev);
|
xen_pv_unbind_evtchn(xendev);
|
||||||
|
|
||||||
if (usbif->urb_sring) {
|
if (usbif->urb_sring) {
|
||||||
xengnttab_unmap(xendev->gnttabdev, usbif->urb_sring, 1);
|
xen_be_unmap_grant_ref(xendev, usbif->urb_sring);
|
||||||
usbif->urb_sring = NULL;
|
usbif->urb_sring = NULL;
|
||||||
}
|
}
|
||||||
if (usbif->conn_sring) {
|
if (usbif->conn_sring) {
|
||||||
xengnttab_unmap(xendev->gnttabdev, usbif->conn_sring, 1);
|
xen_be_unmap_grant_ref(xendev, usbif->conn_sring);
|
||||||
usbif->conn_sring = NULL;
|
usbif->conn_sring = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -877,11 +879,9 @@ static int usbback_connect(struct XenDevice *xendev)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
usbif->urb_sring = xengnttab_map_grant_ref(xendev->gnttabdev, xendev->dom,
|
usbif->urb_sring = xen_be_map_grant_ref(xendev, urb_ring_ref,
|
||||||
urb_ring_ref,
|
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
usbif->conn_sring = xengnttab_map_grant_ref(xendev->gnttabdev, xendev->dom,
|
usbif->conn_sring = xen_be_map_grant_ref(xendev, conn_ring_ref,
|
||||||
conn_ring_ref,
|
|
||||||
PROT_READ | PROT_WRITE);
|
PROT_READ | PROT_WRITE);
|
||||||
if (!usbif->urb_sring || !usbif->conn_sring) {
|
if (!usbif->urb_sring || !usbif->conn_sring) {
|
||||||
xen_pv_printf(xendev, 0, "error mapping rings\n");
|
xen_pv_printf(xendev, 0, "error mapping rings\n");
|
||||||
@ -1024,10 +1024,7 @@ static void usbback_alloc(struct XenDevice *xendev)
|
|||||||
|
|
||||||
/* max_grants: for each request and for the rings (request and connect). */
|
/* max_grants: for each request and for the rings (request and connect). */
|
||||||
max_grants = USBIF_MAX_SEGMENTS_PER_REQUEST * USB_URB_RING_SIZE + 2;
|
max_grants = USBIF_MAX_SEGMENTS_PER_REQUEST * USB_URB_RING_SIZE + 2;
|
||||||
if (xengnttab_set_max_grants(xendev->gnttabdev, max_grants) < 0) {
|
xen_be_set_max_grant_refs(xendev, max_grants);
|
||||||
xen_pv_printf(xendev, 0, "xengnttab_set_max_grants failed: %s\n",
|
|
||||||
strerror(errno));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int usbback_free(struct XenDevice *xendev)
|
static int usbback_free(struct XenDevice *xendev)
|
||||||
|
Loading…
Reference in New Issue
Block a user