[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 1/1] virtio: failover: define the default device to use in
From: |
Laurent Vivier |
Subject: |
Re: [PATCH v2 1/1] virtio: failover: define the default device to use in case of error |
Date: |
Thu, 26 Aug 2021 17:56:09 +0200 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 |
On 24/08/2021 01:25, Michael S. Tsirkin wrote:
> On Mon, Aug 09, 2021 at 07:13:42PM +0200, Laurent Vivier wrote:
>> If the guest driver doesn't support the STANDBY feature, by default
>> we keep the virtio-net device and don't hotplug the VFIO device,
>> but in some cases, user can prefer to use the VFIO device rather
>> than the virtio-net one. We can't unplug the virtio-net device
>> (because on migration it is expected on the destination side)
>> but we can force the guest driver to be disabled. Then, we can
>> hotplug the VFIO device that will be unplugged before the migration
>> like in the normal failover migration but without the failover device.
>>
>> This patch adds a new property to virtio-net device: "failover-default".
>>
>> By default, "failover-default" is set to true and thus the default NIC
>> to use if the failover cannot be enabled is the virtio-net device
>> (this is what is done until now with the virtio-net failover).
>>
>> If "failover-default" is set to false, in case of error, the virtio-net
>> device is not the default anymore and the failover primary device
>> is used instead.
>>
>> If the STANDBY feature is supported by guest and host, the virtio-net
>> failover acts as usual.
>>
>> Signed-off-by: Laurent Vivier <lvivier@redhat.com>
>
> Three things I dislike here. First this is limited to 1.0.
> OTOH this is all about legacy guests without STANDBY,
> would be nicer to support legacy.
So for that we could use my first approach to disable the driver by triggering
an error in
the driver probe function. It was done in v1 by setting vring.num to 0.
> Second: the reason we don't want both
> virtio and VFIO is because their mac addresses match.
> This tends to confuse guest tools.
> I don't see this solved here.
If the driver is not loaded I don't think any guest tool can read the MAC
address of the
virtio-net device.
In fact what we want is to use VFIO device when failover is not available. I
think keeping
both can confuse the guest tools.
>
> Proposal: management supplies an extra dummy mac.
> This mac is used with virtio and its link it down.
> Link state reporting is also optional but
> it has been there for many years.
> If link state reporting is disabled then maybe do not
> expose VFIO after all.
The problem by keeping both interfaces (vfio and virtio-net) outside the
failover
configuration is the networking configuration (ifcfg) will be applied to the
virtio-net
device as it's PCI address is used to identify the failover_net interface. So
the guest
kernel will continue to configure and use the virtio-net device even if the
vfio device is
not hidden. Of course, we also need to define an ifcfg for the vfio device if
failover is
disabled.
> Third thing is option name. Does not hint at the fact that
> for legacy guests we do not get failover at all.
> Let's try to be more explicit please.
ok, but I think this is a minor problem we can discuss once the two previous
ones are solved.
I can also try to implement a POC with your proposition: a different MAC
address and the
link down state.
Thanks,
Laurent
>
>
>> ---
>> include/hw/virtio/virtio-net.h | 1 +
>> hw/net/virtio-net.c | 49 +++++++++++++++++++++++++++++-----
>> 2 files changed, 44 insertions(+), 6 deletions(-)
>>
>> diff --git a/include/hw/virtio/virtio-net.h b/include/hw/virtio/virtio-net.h
>> index 824a69c23f06..ab77930a327e 100644
>> --- a/include/hw/virtio/virtio-net.h
>> +++ b/include/hw/virtio/virtio-net.h
>> @@ -208,6 +208,7 @@ struct VirtIONet {
>> /* primary failover device is hidden*/
>> bool failover_primary_hidden;
>> bool failover;
>> + bool failover_default;
>> DeviceListener primary_listener;
>> Notifier migration_state;
>> VirtioNetRssData rss_data;
>> diff --git a/hw/net/virtio-net.c b/hw/net/virtio-net.c
>> index 16d20cdee52a..972c03232a96 100644
>> --- a/hw/net/virtio-net.c
>> +++ b/hw/net/virtio-net.c
>> @@ -935,12 +935,23 @@ static void virtio_net_set_features(VirtIODevice
>> *vdev, uint64_t features)
>> memset(n->vlans, 0xff, MAX_VLAN >> 3);
>> }
>>
>> - if (virtio_has_feature(features, VIRTIO_NET_F_STANDBY)) {
>> - qapi_event_send_failover_negotiated(n->netclient_name);
>> - qatomic_set(&n->failover_primary_hidden, false);
>> - failover_add_primary(n, &err);
>> - if (err) {
>> - warn_report_err(err);
>> + /*
>> + * if the virtio-net driver has the STANDBY feature, we can plug the
>> primary
>> + * if not but is not the default failover device,
>> + * we need to plug the primary alone and the virtio-net driver will
>> + * be disabled in the validate_features() function but
>> validate_features()
>> + * is only available with virtio 1.0 spec
>> + */
>> + if (n->failover) {
>> + if (virtio_has_feature(features, VIRTIO_NET_F_STANDBY) ||
>> + (virtio_has_feature(features, VIRTIO_F_VERSION_1) &&
>> + !n->failover_default)) {
>> + qapi_event_send_failover_negotiated(n->netclient_name);
>> + qatomic_set(&n->failover_primary_hidden, false);
>> + failover_add_primary(n, &err);
>> + if (err) {
>> + warn_report_err(err);
>> + }
>> }
>> }
>> }
>> @@ -3625,9 +3636,34 @@ static Property virtio_net_properties[] = {
>> DEFINE_PROP_INT32("speed", VirtIONet, net_conf.speed, SPEED_UNKNOWN),
>> DEFINE_PROP_STRING("duplex", VirtIONet, net_conf.duplex_str),
>> DEFINE_PROP_BOOL("failover", VirtIONet, failover, false),
>> + DEFINE_PROP_BOOL("failover-default", VirtIONet, failover_default, true),
>> DEFINE_PROP_END_OF_LIST(),
>> };
>>
>> +/* validate_features() is only available with VIRTIO_F_VERSION_1 */
>> +static int failover_validate_features(VirtIODevice *vdev)
>> +{
>> + VirtIONet *n = VIRTIO_NET(vdev);
>> +
>> + /*
>> + * If the guest driver doesn't support the STANDBY feature, by default
>> + * we keep the virtio-net device and don't hotplug the VFIO device,
>> + * but in some cases, user can prefer to use the VFIO device rather
>> + * than the virtio-net one. We can't unplug the virtio-net device
>> + * (because on migration it is expected on the destination side)
>> + * but we can force the guest driver to be disabled. In this case, We
>> can
>> + * hotplug the VFIO device that will be unplugged before the migration
>> + * like in the normal failover migration but without the failover
>> device.
>> + */
>> + if (n->failover && !n->failover_default &&
>> + !virtio_vdev_has_feature(vdev, VIRTIO_NET_F_STANDBY)) {
>> + /* disable virtio-net */
>> + return -ENODEV;
>> + }
>> +
>> + return 0;
>> +}
>> +
>> static void virtio_net_class_init(ObjectClass *klass, void *data)
>> {
>> DeviceClass *dc = DEVICE_CLASS(klass);
>> @@ -3651,6 +3687,7 @@ static void virtio_net_class_init(ObjectClass *klass,
>> void *data)
>> vdc->post_load = virtio_net_post_load_virtio;
>> vdc->vmsd = &vmstate_virtio_net_device;
>> vdc->primary_unplug_pending = primary_unplug_pending;
>> + vdc->validate_features = failover_validate_features;
>> }
>>
>> static const TypeInfo virtio_net_info = {
>> --
>> 2.31.1
>