Lines Matching refs:nvq

177 static int vhost_net_buf_produce(struct vhost_net_virtqueue *nvq)  in vhost_net_buf_produce()  argument
179 struct vhost_net_buf *rxq = &nvq->rxq; in vhost_net_buf_produce()
182 rxq->tail = ptr_ring_consume_batched(nvq->rx_ring, rxq->queue, in vhost_net_buf_produce()
187 static void vhost_net_buf_unproduce(struct vhost_net_virtqueue *nvq) in vhost_net_buf_unproduce() argument
189 struct vhost_net_buf *rxq = &nvq->rxq; in vhost_net_buf_unproduce()
191 if (nvq->rx_ring && !vhost_net_buf_is_empty(rxq)) { in vhost_net_buf_unproduce()
192 ptr_ring_unconsume(nvq->rx_ring, rxq->queue + rxq->head, in vhost_net_buf_unproduce()
210 static int vhost_net_buf_peek(struct vhost_net_virtqueue *nvq) in vhost_net_buf_peek() argument
212 struct vhost_net_buf *rxq = &nvq->rxq; in vhost_net_buf_peek()
217 if (!vhost_net_buf_produce(nvq)) in vhost_net_buf_peek()
362 struct vhost_net_virtqueue *nvq = in vhost_zerocopy_signal_used() local
367 for (i = nvq->done_idx; i != nvq->upend_idx; i = (i + 1) % UIO_MAXIOV) { in vhost_zerocopy_signal_used()
377 add = min(UIO_MAXIOV - nvq->done_idx, j); in vhost_zerocopy_signal_used()
379 &vq->heads[nvq->done_idx], add); in vhost_zerocopy_signal_used()
380 nvq->done_idx = (nvq->done_idx + add) % UIO_MAXIOV; in vhost_zerocopy_signal_used()
427 struct vhost_net_virtqueue *nvq = in vhost_net_disable_vq() local
429 struct vhost_poll *poll = n->poll + (nvq - n->vqs); in vhost_net_disable_vq()
438 struct vhost_net_virtqueue *nvq = in vhost_net_enable_vq() local
440 struct vhost_poll *poll = n->poll + (nvq - n->vqs); in vhost_net_enable_vq()
450 static void vhost_net_signal_used(struct vhost_net_virtqueue *nvq) in vhost_net_signal_used() argument
452 struct vhost_virtqueue *vq = &nvq->vq; in vhost_net_signal_used()
455 if (!nvq->done_idx) in vhost_net_signal_used()
458 vhost_add_used_and_signal_n(dev, vq, vq->heads, nvq->done_idx); in vhost_net_signal_used()
459 nvq->done_idx = 0; in vhost_net_signal_used()
463 struct vhost_net_virtqueue *nvq, in vhost_tx_batch() argument
469 .num = nvq->batched_xdp, in vhost_tx_batch()
470 .ptr = nvq->xdp, in vhost_tx_batch()
474 if (nvq->batched_xdp == 0) in vhost_tx_batch()
481 vq_err(&nvq->vq, "Fail to batch sending packets\n"); in vhost_tx_batch()
487 for (i = 0; i < nvq->batched_xdp; ++i) in vhost_tx_batch()
488 put_page(virt_to_head_page(nvq->xdp[i].data)); in vhost_tx_batch()
489 nvq->batched_xdp = 0; in vhost_tx_batch()
490 nvq->done_idx = 0; in vhost_tx_batch()
495 vhost_net_signal_used(nvq); in vhost_tx_batch()
496 nvq->batched_xdp = 0; in vhost_tx_batch()
602 struct vhost_net_virtqueue *nvq = &net->vqs[VHOST_NET_VQ_TX]; in vhost_exceeds_maxpend() local
603 struct vhost_virtqueue *vq = &nvq->vq; in vhost_exceeds_maxpend()
605 return (nvq->upend_idx + UIO_MAXIOV - nvq->done_idx) % UIO_MAXIOV > in vhost_exceeds_maxpend()
622 struct vhost_net_virtqueue *nvq, in get_tx_bufs() argument
627 struct vhost_virtqueue *vq = &nvq->vq; in get_tx_bufs()
630 ret = vhost_net_tx_get_vq_desc(net, nvq, out, in, msg, busyloop_intr); in get_tx_bufs()
642 *len = init_iov_iter(vq, &msg->msg_iter, nvq->vhost_hlen, *out); in get_tx_bufs()
645 *len, nvq->vhost_hlen); in get_tx_bufs()
695 static int vhost_net_build_xdp(struct vhost_net_virtqueue *nvq, in vhost_net_build_xdp() argument
698 struct vhost_virtqueue *vq = &nvq->vq; in vhost_net_build_xdp()
704 struct xdp_buff *xdp = &nvq->xdp[nvq->batched_xdp]; in vhost_net_build_xdp()
709 int pad = SKB_DATA_ALIGN(VHOST_NET_RX_PAD + headroom + nvq->sock_hlen); in vhost_net_build_xdp()
710 int sock_hlen = nvq->sock_hlen; in vhost_net_build_xdp()
714 if (unlikely(len < nvq->sock_hlen)) in vhost_net_build_xdp()
764 ++nvq->batched_xdp; in vhost_net_build_xdp()
771 struct vhost_net_virtqueue *nvq = &net->vqs[VHOST_NET_VQ_TX]; in handle_tx_copy() local
772 struct vhost_virtqueue *vq = &nvq->vq; in handle_tx_copy()
790 if (nvq->done_idx == VHOST_NET_BATCH) in handle_tx_copy()
791 vhost_tx_batch(net, nvq, sock, &msg); in handle_tx_copy()
793 head = get_tx_bufs(net, nvq, &msg, &out, &in, &len, in handle_tx_copy()
816 err = vhost_net_build_xdp(nvq, &msg.msg_iter); in handle_tx_copy()
820 vhost_tx_batch(net, nvq, sock, &msg); in handle_tx_copy()
830 vhost_tx_batch(net, nvq, sock, &msg); in handle_tx_copy()
851 vq->heads[nvq->done_idx].id = cpu_to_vhost32(vq, head); in handle_tx_copy()
852 vq->heads[nvq->done_idx].len = 0; in handle_tx_copy()
853 ++nvq->done_idx; in handle_tx_copy()
856 vhost_tx_batch(net, nvq, sock, &msg); in handle_tx_copy()
861 struct vhost_net_virtqueue *nvq = &net->vqs[VHOST_NET_VQ_TX]; in handle_tx_zerocopy() local
862 struct vhost_virtqueue *vq = &nvq->vq; in handle_tx_zerocopy()
887 head = get_tx_bufs(net, nvq, &msg, &out, &in, &len, in handle_tx_zerocopy()
909 ubuf = nvq->ubuf_info + nvq->upend_idx; in handle_tx_zerocopy()
910 vq->heads[nvq->upend_idx].id = cpu_to_vhost32(vq, head); in handle_tx_zerocopy()
911 vq->heads[nvq->upend_idx].len = VHOST_DMA_IN_PROGRESS; in handle_tx_zerocopy()
912 ubuf->ctx = nvq->ubufs; in handle_tx_zerocopy()
913 ubuf->desc = nvq->upend_idx; in handle_tx_zerocopy()
921 ubufs = nvq->ubufs; in handle_tx_zerocopy()
923 nvq->upend_idx = (nvq->upend_idx + 1) % UIO_MAXIOV; in handle_tx_zerocopy()
944 nvq->upend_idx = ((unsigned)nvq->upend_idx - 1) in handle_tx_zerocopy()
970 struct vhost_net_virtqueue *nvq = &net->vqs[VHOST_NET_VQ_TX]; in handle_tx() local
971 struct vhost_virtqueue *vq = &nvq->vq; in handle_tx()
1117 struct vhost_net_virtqueue *nvq = &net->vqs[VHOST_NET_VQ_RX]; in handle_rx() local
1118 struct vhost_virtqueue *vq = &nvq->vq; in handle_rx()
1154 vhost_hlen = nvq->vhost_hlen; in handle_rx()
1155 sock_hlen = nvq->sock_hlen; in handle_rx()
1168 headcount = get_rx_bufs(vq, vq->heads + nvq->done_idx, in handle_rx()
1189 if (nvq->rx_ring) in handle_rx()
1190 msg.msg_control = vhost_net_buf_consume(&nvq->rxq); in handle_rx()
1243 nvq->done_idx += headcount; in handle_rx()
1244 if (nvq->done_idx > VHOST_NET_BATCH) in handle_rx()
1245 vhost_net_signal_used(nvq); in handle_rx()
1257 vhost_net_signal_used(nvq); in handle_rx()
1366 struct vhost_net_virtqueue *nvq = in vhost_net_stop_vq() local
1373 vhost_net_buf_unproduce(nvq); in vhost_net_stop_vq()
1374 nvq->rx_ring = NULL; in vhost_net_stop_vq()
1505 struct vhost_net_virtqueue *nvq; in vhost_net_set_backend() local
1519 nvq = &n->vqs[index]; in vhost_net_set_backend()
1548 vhost_net_buf_unproduce(nvq); in vhost_net_set_backend()
1557 nvq->rx_ring = get_tap_ptr_ring(sock->file); in vhost_net_set_backend()
1559 nvq->rx_ring = NULL; in vhost_net_set_backend()
1562 oldubufs = nvq->ubufs; in vhost_net_set_backend()
1563 nvq->ubufs = ubufs; in vhost_net_set_backend()