Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp30075ybh; Mon, 20 Jul 2020 09:34:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwBycIldbE/FWZ2BlpyHTfgyH4Cgi+uLbw+YFX0nKqJwW+uVKZZ5KZRgJFlyjFwG0GlXt4k X-Received: by 2002:a17:906:2f17:: with SMTP id v23mr21077509eji.343.1595262861600; Mon, 20 Jul 2020 09:34:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595262861; cv=none; d=google.com; s=arc-20160816; b=cpOFN+AFc7QeDM3s4QRvm/fOfqYXsaLzzYS4dnIGKz91pEgADUSLVtKKC1FJX+QtaV F7PytKgmB2rvzMD+ICAjYhWHo165+9xhleeI4U4wYZLOYWYrq+6yJaxsl8bPDZLzO249 bJaOp8pmdq1qM5Zu+XZJm8iKaYJWR3UvMd9JtVjZWAk7+R5NHP6PxTDOzocansPKU0an +lQCNP2Q7n2JwVj/mFVVlZ2Gwl6p8y05SdnPbuZz4jjpe024ooV+rQ9TfGTdN+tl/TgY 8Fvwdes1LQO3UqtEATz6G/9pX63DZ7KSIqYH6qzaEMJPxzmAYuBa7cDVsN2nU8Fkr6Ak bAPg== 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:dkim-signature :dkim-signature:from; bh=clYTdArRdnx8mUCi/6xsqdXNjJnzuyuPzhNso4mGT9g=; b=aMpFuw0MaKllDzqnqp9Tk0D/JknHQav+NUwyrCnlAHcorXXZEow9a/1dum/Cb9rmRX srcLkgL4C/1q1PlXwFp4sgyIAekjLoKi2KpyEN4NtgC6l579FlsnMTdcx00uP5tvZmsG 7nbAOmdwyplb+k8y/PTEmszqQ0aErGwS0jBm3/Rs5/RjSp5xJXc5z0/thzAckhMF5Loc fjFhQKxk/0i9mQysD1vO1JqTRJqEHEJuwSN9866OhTpRhMO/z2wKmHMVq5ugyQrE4LqD NNGAHcnS6+hoG6lrRDnttz1nfttmbJMKcGR04EdJEM+zytmWzlXu4KaaraRcVgYygxZU fbig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=uXP6OXj4; dkim=neutral (no key) header.i=@linutronix.de; 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=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gl18si10350725ejb.588.2020.07.20.09.33.56; Mon, 20 Jul 2020 09:34:21 -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=@linutronix.de header.s=2020 header.b=uXP6OXj4; dkim=neutral (no key) header.i=@linutronix.de; 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=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733045AbgGTQc2 (ORCPT + 99 others); Mon, 20 Jul 2020 12:32:28 -0400 Received: from Galois.linutronix.de ([193.142.43.55]:58860 "EHLO galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731814AbgGTP4m (ORCPT ); Mon, 20 Jul 2020 11:56:42 -0400 From: "Ahmed S. Darwish" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1595260599; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=clYTdArRdnx8mUCi/6xsqdXNjJnzuyuPzhNso4mGT9g=; b=uXP6OXj4rWOPT9ZuoQGhCoFDOm9E+p7U4ur8edGLpLfoB1AlvIgmmnhesTx0TREpABsnZ/ gLBb0J9qY41Vo7hNHPVFUoNpbyxJQ6VHTZ+u1tPAA2wRG7wc/CLS2o0FG/FTf99KnxuiaG s7mGpi466rjCvRjQB9KSG6vq/TkxJJR3G9cPZDgKnI/G8UHHmzzmew9jHWbqabruzHrb/9 8uMifwVm2uSKKPJ4KJGOw4VArdJERrk+U/SxEDgVxh9jSB2sB04L5H8k9jktzIHTib08LI OBgN11BbPi+ORsSWRsmaLxMDGXeUiMBADGAgY20gHwMKaWTGZraixjL1xITBZQ== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1595260599; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=clYTdArRdnx8mUCi/6xsqdXNjJnzuyuPzhNso4mGT9g=; b=fx6dou1SVwHKIuhBOH55Prdh6wdRl0YmMNh7qRjwAe1n+oDXY6kyjCRQE4DEbKFGOB8+XH 5s0q7veTTE+t/mAw== To: Peter Zijlstra , Ingo Molnar , Will Deacon Cc: Thomas Gleixner , "Paul E. McKenney" , "Sebastian A. Siewior" , Steven Rostedt , LKML , "Ahmed S. Darwish" , Pablo Neira Ayuso , Jozsef Kadlecsik , Florian Westphal , "David S. Miller" , Jakub Kicinski , netfilter-devel@vger.kernel.org, coreteam@netfilter.org, netdev@vger.kernel.org Subject: [PATCH v4 14/24] netfilter: conntrack: Use sequence counter with associated spinlock Date: Mon, 20 Jul 2020 17:55:20 +0200 Message-Id: <20200720155530.1173732-15-a.darwish@linutronix.de> In-Reply-To: <20200720155530.1173732-1-a.darwish@linutronix.de> References: <20200519214547.352050-1-a.darwish@linutronix.de> <20200720155530.1173732-1-a.darwish@linutronix.de> 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 A sequence counter write side critical section must be protected by some form of locking to serialize writers. A plain seqcount_t does not contain the information of which lock must be held when entering a write side critical section. Use the new seqcount_spinlock_t data type, which allows to associate a spinlock with the sequence counter. This enables lockdep to verify that the spinlock used for writer serialization is held when the write side critical section is entered. If lockdep is disabled this lock association is compiled out and has neither storage size nor runtime overhead. Signed-off-by: Ahmed S. Darwish --- include/net/netfilter/nf_conntrack.h | 2 +- net/netfilter/nf_conntrack_core.c | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/include/net/netfilter/nf_conntrack.h b/include/net/netfilter/nf_conntrack.h index 90690e37a56f..ea4e2010b246 100644 --- a/include/net/netfilter/nf_conntrack.h +++ b/include/net/netfilter/nf_conntrack.h @@ -286,7 +286,7 @@ int nf_conntrack_hash_resize(unsigned int hashsize); extern struct hlist_nulls_head *nf_conntrack_hash; extern unsigned int nf_conntrack_htable_size; -extern seqcount_t nf_conntrack_generation; +extern seqcount_spinlock_t nf_conntrack_generation; extern unsigned int nf_conntrack_max; /* must be called with rcu read lock held */ diff --git a/net/netfilter/nf_conntrack_core.c b/net/netfilter/nf_conntrack_core.c index 79cd9dde457b..b8c54d390f93 100644 --- a/net/netfilter/nf_conntrack_core.c +++ b/net/netfilter/nf_conntrack_core.c @@ -180,7 +180,7 @@ EXPORT_SYMBOL_GPL(nf_conntrack_htable_size); unsigned int nf_conntrack_max __read_mostly; EXPORT_SYMBOL_GPL(nf_conntrack_max); -seqcount_t nf_conntrack_generation __read_mostly; +seqcount_spinlock_t nf_conntrack_generation __read_mostly; static unsigned int nf_conntrack_hash_rnd __read_mostly; static u32 hash_conntrack_raw(const struct nf_conntrack_tuple *tuple, @@ -2598,7 +2598,8 @@ int nf_conntrack_init_start(void) /* struct nf_ct_ext uses u8 to store offsets/size */ BUILD_BUG_ON(total_extension_size() > 255u); - seqcount_init(&nf_conntrack_generation); + seqcount_spinlock_init(&nf_conntrack_generation, + &nf_conntrack_locks_all_lock); for (i = 0; i < CONNTRACK_LOCKS; i++) spin_lock_init(&nf_conntrack_locks[i]); -- 2.20.1