vhost user: add support of live migration
Some vhost user backends are able to support live migration. To provide this service the following features must be added: 1. Add the VIRTIO_NET_F_GUEST_ANNOUNCE capability to vhost-net when netdev backend is vhost-user. 2. Provide a nop receive callback to vhost-user. This callback is called by: * qemu_announce_self after a migration to send fake RARP to avoid network outage for peers talking to the migrated guest. - For guest with GUEST_ANNOUNCE capabilities, guest already sends GARP when the bit VIRTIO_NET_S_ANNOUNCE is set. => These packets must be discarded. - For guest without GUEST_ANNOUNCE capabilities, migration termination is notified when the guest sends packets. => These packets can be discarded. * virtio_net_tx_bh with a dummy boot to send fake bootp/dhcp request. BIOS guest manages virtio driver to send 4 bootp/dhcp request in case of dummy boot. => These packets must be discarded. Signed-off-by: Thibaut Collet <thibaut.collet@6wind.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Tested-by: Thibaut Collet <thibaut.collet@6wind.com>
This commit is contained in:
parent
69b32a6ce4
commit
f6f56291de
@ -85,6 +85,8 @@ static const int user_feature_bits[] = {
|
|||||||
VIRTIO_NET_F_CTRL_MAC_ADDR,
|
VIRTIO_NET_F_CTRL_MAC_ADDR,
|
||||||
VIRTIO_NET_F_CTRL_GUEST_OFFLOADS,
|
VIRTIO_NET_F_CTRL_GUEST_OFFLOADS,
|
||||||
|
|
||||||
|
VIRTIO_NET_F_GUEST_ANNOUNCE,
|
||||||
|
|
||||||
VIRTIO_NET_F_MQ,
|
VIRTIO_NET_F_MQ,
|
||||||
|
|
||||||
VHOST_INVALID_FEATURE_BIT
|
VHOST_INVALID_FEATURE_BIT
|
||||||
|
@ -103,6 +103,15 @@ err:
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ssize_t vhost_user_receive(NetClientState *nc, const uint8_t *buf,
|
||||||
|
size_t size)
|
||||||
|
{
|
||||||
|
/* Discard the request that is received and managed by backend
|
||||||
|
* by an other way.
|
||||||
|
*/
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
static void vhost_user_cleanup(NetClientState *nc)
|
static void vhost_user_cleanup(NetClientState *nc)
|
||||||
{
|
{
|
||||||
VhostUserState *s = DO_UPCAST(VhostUserState, nc, nc);
|
VhostUserState *s = DO_UPCAST(VhostUserState, nc, nc);
|
||||||
@ -132,6 +141,7 @@ static bool vhost_user_has_ufo(NetClientState *nc)
|
|||||||
static NetClientInfo net_vhost_user_info = {
|
static NetClientInfo net_vhost_user_info = {
|
||||||
.type = NET_CLIENT_OPTIONS_KIND_VHOST_USER,
|
.type = NET_CLIENT_OPTIONS_KIND_VHOST_USER,
|
||||||
.size = sizeof(VhostUserState),
|
.size = sizeof(VhostUserState),
|
||||||
|
.receive = vhost_user_receive,
|
||||||
.cleanup = vhost_user_cleanup,
|
.cleanup = vhost_user_cleanup,
|
||||||
.has_vnet_hdr = vhost_user_has_vnet_hdr,
|
.has_vnet_hdr = vhost_user_has_vnet_hdr,
|
||||||
.has_ufo = vhost_user_has_ufo,
|
.has_ufo = vhost_user_has_ufo,
|
||||||
@ -182,8 +192,6 @@ static int net_vhost_user_init(NetClientState *peer, const char *device,
|
|||||||
snprintf(nc->info_str, sizeof(nc->info_str), "vhost-user%d to %s",
|
snprintf(nc->info_str, sizeof(nc->info_str), "vhost-user%d to %s",
|
||||||
i, chr->label);
|
i, chr->label);
|
||||||
|
|
||||||
/* We don't provide a receive callback */
|
|
||||||
nc->receive_disabled = 1;
|
|
||||||
nc->queue_index = i;
|
nc->queue_index = i;
|
||||||
|
|
||||||
s = DO_UPCAST(VhostUserState, nc, nc);
|
s = DO_UPCAST(VhostUserState, nc, nc);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user