Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2398072pxu; Mon, 7 Dec 2020 05:44:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJwpEIHdE0Nk394EKXA8SvfOGr6BEYYkS9ugRO2LmiHWh0t73pxTBuHZYIXer3cHTFNRVWu1 X-Received: by 2002:a17:906:94c5:: with SMTP id d5mr18442847ejy.427.1607348671926; Mon, 07 Dec 2020 05:44:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607348671; cv=none; d=google.com; s=arc-20160816; b=ABLROMB7o8Squr7GSiwGFKDKsXgpgvAABkOWBfYORGpQEaE9L280xUMqG7STgSgcTX 46t5PqPgh91lGejItbTjiJO32kSne4ky2NtpynehGGOGYAVLb9OjnrRNMA1GjMz6BRIs nYl9j0pmSvaDtJ2dPUudSMdj7PGmHTEx+VIPNfj1eiDS/K9DyOUg5AIImKO27y/ZD9dD hcYXg705lpcZyLIUTsb7h1llW00hK8oTOCbWpet3fK8yZoZ0GgQsiGWS0xlLsnk5+8Sz KEwo58sW8Id9WhboLuGlNr+0pRuTyiNiDdX5ZiSI1OipcKh3q+8KuVGsUUsctmhgYQLW pXvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=KYvmLxbAFyopAIQjMJW+g1uwx8LNGrZf6o6RvSm/k7A=; b=jqOvS8Wo41V5+GDYIaAFoJA1+3tAPq4DwbxFYROncHc8dTsf0KNPzH81I/u6H8K5k+ y8mp/l2yKoiQh32V/aZcjjEdPzkxXWexNr9TYmwPVoj7IJF0PVGHqPGBdNoV377PCk3o JyEAQVpQ+Jo4E8jqJn9ICplIIeRsSEYqCa1ePNgYuf9OKR57p0/06CbCwDaMAYfzqIX9 CpJvivi0MkF3VbAfiFx8RFY1RoRSWUZq73ZXS8xHe48jyPaGqtTNnUXGmEpLkNbQnuqb UjXLpqn92SvQFOG1xRjNLXPce6HyqA71Vpm625zSbeCTFoOuNorFCPB4a6/dEu1ZX4iM 1l3Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-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 dn23si7736800edb.27.2020.12.07.05.44.05; Mon, 07 Dec 2020 05:44:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726096AbgLGNn4 (ORCPT + 99 others); Mon, 7 Dec 2020 08:43:56 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32950 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726067AbgLGNnz (ORCPT ); Mon, 7 Dec 2020 08:43:55 -0500 Received: from orbyte.nwl.cc (orbyte.nwl.cc [IPv6:2001:41d0:e:133a::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 82359C0613D1; Mon, 7 Dec 2020 05:43:15 -0800 (PST) Received: from localhost ([::1]:60640 helo=tatos) by orbyte.nwl.cc with esmtp (Exim 4.94) (envelope-from ) id 1kmGnJ-0000vd-Cb; Mon, 07 Dec 2020 14:43:13 +0100 From: Phil Sutter To: Steffen Klassert Cc: linux-crypto@vger.kernel.org, netfilter-devel@vger.kernel.org, netdev@vger.kernel.org, Nicolas Dichtel Subject: [PATCH v2] xfrm: interface: Don't hide plain packets from netfilter Date: Mon, 7 Dec 2020 14:43:09 +0100 Message-Id: <20201207134309.16762-1-phil@nwl.cc> X-Mailer: git-send-email 2.28.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org With an IPsec tunnel without dedicated interface, netfilter sees locally generated packets twice as they exit the physical interface: Once as "the inner packet" with IPsec context attached and once as the encrypted (ESP) packet. With xfrm_interface, the inner packet did not traverse NF_INET_LOCAL_OUT hook anymore, making it impossible to match on both inner header values and associated IPsec data from that hook. Fix this by looping packets transmitted from xfrm_interface through NF_INET_LOCAL_OUT before passing them on to dst_output(), which makes behaviour consistent again from netfilter's point of view. Fixes: f203b76d78092 ("xfrm: Add virtual xfrm interfaces") Signed-off-by: Phil Sutter --- Changes since v1: - Extend recipients list, no code changes. --- net/xfrm/xfrm_interface.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/net/xfrm/xfrm_interface.c b/net/xfrm/xfrm_interface.c index aa4cdcf69d471..24af61c95b4d4 100644 --- a/net/xfrm/xfrm_interface.c +++ b/net/xfrm/xfrm_interface.c @@ -317,7 +317,8 @@ xfrmi_xmit2(struct sk_buff *skb, struct net_device *dev, struct flowi *fl) skb_dst_set(skb, dst); skb->dev = tdev; - err = dst_output(xi->net, skb->sk, skb); + err = NF_HOOK(skb_dst(skb)->ops->family, NF_INET_LOCAL_OUT, xi->net, + skb->sk, skb, NULL, skb_dst(skb)->dev, dst_output); if (net_xmit_eval(err) == 0) { struct pcpu_sw_netstats *tstats = this_cpu_ptr(dev->tstats); -- 2.28.0