15 #ifndef __VIRTIO_VHOST_USER_H__ 16 #define __VIRTIO_VHOST_USER_H__ 19 #define VHOST_MEMORY_MAX_NREGIONS 8 20 #define VHOST_USER_MSG_HDR_SZ 12 21 #define VHOST_VRING_MAX_SIZE 32768 22 #define VHOST_VRING_MAX_N 16 //8TX + 8RX 23 #define VHOST_VRING_IDX_RX(qid) (2*qid) 24 #define VHOST_VRING_IDX_TX(qid) (2*qid + 1) 26 #define VHOST_USER_VRING_NOFD_MASK 0x100 27 #define VIRTQ_DESC_F_NEXT 1 28 #define VIRTQ_DESC_F_WRITE 2 29 #define VIRTQ_DESC_F_INDIRECT 4 31 #define VIRTQ_DESC_F_AVAIL (1 << 7) 32 #define VIRTQ_DESC_F_USED (1 << 15) 34 #define VRING_EVENT_F_ENABLE 0x0 35 #define VRING_EVENT_F_DISABLE 0x1 36 #define VRING_EVENT_F_DESC 0x2 38 #define VHOST_USER_PROTOCOL_F_MQ 0 39 #define VHOST_USER_PROTOCOL_F_LOG_SHMFD 1 40 #define VHOST_VRING_F_LOG 0 42 #define VHOST_USER_F_PROTOCOL_FEATURES 30 43 #define VHOST_USER_PROTOCOL_FEATURES ((1ULL << VHOST_USER_PROTOCOL_F_MQ) | \ 44 (1ULL << VHOST_USER_PROTOCOL_F_LOG_SHMFD)) 47 #define VIRTIO_NET_CTRL_MQ 4 48 #define VIRTIO_NET_CTRL_MQ_VQ_PAIRS_SET 0 49 #define VIRTIO_NET_CTRL_MQ_VQ_PAIRS_MIN 1 50 #define VIRTIO_NET_CTRL_MQ_VQ_PAIRS_MAX 0x8000 52 #define VRING_USED_F_NO_NOTIFY 1 53 #define VRING_AVAIL_F_NO_INTERRUPT 1 55 #define vu_log_debug(dev, f, ...) \ 57 vlib_log(VLIB_LOG_LEVEL_DEBUG, vhost_user_main.log_default, "%U: " f, \ 58 format_vnet_hw_if_index_name, vnet_get_main(), \ 59 dev->hw_if_index, ##__VA_ARGS__); \ 62 #define vu_log_warn(dev, f, ...) \ 64 vlib_log(VLIB_LOG_LEVEL_WARNING, vhost_user_main.log_default, "%U: " f, \ 65 format_vnet_hw_if_index_name, vnet_get_main(), \ 66 dev->hw_if_index, ##__VA_ARGS__); \ 68 #define vu_log_err(dev, f, ...) \ 70 vlib_log(VLIB_LOG_LEVEL_ERR, vhost_user_main.log_default, "%U: " f, \ 71 format_vnet_hw_if_index_name, vnet_get_main(), \ 72 dev->hw_if_index, ##__VA_ARGS__); \ 75 #define UNIX_GET_FD(unixfd_idx) ({ \ 76 typeof(unixfd_idx) __unixfd_idx = (unixfd_idx); \ 77 (__unixfd_idx != ~0) ? \ 78 pool_elt_at_index (file_main.file_pool, \ 79 __unixfd_idx)->file_descriptor : -1; }) 81 #define foreach_virtio_trace_flags \ 82 _ (SIMPLE_CHAINED, 0, "Simple descriptor chaining") \ 83 _ (SINGLE_DESC, 1, "Single descriptor packet") \ 84 _ (INDIRECT, 2, "Indirect descriptor") \ 85 _ (MAP_ERROR, 4, "Memory mapping error") 89 #define _(n,i,s) VIRTIO_TRACE_F_##n, 94 #define foreach_virtio_net_feature \ 95 _ (VIRTIO_NET_F_CSUM, 0) \ 96 _ (VIRTIO_NET_F_GUEST_CSUM, 1) \ 97 _ (VIRTIO_NET_F_GUEST_TSO4, 7) \ 98 _ (VIRTIO_NET_F_GUEST_TSO6, 8) \ 99 _ (VIRTIO_NET_F_GUEST_UFO, 10) \ 100 _ (VIRTIO_NET_F_HOST_TSO4, 11) \ 101 _ (VIRTIO_NET_F_HOST_TSO6, 12) \ 102 _ (VIRTIO_NET_F_HOST_UFO, 14) \ 103 _ (VIRTIO_NET_F_MRG_RXBUF, 15) \ 104 _ (VIRTIO_NET_F_CTRL_VQ, 17) \ 105 _ (VIRTIO_NET_F_GUEST_ANNOUNCE, 21) \ 106 _ (VIRTIO_NET_F_MQ, 22) \ 107 _ (VHOST_F_LOG_ALL, 26) \ 108 _ (VIRTIO_F_ANY_LAYOUT, 27) \ 109 _ (VIRTIO_F_INDIRECT_DESC, 28) \ 110 _ (VIRTIO_F_EVENT_IDX, 29) \ 111 _ (VHOST_USER_F_PROTOCOL_FEATURES, 30) \ 112 _ (VIRTIO_F_VERSION_1, 32) \ 113 _ (VIRTIO_F_RING_PACKED, 34) \ 114 _ (VIRTIO_F_IN_ORDER, 35) 118 #define _(f,n) FEAT_##f = (n), 123 #define FEATURE_VIRTIO_NET_F_HOST_TSO_FEATURE_BITS \ 124 ((1ULL << FEAT_VIRTIO_NET_F_CSUM) | \ 125 (1ULL << FEAT_VIRTIO_NET_F_HOST_UFO) | \ 126 (1ULL << FEAT_VIRTIO_NET_F_HOST_TSO4) | \ 127 (1ULL << FEAT_VIRTIO_NET_F_HOST_TSO6)) 129 #define FEATURE_VIRTIO_NET_F_GUEST_TSO_FEATURE_BITS \ 130 ((1ULL << FEAT_VIRTIO_NET_F_GUEST_CSUM) | \ 131 (1ULL << FEAT_VIRTIO_NET_F_GUEST_UFO) | \ 132 (1ULL << FEAT_VIRTIO_NET_F_GUEST_TSO4) | \ 133 (1ULL << FEAT_VIRTIO_NET_F_GUEST_TSO6)) 135 #define FEATURE_VIRTIO_NET_F_HOST_GUEST_TSO_FEATURE_BITS \ 136 (FEATURE_VIRTIO_NET_F_HOST_TSO_FEATURE_BITS | \ 137 FEATURE_VIRTIO_NET_F_GUEST_TSO_FEATURE_BITS) 140 const char *sock_filename,
u8 is_server,
142 u8 renumber,
u32 custom_dev_instance,
u8 * hwaddr,
143 u8 enable_gso,
u8 enable_packed);
145 const char *sock_filename,
u8 is_server,
147 u8 renumber,
u32 custom_dev_instance,
148 u8 enable_gso,
u8 enable_packed);
159 } __attribute ((packed)) vhost_user_memory_region_t;
166 } __attribute ((packed)) vhost_user_memory_t;
171 } __attribute ((packed)) vhost_vring_state_t;
176 u64 desc_user_addr, used_user_addr, avail_user_addr, log_guest_addr;
177 } __attribute ((packed)) vhost_vring_addr_t;
183 } __attribute ((packed)) vhost_user_log_t;
221 volatile uint16_t idx;
242 }) vring_packed_desc_t;
250 }) vring_desc_event_t;
260 } __attribute ((packed)) virtio_net_hdr_t;
263 virtio_net_hdr_t hdr;
265 } __attribute ((packed)) virtio_net_hdr_mrg_rxbuf_t;
279 } __attribute ((packed)) vhost_user_msg_t;
333 #define VHOST_USER_EVENT_START_TIMER 1 334 #define VHOST_USER_EVENT_STOP_TIMER 2 343 char sock_filename[256];
395 virtio_net_hdr_mrg_rxbuf_t
hdr;
398 #define VHOST_USER_RX_BUFFERS_N (2 * VLIB_FRAME_SIZE + 2) 399 #define VHOST_USER_COPY_ARRAY_N (4 * VLIB_FRAME_SIZE) 450 u8 sock_filename[256];
typedef CLIB_PACKED(struct { u64 addr;u32 len;u16 id;u16 flags;}) vring_packed_desc_t
#define CLIB_CACHE_LINE_ALIGN_MARK(mark)
u32 virtio_ring_flags
The device index.
int vhost_user_modify_if(vnet_main_t *vnm, vlib_main_t *vm, const char *sock_filename, u8 is_server, u32 sw_if_index, u64 feature_mask, u8 renumber, u32 custom_dev_instance, u8 enable_gso, u8 enable_packed)
virtio_net_hdr_mrg_rxbuf_t hdr
Length of the first data descriptor.
vhost_cpu_t * cpus
Per-CPU data for vhost-user.
vring_desc_event_t * used_event
#define VHOST_VRING_MAX_SIZE
int vhost_user_dump_ifs(vnet_main_t *vnm, vlib_main_t *vm, vhost_user_intf_details_t **out_vuids)
#define VHOST_VRING_MAX_N
enum vhost_user_req vhost_user_req_t
vring_packed_desc_t * packed_desc
vnet_device_class_t vhost_user_device_class
vhost_vring_state_t state
#define foreach_virtio_trace_flags
struct _vnet_device_class vnet_device_class_t
vhost_trace_t * current_trace
int vhost_user_delete_if(vnet_main_t *vnm, vlib_main_t *vm, u32 sw_if_index)
vl_api_interface_index_t sw_if_index
#define VHOST_USER_COPY_ARRAY_N
u32 random
Pseudo random iterator.
vlib_node_registration_t vhost_user_input_node
(constructor) VLIB_REGISTER_NODE (vhost_user_input_node)
vlib_node_registration_t vhost_user_send_interrupt_node
(constructor) VLIB_REGISTER_NODE (vhost_user_send_interrupt_node)
vlib_log_class_t log_default
u32 * show_dev_instance_by_real_dev_instance
u16 device_index
The interface queue index (Not the virtio vring idx)
vhost_user_intf_t * vhost_user_interfaces
u16 first_desc_len
Runtime queue flags.
int vhost_user_create_if(vnet_main_t *vnm, vlib_main_t *vm, const char *sock_filename, u8 is_server, u32 *sw_if_index, u64 feature_mask, u8 renumber, u32 custom_dev_instance, u8 *hwaddr, u8 enable_gso, u8 enable_packed)
#define VHOST_USER_RX_BUFFERS_N
#define foreach_virtio_net_feature
vlib_buffer_t ** rx_buffers_pdesc
vhost_user_main_t vhost_user_main
vring_desc_event_t * avail_event
mhash_t if_index_by_sock_name
struct _vlib_node_registration vlib_node_registration_t
VLIB buffer representation.
#define VHOST_MEMORY_MAX_NREGIONS
STATIC_ASSERT_SIZEOF(vring_packed_desc_t, 16)
vhost_user_memory_t memory
vhost_user_memory_region_t regions[VHOST_MEMORY_MAX_NREGIONS]
int dont_dump_vhost_user_memory