Commit 247643f8 authored by Eugenio Pérez's avatar Eugenio Pérez Committed by Michael S. Tsirkin

vhost: Create accessors for virtqueues private_data

Signed-off-by: default avatarEugenio Pérez <eperezma@redhat.com>
Link: https://lore.kernel.org/r/20200331192804.6019-2-eperezma@redhat.comSigned-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
parent 21818ed0
...@@ -424,7 +424,7 @@ static void vhost_net_disable_vq(struct vhost_net *n, ...@@ -424,7 +424,7 @@ static void vhost_net_disable_vq(struct vhost_net *n,
struct vhost_net_virtqueue *nvq = struct vhost_net_virtqueue *nvq =
container_of(vq, struct vhost_net_virtqueue, vq); container_of(vq, struct vhost_net_virtqueue, vq);
struct vhost_poll *poll = n->poll + (nvq - n->vqs); struct vhost_poll *poll = n->poll + (nvq - n->vqs);
if (!vq->private_data) if (!vhost_vq_get_backend(vq))
return; return;
vhost_poll_stop(poll); vhost_poll_stop(poll);
} }
...@@ -437,7 +437,7 @@ static int vhost_net_enable_vq(struct vhost_net *n, ...@@ -437,7 +437,7 @@ static int vhost_net_enable_vq(struct vhost_net *n,
struct vhost_poll *poll = n->poll + (nvq - n->vqs); struct vhost_poll *poll = n->poll + (nvq - n->vqs);
struct socket *sock; struct socket *sock;
sock = vq->private_data; sock = vhost_vq_get_backend(vq);
if (!sock) if (!sock)
return 0; return 0;
...@@ -524,7 +524,7 @@ static void vhost_net_busy_poll(struct vhost_net *net, ...@@ -524,7 +524,7 @@ static void vhost_net_busy_poll(struct vhost_net *net,
return; return;
vhost_disable_notify(&net->dev, vq); vhost_disable_notify(&net->dev, vq);
sock = rvq->private_data; sock = vhost_vq_get_backend(rvq);
busyloop_timeout = poll_rx ? rvq->busyloop_timeout: busyloop_timeout = poll_rx ? rvq->busyloop_timeout:
tvq->busyloop_timeout; tvq->busyloop_timeout;
...@@ -570,8 +570,10 @@ static int vhost_net_tx_get_vq_desc(struct vhost_net *net, ...@@ -570,8 +570,10 @@ static int vhost_net_tx_get_vq_desc(struct vhost_net *net,
if (r == tvq->num && tvq->busyloop_timeout) { if (r == tvq->num && tvq->busyloop_timeout) {
/* Flush batched packets first */ /* Flush batched packets first */
if (!vhost_sock_zcopy(tvq->private_data)) if (!vhost_sock_zcopy(vhost_vq_get_backend(tvq)))
vhost_tx_batch(net, tnvq, tvq->private_data, msghdr); vhost_tx_batch(net, tnvq,
vhost_vq_get_backend(tvq),
msghdr);
vhost_net_busy_poll(net, rvq, tvq, busyloop_intr, false); vhost_net_busy_poll(net, rvq, tvq, busyloop_intr, false);
...@@ -685,7 +687,7 @@ static int vhost_net_build_xdp(struct vhost_net_virtqueue *nvq, ...@@ -685,7 +687,7 @@ static int vhost_net_build_xdp(struct vhost_net_virtqueue *nvq,
struct vhost_virtqueue *vq = &nvq->vq; struct vhost_virtqueue *vq = &nvq->vq;
struct vhost_net *net = container_of(vq->dev, struct vhost_net, struct vhost_net *net = container_of(vq->dev, struct vhost_net,
dev); dev);
struct socket *sock = vq->private_data; struct socket *sock = vhost_vq_get_backend(vq);
struct page_frag *alloc_frag = &net->page_frag; struct page_frag *alloc_frag = &net->page_frag;
struct virtio_net_hdr *gso; struct virtio_net_hdr *gso;
struct xdp_buff *xdp = &nvq->xdp[nvq->batched_xdp]; struct xdp_buff *xdp = &nvq->xdp[nvq->batched_xdp];
...@@ -952,7 +954,7 @@ static void handle_tx(struct vhost_net *net) ...@@ -952,7 +954,7 @@ static void handle_tx(struct vhost_net *net)
struct socket *sock; struct socket *sock;
mutex_lock_nested(&vq->mutex, VHOST_NET_VQ_TX); mutex_lock_nested(&vq->mutex, VHOST_NET_VQ_TX);
sock = vq->private_data; sock = vhost_vq_get_backend(vq);
if (!sock) if (!sock)
goto out; goto out;
...@@ -1121,7 +1123,7 @@ static void handle_rx(struct vhost_net *net) ...@@ -1121,7 +1123,7 @@ static void handle_rx(struct vhost_net *net)
int recv_pkts = 0; int recv_pkts = 0;
mutex_lock_nested(&vq->mutex, VHOST_NET_VQ_RX); mutex_lock_nested(&vq->mutex, VHOST_NET_VQ_RX);
sock = vq->private_data; sock = vhost_vq_get_backend(vq);
if (!sock) if (!sock)
goto out; goto out;
...@@ -1345,9 +1347,9 @@ static struct socket *vhost_net_stop_vq(struct vhost_net *n, ...@@ -1345,9 +1347,9 @@ static struct socket *vhost_net_stop_vq(struct vhost_net *n,
container_of(vq, struct vhost_net_virtqueue, vq); container_of(vq, struct vhost_net_virtqueue, vq);
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
sock = vq->private_data; sock = vhost_vq_get_backend(vq);
vhost_net_disable_vq(n, vq); vhost_net_disable_vq(n, vq);
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
vhost_net_buf_unproduce(nvq); vhost_net_buf_unproduce(nvq);
nvq->rx_ring = NULL; nvq->rx_ring = NULL;
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
...@@ -1521,7 +1523,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd) ...@@ -1521,7 +1523,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd)
} }
/* start polling new socket */ /* start polling new socket */
oldsock = vq->private_data; oldsock = vhost_vq_get_backend(vq);
if (sock != oldsock) { if (sock != oldsock) {
ubufs = vhost_net_ubuf_alloc(vq, ubufs = vhost_net_ubuf_alloc(vq,
sock && vhost_sock_zcopy(sock)); sock && vhost_sock_zcopy(sock));
...@@ -1531,7 +1533,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd) ...@@ -1531,7 +1533,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd)
} }
vhost_net_disable_vq(n, vq); vhost_net_disable_vq(n, vq);
vq->private_data = sock; vhost_vq_set_backend(vq, sock);
vhost_net_buf_unproduce(nvq); vhost_net_buf_unproduce(nvq);
r = vhost_vq_init_access(vq); r = vhost_vq_init_access(vq);
if (r) if (r)
...@@ -1568,7 +1570,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd) ...@@ -1568,7 +1570,7 @@ static long vhost_net_set_backend(struct vhost_net *n, unsigned index, int fd)
return 0; return 0;
err_used: err_used:
vq->private_data = oldsock; vhost_vq_set_backend(vq, oldsock);
vhost_net_enable_vq(n, vq); vhost_net_enable_vq(n, vq);
if (ubufs) if (ubufs)
vhost_net_ubuf_put_wait_and_free(ubufs); vhost_net_ubuf_put_wait_and_free(ubufs);
......
...@@ -452,7 +452,7 @@ vhost_scsi_do_evt_work(struct vhost_scsi *vs, struct vhost_scsi_evt *evt) ...@@ -452,7 +452,7 @@ vhost_scsi_do_evt_work(struct vhost_scsi *vs, struct vhost_scsi_evt *evt)
unsigned out, in; unsigned out, in;
int head, ret; int head, ret;
if (!vq->private_data) { if (!vhost_vq_get_backend(vq)) {
vs->vs_events_missed = true; vs->vs_events_missed = true;
return; return;
} }
...@@ -892,7 +892,7 @@ vhost_scsi_get_req(struct vhost_virtqueue *vq, struct vhost_scsi_ctx *vc, ...@@ -892,7 +892,7 @@ vhost_scsi_get_req(struct vhost_virtqueue *vq, struct vhost_scsi_ctx *vc,
} else { } else {
struct vhost_scsi_tpg **vs_tpg, *tpg; struct vhost_scsi_tpg **vs_tpg, *tpg;
vs_tpg = vq->private_data; /* validated at handler entry */ vs_tpg = vhost_vq_get_backend(vq); /* validated at handler entry */
tpg = READ_ONCE(vs_tpg[*vc->target]); tpg = READ_ONCE(vs_tpg[*vc->target]);
if (unlikely(!tpg)) { if (unlikely(!tpg)) {
...@@ -929,7 +929,7 @@ vhost_scsi_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq) ...@@ -929,7 +929,7 @@ vhost_scsi_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq)
* We can handle the vq only after the endpoint is setup by calling the * We can handle the vq only after the endpoint is setup by calling the
* VHOST_SCSI_SET_ENDPOINT ioctl. * VHOST_SCSI_SET_ENDPOINT ioctl.
*/ */
vs_tpg = vq->private_data; vs_tpg = vhost_vq_get_backend(vq);
if (!vs_tpg) if (!vs_tpg)
goto out; goto out;
...@@ -1184,7 +1184,7 @@ vhost_scsi_ctl_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq) ...@@ -1184,7 +1184,7 @@ vhost_scsi_ctl_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq)
* We can handle the vq only after the endpoint is setup by calling the * We can handle the vq only after the endpoint is setup by calling the
* VHOST_SCSI_SET_ENDPOINT ioctl. * VHOST_SCSI_SET_ENDPOINT ioctl.
*/ */
if (!vq->private_data) if (!vhost_vq_get_backend(vq))
goto out; goto out;
memset(&vc, 0, sizeof(vc)); memset(&vc, 0, sizeof(vc));
...@@ -1322,7 +1322,7 @@ static void vhost_scsi_evt_handle_kick(struct vhost_work *work) ...@@ -1322,7 +1322,7 @@ static void vhost_scsi_evt_handle_kick(struct vhost_work *work)
struct vhost_scsi *vs = container_of(vq->dev, struct vhost_scsi, dev); struct vhost_scsi *vs = container_of(vq->dev, struct vhost_scsi, dev);
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
if (!vq->private_data) if (!vhost_vq_get_backend(vq))
goto out; goto out;
if (vs->vs_events_missed) if (vs->vs_events_missed)
...@@ -1460,7 +1460,7 @@ vhost_scsi_set_endpoint(struct vhost_scsi *vs, ...@@ -1460,7 +1460,7 @@ vhost_scsi_set_endpoint(struct vhost_scsi *vs,
for (i = 0; i < VHOST_SCSI_MAX_VQ; i++) { for (i = 0; i < VHOST_SCSI_MAX_VQ; i++) {
vq = &vs->vqs[i].vq; vq = &vs->vqs[i].vq;
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
vq->private_data = vs_tpg; vhost_vq_set_backend(vq, vs_tpg);
vhost_vq_init_access(vq); vhost_vq_init_access(vq);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
} }
...@@ -1547,7 +1547,7 @@ vhost_scsi_clear_endpoint(struct vhost_scsi *vs, ...@@ -1547,7 +1547,7 @@ vhost_scsi_clear_endpoint(struct vhost_scsi *vs,
for (i = 0; i < VHOST_SCSI_MAX_VQ; i++) { for (i = 0; i < VHOST_SCSI_MAX_VQ; i++) {
vq = &vs->vqs[i].vq; vq = &vs->vqs[i].vq;
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
} }
} }
......
...@@ -49,7 +49,7 @@ static void handle_vq(struct vhost_test *n) ...@@ -49,7 +49,7 @@ static void handle_vq(struct vhost_test *n)
void *private; void *private;
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
private = vq->private_data; private = vhost_vq_get_backend(vq);
if (!private) { if (!private) {
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
return; return;
...@@ -133,8 +133,8 @@ static void *vhost_test_stop_vq(struct vhost_test *n, ...@@ -133,8 +133,8 @@ static void *vhost_test_stop_vq(struct vhost_test *n,
void *private; void *private;
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
private = vq->private_data; private = vhost_vq_get_backend(vq);
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
return private; return private;
} }
...@@ -198,8 +198,8 @@ static long vhost_test_run(struct vhost_test *n, int test) ...@@ -198,8 +198,8 @@ static long vhost_test_run(struct vhost_test *n, int test)
priv = test ? n : NULL; priv = test ? n : NULL;
/* start polling new socket */ /* start polling new socket */
oldpriv = vq->private_data; oldpriv = vhost_vq_get_backend(vq);
vq->private_data = priv; vhost_vq_set_backend(vq, priv);
r = vhost_vq_init_access(&n->vqs[index]); r = vhost_vq_init_access(&n->vqs[index]);
......
...@@ -231,6 +231,33 @@ enum { ...@@ -231,6 +231,33 @@ enum {
(1ULL << VIRTIO_F_VERSION_1) (1ULL << VIRTIO_F_VERSION_1)
}; };
/**
* vhost_vq_set_backend - Set backend.
*
* @vq Virtqueue.
* @private_data The private data.
*
* Context: Need to call with vq->mutex acquired.
*/
static inline void vhost_vq_set_backend(struct vhost_virtqueue *vq,
void *private_data)
{
vq->private_data = private_data;
}
/**
* vhost_vq_get_backend - Get backend.
*
* @vq Virtqueue.
*
* Context: Need to call with vq->mutex acquired.
* Return: Private data previously set with vhost_vq_set_backend.
*/
static inline void *vhost_vq_get_backend(struct vhost_virtqueue *vq)
{
return vq->private_data;
}
static inline bool vhost_has_feature(struct vhost_virtqueue *vq, int bit) static inline bool vhost_has_feature(struct vhost_virtqueue *vq, int bit)
{ {
return vq->acked_features & (1ULL << bit); return vq->acked_features & (1ULL << bit);
......
...@@ -91,7 +91,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock, ...@@ -91,7 +91,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
if (!vq->private_data) if (!vhost_vq_get_backend(vq))
goto out; goto out;
/* Avoid further vmexits, we're already processing the virtqueue */ /* Avoid further vmexits, we're already processing the virtqueue */
...@@ -440,7 +440,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work) ...@@ -440,7 +440,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
if (!vq->private_data) if (!vhost_vq_get_backend(vq))
goto out; goto out;
vhost_disable_notify(&vsock->dev, vq); vhost_disable_notify(&vsock->dev, vq);
...@@ -533,8 +533,8 @@ static int vhost_vsock_start(struct vhost_vsock *vsock) ...@@ -533,8 +533,8 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)
goto err_vq; goto err_vq;
} }
if (!vq->private_data) { if (!vhost_vq_get_backend(vq)) {
vq->private_data = vsock; vhost_vq_set_backend(vq, vsock);
ret = vhost_vq_init_access(vq); ret = vhost_vq_init_access(vq);
if (ret) if (ret)
goto err_vq; goto err_vq;
...@@ -547,14 +547,14 @@ static int vhost_vsock_start(struct vhost_vsock *vsock) ...@@ -547,14 +547,14 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)
return 0; return 0;
err_vq: err_vq:
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
for (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) { for (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {
vq = &vsock->vqs[i]; vq = &vsock->vqs[i];
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
} }
err: err:
...@@ -577,7 +577,7 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock) ...@@ -577,7 +577,7 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock)
struct vhost_virtqueue *vq = &vsock->vqs[i]; struct vhost_virtqueue *vq = &vsock->vqs[i];
mutex_lock(&vq->mutex); mutex_lock(&vq->mutex);
vq->private_data = NULL; vhost_vq_set_backend(vq, NULL);
mutex_unlock(&vq->mutex); mutex_unlock(&vq->mutex);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment