Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp321708pxx; Wed, 28 Oct 2020 05:54:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJztydqxyOy5tfOrQ/Uwqh3yxEAb9AT0ApBAOxLmMVSCXP5W3Ov9OBfgD0KRsj+d/84x/zFl X-Received: by 2002:a17:906:814:: with SMTP id e20mr7754267ejd.367.1603889645923; Wed, 28 Oct 2020 05:54:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603889645; cv=none; d=google.com; s=arc-20160816; b=tmEWnsVtg53tt9tXnOuJzU6ECa0C+sgRWsj5aJHtsAxB9khHnVcFBuHOUW5Fjy+Kjh 9hhBYJ7Oj5chNRl4njjSiblBmcn44p2UK+JWAgDBTDzCJW/ReBINQnQZNcMER1p+Dq1m BlV9MLPndGObtijGqqzNBoWHsVMlwBdFKxVQAMk487ILfuoNjQweQrQwCo2bG2rV7l7V Jew9CftG88LkTr2bdo7Qe3+aGN2AobNPdjmm8Oo1wpqRo9cCDFDXuhesGb7yldlfSIY9 SpqR2Vf9cTgexdlHhGOK41Ewun0x11cklJpd5KM3eUu+ehSYAAopfTtH5Q3ahMHQ+TDd oe/A== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=VBqjq+cpruaQklvfNexKkIfeymgEQJvYb216oaNe6uY=; b=Hr+AKHprTz25u/oWaXCyIywpyWoa6eGi6KkXB5jY7nc44IwDTRpQtX5+I7J80aqYA/ 5OYYjHFHmMQ9ecvWj9sQv21lckoGjNUUqpigsbMz6WNLLNcuquC9z5KUVxZ0NL6gETY6 EeAIgcX4xpvv1dWLlPOPuD1DAFm54yo/aCl7cCXGbIufFWSBFU8sK5wlUS7dO0UtCOWv gDpHg+65Xi/67kho9LZMftLlXwpFGABtCUYjtJVXT2gfLYndTMtgOnJWoZ9hDx9a5JhN KyNj6uXESpoFWnZuoiEB4zS9BZZBiwRzHzeEdqU2E+Seb8J2fN/2m+dgp75JmIdkcL18 BQjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OF4sG9rj; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lg14si2653130ejb.82.2020.10.28.05.53.43; Wed, 28 Oct 2020 05:54:05 -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=@kernel.org header.s=default header.b=OF4sG9rj; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1799429AbgJ0Pb0 (ORCPT + 99 others); Tue, 27 Oct 2020 11:31:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:36778 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1797172AbgJ0PWB (ORCPT ); Tue, 27 Oct 2020 11:22:01 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 48AED2064B; Tue, 27 Oct 2020 15:22:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603812120; bh=ueLpwSj42/IMBAfeAnVYV+9171aWEf9zxyjuHGwJu94=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OF4sG9rjRqO3VmmmSpqeSaXq1+b0udaG/rxdSPQ7DorL+aaNcYNHGG78N0uBSFbiz 4JkoIFWzNYIabToUVBXEqpjVdmU6PBtfWsndrgCGj0r0En4szq0AUFJLx6UYiRIi45 /hBy1iVR7asWPfh/k6xK3aw8iWaMLn0OcB/cDDG0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Qian Cai , "Peter Zijlstra (Intel)" , Sasha Levin , Boqun Feng Subject: [PATCH 5.9 099/757] seqlock: Unbreak lockdep Date: Tue, 27 Oct 2020 14:45:49 +0100 Message-Id: <20201027135455.193405732@linuxfoundation.org> X-Mailer: git-send-email 2.29.1 In-Reply-To: <20201027135450.497324313@linuxfoundation.org> References: <20201027135450.497324313@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: peterz@infradead.org [ Upstream commit 267580db047ef428a70bef8287ca62c5a450c139 ] seqcount_LOCKNAME_init() needs to be a macro due to the lockdep annotation in seqcount_init(). Since a macro cannot define another macro, we need to effectively revert commit: e4e9ab3f9f91 ("seqlock: Fold seqcount_LOCKNAME_init() definition"). Fixes: e4e9ab3f9f91 ("seqlock: Fold seqcount_LOCKNAME_init() definition") Reported-by: Qian Cai Debugged-by: Boqun Feng Signed-off-by: Peter Zijlstra (Intel) Tested-by: Qian Cai Link: https://lkml.kernel.org/r/20200915143028.GB2674@hirez.programming.kicks-ass.net Signed-off-by: Sasha Levin --- include/linux/seqlock.h | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/include/linux/seqlock.h b/include/linux/seqlock.h index 962d9768945f0..7b99e3dba2065 100644 --- a/include/linux/seqlock.h +++ b/include/linux/seqlock.h @@ -154,6 +154,19 @@ static inline void seqcount_lockdep_reader_access(const seqcount_t *s) * @lock: Pointer to the associated LOCKTYPE */ +#define seqcount_LOCKNAME_init(s, _lock, lockname) \ + do { \ + seqcount_##lockname##_t *____s = (s); \ + seqcount_init(&____s->seqcount); \ + __SEQ_LOCK(____s->lock = (_lock)); \ + } while (0) + +#define seqcount_raw_spinlock_init(s, lock) seqcount_LOCKNAME_init(s, lock, raw_spinlock) +#define seqcount_spinlock_init(s, lock) seqcount_LOCKNAME_init(s, lock, spinlock) +#define seqcount_rwlock_init(s, lock) seqcount_LOCKNAME_init(s, lock, rwlock); +#define seqcount_mutex_init(s, lock) seqcount_LOCKNAME_init(s, lock, mutex); +#define seqcount_ww_mutex_init(s, lock) seqcount_LOCKNAME_init(s, lock, ww_mutex); + /* * SEQCOUNT_LOCKTYPE() - Instantiate seqcount_LOCKNAME_t and helpers * @locktype: actual typename @@ -167,13 +180,6 @@ typedef struct seqcount_##lockname { \ __SEQ_LOCK(locktype *lock); \ } seqcount_##lockname##_t; \ \ -static __always_inline void \ -seqcount_##lockname##_init(seqcount_##lockname##_t *s, locktype *lock) \ -{ \ - seqcount_init(&s->seqcount); \ - __SEQ_LOCK(s->lock = lock); \ -} \ - \ static __always_inline seqcount_t * \ __seqcount_##lockname##_ptr(seqcount_##lockname##_t *s) \ { \ @@ -228,13 +234,12 @@ SEQCOUNT_LOCKTYPE(struct ww_mutex, ww_mutex, true, &s->lock->base) __SEQ_LOCK(.lock = (assoc_lock)) \ } -#define SEQCNT_SPINLOCK_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) #define SEQCNT_RAW_SPINLOCK_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) +#define SEQCNT_SPINLOCK_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) #define SEQCNT_RWLOCK_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) #define SEQCNT_MUTEX_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) #define SEQCNT_WW_MUTEX_ZERO(name, lock) SEQCOUNT_LOCKTYPE_ZERO(name, lock) - #define __seqprop_case(s, lockname, prop) \ seqcount_##lockname##_t: __seqcount_##lockname##_##prop((void *)(s)) -- 2.25.1