2017-12-19 15:49:03 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
2018-04-05 16:01:31 +00:00
|
|
|
* Copyright(c) 2010-2018 Intel Corporation
|
2015-02-23 17:36:31 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _VHOST_NET_USER_H
|
|
|
|
#define _VHOST_NET_USER_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <linux/vhost.h>
|
|
|
|
|
2017-04-01 07:22:57 +00:00
|
|
|
#include "rte_vhost.h"
|
2015-02-23 17:36:31 +00:00
|
|
|
|
|
|
|
/* refer to hw/virtio/vhost-user.c */
|
|
|
|
|
2016-04-30 05:11:19 +00:00
|
|
|
#define VHOST_MEMORY_MAX_NREGIONS 8
|
|
|
|
|
vhost: refactor code structure
The code structure is a bit messy now. For example, vhost-user message
handling is spread to three different files:
vhost-net-user.c virtio-net.c virtio-net-user.c
Where, vhost-net-user.c is the entrance to handle all those messages
and then invoke the right method for a specific message. Some of them
are stored at virtio-net.c, while others are stored at virtio-net-user.c.
The truth is all of them should be in one file, vhost_user.c.
So this patch refactors the source code structure: mainly on renaming
files and moving code from one file to another file that is more suitable
for storing it. Thus, no functional changes are made.
After the refactor, the code structure becomes to:
- socket.c handles all vhost-user socket file related stuff, such
as, socket file creation for server mode, reconnection
for client mode.
- vhost.c mainly on stuff like vhost device creation/destroy/reset.
Most of the vhost API implementation are there, too.
- vhost_user.c all stuff about vhost-user messages handling goes there.
- virtio_net.c all stuff about virtio-net should go there. It has virtio
net Rx/Tx implementation only so far: it's just a rename
from vhost_rxtx.c
Signed-off-by: Yuanhan Liu <yuanhan.liu@linux.intel.com>
Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
2016-08-18 08:48:39 +00:00
|
|
|
#define VHOST_USER_PROTOCOL_FEATURES ((1ULL << VHOST_USER_PROTOCOL_F_MQ) | \
|
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_LOG_SHMFD) |\
|
2016-12-12 17:54:00 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_RARP) | \
|
2017-10-05 08:36:09 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_REPLY_ACK) | \
|
2017-10-05 08:36:12 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_NET_MTU) | \
|
2018-04-05 16:01:31 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_SLAVE_REQ) | \
|
2018-06-08 03:22:23 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_CRYPTO_SESSION) | \
|
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_SLAVE_SEND_FD) | \
|
2018-10-12 12:40:47 +00:00
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_HOST_NOTIFIER) | \
|
|
|
|
(1ULL << VHOST_USER_PROTOCOL_F_PAGEFAULT))
|
vhost: refactor code structure
The code structure is a bit messy now. For example, vhost-user message
handling is spread to three different files:
vhost-net-user.c virtio-net.c virtio-net-user.c
Where, vhost-net-user.c is the entrance to handle all those messages
and then invoke the right method for a specific message. Some of them
are stored at virtio-net.c, while others are stored at virtio-net-user.c.
The truth is all of them should be in one file, vhost_user.c.
So this patch refactors the source code structure: mainly on renaming
files and moving code from one file to another file that is more suitable
for storing it. Thus, no functional changes are made.
After the refactor, the code structure becomes to:
- socket.c handles all vhost-user socket file related stuff, such
as, socket file creation for server mode, reconnection
for client mode.
- vhost.c mainly on stuff like vhost device creation/destroy/reset.
Most of the vhost API implementation are there, too.
- vhost_user.c all stuff about vhost-user messages handling goes there.
- virtio_net.c all stuff about virtio-net should go there. It has virtio
net Rx/Tx implementation only so far: it's just a rename
from vhost_rxtx.c
Signed-off-by: Yuanhan Liu <yuanhan.liu@linux.intel.com>
Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
2016-08-18 08:48:39 +00:00
|
|
|
|
2015-02-23 17:36:31 +00:00
|
|
|
typedef enum VhostUserRequest {
|
|
|
|
VHOST_USER_NONE = 0,
|
|
|
|
VHOST_USER_GET_FEATURES = 1,
|
|
|
|
VHOST_USER_SET_FEATURES = 2,
|
|
|
|
VHOST_USER_SET_OWNER = 3,
|
|
|
|
VHOST_USER_RESET_OWNER = 4,
|
|
|
|
VHOST_USER_SET_MEM_TABLE = 5,
|
|
|
|
VHOST_USER_SET_LOG_BASE = 6,
|
|
|
|
VHOST_USER_SET_LOG_FD = 7,
|
|
|
|
VHOST_USER_SET_VRING_NUM = 8,
|
|
|
|
VHOST_USER_SET_VRING_ADDR = 9,
|
|
|
|
VHOST_USER_SET_VRING_BASE = 10,
|
|
|
|
VHOST_USER_GET_VRING_BASE = 11,
|
|
|
|
VHOST_USER_SET_VRING_KICK = 12,
|
|
|
|
VHOST_USER_SET_VRING_CALL = 13,
|
|
|
|
VHOST_USER_SET_VRING_ERR = 14,
|
2015-10-22 12:35:49 +00:00
|
|
|
VHOST_USER_GET_PROTOCOL_FEATURES = 15,
|
|
|
|
VHOST_USER_SET_PROTOCOL_FEATURES = 16,
|
2015-10-22 12:35:50 +00:00
|
|
|
VHOST_USER_GET_QUEUE_NUM = 17,
|
2015-10-22 12:35:54 +00:00
|
|
|
VHOST_USER_SET_VRING_ENABLE = 18,
|
2016-01-29 04:58:01 +00:00
|
|
|
VHOST_USER_SEND_RARP = 19,
|
2017-03-12 16:33:59 +00:00
|
|
|
VHOST_USER_NET_SET_MTU = 20,
|
2017-10-05 08:36:12 +00:00
|
|
|
VHOST_USER_SET_SLAVE_REQ_FD = 21,
|
2017-10-05 08:36:18 +00:00
|
|
|
VHOST_USER_IOTLB_MSG = 22,
|
2018-04-05 16:01:31 +00:00
|
|
|
VHOST_USER_CRYPTO_CREATE_SESS = 26,
|
|
|
|
VHOST_USER_CRYPTO_CLOSE_SESS = 27,
|
2018-10-12 12:40:39 +00:00
|
|
|
VHOST_USER_POSTCOPY_ADVISE = 28,
|
2018-10-12 12:40:40 +00:00
|
|
|
VHOST_USER_POSTCOPY_LISTEN = 29,
|
2018-10-12 12:40:44 +00:00
|
|
|
VHOST_USER_POSTCOPY_END = 30,
|
2019-10-09 20:48:32 +00:00
|
|
|
VHOST_USER_GET_INFLIGHT_FD = 31,
|
|
|
|
VHOST_USER_SET_INFLIGHT_FD = 32,
|
|
|
|
VHOST_USER_MAX = 33
|
2015-02-23 17:36:31 +00:00
|
|
|
} VhostUserRequest;
|
|
|
|
|
2017-10-05 08:36:12 +00:00
|
|
|
typedef enum VhostUserSlaveRequest {
|
|
|
|
VHOST_USER_SLAVE_NONE = 0,
|
2017-10-05 08:36:16 +00:00
|
|
|
VHOST_USER_SLAVE_IOTLB_MSG = 1,
|
2019-12-20 08:22:55 +00:00
|
|
|
VHOST_USER_SLAVE_CONFIG_CHANGE_MSG = 2,
|
2018-06-08 03:22:23 +00:00
|
|
|
VHOST_USER_SLAVE_VRING_HOST_NOTIFIER_MSG = 3,
|
2017-10-05 08:36:12 +00:00
|
|
|
VHOST_USER_SLAVE_MAX
|
|
|
|
} VhostUserSlaveRequest;
|
|
|
|
|
2015-02-23 17:36:31 +00:00
|
|
|
typedef struct VhostUserMemoryRegion {
|
|
|
|
uint64_t guest_phys_addr;
|
|
|
|
uint64_t memory_size;
|
|
|
|
uint64_t userspace_addr;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
} VhostUserMemoryRegion;
|
|
|
|
|
|
|
|
typedef struct VhostUserMemory {
|
|
|
|
uint32_t nregions;
|
|
|
|
uint32_t padding;
|
|
|
|
VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
|
|
|
|
} VhostUserMemory;
|
|
|
|
|
2016-01-29 04:57:56 +00:00
|
|
|
typedef struct VhostUserLog {
|
|
|
|
uint64_t mmap_size;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
} VhostUserLog;
|
|
|
|
|
2018-04-05 16:01:31 +00:00
|
|
|
/* Comply with Cryptodev-Linux */
|
|
|
|
#define VHOST_USER_CRYPTO_MAX_HMAC_KEY_LENGTH 512
|
|
|
|
#define VHOST_USER_CRYPTO_MAX_CIPHER_KEY_LENGTH 64
|
|
|
|
|
|
|
|
/* Same structure as vhost-user backend session info */
|
|
|
|
typedef struct VhostUserCryptoSessionParam {
|
|
|
|
int64_t session_id;
|
|
|
|
uint32_t op_code;
|
|
|
|
uint32_t cipher_algo;
|
|
|
|
uint32_t cipher_key_len;
|
|
|
|
uint32_t hash_algo;
|
|
|
|
uint32_t digest_len;
|
|
|
|
uint32_t auth_key_len;
|
|
|
|
uint32_t aad_len;
|
|
|
|
uint8_t op_type;
|
|
|
|
uint8_t dir;
|
|
|
|
uint8_t hash_mode;
|
|
|
|
uint8_t chaining_dir;
|
|
|
|
uint8_t *ciphe_key;
|
|
|
|
uint8_t *auth_key;
|
|
|
|
uint8_t cipher_key_buf[VHOST_USER_CRYPTO_MAX_CIPHER_KEY_LENGTH];
|
|
|
|
uint8_t auth_key_buf[VHOST_USER_CRYPTO_MAX_HMAC_KEY_LENGTH];
|
|
|
|
} VhostUserCryptoSessionParam;
|
|
|
|
|
2018-06-08 03:22:23 +00:00
|
|
|
typedef struct VhostUserVringArea {
|
|
|
|
uint64_t u64;
|
|
|
|
uint64_t size;
|
|
|
|
uint64_t offset;
|
|
|
|
} VhostUserVringArea;
|
|
|
|
|
2019-10-09 20:48:29 +00:00
|
|
|
typedef struct VhostUserInflight {
|
|
|
|
uint64_t mmap_size;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
uint16_t num_queues;
|
|
|
|
uint16_t queue_size;
|
|
|
|
} VhostUserInflight;
|
|
|
|
|
2015-02-23 17:36:31 +00:00
|
|
|
typedef struct VhostUserMsg {
|
2017-10-10 12:47:54 +00:00
|
|
|
union {
|
2018-02-05 12:16:00 +00:00
|
|
|
uint32_t master; /* a VhostUserRequest value */
|
|
|
|
uint32_t slave; /* a VhostUserSlaveRequest value*/
|
2017-10-10 12:47:54 +00:00
|
|
|
} request;
|
2015-02-23 17:36:31 +00:00
|
|
|
|
|
|
|
#define VHOST_USER_VERSION_MASK 0x3
|
|
|
|
#define VHOST_USER_REPLY_MASK (0x1 << 2)
|
2016-12-12 17:54:00 +00:00
|
|
|
#define VHOST_USER_NEED_REPLY (0x1 << 3)
|
2015-02-23 17:36:31 +00:00
|
|
|
uint32_t flags;
|
|
|
|
uint32_t size; /* the following payload size */
|
|
|
|
union {
|
|
|
|
#define VHOST_USER_VRING_IDX_MASK 0xff
|
|
|
|
#define VHOST_USER_VRING_NOFD_MASK (0x1<<8)
|
|
|
|
uint64_t u64;
|
|
|
|
struct vhost_vring_state state;
|
|
|
|
struct vhost_vring_addr addr;
|
|
|
|
VhostUserMemory memory;
|
2016-01-29 04:57:56 +00:00
|
|
|
VhostUserLog log;
|
2017-10-05 08:36:16 +00:00
|
|
|
struct vhost_iotlb_msg iotlb;
|
2018-04-05 16:01:31 +00:00
|
|
|
VhostUserCryptoSessionParam crypto_session;
|
2018-06-08 03:22:23 +00:00
|
|
|
VhostUserVringArea area;
|
2019-10-09 20:48:29 +00:00
|
|
|
VhostUserInflight inflight;
|
2015-02-23 17:36:31 +00:00
|
|
|
} payload;
|
|
|
|
int fds[VHOST_MEMORY_MAX_NREGIONS];
|
2018-10-12 12:40:35 +00:00
|
|
|
int fd_num;
|
2015-02-23 17:36:31 +00:00
|
|
|
} __attribute((packed)) VhostUserMsg;
|
|
|
|
|
|
|
|
#define VHOST_USER_HDR_SIZE offsetof(VhostUserMsg, payload.u64)
|
|
|
|
|
|
|
|
/* The version of the protocol we support */
|
|
|
|
#define VHOST_USER_VERSION 0x1
|
|
|
|
|
vhost: refactor code structure
The code structure is a bit messy now. For example, vhost-user message
handling is spread to three different files:
vhost-net-user.c virtio-net.c virtio-net-user.c
Where, vhost-net-user.c is the entrance to handle all those messages
and then invoke the right method for a specific message. Some of them
are stored at virtio-net.c, while others are stored at virtio-net-user.c.
The truth is all of them should be in one file, vhost_user.c.
So this patch refactors the source code structure: mainly on renaming
files and moving code from one file to another file that is more suitable
for storing it. Thus, no functional changes are made.
After the refactor, the code structure becomes to:
- socket.c handles all vhost-user socket file related stuff, such
as, socket file creation for server mode, reconnection
for client mode.
- vhost.c mainly on stuff like vhost device creation/destroy/reset.
Most of the vhost API implementation are there, too.
- vhost_user.c all stuff about vhost-user messages handling goes there.
- virtio_net.c all stuff about virtio-net should go there. It has virtio
net Rx/Tx implementation only so far: it's just a rename
from vhost_rxtx.c
Signed-off-by: Yuanhan Liu <yuanhan.liu@linux.intel.com>
Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
2016-08-18 08:48:39 +00:00
|
|
|
|
|
|
|
/* vhost_user.c */
|
|
|
|
int vhost_user_msg_handler(int vid, int fd);
|
2017-10-05 08:36:16 +00:00
|
|
|
int vhost_user_iotlb_miss(struct virtio_net *dev, uint64_t iova, uint8_t perm);
|
vhost: refactor code structure
The code structure is a bit messy now. For example, vhost-user message
handling is spread to three different files:
vhost-net-user.c virtio-net.c virtio-net-user.c
Where, vhost-net-user.c is the entrance to handle all those messages
and then invoke the right method for a specific message. Some of them
are stored at virtio-net.c, while others are stored at virtio-net-user.c.
The truth is all of them should be in one file, vhost_user.c.
So this patch refactors the source code structure: mainly on renaming
files and moving code from one file to another file that is more suitable
for storing it. Thus, no functional changes are made.
After the refactor, the code structure becomes to:
- socket.c handles all vhost-user socket file related stuff, such
as, socket file creation for server mode, reconnection
for client mode.
- vhost.c mainly on stuff like vhost device creation/destroy/reset.
Most of the vhost API implementation are there, too.
- vhost_user.c all stuff about vhost-user messages handling goes there.
- virtio_net.c all stuff about virtio-net should go there. It has virtio
net Rx/Tx implementation only so far: it's just a rename
from vhost_rxtx.c
Signed-off-by: Yuanhan Liu <yuanhan.liu@linux.intel.com>
Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
2016-08-18 08:48:39 +00:00
|
|
|
|
|
|
|
/* socket.c */
|
2018-10-12 12:40:35 +00:00
|
|
|
int read_fd_message(int sockfd, char *buf, int buflen, int *fds, int max_fds,
|
|
|
|
int *fd_num);
|
vhost: refactor code structure
The code structure is a bit messy now. For example, vhost-user message
handling is spread to three different files:
vhost-net-user.c virtio-net.c virtio-net-user.c
Where, vhost-net-user.c is the entrance to handle all those messages
and then invoke the right method for a specific message. Some of them
are stored at virtio-net.c, while others are stored at virtio-net-user.c.
The truth is all of them should be in one file, vhost_user.c.
So this patch refactors the source code structure: mainly on renaming
files and moving code from one file to another file that is more suitable
for storing it. Thus, no functional changes are made.
After the refactor, the code structure becomes to:
- socket.c handles all vhost-user socket file related stuff, such
as, socket file creation for server mode, reconnection
for client mode.
- vhost.c mainly on stuff like vhost device creation/destroy/reset.
Most of the vhost API implementation are there, too.
- vhost_user.c all stuff about vhost-user messages handling goes there.
- virtio_net.c all stuff about virtio-net should go there. It has virtio
net Rx/Tx implementation only so far: it's just a rename
from vhost_rxtx.c
Signed-off-by: Yuanhan Liu <yuanhan.liu@linux.intel.com>
Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
2016-08-18 08:48:39 +00:00
|
|
|
int send_fd_message(int sockfd, char *buf, int buflen, int *fds, int fd_num);
|
|
|
|
|
2015-02-23 17:36:31 +00:00
|
|
|
#endif
|