Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp538605ybz; Wed, 22 Apr 2020 03:15:05 -0700 (PDT) X-Google-Smtp-Source: APiQypJWnA6sGodtBWYUJkDp/sktTbBWCagvrlsBe2iuuK6XvH3htPLkYPXr3QCFobRktHzaJLMO X-Received: by 2002:a05:6402:1d88:: with SMTP id dk8mr14088943edb.52.1587550505189; Wed, 22 Apr 2020 03:15:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587550505; cv=none; d=google.com; s=arc-20160816; b=ceb6aDwcyF9d1KB/pWF/8iQ/CeA7pWdYQDZjIA/hofNDMSqcwWH4ocfs2IJxBTWewS lwtmR6CKuhCqM4p9K/srlcfUyH446tXUZTL7h4i7ppxQoyG5hADqJsA5BbGOppOHBJ3Y 4FiplRoeF6gMM1KdosDjLG83d6UBEPs/NRbSIYLuvVga/ZaGJj932wSDmfTmj+wYEkMh MpGHhJARS4iri5or84CMLIXiBtUjy54VzZvw5TbBGazx1YE/WbXFYvR8/IyJmP6wDcSM x0FI/tOg2JauTxgzr8jWZa5JbYSRfEUSd2YjC4392g1eX+Rp1ZBE9jy14yHiR+1W/lTC QRLA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=z7nR78Oo6dJyaRNAEQZpvPUS9XO0JDHhbRWShnIG/60=; b=lAvPlUtuSAEzQe2aRfEtJLGbGdtNuXeXz6jZkbHsf89HUZuvpDMaE14v9GVlevobF0 HHW3Kyq5pcvY3JqVRw3nb6LeRURIGo7NlyImWd7cKhhWYuCfaXPro5FscyjeQFQ768u0 BRtYPeb8ST1iOsCwFamTzy4hy2MO+zPtO4WtWoDV/ingHp44sxVzvD/8t9/v8ZmlygLi /z3Ot9Ao/eykKS30nD7k6RbqCyNZr0XA56rCI3DAMuKhEx3L+8pXikvf5lmzRMfbbdaV U7aOIYhU3ikK8aZ9xmvoSxCUzVpKGDB4OFs8o3xTwUlAchEIl9WqtFLfM/+oBGW6Mybk rfkw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DFbZfgFl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y13si3164980edq.430.2020.04.22.03.14.41; Wed, 22 Apr 2020 03:15:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DFbZfgFl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729010AbgDVKMi (ORCPT + 99 others); Wed, 22 Apr 2020 06:12:38 -0400 Received: from mail.kernel.org ([198.145.29.99]:45426 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728819AbgDVKMZ (ORCPT ); Wed, 22 Apr 2020 06:12:25 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D616F20575; Wed, 22 Apr 2020 10:12:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587550344; bh=gWC0m1bf5GBLVpVZ+GDC5apO0b5wKNLHiXHzt13xFmM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DFbZfgFl1oejmNCrdiWX3fPatRTKQM9E7ATum+UzE3Rd/JyjKA9emkBIfcjyeDzN0 gyw+RD8C3c7YyBGtX6TL8PbVrX/wQ/HtGYz5bwLQNI8bvfMVkukVEc1NAywe6umNM0 Zh0G1v8ACn+LD5NWt7FNHOlnU7wvE6dEEvQHRGlI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tim Stallard , "David S. Miller" Subject: [PATCH 4.14 109/199] net: ipv6: do not consider routes via gateways for anycast address check Date: Wed, 22 Apr 2020 11:57:15 +0200 Message-Id: <20200422095108.624850147@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200422095057.806111593@linuxfoundation.org> References: <20200422095057.806111593@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tim Stallard [ Upstream commit 03e2a984b6165621f287fadf5f4b5cd8b58dcaba ] The behaviour for what is considered an anycast address changed in commit 45e4fd26683c ("ipv6: Only create RTF_CACHE routes after encountering pmtu exception"). This now considers the first address in a subnet where there is a route via a gateway to be an anycast address. This breaks path MTU discovery and traceroutes when a host in a remote network uses the address at the start of a prefix (eg 2600:: advertised as 2600::/48 in the DFZ) as ICMP errors will not be sent to anycast addresses. This patch excludes any routes with a gateway, or via point to point links, like the behaviour previously from rt6_is_gw_or_nonexthop in net/ipv6/route.c. This can be tested with: ip link add v1 type veth peer name v2 ip netns add test ip netns exec test ip link set lo up ip link set v2 netns test ip link set v1 up ip netns exec test ip link set v2 up ip addr add 2001:db8::1/64 dev v1 nodad ip addr add 2001:db8:100:: dev lo nodad ip netns exec test ip addr add 2001:db8::2/64 dev v2 nodad ip netns exec test ip route add unreachable 2001:db8:1::1 ip netns exec test ip route add 2001:db8:100::/64 via 2001:db8::1 ip netns exec test sysctl net.ipv6.conf.all.forwarding=1 ip route add 2001:db8:1::1 via 2001:db8::2 ping -I 2001:db8::1 2001:db8:1::1 -c1 ping -I 2001:db8:100:: 2001:db8:1::1 -c1 ip addr delete 2001:db8:100:: dev lo ip netns delete test Currently the first ping will get back a destination unreachable ICMP error, but the second will never get a response, with "icmp6_send: acast source" logged. After this patch, both get destination unreachable ICMP replies. Fixes: 45e4fd26683c ("ipv6: Only create RTF_CACHE routes after encountering pmtu exception") Signed-off-by: Tim Stallard Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- include/net/ip6_route.h | 1 + 1 file changed, 1 insertion(+) --- a/include/net/ip6_route.h +++ b/include/net/ip6_route.h @@ -207,6 +207,7 @@ static inline bool ipv6_anycast_destinat return rt->rt6i_flags & RTF_ANYCAST || (rt->rt6i_dst.plen < 127 && + !(rt->rt6i_flags & (RTF_GATEWAY | RTF_NONEXTHOP)) && ipv6_addr_equal(&rt->rt6i_dst.addr, daddr)); }