Skip to content

Commit 4974d5f

Browse files
LorenzoBianconidavem330
authored andcommitted
net: ip6_gre: initialize erspan_ver just for erspan tunnels
After commit c706863 ("net: ip6_gre: always reports o_key to userspace"), ip6gre and ip6gretap tunnels started reporting TUNNEL_KEY output flag even if it is not configured. ip6gre_fill_info checks erspan_ver value to add TUNNEL_KEY for erspan tunnels, however in commit 84581bd ("erspan: set erspan_ver to 1 by default when adding an erspan dev") erspan_ver is initialized to 1 even for ip6gre or ip6gretap Fix the issue moving erspan_ver initialization in a dedicated routine Fixes: c706863 ("net: ip6_gre: always reports o_key to userspace") Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@redhat.com> Reviewed-by: Greg Rose <gvrose8192@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent a31687e commit 4974d5f

File tree

1 file changed

+20
-14
lines changed

1 file changed

+20
-14
lines changed

net/ipv6/ip6_gre.c

Lines changed: 20 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -1719,6 +1719,24 @@ static int ip6erspan_tap_validate(struct nlattr *tb[], struct nlattr *data[],
17191719
return 0;
17201720
}
17211721

1722+
static void ip6erspan_set_version(struct nlattr *data[],
1723+
struct __ip6_tnl_parm *parms)
1724+
{
1725+
parms->erspan_ver = 1;
1726+
if (data[IFLA_GRE_ERSPAN_VER])
1727+
parms->erspan_ver = nla_get_u8(data[IFLA_GRE_ERSPAN_VER]);
1728+
1729+
if (parms->erspan_ver == 1) {
1730+
if (data[IFLA_GRE_ERSPAN_INDEX])
1731+
parms->index = nla_get_u32(data[IFLA_GRE_ERSPAN_INDEX]);
1732+
} else if (parms->erspan_ver == 2) {
1733+
if (data[IFLA_GRE_ERSPAN_DIR])
1734+
parms->dir = nla_get_u8(data[IFLA_GRE_ERSPAN_DIR]);
1735+
if (data[IFLA_GRE_ERSPAN_HWID])
1736+
parms->hwid = nla_get_u16(data[IFLA_GRE_ERSPAN_HWID]);
1737+
}
1738+
}
1739+
17221740
static void ip6gre_netlink_parms(struct nlattr *data[],
17231741
struct __ip6_tnl_parm *parms)
17241742
{
@@ -1767,20 +1785,6 @@ static void ip6gre_netlink_parms(struct nlattr *data[],
17671785

17681786
if (data[IFLA_GRE_COLLECT_METADATA])
17691787
parms->collect_md = true;
1770-
1771-
parms->erspan_ver = 1;
1772-
if (data[IFLA_GRE_ERSPAN_VER])
1773-
parms->erspan_ver = nla_get_u8(data[IFLA_GRE_ERSPAN_VER]);
1774-
1775-
if (parms->erspan_ver == 1) {
1776-
if (data[IFLA_GRE_ERSPAN_INDEX])
1777-
parms->index = nla_get_u32(data[IFLA_GRE_ERSPAN_INDEX]);
1778-
} else if (parms->erspan_ver == 2) {
1779-
if (data[IFLA_GRE_ERSPAN_DIR])
1780-
parms->dir = nla_get_u8(data[IFLA_GRE_ERSPAN_DIR]);
1781-
if (data[IFLA_GRE_ERSPAN_HWID])
1782-
parms->hwid = nla_get_u16(data[IFLA_GRE_ERSPAN_HWID]);
1783-
}
17841788
}
17851789

17861790
static int ip6gre_tap_init(struct net_device *dev)
@@ -2203,6 +2207,7 @@ static int ip6erspan_newlink(struct net *src_net, struct net_device *dev,
22032207
int err;
22042208

22052209
ip6gre_netlink_parms(data, &nt->parms);
2210+
ip6erspan_set_version(data, &nt->parms);
22062211
ign = net_generic(net, ip6gre_net_id);
22072212

22082213
if (nt->parms.collect_md) {
@@ -2248,6 +2253,7 @@ static int ip6erspan_changelink(struct net_device *dev, struct nlattr *tb[],
22482253
if (IS_ERR(t))
22492254
return PTR_ERR(t);
22502255

2256+
ip6erspan_set_version(data, &p);
22512257
ip6gre_tunnel_unlink_md(ign, t);
22522258
ip6gre_tunnel_unlink(ign, t);
22532259
ip6erspan_tnl_change(t, &p, !tb[IFLA_MTU]);

0 commit comments

Comments
 (0)