From: Stefano Brivio <sbrivio@redhat.com>
To: Sabrina Dubroca <sd@queasysnail.net>
Cc: netdev@vger.kernel.org
Subject: Re: [PATCH net] geneve: allow changing DF behavior after creation
Date: Thu, 18 Jun 2020 17:20:35 +0200 [thread overview]
Message-ID: <20200618172035.37f99a30@redhat.com> (raw)
In-Reply-To: <20200618130347.GA2557669@bistromath.localdomain>
On Thu, 18 Jun 2020 15:03:47 +0200
Sabrina Dubroca <sd@queasysnail.net> wrote:
> 2020-06-18, 12:26:29 +0200, Stefano Brivio wrote:
> > On Thu, 18 Jun 2020 12:13:22 +0200
> > Sabrina Dubroca <sd@queasysnail.net> wrote:
> >
> > > Currently, trying to change the DF parameter of a geneve device does
> > > nothing:
> > >
> > > # ip -d link show geneve1
> > > 14: geneve1: <snip>
> > > link/ether <snip>
> > > geneve id 1 remote 10.0.0.1 ttl auto df set dstport 6081 <snip>
> > > # ip link set geneve1 type geneve id 1 df unset
> > > # ip -d link show geneve1
> > > 14: geneve1: <snip>
> > > link/ether <snip>
> > > geneve id 1 remote 10.0.0.1 ttl auto df set dstport 6081 <snip>
> > >
> > > We just need to update the value in geneve_changelink.
> > >
> > > Fixes: a025fb5f49ad ("geneve: Allow configuration of DF behaviour")
> > > Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
> > > ---
> > > drivers/net/geneve.c | 1 +
> > > 1 file changed, 1 insertion(+)
> > >
> > > diff --git a/drivers/net/geneve.c b/drivers/net/geneve.c
> > > index 75266580b586..4661ef865807 100644
> > > --- a/drivers/net/geneve.c
> > > +++ b/drivers/net/geneve.c
> > > @@ -1649,6 +1649,7 @@ static int geneve_changelink(struct net_device *dev, struct nlattr *tb[],
> > > geneve->collect_md = metadata;
> > > geneve->use_udp6_rx_checksums = use_udp6_rx_checksums;
> > > geneve->ttl_inherit = ttl_inherit;
> > > + geneve->df = df;
> >
> > I introduced this bug as I didn't notice the asymmetry with VXLAN,
> > where vxlan_nl2conf() takes care of this for both new links and link
> > changes.
>
> Yeah, I didn't notice either :/
>
> > Here, this block is duplicated in geneve_configure(), which,
> > somewhat surprisingly given the name, is not called from
> > geneve_changelink(). Did you consider factoring out (at least) this
> > block to have it shared?
>
> Then I'd have to introduce another lovely function with an absurdly
> long argument list. I'd rather clean that up in all of geneve and
> introduce something like struct vxlan_config, but it's a bit much for
> net. I'll do that once this fix finds its way into net-next.
Yeah, sure, I didn't mean you should simply copy and paste that
somewhere. Either something like struct vxlan_config used around the
current logic, or perhaps even better, something like vxlan_nl2conf()
does.
I didn't check whether something in GENEVE is so special compared to
VXLAN as to prevent this, though.
--
Stefano
next prev parent reply other threads:[~2020-06-18 15:20 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-06-18 10:13 [PATCH net] geneve: allow changing DF behavior after creation Sabrina Dubroca
2020-06-18 10:26 ` Stefano Brivio
2020-06-18 13:03 ` Sabrina Dubroca
2020-06-18 15:20 ` Stefano Brivio [this message]
2020-06-20 3:07 ` David Miller
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=20200618172035.37f99a30@redhat.com \
--to=sbrivio@redhat.com \
--cc=netdev@vger.kernel.org \
--cc=sd@queasysnail.net \
/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).