diff options
-rw-r--r-- | net/ipv6/seg6_local.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/net/ipv6/seg6_local.c b/net/ipv6/seg6_local.c index 609b94e970de..c6263256fcf6 100644 --- a/net/ipv6/seg6_local.c +++ b/net/ipv6/seg6_local.c | |||
@@ -357,6 +357,11 @@ static int seg6_local_input(struct sk_buff *skb) | |||
357 | struct seg6_action_desc *desc; | 357 | struct seg6_action_desc *desc; |
358 | struct seg6_local_lwt *slwt; | 358 | struct seg6_local_lwt *slwt; |
359 | 359 | ||
360 | if (skb->protocol != htons(ETH_P_IPV6)) { | ||
361 | kfree_skb(skb); | ||
362 | return -EINVAL; | ||
363 | } | ||
364 | |||
360 | slwt = seg6_local_lwtunnel(orig_dst->lwtstate); | 365 | slwt = seg6_local_lwtunnel(orig_dst->lwtstate); |
361 | desc = slwt->desc; | 366 | desc = slwt->desc; |
362 | 367 | ||
@@ -623,6 +628,9 @@ static int seg6_local_build_state(struct nlattr *nla, unsigned int family, | |||
623 | struct seg6_local_lwt *slwt; | 628 | struct seg6_local_lwt *slwt; |
624 | int err; | 629 | int err; |
625 | 630 | ||
631 | if (family != AF_INET6) | ||
632 | return -EINVAL; | ||
633 | |||
626 | err = nla_parse_nested(tb, SEG6_LOCAL_MAX, nla, seg6_local_policy, | 634 | err = nla_parse_nested(tb, SEG6_LOCAL_MAX, nla, seg6_local_policy, |
627 | extack); | 635 | extack); |
628 | 636 | ||