| /linux-6.15/include/linux/ |
| H A D | virtio.h | 31 struct virtqueue { struct 33 void (*callback)(struct virtqueue *vq); argument 43 int virtqueue_add_outbuf(struct virtqueue *vq, argument 48 int virtqueue_add_inbuf(struct virtqueue *vq, 53 int virtqueue_add_inbuf_ctx(struct virtqueue *vq, 70 int virtqueue_add_sgs(struct virtqueue *vq, 79 bool virtqueue_kick(struct virtqueue *vq); 83 bool virtqueue_notify(struct virtqueue *vq); 92 bool virtqueue_enable_cb(struct virtqueue *vq); 114 int virtqueue_reset(struct virtqueue *vq, [all …]
|
| H A D | virtio_ring.h | 60 struct virtqueue; 69 struct virtqueue *vring_create_virtqueue(unsigned int index, 76 bool (*notify)(struct virtqueue *vq), 77 void (*callback)(struct virtqueue *vq), 91 bool (*notify)(struct virtqueue *vq), 92 void (*callback)(struct virtqueue *vq), 100 struct virtqueue *vring_new_virtqueue(unsigned int index, 107 bool (*notify)(struct virtqueue *vq), 108 void (*callback)(struct virtqueue *vq), 115 void vring_del_virtqueue(struct virtqueue *vq); [all …]
|
| H A D | virtio_config.h | 19 typedef void vq_callback_t(struct virtqueue *); 118 struct virtqueue *vqs[], 126 int (*set_vq_affinity)(struct virtqueue *vq, 132 int (*disable_vq_and_reset)(struct virtqueue *vq); 133 int (*enable_vq_after_reset)(struct virtqueue *vq); 222 struct virtqueue *vqs[], in virtio_find_vqs() 230 struct virtqueue *virtio_find_single_vq(struct virtio_device *vdev, in virtio_find_single_vq() 236 struct virtqueue *vq; in virtio_find_single_vq() 320 int virtqueue_set_affinity(struct virtqueue *vq, const struct cpumask *cpu_mask) in virtqueue_set_affinity()
|
| /linux-6.15/tools/virtio/linux/ |
| H A D | virtio.h | 20 struct virtqueue { struct 22 void (*callback)(struct virtqueue *vq); argument 33 int virtqueue_add_sgs(struct virtqueue *vq, argument 40 int virtqueue_add_outbuf(struct virtqueue *vq, 45 int virtqueue_add_inbuf(struct virtqueue *vq, 50 bool virtqueue_kick(struct virtqueue *vq); 54 void virtqueue_disable_cb(struct virtqueue *vq); 56 bool virtqueue_enable_cb(struct virtqueue *vq); 67 bool (*notify)(struct virtqueue *vq), 68 void (*callback)(struct virtqueue *vq), [all …]
|
| H A D | virtio_config.h | 9 int (*disable_vq_and_reset)(struct virtqueue *vq); 10 int (*enable_vq_after_reset)(struct virtqueue *vq);
|
| /linux-6.15/drivers/virtio/ |
| H A D | virtio_ring.c | 163 struct virtqueue vq; 208 bool (*notify)(struct virtqueue *vq); 1195 bool (*notify)(struct virtqueue *), in vring_create_virtqueue_split() argument 1196 void (*callback)(struct virtqueue *), in vring_create_virtqueue_split() argument 1201 struct virtqueue *vq; in vring_create_virtqueue_split() 2173 bool (*notify)(struct virtqueue *), in vring_create_virtqueue_packed() argument 2179 struct virtqueue *vq; in vring_create_virtqueue_packed() 2729 bool (*notify)(struct virtqueue *), in vring_create_virtqueue() argument 2753 bool (*notify)(struct virtqueue *), in vring_create_virtqueue_dma() argument 3048 struct virtqueue *_vq; in virtio_break_device() [all …]
|
| H A D | virtio_pci_common.h | 36 struct virtqueue *vq; 101 struct virtqueue *(*setup_vq)(struct virtio_pci_device *vp_dev, 104 void (*callback)(struct virtqueue *vq), 131 bool vp_notify(struct virtqueue *vq); 136 struct virtqueue *vqs[], struct virtqueue_info vqs_info[], 145 int vp_set_vq_affinity(struct virtqueue *vq, const struct cpumask *cpu_mask); 197 void vp_modern_avq_done(struct virtqueue *vq);
|
| H A D | virtio_vdpa.c | 40 struct virtqueue *vq; 106 static bool virtio_vdpa_notify(struct virtqueue *vq) in virtio_vdpa_notify() 116 static bool virtio_vdpa_notify_with_data(struct virtqueue *vq) in virtio_vdpa_notify_with_data() 143 static struct virtqueue * 145 void (*callback)(struct virtqueue *vq), in virtio_vdpa_setup_vq() 153 bool (*notify)(struct virtqueue *vq) = virtio_vdpa_notify; in virtio_vdpa_setup_vq() 155 struct virtqueue *vq; in virtio_vdpa_setup_vq() 270 static void virtio_vdpa_del_vq(struct virtqueue *vq) in virtio_vdpa_del_vq() 293 struct virtqueue *vq, *n; in virtio_vdpa_del_vqs() 360 struct virtqueue *vqs[], in virtio_vdpa_find_vqs() [all …]
|
| H A D | virtio_pci_common.c | 51 bool vp_notify(struct virtqueue *vq) in vp_notify() 207 void (*callback)(struct virtqueue *vq), in vp_setup_vq() 215 struct virtqueue *vq; in vp_setup_vq() 271 struct virtqueue *vq, *n; in vp_del_vqs() 329 static struct virtqueue * 337 struct virtqueue *vq; in vp_find_one_vq_msix() 377 struct virtqueue *vqs[], in vp_find_vqs_msix() 386 struct virtqueue *vq; in vp_find_vqs_msix() 458 struct virtqueue *vqs[], in vp_find_vqs_intx() 464 struct virtqueue *vq; in vp_find_vqs_intx() [all …]
|
| H A D | virtio_mmio.c | 99 struct virtqueue *vq; 279 static bool vm_notify(struct virtqueue *vq) in vm_notify() 289 static bool vm_notify_with_data(struct virtqueue *vq) in vm_notify_with_data() 329 static void vm_del_vq(struct virtqueue *vq) in vm_del_vq() 357 struct virtqueue *vq, *n; in vm_del_vqs() 372 static struct virtqueue *vm_setup_vq(struct virtio_device *vdev, unsigned int index, in vm_setup_vq() 373 void (*callback)(struct virtqueue *vq), in vm_setup_vq() 377 bool (*notify)(struct virtqueue *vq); in vm_setup_vq() 379 struct virtqueue *vq; in vm_setup_vq() 491 struct virtqueue *vqs[], in vm_find_vqs()
|
| H A D | virtio_pci_legacy.c | 110 static struct virtqueue *setup_vq(struct virtio_pci_device *vp_dev, in setup_vq() 113 void (*callback)(struct virtqueue *vq), in setup_vq() 118 struct virtqueue *vq; in setup_vq() 173 struct virtqueue *vq = info->vq; in del_vq()
|
| H A D | virtio_pci_modern.c | 47 void vp_modern_avq_done(struct virtqueue *vq) in vp_modern_avq_done() 73 struct virtqueue *vq; in virtqueue_exec_admin_cmd() 341 struct virtqueue *vq; in vp_modern_avq_cleanup() 556 static int vp_active_vq(struct virtqueue *vq, u16 msix_vec) in vp_active_vq() 665 static bool vp_notify_with_data(struct virtqueue *vq) in vp_notify_with_data() 677 void (*callback)(struct virtqueue *vq), in setup_vq() 684 bool (*notify)(struct virtqueue *vq); in setup_vq() 685 struct virtqueue *vq; in setup_vq() 734 struct virtqueue *vqs[], in vp_modern_find_vqs() 739 struct virtqueue *vq; in vp_modern_find_vqs() [all …]
|
| H A D | virtio_balloon.c | 57 struct virtqueue *inflate_vq, *deflate_vq, *stats_vq, *free_page_vq; 120 struct virtqueue *reporting_vq; 176 static void balloon_ack(struct virtqueue *vq) in balloon_ack() 183 static void tell_host(struct virtio_balloon *vb, struct virtqueue *vq) in tell_host() 204 struct virtqueue *vq = vb->reporting_vq; in virtballoon_free_page_report() 434 static void stats_request(struct virtqueue *vq) in stats_request() 448 struct virtqueue *vq; in stats_handle_request() 582 struct virtqueue *vqs[VIRTIO_BALLOON_VQ_MAX]; in init_vqs() 662 struct virtqueue *vq = vb->free_page_vq; in send_cmd_id_start() 681 struct virtqueue *vq = vb->free_page_vq; in send_cmd_id_stop() [all …]
|
| /linux-6.15/Documentation/driver-api/virtio/ |
| H A D | writing_virtio_drivers.rst | 24 virtqueue definitions in the device. A basic driver skeleton could look 34 struct virtqueue *vq; 37 static void virtio_dummy_recv_cb(struct virtqueue *vq) 57 /* the device has a single virtqueue */ 121 virtqueue. virtio_device_ready() is used to enable the virtqueue and to 144 appropriate virtqueue using any of the virtqueue_add_inbuf(), 148 `scatterlists`, respectively. Then, once the virtqueue is set up, a call 168 read the data produced by the device (if the virtqueue was set up with 175 The virtqueue callbacks can be disabled and re-enabled using the 187 device or the virtqueue (virtio_reset_device()).
|
| /linux-6.15/net/vmw_vsock/ |
| H A D | virtio_transport.c | 31 struct virtqueue *vqs[VSOCK_VQ_MAX]; 159 struct virtqueue *vq; in virtio_transport_send_pkt_work() 216 struct virtqueue *vq = vsock->vqs[VSOCK_VQ_TX]; in virtio_transport_send_skb_fast_path() 292 struct virtqueue *rx_vq = vsock->vqs[VSOCK_VQ_RX]; in virtio_transport_cancel_pkt() 312 struct virtqueue *vq; in virtio_vsock_rx_fill() 343 struct virtqueue *vq; in virtio_transport_tx_work() 373 struct virtqueue *vq = vsock->vqs[VSOCK_VQ_RX]; in virtio_transport_more_replies() 387 struct virtqueue *vq; in virtio_vsock_event_fill_one() 449 struct virtqueue *vq; in virtio_transport_event_work() 512 struct virtqueue *vq = vsock->vqs[VSOCK_VQ_TX]; in virtio_transport_can_msgzerocopy() [all …]
|
| /linux-6.15/drivers/gpu/drm/virtio/ |
| H A D | virtgpu_trace.h | 12 TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr, u32 seqno), 43 TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr, u32 seqno), 48 TP_PROTO(struct virtqueue *vq, struct virtio_gpu_ctrl_hdr *hdr, u32 seqno),
|
| /linux-6.15/drivers/i2c/busses/ |
| H A D | i2c-virtio.c | 31 struct virtqueue *vq; 48 static void virtio_i2c_msg_done(struct virtqueue *vq) in virtio_i2c_msg_done() 57 static int virtio_i2c_prepare_reqs(struct virtqueue *vq, in virtio_i2c_prepare_reqs() 109 static int virtio_i2c_complete_reqs(struct virtqueue *vq, in virtio_i2c_complete_reqs() 137 struct virtqueue *vq = vi->vq; in virtio_i2c_xfer()
|
| /linux-6.15/drivers/nvdimm/ |
| H A D | virtio_pmem.h | 36 struct virtqueue *req_vq; 53 void virtio_pmem_host_ack(struct virtqueue *vq);
|
| /linux-6.15/Documentation/userspace-api/ |
| H A D | vduse.rst | 28 2. Setup each virtqueue with ioctl(VDUSE_VQ_SETUP) on /dev/vduse/$NAME. 104 add per-virtqueue configuration such as the max size of virtqueue to the device. 140 - VDUSE_GET_VQ_STATE: Get the state for virtqueue, userspace should return 141 avail index for split virtqueue or the device/driver ring wrap counters and 142 the avail and used index for packed virtqueue. 157 1. Get the specified virtqueue's information with the VDUSE_VQ_GET_INFO ioctl, 230 5. Inject an interrupt for specific virtqueue with the VDUSE_INJECT_VQ_IRQ ioctl
|
| /linux-6.15/drivers/bluetooth/ |
| H A D | virtio_bt.c | 24 struct virtqueue *vqs[VIRTBT_NUM_VQS]; 31 struct virtqueue *vq = vbt->vqs[VIRTBT_VQ_RX]; in virtbt_add_inbuf() 77 struct virtqueue *vq = vbt->vqs[i]; in virtbt_close_vdev() 239 static void virtbt_tx_done(struct virtqueue *vq) in virtbt_tx_done() 248 static void virtbt_rx_done(struct virtqueue *vq) in virtbt_rx_done()
|
| /linux-6.15/sound/virtio/ |
| H A D | virtio_pcm.h | 105 void virtsnd_pcm_tx_notify_cb(struct virtqueue *vqueue); 107 void virtsnd_pcm_rx_notify_cb(struct virtqueue *vqueue);
|
| /linux-6.15/drivers/char/ |
| H A D | virtio_console.c | 147 struct virtqueue *c_ivq, *c_ovq; 156 struct virtqueue **in_vqs, **out_vqs; 188 struct virtqueue *in_vq, *out_vq; 308 struct virtqueue *vq) in find_port_by_vq() 543 struct virtqueue *vq; in __send_control_msg() 600 struct virtqueue *out_vq; in __send_to_port() 1663 struct virtqueue *vq; in control_work_handler() 1698 static void out_intr(struct virtqueue *vq) in out_intr() 1711 static void in_intr(struct virtqueue *vq) in in_intr() 1805 struct virtqueue **vqs; in init_vqs() [all …]
|
| /linux-6.15/drivers/s390/virtio/ |
| H A D | virtio_ccw.c | 158 struct virtqueue *vq; 457 static bool virtio_ccw_kvm_notify(struct virtqueue *vq) in virtio_ccw_kvm_notify() 462 static bool virtio_ccw_kvm_notify_with_data(struct virtqueue *vq) in virtio_ccw_kvm_notify_with_data() 483 static void virtio_ccw_del_vq(struct virtqueue *vq, struct ccw1 *ccw) in virtio_ccw_del_vq() 532 struct virtqueue *vq, *n; in virtio_ccw_del_vqs() 554 bool (*notify)(struct virtqueue *vq); in virtio_ccw_setup_vq() 556 struct virtqueue *vq = NULL; in virtio_ccw_setup_vq() 651 struct virtqueue *vqs[], int nvqs, in virtio_ccw_register_adapter_ind() 701 struct virtqueue *vqs[], in virtio_ccw_find_vqs() 1128 struct virtqueue *vq; in virtio_ccw_vq_by_ind() [all …]
|
| /linux-6.15/arch/um/drivers/ |
| H A D | virtio_uml.c | 381 struct virtqueue *vq; in vu_req_read_message() 443 struct virtqueue *vq; in vu_req_interrupt() 789 static bool vu_notify(struct virtqueue *vq) in vu_notify() 817 struct virtqueue *vq = opaque; in vu_interrupt() 893 struct virtqueue *vq, *n; in vu_del_vqs() 908 struct virtqueue *vq) in vu_setup_vq_call_fd() 962 struct virtqueue *vq; in vu_setup_vq() 1033 struct virtqueue *vqs[], in vu_find_vqs() 1039 struct virtqueue *vq; in vu_find_vqs() 1425 struct virtqueue *vq; in virtio_uml_suspend() [all …]
|
| H A D | virtio_pcidev.c | 38 struct virtqueue *cmd_vq, *irq_vq; 393 static void virtio_pcidev_irq_vq_addbuf(struct virtqueue *vq, void *buf, bool kick) in virtio_pcidev_irq_vq_addbuf() 404 static void virtio_pcidev_handle_irq_message(struct virtqueue *vq, in virtio_pcidev_handle_irq_message() 435 static void virtio_pcidev_cmd_vq_cb(struct virtqueue *vq) in virtio_pcidev_cmd_vq_cb() 449 static void virtio_pcidev_irq_vq_cb(struct virtqueue *vq) in virtio_pcidev_irq_vq_cb() 469 struct virtqueue *vqs[2]; in virtio_pcidev_init_vqs()
|