Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp683306pxu; Wed, 7 Oct 2020 13:04:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzfAW6Y3e8veFVG0QiNkBeIqDfD72inikeR90TIK6HCstr/DoFEwcx1kjuYt9ZomfgANb6f X-Received: by 2002:a17:907:43c0:: with SMTP id ok24mr4981445ejb.385.1602101057737; Wed, 07 Oct 2020 13:04:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602101057; cv=none; d=google.com; s=arc-20160816; b=B/pzXFELFnMwIhOS6d2zssvtfMux12JDWB5qlO93+JRIQP79btphFeqUaxHkDCcgpT sbL1SaqqpHZYZc7ZU61QbHEw4y1lHgezzFsX2YhHSw4QHd1uTlJ9tfSJPhaxmBT8HD53 OiB0kvNl5jmJXgTaO00NePc0zQeDjUVSBFAfnvK9ceSKoEphBn8nECbK6peQ8n6bw5RD aWFzQ2Om41ZY4MVSxN/SCSv9icoHjTG46zLwg9E0dK9s9bOtViFS8EWOXq6S2M3x32zf VJQDAKOqPJUyLFAiqrWXWALuMD+3OZfm/sR9dDVUXIua3NNn+r6kCkDSgRg0WmAN9AER uIVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:from:message-id:content-transfer-encoding :user-agent:subject:to:date:dkim-signature; bh=C0+5yjcysMk84GoYj0z05bOXjUBeWKhioIraoOaj5pU=; b=QOiOObgjPYFm33JkejatAR7KQscQlF3W39FVgy/Tlw2bMsv1ZSUTmYNR40rDlmFL5B s5nA1NoV8FJVqoNaz0rUadaW3AFQIUtSPJ7xmjkW0TERkBOh3winru0ZhDJY27+qWm4z +ULogAqko13CVkAgk4PdianpA276wmOJjCMSeDMpP+dg3kQ1xHPBd4Ck6s5blyKtWwFf fSGL50MvkKliy+o+DfIB3x9ALr0FQzeIcsgXdrUNjqeyIHFN7sevU1iXCSDLeZqIsugC x+Ngh2SsWUTpTT2rdMPtWAGS6y6ms5ZB7h0Iu/KpE15ux+PGaaZUc4scZ8glcg0uYcCg 67lg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@arista.com header.s=Arista-A header.b=mXoD2Q+n; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=arista.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w15si2394595edf.56.2020.10.07.13.03.54; Wed, 07 Oct 2020 13:04:17 -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=@arista.com header.s=Arista-A header.b=mXoD2Q+n; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=arista.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727937AbgJGTcx (ORCPT + 99 others); Wed, 7 Oct 2020 15:32:53 -0400 Received: from mx.aristanetworks.com ([162.210.129.12]:28723 "EHLO smtp.aristanetworks.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726129AbgJGTcx (ORCPT ); Wed, 7 Oct 2020 15:32:53 -0400 Received: from us180.sjc.aristanetworks.com (us180.sjc.aristanetworks.com [10.243.128.7]) by smtp.aristanetworks.com (Postfix) with ESMTP id 925304000A4; Wed, 7 Oct 2020 12:32:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arista.com; s=Arista-A; t=1602099172; bh=C0+5yjcysMk84GoYj0z05bOXjUBeWKhioIraoOaj5pU=; h=Date:To:Subject:From:From; b=mXoD2Q+nkriF0p709lff2+rKBzk1REnY4s8WWlfDsdp8XssJvXd27weNqnsFx5/U/ sRUi67pxVPh5Y1O4b2/L1D+zOL9gmM86BSOv1xl5badSNO8lnSusEz9+dTETDN/B2P yDPwY0lve2/jTMyBTnHwZM2B3zQZ1yFqXPIE+Q458cvvJ+bWR0ZKcN8LvQTzqSDKl9 c8HjBTU+6M9Ifi9cVezxItw69tTl98ScyOuKIrXsD0rOAjhqdMPRjsWLzgrg449rob BLG0t3+vLnLsM8/zxfEgRo1tDe4Sahgq6xzk7LYcqIq14UeYcigAnEkAUCMGKhDceW 7zhhKeaxmY6cQ== Received: by us180.sjc.aristanetworks.com (Postfix, from userid 10189) id 7009D95C169C; Wed, 7 Oct 2020 12:32:52 -0700 (PDT) Date: Wed, 07 Oct 2020 12:32:52 -0700 To: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, coreteam@netfilter.org, netfilter-devel@vger.kernel.org, kuba@kernel.org, davem@davemloft.net, fw@strlen.org, kadlec@netfilter.org, pablo@netfilter.org, fruggeri@arista.com Subject: [PATCH nf v2] netfilter: conntrack: connection timeout after re-register User-Agent: Heirloom mailx 12.5 7/5/10 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Message-Id: <20201007193252.7009D95C169C@us180.sjc.aristanetworks.com> From: fruggeri@arista.com (Francesco Ruggeri) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If the first packet conntrack sees after a re-register is an outgoing keepalive packet with no data (SEG.SEQ = SND.NXT-1), td_end is set to SND.NXT-1. When the peer correctly acknowledges SND.NXT, tcp_in_window fails check III (Upper bound for valid (s)ack: sack <= receiver.td_end) and returns false, which cascades into nf_conntrack_in setting skb->_nfct = 0 and in later conntrack iptables rules not matching. In cases where iptables are dropping packets that do not match conntrack rules this can result in idle tcp connections to time out. v2: adjust td_end when getting the reply rather than when sending out the keepalive packet. Fixes: f94e63801ab2 ("netfilter: conntrack: reset tcp maxwin on re-register") Signed-off-by: Francesco Ruggeri --- net/netfilter/nf_conntrack_proto_tcp.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/net/netfilter/nf_conntrack_proto_tcp.c b/net/netfilter/nf_conntrack_proto_tcp.c index e8c86ee4c1c4..c8fb2187ad4b 100644 --- a/net/netfilter/nf_conntrack_proto_tcp.c +++ b/net/netfilter/nf_conntrack_proto_tcp.c @@ -541,13 +541,20 @@ static bool tcp_in_window(const struct nf_conn *ct, swin = win << sender->td_scale; sender->td_maxwin = (swin == 0 ? 1 : swin); sender->td_maxend = end + sender->td_maxwin; - /* - * We haven't seen traffic in the other direction yet - * but we have to tweak window tracking to pass III - * and IV until that happens. - */ - if (receiver->td_maxwin == 0) + if (receiver->td_maxwin == 0) { + /* We haven't seen traffic in the other + * direction yet but we have to tweak window + * tracking to pass III and IV until that + * happens. + */ receiver->td_end = receiver->td_maxend = sack; + } else if (sack == receiver->td_end + 1) { + /* Likely a reply to a keepalive. + * Needed for III. + */ + receiver->td_end++; + } + } } else if (((state->state == TCP_CONNTRACK_SYN_SENT && dir == IP_CT_DIR_ORIGINAL) -- 2.28.0