提交 2b8819c6 编写于 作者: V Victor Kaplansky 提交者: Michael S. Tsirkin

vhost-user: modify SET_LOG_BASE to pass mmap size and offset

Unlike the kernel, vhost-user application accesses log table by
mmaping it to its user space. This change adds two new fields to
VhostUserMsg payload: mmap_size, and mmap_offset and make QEMU to
pass the to vhost-user application in VHOST_USER_SET_LOG_BASE
request.
Signed-off-by: NVictor Kaplansky <victork@redhat.com>
Reviewed-by: NMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
上级 393f04d3
...@@ -98,6 +98,7 @@ typedef struct VhostUserMsg { ...@@ -98,6 +98,7 @@ typedef struct VhostUserMsg {
struct vhost_vring_state state; struct vhost_vring_state state;
struct vhost_vring_addr addr; struct vhost_vring_addr addr;
VhostUserMemory memory; VhostUserMemory memory;
VhostUserLog log;
}; };
} QEMU_PACKED VhostUserMsg; } QEMU_PACKED VhostUserMsg;
...@@ -282,7 +283,12 @@ Message types ...@@ -282,7 +283,12 @@ Message types
Master payload: u64 Master payload: u64
Slave payload: N/A Slave payload: N/A
Sets the logging base address. Sets logging shared memory space.
When slave has VHOST_USER_PROTOCOL_F_LOG_SHMFD protocol
feature, the log memory fd is provided in the ancillary data of
VHOST_USER_SET_LOG_BASE message, the size and offset of shared
memory area provided in the message.
* VHOST_USER_SET_LOG_FD * VHOST_USER_SET_LOG_FD
......
...@@ -75,6 +75,11 @@ typedef struct VhostUserMemory { ...@@ -75,6 +75,11 @@ typedef struct VhostUserMemory {
VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS]; VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
} VhostUserMemory; } VhostUserMemory;
typedef struct VhostUserLog {
uint64_t mmap_size;
uint64_t mmap_offset;
} VhostUserLog;
typedef struct VhostUserMsg { typedef struct VhostUserMsg {
VhostUserRequest request; VhostUserRequest request;
...@@ -89,6 +94,7 @@ typedef struct VhostUserMsg { ...@@ -89,6 +94,7 @@ typedef struct VhostUserMsg {
struct vhost_vring_state state; struct vhost_vring_state state;
struct vhost_vring_addr addr; struct vhost_vring_addr addr;
VhostUserMemory memory; VhostUserMemory memory;
VhostUserLog log;
} payload; } payload;
} QEMU_PACKED VhostUserMsg; } QEMU_PACKED VhostUserMsg;
...@@ -200,8 +206,9 @@ static int vhost_user_set_log_base(struct vhost_dev *dev, uint64_t base, ...@@ -200,8 +206,9 @@ static int vhost_user_set_log_base(struct vhost_dev *dev, uint64_t base,
VhostUserMsg msg = { VhostUserMsg msg = {
.request = VHOST_USER_SET_LOG_BASE, .request = VHOST_USER_SET_LOG_BASE,
.flags = VHOST_USER_VERSION, .flags = VHOST_USER_VERSION,
.payload.u64 = base, .payload.log.mmap_size = log->size,
.size = sizeof(msg.payload.u64), .payload.log.mmap_offset = 0,
.size = sizeof(msg.payload.log),
}; };
if (shmfd && log->fd != -1) { if (shmfd && log->fd != -1) {
......
...@@ -86,6 +86,11 @@ typedef struct VhostUserMemory { ...@@ -86,6 +86,11 @@ typedef struct VhostUserMemory {
VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS]; VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
} VhostUserMemory; } VhostUserMemory;
typedef struct VhostUserLog {
uint64_t mmap_size;
uint64_t mmap_offset;
} VhostUserLog;
typedef struct VhostUserMsg { typedef struct VhostUserMsg {
VhostUserRequest request; VhostUserRequest request;
...@@ -94,10 +99,13 @@ typedef struct VhostUserMsg { ...@@ -94,10 +99,13 @@ typedef struct VhostUserMsg {
uint32_t flags; uint32_t flags;
uint32_t size; /* the following payload size */ uint32_t size; /* the following payload size */
union { union {
#define VHOST_USER_VRING_IDX_MASK (0xff)
#define VHOST_USER_VRING_NOFD_MASK (0x1<<8)
uint64_t u64; uint64_t u64;
struct vhost_vring_state state; struct vhost_vring_state state;
struct vhost_vring_addr addr; struct vhost_vring_addr addr;
VhostUserMemory memory; VhostUserMemory memory;
VhostUserLog log;
} payload; } payload;
} QEMU_PACKED VhostUserMsg; } QEMU_PACKED VhostUserMsg;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册