Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3314522ybt; Mon, 29 Jun 2020 22:46:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzMwiEP7DL5VrBDr2nCds9vbkCYMXMO88DwNPj7gFBAZsCOkGdxqISSyaxWwks4mBSfH234 X-Received: by 2002:aa7:d78b:: with SMTP id s11mr15375975edq.319.1593496015234; Mon, 29 Jun 2020 22:46:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593496015; cv=none; d=google.com; s=arc-20160816; b=0BXCZvHswKFH6VZT0MHstoI6jVzN7lMH0zBhjIfcUn6cUuMcVBZjwnC8uRzDZd5I2z VABsEaBEnd83cuu8SQQd0+JjqKgOEs3jWHaOeKK/gXrUOmzYXhgICk3/Hvgncs0+Lybo MxHTWltN1ZT5NQAGq6QNT19Enq3Ofde+MkXXhoBUPTM6Ay5LWmTUxoThOKKbpBGyXp3b KTaNkoOAVEt2m2wqSPnlQ0Ku3qqWKpDG+ucpxYbVEMP4jIFM2QWRwqngHfctC96HrX8Q 92bwTZ6SWHoxzfrtvGN8JljsTpGRfcZ/aWKo8RCM/ivXz0swnnuGbmysdPEn25GD+osm Ccvw== 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=wKd8jxVxHsYkgbh3pSPJG/AYZrCWanaGw5KUviZ8tWdpblnRhlXkgaiNeAvKs4H+vo hWPB5ZbKkmfeG9FEJmgDUuHhHxQF8ResoBtRooaOVSliT0J4vVwnxbTCCyFfmXMyK33Z 87CUksKryWD6TwMWOC0ubm/Cy0o4lpESU2fslducpFkGruUdK5wwmO27x2o2lX8PzRoQ yG1NoA2ph3xhyBsvfGdVvIsD01p5uw2UJ24GKPbvrJEinqkkVmYEcdFMBdyhMjT2XvLi GbxMPgUoN8Vajc/jSnfoX4CLgGIswrIqhIfxgm1JjgehGFE0W7uz56FWdjEXqSTfDF6E nYVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b="T/LmeQNK"; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=hObExUIP; 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 y60si1148520edy.505.2020.06.29.22.46.32; Mon, 29 Jun 2020 22:46:55 -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="T/LmeQNK"; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=hObExUIP; 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 S1729896AbgF3Fpp (ORCPT + 99 others); Tue, 30 Jun 2020 01:45:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729852AbgF3Fpo (ORCPT ); Tue, 30 Jun 2020 01:45:44 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5A9BAC061755; Mon, 29 Jun 2020 22:45:44 -0700 (PDT) From: "Ahmed S. Darwish" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1593495942; 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=T/LmeQNKMc+/l/6/31my3pqQXQysJxyE2tCwhllHN8ZQ/oK8edpq5Q/9c3MNnZKzgN1vkZ LNXCbhNQGiFWc+nFmdU5VxA81dryKs1inTA4p65ZnSZ6Ia85XmxS+D5JU1PxTwm+dx0wig G3Lyv/AxLLySQ7s9OhVnNzoeTSAQEKM2EUG9Tmayxc7kPh66ctHdWtKVHmH2S8NyV+1dNU n9DbDtcHxlk88lptGBbWldfB4V/g7Er05mu2TVk4hc1YDeQmBJWLjpwxYygxWT5rMkG9hS rSahmj1jUS+Gn9FHh9PzAxDZJ93XPuWytsW1A9LLYRhxL+3HAiB5HWXRlNjwqA== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1593495943; 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=hObExUIPTGSjTrb4AjdvBqED3ALsrxTx2TXWv0SR6xcUJBZbXRRxRYjsPATEn7S3G2Fy+7 tVPAHbMIpvT3RYBg== 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 v3 10/20] netfilter: conntrack: Use sequence counter with associated spinlock Date: Tue, 30 Jun 2020 07:44:42 +0200 Message-Id: <20200630054452.3675847-11-a.darwish@linutronix.de> In-Reply-To: <20200630054452.3675847-1-a.darwish@linutronix.de> References: <20200519214547.352050-1-a.darwish@linutronix.de> <20200630054452.3675847-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