Message ID | 1393502278-32297-1-git-send-email-hans@schillstrom.com |
---|---|
State | Accepted, archived |
Delegated to: | David Miller |
Headers | show |
From: Hans Schillstrom <hans@schillstrom.com> Date: Thu, 27 Feb 2014 12:57:58 +0100 > The commit 9195bb8e381d81d5a315f911904cdf0cfcc919b8 ("ipv6: improve > ipv6_find_hdr() to skip empty routing headers") broke ipv6_find_hdr(). > > When a target is specified like IPPROTO_ICMPV6 ipv6_find_hdr() > returns -ENOENT when it's found, not the header as expected. > > A part of IPVS is broken and possible also nft_exthdr_eval(). > When target is -1 which it is most cases, it works. > > This patch exits the do while loop if the specific header is found > so the nexthdr could be returned as expected. > > Reported-by: Art -kwaak- van Breemen <ard@telegraafnet.nl> > Signed-off-by: Hans Schillstrom <hans@schillstrom.com> > CC:Ansis Atteka <aatteka@nicira.com> Looks good, applied and queued up for -stable, thanks! -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/net/ipv6/exthdrs_core.c b/net/ipv6/exthdrs_core.c index 140748d..8af3eb5 100644 --- a/net/ipv6/exthdrs_core.c +++ b/net/ipv6/exthdrs_core.c @@ -212,7 +212,7 @@ int ipv6_find_hdr(const struct sk_buff *skb, unsigned int *offset, found = (nexthdr == target); if ((!ipv6_ext_hdr(nexthdr)) || nexthdr == NEXTHDR_NONE) { - if (target < 0) + if (target < 0 || found) break; return -ENOENT; }
The commit 9195bb8e381d81d5a315f911904cdf0cfcc919b8 ("ipv6: improve ipv6_find_hdr() to skip empty routing headers") broke ipv6_find_hdr(). When a target is specified like IPPROTO_ICMPV6 ipv6_find_hdr() returns -ENOENT when it's found, not the header as expected. A part of IPVS is broken and possible also nft_exthdr_eval(). When target is -1 which it is most cases, it works. This patch exits the do while loop if the specific header is found so the nexthdr could be returned as expected. Reported-by: Art -kwaak- van Breemen <ard@telegraafnet.nl> Signed-off-by: Hans Schillstrom <hans@schillstrom.com> CC:Ansis Atteka <aatteka@nicira.com> --- net/ipv6/exthdrs_core.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)