[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <38c9c698-6304-dfa8-7b79-a1cb1e00860b@ovn.org>
Date: Wed, 17 Aug 2022 20:19:26 +0200
From: Ilya Maximets <i.maximets@....org>
To: Andrey Zhadchenko <andrey.zhadchenko@...tuozzo.com>,
netdev@...r.kernel.org
Cc: dev@...nvswitch.org, brauner@...nel.org, edumazet@...gle.com,
avagin@...gle.com, alexander.mikhalitsyn@...tuozzo.com,
kuba@...nel.org, pabeni@...hat.com, davem@...emloft.net,
ptikhomirov@...tuozzo.com, i.maximets@....org,
Aaron Conole <aconole@...hat.com>
Subject: Re: [ovs-dev] [PATCH net-next 0/1] openvswitch: allow specifying
ifindex of new interfaces
On 8/17/22 14:49, Andrey Zhadchenko via dev wrote:
> Hi!
>
> CRIU currently do not support checkpoint/restore of OVS configurations, but
> there was several requests for it. For example,
> https://github.com/lxc/lxc/issues/2909
>
> The main problem is ifindexes of newly created interfaces. We realy need to
> preserve them after restore. Current openvswitch API does not allow to
> specify ifindex. Most of the time we can just create an interface via
> generic netlink requests and plug it into ovs but datapaths (generally any
> OVS_VPORT_TYPE_INTERNAL) can only be created via openvswitch requests which
> do not support selecting ifindex.
Hmm. Assuming you restored network interfaces by re-creating them
on a target system, but I'm curious how do you restore the upcall PID?
Are you somehow re-creating the netlink socket with the same PID?
If that will not be done, no traffic will be able to flow through OVS
anyway until you remove/re-add the port in userspace or re-start OVS.
Or am I missing something?
Best regards, Ilya Maximets.
>
> This patch allows to do so.
> For new datapaths I decided to use dp_infindex in header as infindex
> because it control ifindex for other requests too.
> For internal vports I reused OVS_VPORT_ATTR_IFINDEX.
>
> The only concern I have is that previously dp_ifindex was not used for
> OVS_DP_VMD_NEW requests and some software may not set it to zero. However
> we have been running this patch at Virtuozzo for 2 years and have not
> encountered this problem. Not sure if it is worth to add new
> ovs_datapath_attr instead.
>
>
> As a broader solution, another generic approach is possible: modify
> __dev_change_net_namespace() to allow changing ifindexes within the same
> netns. Yet we will still need to ignore NETIF_F_NETNS_LOCAL and I am not
> sure that all its users are ready for ifindex change.
> This will be indeed better for CRIU so we won't need to change every SDN
> module to be able to checkpoint/restore it. And probably avoid some bloat.
> What do you think of this?
>
> Andrey Zhadchenko (1):
> openvswitch: allow specifying ifindex of new interfaces
>
> include/uapi/linux/openvswitch.h | 4 ++++
> net/openvswitch/datapath.c | 16 ++++++++++++++--
> net/openvswitch/vport-internal_dev.c | 1 +
> net/openvswitch/vport.h | 2 ++
> 4 files changed, 21 insertions(+), 2 deletions(-)
>
Powered by blists - more mailing lists