qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: "Michael S. Tsirkin" <mst@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>,
	qemu-devel@nongnu.org, philmd@linaro.org, thuth@redhat.com,
	eblake@redhat.com, michael.roth@amd.com, farosas@suse.de,
	peterx@redhat.com, berrange@redhat.com, jasowang@redhat.com,
	steven.sistare@oracle.com, leiyang@redhat.com,
	davydov-max@yandex-team.ru, yc-core@yandex-team.ru
Subject: Re: [PATCH v6 16/19] qapi: add interface for backend-transfer virtio-net/tap migration
Date: Mon, 6 Oct 2025 10:55:31 -0400	[thread overview]
Message-ID: <20251006105159-mutt-send-email-mst@kernel.org> (raw)
In-Reply-To: <878qhoksd3.fsf@pond.sub.org>

On Mon, Oct 06, 2025 at 04:38:32PM +0200, Markus Armbruster wrote:
> "Michael S. Tsirkin" <mst@redhat.com> writes:
> 
> > On Mon, Oct 06, 2025 at 03:23:06PM +0200, Markus Armbruster wrote:
> >> Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru> writes:
> >> 
> >> > To migrate virtio-net TAP device backend (including open fds) locally,
> >> > user should simply set migration parameter
> >> >
> >> >    backend-transfer = ["virtio-net-tap"]
> >> >
> >> > Why not simple boolean? To simplify migration to further versions,
> >> > when more devices will support backend-transfer migration.
> >> >
> >> > Alternatively, we may add per-device option to disable backend-transfer
> >> > migration, but still:
> >> >
> >> > 1. It's more comfortable to set same capabilities/parameters on both
> >> > source and target QEMU, than care about each device.
> >> >
> >> > 2. To not break the design, that machine-type + device options +
> >> > migration capabilities and parameters are fully define the resulting
> >> > migration stream. We'll break this if add in future more
> >> > backend-transfer support in devices under same backend-transfer=true
> >> > parameter.
> >> >
> >> > Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
> >> > ---
> >> >  include/qapi/util.h | 17 ++++++++++++++++
> >> >  migration/options.c | 32 ++++++++++++++++++++++++++++++
> >> >  migration/options.h |  2 ++
> >> >  qapi/migration.json | 47 ++++++++++++++++++++++++++++++++++++---------
> >> >  4 files changed, 89 insertions(+), 9 deletions(-)
> >> >
> >> > diff --git a/include/qapi/util.h b/include/qapi/util.h
> >> > index 29bc4eb865..b953402416 100644
> >> > --- a/include/qapi/util.h
> >> > +++ b/include/qapi/util.h
> >> > @@ -69,4 +69,21 @@ int parse_qapi_name(const char *name, bool complete);
> >> >          _len;                                                       \
> >> >      })
> >> >  
> >> > +/*
> >> > + * For any GenericList @list, return true if it contains specified
> >> > + * element.
> >> > + */
> >> > +#define QAPI_LIST_CONTAINS(list, el)                                \
> >> > +    ({                                                              \
> >> > +        bool _found = false;                                        \
> >> > +        typeof_strip_qual(list) _tail;                              \
> >> > +        for (_tail = list; _tail != NULL; _tail = _tail->next) {    \
> >> > +            if (_tail->value == el) {                               \
> >> > +                _found = true;                                      \
> >> > +                break;                                              \
> >> > +            }                                                       \
> >> > +        }                                                           \
> >> > +        _found;                                                     \
> >> > +    })
> >> > +
> >> 
> >> Not a fan of lengthy macros.
> >> 
> >> There's a single use below: migrate_virtio_net_tap().  I can't see
> >> potential uses for such a search in existing code.
> >
> > However, QAPI_LIST_FOR_EACH can potentially be used to implement
> > QAPI_LIST_LENGTH.
> >
> > #define QAPI_LIST_FOR_EACH(list, tail)                    \
> >         for (tail = list; tail != NULL; tail = tail->next)
> >
> > and
> >
> > #define QAPI_LIST_LENGTH(list)                                      \
> >     ({                                                              \
> >         size_t _len = 0;                                            \
> >         typeof_strip_qual(list) _tail;                              \
> >         QAPI_LIST_FOR_EACH(list, tail) {                            \
> >             _len++;                                                 \
> >         }                                                           \
> >         _len;                                                       \
> >     })
> 
> Yes, but would QAPI_LIST_FOR_EACH be better than the straightfoward &
> simple for-loop?
> 
> [...]

Well I don't really remember off hand how QAPI lists work so for me I'd
have to otherwise go read the code to check this is the right way to
walk this list.

Which reminds me, why are these custom like this and not just QLIST?


-- 
MST



  reply	other threads:[~2025-10-06 14:57 UTC|newest]

Thread overview: 31+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-09-23 10:00 [PATCH v6 00/19] virtio-net: live-TAP local migration Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 01/19] net/tap: net_init_tap_one(): drop extra error propagation Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 02/19] net/tap: net_init_tap_one(): move parameter checking earlier Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 03/19] net/tap: rework net_tap_init() Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 04/19] net/tap: pass NULL to net_init_tap_one() in cases when scripts are NULL Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 05/19] net/tap: rework scripts handling Vladimir Sementsov-Ogievskiy
2025-09-23 10:39   ` Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 06/19] net/tap: setup exit notifier only when needed Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 07/19] net/tap: split net_tap_fd_init() Vladimir Sementsov-Ogievskiy
2025-09-23 10:00 ` [PATCH v6 08/19] net/tap: tap_set_sndbuf(): add return value Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 09/19] net/tap: rework tap_set_sndbuf() Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 10/19] net/tap: rework sndbuf handling Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 11/19] net/tap: introduce net_tap_setup() Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 12/19] net/tap: move vhost fd initialization to net_tap_new() Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 13/19] net/tap: finalize net_tap_set_fd() logic Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 14/19] migration: add MIG_EVENT_PRE_INCOMING Vladimir Sementsov-Ogievskiy
2025-09-30 19:25   ` Peter Xu
2025-09-23 10:01 ` [PATCH v6 15/19] net/tap: postpone tap setup to pre-incoming Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 16/19] qapi: add interface for backend-transfer virtio-net/tap migration Vladimir Sementsov-Ogievskiy
2025-10-06 13:23   ` Markus Armbruster
2025-10-06 13:33     ` Michael S. Tsirkin
2025-10-06 14:38       ` Markus Armbruster
2025-10-06 14:55         ` Michael S. Tsirkin [this message]
2025-10-06 17:06           ` Markus Armbruster
2025-10-07  8:57     ` Vladimir Sementsov-Ogievskiy
2025-10-07 11:42       ` Markus Armbruster
2025-09-23 10:01 ` [PATCH v6 17/19] virtio-net: support backend-transfer migration for virtio-net/tap Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 18/19] tests/functional: add skipWithoutSudo() decorator Vladimir Sementsov-Ogievskiy
2025-09-23 10:01 ` [PATCH v6 19/19] tests/functional: add test_x86_64_tap_migration Vladimir Sementsov-Ogievskiy
2025-09-24  8:02 ` [PATCH v6 00/19] virtio-net: live-TAP local migration Lei Yang
2025-10-01 16:33 ` Maksim Davydov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20251006105159-mutt-send-email-mst@kernel.org \
    --to=mst@redhat.com \
    --cc=armbru@redhat.com \
    --cc=berrange@redhat.com \
    --cc=davydov-max@yandex-team.ru \
    --cc=eblake@redhat.com \
    --cc=farosas@suse.de \
    --cc=jasowang@redhat.com \
    --cc=leiyang@redhat.com \
    --cc=michael.roth@amd.com \
    --cc=peterx@redhat.com \
    --cc=philmd@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=steven.sistare@oracle.com \
    --cc=thuth@redhat.com \
    --cc=vsementsov@yandex-team.ru \
    --cc=yc-core@yandex-team.ru \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).