vhost: introduce postcopy advise message
[dpdk.git] / lib / librte_vhost / vhost_user.h
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2010-2018 Intel Corporation
3  */
4
5 #ifndef _VHOST_NET_USER_H
6 #define _VHOST_NET_USER_H
7
8 #include <stdint.h>
9 #include <linux/vhost.h>
10
11 #include "rte_vhost.h"
12
13 /* refer to hw/virtio/vhost-user.c */
14
15 #define VHOST_MEMORY_MAX_NREGIONS 8
16
17 #define VHOST_USER_PROTOCOL_FEATURES    ((1ULL << VHOST_USER_PROTOCOL_F_MQ) | \
18                                          (1ULL << VHOST_USER_PROTOCOL_F_LOG_SHMFD) |\
19                                          (1ULL << VHOST_USER_PROTOCOL_F_RARP) | \
20                                          (1ULL << VHOST_USER_PROTOCOL_F_REPLY_ACK) | \
21                                          (1ULL << VHOST_USER_PROTOCOL_F_NET_MTU) | \
22                                          (1ULL << VHOST_USER_PROTOCOL_F_SLAVE_REQ) | \
23                                          (1ULL << VHOST_USER_PROTOCOL_F_CRYPTO_SESSION) | \
24                                          (1ULL << VHOST_USER_PROTOCOL_F_SLAVE_SEND_FD) | \
25                                          (1ULL << VHOST_USER_PROTOCOL_F_HOST_NOTIFIER))
26
27 typedef enum VhostUserRequest {
28         VHOST_USER_NONE = 0,
29         VHOST_USER_GET_FEATURES = 1,
30         VHOST_USER_SET_FEATURES = 2,
31         VHOST_USER_SET_OWNER = 3,
32         VHOST_USER_RESET_OWNER = 4,
33         VHOST_USER_SET_MEM_TABLE = 5,
34         VHOST_USER_SET_LOG_BASE = 6,
35         VHOST_USER_SET_LOG_FD = 7,
36         VHOST_USER_SET_VRING_NUM = 8,
37         VHOST_USER_SET_VRING_ADDR = 9,
38         VHOST_USER_SET_VRING_BASE = 10,
39         VHOST_USER_GET_VRING_BASE = 11,
40         VHOST_USER_SET_VRING_KICK = 12,
41         VHOST_USER_SET_VRING_CALL = 13,
42         VHOST_USER_SET_VRING_ERR = 14,
43         VHOST_USER_GET_PROTOCOL_FEATURES = 15,
44         VHOST_USER_SET_PROTOCOL_FEATURES = 16,
45         VHOST_USER_GET_QUEUE_NUM = 17,
46         VHOST_USER_SET_VRING_ENABLE = 18,
47         VHOST_USER_SEND_RARP = 19,
48         VHOST_USER_NET_SET_MTU = 20,
49         VHOST_USER_SET_SLAVE_REQ_FD = 21,
50         VHOST_USER_IOTLB_MSG = 22,
51         VHOST_USER_CRYPTO_CREATE_SESS = 26,
52         VHOST_USER_CRYPTO_CLOSE_SESS = 27,
53         VHOST_USER_POSTCOPY_ADVISE = 28,
54         VHOST_USER_MAX = 29
55 } VhostUserRequest;
56
57 typedef enum VhostUserSlaveRequest {
58         VHOST_USER_SLAVE_NONE = 0,
59         VHOST_USER_SLAVE_IOTLB_MSG = 1,
60         VHOST_USER_SLAVE_VRING_HOST_NOTIFIER_MSG = 3,
61         VHOST_USER_SLAVE_MAX
62 } VhostUserSlaveRequest;
63
64 typedef struct VhostUserMemoryRegion {
65         uint64_t guest_phys_addr;
66         uint64_t memory_size;
67         uint64_t userspace_addr;
68         uint64_t mmap_offset;
69 } VhostUserMemoryRegion;
70
71 typedef struct VhostUserMemory {
72         uint32_t nregions;
73         uint32_t padding;
74         VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
75 } VhostUserMemory;
76
77 typedef struct VhostUserLog {
78         uint64_t mmap_size;
79         uint64_t mmap_offset;
80 } VhostUserLog;
81
82 /* Comply with Cryptodev-Linux */
83 #define VHOST_USER_CRYPTO_MAX_HMAC_KEY_LENGTH   512
84 #define VHOST_USER_CRYPTO_MAX_CIPHER_KEY_LENGTH 64
85
86 /* Same structure as vhost-user backend session info */
87 typedef struct VhostUserCryptoSessionParam {
88         int64_t session_id;
89         uint32_t op_code;
90         uint32_t cipher_algo;
91         uint32_t cipher_key_len;
92         uint32_t hash_algo;
93         uint32_t digest_len;
94         uint32_t auth_key_len;
95         uint32_t aad_len;
96         uint8_t op_type;
97         uint8_t dir;
98         uint8_t hash_mode;
99         uint8_t chaining_dir;
100         uint8_t *ciphe_key;
101         uint8_t *auth_key;
102         uint8_t cipher_key_buf[VHOST_USER_CRYPTO_MAX_CIPHER_KEY_LENGTH];
103         uint8_t auth_key_buf[VHOST_USER_CRYPTO_MAX_HMAC_KEY_LENGTH];
104 } VhostUserCryptoSessionParam;
105
106 typedef struct VhostUserVringArea {
107         uint64_t u64;
108         uint64_t size;
109         uint64_t offset;
110 } VhostUserVringArea;
111
112 typedef struct VhostUserMsg {
113         union {
114                 uint32_t master; /* a VhostUserRequest value */
115                 uint32_t slave;  /* a VhostUserSlaveRequest value*/
116         } request;
117
118 #define VHOST_USER_VERSION_MASK     0x3
119 #define VHOST_USER_REPLY_MASK       (0x1 << 2)
120 #define VHOST_USER_NEED_REPLY           (0x1 << 3)
121         uint32_t flags;
122         uint32_t size; /* the following payload size */
123         union {
124 #define VHOST_USER_VRING_IDX_MASK   0xff
125 #define VHOST_USER_VRING_NOFD_MASK  (0x1<<8)
126                 uint64_t u64;
127                 struct vhost_vring_state state;
128                 struct vhost_vring_addr addr;
129                 VhostUserMemory memory;
130                 VhostUserLog    log;
131                 struct vhost_iotlb_msg iotlb;
132                 VhostUserCryptoSessionParam crypto_session;
133                 VhostUserVringArea area;
134         } payload;
135         int fds[VHOST_MEMORY_MAX_NREGIONS];
136         int fd_num;
137 } __attribute((packed)) VhostUserMsg;
138
139 #define VHOST_USER_HDR_SIZE offsetof(VhostUserMsg, payload.u64)
140
141 /* The version of the protocol we support */
142 #define VHOST_USER_VERSION    0x1
143
144
145 /* vhost_user.c */
146 int vhost_user_msg_handler(int vid, int fd);
147 int vhost_user_iotlb_miss(struct virtio_net *dev, uint64_t iova, uint8_t perm);
148 int vhost_user_host_notifier_ctrl(int vid, bool enable);
149
150 /* socket.c */
151 int read_fd_message(int sockfd, char *buf, int buflen, int *fds, int max_fds,
152                 int *fd_num);
153 int send_fd_message(int sockfd, char *buf, int buflen, int *fds, int fd_num);
154
155 #endif