Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2530521lqp; Mon, 25 Mar 2024 01:19:36 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXUj+TeAy8gxelFIS0Z0RLMmz6yxpM+r+kUCObHbnymg8YO6TJXM0tuvF7Pctn5mtlUeWj78rZmU4MKxAoJ7qQI5xbG4ToPS/HQJLfRAQ== X-Google-Smtp-Source: AGHT+IGBOjDNmgj4+w24GA09Ff30QxXkOyy5rPTObzOkTR8ux+xPYJV4y5dYP1RbKIH0FKEBv+xJ X-Received: by 2002:a17:906:249a:b0:a46:cef3:4aba with SMTP id e26-20020a170906249a00b00a46cef34abamr3682431ejb.75.1711354776297; Mon, 25 Mar 2024 01:19:36 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711354776; cv=pass; d=google.com; s=arc-20160816; b=Mi5LsGGnPoRIv1VuhJwSX43BMaF7lpWFn+TTYBBslBa7YihGRxGqMztcsYy/FtGmjj 4AM2xW80yYNo7dIANXEr9qViTGtgDkJaqZ/AgBVWDyb+1Z4oKopIDcnodknBGmbPLyM4 m4cz3yitEW9L0gUagXRWtSxN3PV/dNGU8YozTvSVQkGS6xfUK2vEIhkUVGYBR/DQ/TXh XXcUsY2ztSAGnyo18I0XMB7kgjFq6icZtGb2exE1J40UKfE/0VWEdUgqzSZTwWLD7sWR xUgz2tXzAqMnDnLpIC65+aAxSeiSsezT+hwjeI/p56f2E5iufX+mxGfAhCp3IMRAeEYB w05A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=MJ4Tpv1rBFGauqFJElaHMkoRUZ3LBpTdEyk2WWl0eFQ=; fh=a40m1cIRpERCNllX3KCGlQH0a9Lw4vzrfu7HykomUeA=; b=rBybiLYHfBwz22niFQ1PJSvG7nPCHtiAKekPklAtKnW0efibgaZvt2PtWLDNJZjXW4 D8OUN9Mmha5aK1CiBc6xjpDYF3KQcq2VecBOA+ZLF/01rz2roqrCCUTG34wsRnNSvNvD lwysvjxOauMFM+hoep8OuSTIsu4opX7fOMbJ2HZgwI/C/g/0UZrLEMH7kmf+6ByEJvxn DoH1gWDKfkvo3DsfHUMYJGE3DHRhzNTGqiWLnSLQSfC8na4c4BV4/337WjNpvYHc0M00 5Ba1Nkvx0bABRgqNC7ji5MaVXl9To8ckBQT6RUEn9VtTdj+AJL1jub0zabEtx5ZABUuy 8kLQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YKhrZt4F; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116042-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116042-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id le13-20020a170907170d00b00a4662353230si2313965ejc.681.2024.03.25.01.19.36 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 01:19:36 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-116042-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YKhrZt4F; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116042-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116042-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 0B7421F305CA for ; Mon, 25 Mar 2024 08:19:36 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id E80AA272989; Mon, 25 Mar 2024 03:28:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="YKhrZt4F" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EBB5417653A; Sun, 24 Mar 2024 23:37:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323434; cv=none; b=pYuZXn6zXpUKXJot3H4C6PijyywL6XWFZpkQP1+k5669R0pqW/Kw7T812IvzYP5S/l6TRO99+TTm1/1kZ91yBa30gGMtUwQcRmJVGVvlJKnOilssJ0OgAun3TZ4p6c2Kp5liE+3jrlGZydhfOYb0SW0cGXQOYJC64roaYkQ5GEA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323434; c=relaxed/simple; bh=vHQWxmR2KBzDLTijSawxGqzNKDYiaWW7CDZBDWPM3Bs=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=W05YbJGq8ITQMQ+gVvTtZ4uQpZX5252+S7izWX11lANLo9NLXrFsDL1Zq7w11pitxnkPfVjiHBMb3TmaHH6rrFS70ooVTE81fJ+ektESHa94mHV4/EI3el7DLLPQY7VqffndvQd2hTMS+ECW0XpUVFFMQvjJRwhFgyg6pKhfrJM= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=YKhrZt4F; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 06CF5C433C7; Sun, 24 Mar 2024 23:37:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711323433; bh=vHQWxmR2KBzDLTijSawxGqzNKDYiaWW7CDZBDWPM3Bs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=YKhrZt4FPrPUQ6J0QvQ9l+4plGds6Xv6AaHs2fmNhlEUMVN206neUIeU3NJruTPYP ywjsIuzCW82oey6YqQO46UAMHjbmLelvCF70aTI6ck5hJtz0nS/KUh7qFvuMpM7v1r a58gOiBptHfBkKP0qoRAIRUiWOLAMNULIiCnwcaOvjQw/5hotM3fW21u8hUdDwp6z2 wiBRv9bauvfDyrnN6FFv9WrXoxJQKIAPQIM1rOmrRZUDRP46TBRHzzbEAD/K0LW1KX v1K6lKY4pp2kIhBQztaAwvlF0YyecPisAX88Y5m6sLSgK7RGqLUoRE6sbz3fzNjda4 WnxealhnLxN/g== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Shiming Cheng , Lena Wang , David Ahern , "David S . Miller" , Sasha Levin Subject: [PATCH 5.15 136/317] ipv6: fib6_rules: flush route cache when rule is changed Date: Sun, 24 Mar 2024 19:31:56 -0400 Message-ID: <20240324233458.1352854-137-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324233458.1352854-1-sashal@kernel.org> References: <20240324233458.1352854-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Shiming Cheng [ Upstream commit c4386ab4f6c600f75fdfd21143f89bac3e625d0d ] When rule policy is changed, ipv6 socket cache is not refreshed. The sock's skb still uses a outdated route cache and was sent to a wrong interface. To avoid this error we should update fib node's version when rule is changed. Then skb's route will be reroute checked as route cache version is already different with fib node version. The route cache is refreshed to match the latest rule. Fixes: 101367c2f8c4 ("[IPV6]: Policy Routing Rules") Signed-off-by: Shiming Cheng Signed-off-by: Lena Wang Reviewed-by: David Ahern Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/ipv6/fib6_rules.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/net/ipv6/fib6_rules.c b/net/ipv6/fib6_rules.c index dcedfe29d9d93..8e9e80eb0f329 100644 --- a/net/ipv6/fib6_rules.c +++ b/net/ipv6/fib6_rules.c @@ -446,6 +446,11 @@ static size_t fib6_rule_nlmsg_payload(struct fib_rule *rule) + nla_total_size(16); /* src */ } +static void fib6_rule_flush_cache(struct fib_rules_ops *ops) +{ + rt_genid_bump_ipv6(ops->fro_net); +} + static const struct fib_rules_ops __net_initconst fib6_rules_ops_template = { .family = AF_INET6, .rule_size = sizeof(struct fib6_rule), @@ -458,6 +463,7 @@ static const struct fib_rules_ops __net_initconst fib6_rules_ops_template = { .compare = fib6_rule_compare, .fill = fib6_rule_fill, .nlmsg_payload = fib6_rule_nlmsg_payload, + .flush_cache = fib6_rule_flush_cache, .nlgroup = RTNLGRP_IPV6_RULE, .policy = fib6_rule_policy, .owner = THIS_MODULE, -- 2.43.0