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