Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp1737656ybn; Thu, 26 Sep 2019 01:12:42 -0700 (PDT) X-Google-Smtp-Source: APXvYqy7MykDOUpIEzFm0Ep3rmtQISdwhQLQcAJpDviUnvL0I/yEW3eYTroqGZnxkJHGFa8nHYnM X-Received: by 2002:aa7:d501:: with SMTP id y1mr2154683edq.226.1569485562771; Thu, 26 Sep 2019 01:12:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569485562; cv=none; d=google.com; s=arc-20160816; b=ipdHS2//Jp4aGB2BE8jiVTBM5ktxzCUTW5qgKCkK+8cxVzEL2P+KF8ufd/SmU7CppC Rwp8oRvjICKSF8VDrXF/gtZob3ueXQflitdUWBzNSGyH6pl1arLWEP8XMZMhSIUvwZLA Z86hxEGW04h27XTJ/o9KlD0F0sfC5wd8t/dnsd5ts6LsML5qs3DHj5ym5ron/fLA7IA1 Y0liXoHV2AfJ8YtA39czHx/240w5NOxk6cBx5A54dN+KCuIFb7owsOo9I6wKg6DhnH3A G0bPbYjqeZVhjU6AfEcITtWvzWC2ogFGhv6Qt7n7KYG+gDuFVOQ+uVl5Ac2s0mYA8EfN jS2A== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=Ga7lZxceI3ldVQqXqxTXSL25kTtTRNejVagaTKOKEF8=; b=xRBohGtxV0Hf3nMH1h44zY+3Mo7xF5+T1Sunf7OPCJze9bfKsJYzgmqo4i/3VfA4VV OHg4x4v1/BvY/5TYE2iUNPPhLPKbldI/O1wg5reOBAahj5SxvI0IrXr0SoHgaTlKx3ZE nA0AouTOhVWful3utyoewFwWlz7IavwYlaUJwD9UVpWCQc6pjH50pTqCS7J48ape2r8C NEb7XVid5PRVxHdFJGcTJeLmhw2aLyzIlJy1c8nIieKusrXYMBqU7vUJkHSs1BP1B3Fu /2JHx0o0c4RBMOC7FRWDT1aPBSqadQzHT1xqhGfNlTjJ+1ZjRBf6m+bQBKG/vL4Khgvu /7qw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@zx2c4.com header.s=mail header.b=H7wz64VD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zx2c4.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t26si587834eju.238.2019.09.26.01.12.19; Thu, 26 Sep 2019 01:12:42 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@zx2c4.com header.s=mail header.b=H7wz64VD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zx2c4.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2406249AbfIXOBh (ORCPT + 99 others); Tue, 24 Sep 2019 10:01:37 -0400 Received: from frisell.zx2c4.com ([192.95.5.64]:54159 "EHLO frisell.zx2c4.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725855AbfIXOBg (ORCPT ); Tue, 24 Sep 2019 10:01:36 -0400 Received: by frisell.zx2c4.com (ZX2C4 Mail Server) with ESMTP id 631b8b0a; Tue, 24 Sep 2019 13:15:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha1; c=relaxed; d=zx2c4.com; h=from:to:cc :subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; s=mail; bh=Ni0hMWlCiFMnaQshc8kXJTh4/ bA=; b=H7wz64VDaOrxEUv3s1Ld0Cxy5fxjQ7KDf3qDpuwvJWYtNDFt3ZOoJrMbC +VqSW6VXZG/sGw36U8i5a1LZBEVod3YhBIIuKOT7fuWAbe+YoF0Ii/mkuyUXPpLb bKeiyEWoUlR4gxE5yTTcO2TNE4bjON9h/pVWs+ax0xr7Z+3pSEffUBsmRtm7zZ5k 5tnqb0NDzl44j7+o1E3TBKCgCNUi8x9QVr45dtJAcagJnUkPDsR5GsA1RxW2dhu4 Rz2TkKCiQCYihPKYSNCFbY788kGurMsV9BXZ1trgo6IZkm2xMDPzgPTUar8MQ4t8 CfZQsAJPoOoJGIJSgO/oyZvKmlizA== Received: by frisell.zx2c4.com (ZX2C4 Mail Server) with ESMTPSA id 44093bc1 (TLSv1.2:ECDHE-RSA-AES256-GCM-SHA384:256:NO); Tue, 24 Sep 2019 13:15:56 +0000 (UTC) From: "Jason A. Donenfeld" To: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, davem@davemloft.net, weiwan@google.com Cc: "Jason A. Donenfeld" , stable@vger.kernel.org Subject: [PATCH v2] ipv6: do not free rt if FIB_LOOKUP_NOREF is set on suppress rule Date: Tue, 24 Sep 2019 16:01:28 +0200 Message-Id: <20190924140128.19394-1-Jason@zx2c4.com> In-Reply-To: <20190924.145257.2013712373872209531.davem@davemloft.net> References: <20190924.145257.2013712373872209531.davem@davemloft.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit 7d9e5f422150 removed references from certain dsts, but accounting for this never translated down into the fib6 suppression code. This bug was triggered by WireGuard users who use wg-quick(8), which uses the "suppress-prefix" directive to ip-rule(8) for routing all of their internet traffic without routing loops. The test case added here causes the reference underflow by causing packets to evaluate a suppress rule. Cc: stable@vger.kernel.org Fixes: 7d9e5f422150 ("ipv6: convert major tx path to use RT6_LOOKUP_F_DST_NOREF") Signed-off-by: Jason A. Donenfeld --- net/ipv6/fib6_rules.c | 3 ++- tools/testing/selftests/net/fib_tests.sh | 17 ++++++++++++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/net/ipv6/fib6_rules.c b/net/ipv6/fib6_rules.c index d22b6c140f23..f9e8fe3ff0c5 100644 --- a/net/ipv6/fib6_rules.c +++ b/net/ipv6/fib6_rules.c @@ -287,7 +287,8 @@ static bool fib6_rule_suppress(struct fib_rule *rule, struct fib_lookup_arg *arg return false; suppress_route: - ip6_rt_put(rt); + if (!(arg->flags & FIB_LOOKUP_NOREF)) + ip6_rt_put(rt); return true; } diff --git a/tools/testing/selftests/net/fib_tests.sh b/tools/testing/selftests/net/fib_tests.sh index 4465fc2dae14..c2c5f2bf0f95 100755 --- a/tools/testing/selftests/net/fib_tests.sh +++ b/tools/testing/selftests/net/fib_tests.sh @@ -9,7 +9,7 @@ ret=0 ksft_skip=4 # all tests in this script. Can be overridden with -t option -TESTS="unregister down carrier nexthop ipv6_rt ipv4_rt ipv6_addr_metric ipv4_addr_metric ipv6_route_metrics ipv4_route_metrics ipv4_route_v6_gw rp_filter" +TESTS="unregister down carrier nexthop suppress ipv6_rt ipv4_rt ipv6_addr_metric ipv4_addr_metric ipv6_route_metrics ipv4_route_metrics ipv4_route_v6_gw rp_filter" VERBOSE=0 PAUSE_ON_FAIL=no @@ -614,6 +614,20 @@ fib_nexthop_test() cleanup } +fib_suppress_test() +{ + $IP link add dummy1 type dummy + $IP link set dummy1 up + $IP -6 route add default dev dummy1 + $IP -6 rule add table main suppress_prefixlength 0 + ping -f -c 1000 -W 1 1234::1 || true + $IP -6 rule del table main suppress_prefixlength 0 + $IP link del dummy1 + + # If we got here without crashing, we're good. + return 0 +} + ################################################################################ # Tests on route add and replace @@ -1591,6 +1605,7 @@ do fib_carrier_test|carrier) fib_carrier_test;; fib_rp_filter_test|rp_filter) fib_rp_filter_test;; fib_nexthop_test|nexthop) fib_nexthop_test;; + fib_suppress_test|suppress) fib_suppress_test;; ipv6_route_test|ipv6_rt) ipv6_route_test;; ipv4_route_test|ipv4_rt) ipv4_route_test;; ipv6_addr_metric) ipv6_addr_metric_test;; -- 2.21.0