Received: by 10.213.65.68 with SMTP id h4csp3893827imn; Tue, 3 Apr 2018 12:33:35 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/O9GIfnfzbDRXMt5i14b5ghYEXuXtHp9Tc/gEOF0eUkcmobZvJS4BgVGYWuPHVqxOqyrZt X-Received: by 2002:a17:902:30f:: with SMTP id 15-v6mr14969284pld.365.1522784015942; Tue, 03 Apr 2018 12:33:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522784015; cv=none; d=google.com; s=arc-20160816; b=Z6MuD5j2cmj2xVSBla4u0E6T3qg51/CDFE6rYjC8Vq/qDzKjFR7DGi4RbmdDqXjfwg Lav3WTV+X0duyPp1aL8zBEp6B684yhKeLEtt0lXrF3NjLqOFJmSbujq28xmo4JCW3E8+ vIyAjith2UjNEkdDKgrkrWb4HDvRYb9+se5XMw8/cdNYEV7zEh1uRQoBiDhPT4CN0NtA oVEonTH2pPtQmJr6RuHRf4zVYUXxAhl37498ALbQTQSf+IMZwpNkfVqDbh8n6VR/s094 x/CAFHiuf1+zkX6vQ+Fjgl+pYpmR6ejhvfTuGPL+5vTKflm7Z/vVJMfe/JV0Sn9W6mdR TQLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=ojVbPARuA3jsm5o7vkBA725MPpI1a259xTekvLwwW9c=; b=su6Yd6NsNWkVjDq7BDyJr23p0nQxLbu+jsBNfDe+OyLF2fzCWtsOUrg7+wIcnJ7+zy eMy/ykOW3d2wA/QFRvvdeSbYpK0F9NBwLKmvFju3IwlRS4DT3aCs7Ma7MrFJ8OMXXGz/ SALQtaZNSDqZ80XmHpj51PSC98dO39wrPHFRjYYL8Z91xq3x3hpFto3qX/cvV1cilgnj m/I3mUF1hkl9W0iIDouRA01n6BdOfb/kHWm8193uUYbFJaI8BTAeH3q3kxLjFqoLF52+ nWubxY23kDvXMI5OBtgjleKh7F5fkIjkzwdye489gcuq2Izrp4YuQp29oxra62k8FD// dCFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=dUeKOVW3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b33-v6si1193665plb.503.2018.04.03.12.33.21; Tue, 03 Apr 2018 12:33:35 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=dUeKOVW3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753060AbeDCTbv (ORCPT + 99 others); Tue, 3 Apr 2018 15:31:51 -0400 Received: from mail-wm0-f65.google.com ([74.125.82.65]:37635 "EHLO mail-wm0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752973AbeDCTbt (ORCPT ); Tue, 3 Apr 2018 15:31:49 -0400 Received: by mail-wm0-f65.google.com with SMTP id r131so37300053wmb.2 for ; Tue, 03 Apr 2018 12:31:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=ojVbPARuA3jsm5o7vkBA725MPpI1a259xTekvLwwW9c=; b=dUeKOVW36kqGuc73qTxwmjos2r/G3hwQbUN3YjldCgN/GQ8YD7//mP6a4889sFRmQ4 IxKQLxpluzmXsUKKrFEo/0R4MWfk3BIYtK0u9THXlIBQcMyPykCMQwoQncsRwH+Lkzw7 Qau6JEDvrAlHCVlwJOSCi+r31AFFTNF6iBna8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=ojVbPARuA3jsm5o7vkBA725MPpI1a259xTekvLwwW9c=; b=aAwPDz29EAX9JWuRw03PsUb09oKvmWf0F+nX43aULhuAQbb1rtJ6AM0rJ9/SZYixXp 31jKrXGQnReOzTxF6c0asu/wfTIjYoxmoWyebwrSGqAiIEJzKTBJAotne3f0QO9mj+so +8Z7abI/f52OhNWxZsinX1XVt4aZMgVgzLF0CHf87eXfdcA61IUEcq6K8mVAD8yRfFz4 FrqbjK68A9uEAFAet9pGw9WG1Us85mt509Zr5UO2J/rEMv+cVbT/pCK5C3cVBqlAy8eF b94ib8kwn/X4hTB6hzUUiWRXIAhXAsr8jZIIVc/BSJCT+q9AFm5VSfbdIDNP1AkPCpEj 0okQ== X-Gm-Message-State: ALQs6tCuivWzQNuo4JHZ97xVm1Pb7CinoBTRhmWrTagZwIprMQnVG3pj Yc6qPY6kKTwg6dOp81dCnrU9FQ== X-Received: by 10.28.114.2 with SMTP id n2mr3431996wmc.134.1522783908112; Tue, 03 Apr 2018 12:31:48 -0700 (PDT) Received: from andrea (host187-49-dynamic.250-95-r.retail.telecomitalia.it. [95.250.49.187]) by smtp.gmail.com with ESMTPSA id l131sm1806480wmb.36.2018.04.03.12.31.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 03 Apr 2018 12:31:47 -0700 (PDT) Date: Tue, 3 Apr 2018 21:31:39 +0200 From: Andrea Parri To: David Howells Cc: paulmck@linux.vnet.ibm.com, Ingo Molnar , Peter Zijlstra , linux-kernel@vger.kernel.org, Andrea Parri , Alan Stern , Will Deacon , Boqun Feng , Nicholas Piggin , Jade Alglave , Luc Maranget , Akira Yokosawa Subject: Re: [PATCH v2 1/3] locking: Document the semantics of spin_is_locked() Message-ID: <20180403193139.GA6143@andrea> References: <20180403140715.GA5375@andrea> <20180403133543.GA26653@andrea> <1522600912-6208-2-git-send-email-andrea.parri@amarulasolutions.com> <1522600912-6208-1-git-send-email-andrea.parri@amarulasolutions.com> <29562.1522759749@warthog.procyon.org.uk> <13191.1522763553@warthog.procyon.org.uk> <3766.1522768987@warthog.procyon.org.uk> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <3766.1522768987@warthog.procyon.org.uk> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Apr 03, 2018 at 04:23:07PM +0100, David Howells wrote: > Andrea Parri wrote: > > > Sorry, but I don't understand your objection: are you suggesting to add > > something like "Always return 0 on !SMP" to the comment? what else? > > Something like that, possibly along with a warning that this might not be what > you want. You might actually want it to return true on !SMP, it depends on > what you're using it for. I ended up with the following revision. I hesitated on whether to refer to 'include/linux/spinlock_up.h' or not, but in the end I decided to not include the reference. Please let me know what you think about this. Andrea From 85f2d12d4ad9769cc9f69cc5f447fdb8c5ed4d14 Mon Sep 17 00:00:00 2001 From: Andrea Parri Date: Tue, 3 Apr 2018 21:23:07 +0200 Subject: [PATCH v3 1/3] locking: Document the semantics of spin_is_locked() There appeared to be a certain, recurrent uncertainty concerning the semantics of spin_is_locked(), likely a consequence of the fact that this semantics remains undocumented or that it has been historically linked to the (likewise unclear) semantics of spin_unlock_wait(). A recent auditing [1] of the callers of the primitive confirmed that none of them are relying on particular ordering guarantees; document this semantics by adding a docbook header to spin_is_locked(). [1] https://marc.info/?l=linux-kernel&m=151981440005264&w=2 Signed-off-by: Andrea Parri Cc: Alan Stern Cc: Will Deacon Cc: Peter Zijlstra Cc: Boqun Feng Cc: Nicholas Piggin Cc: David Howells Cc: Jade Alglave Cc: Luc Maranget Cc: "Paul E. McKenney" Cc: Akira Yokosawa Cc: Ingo Molnar --- include/linux/spinlock.h | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/include/linux/spinlock.h b/include/linux/spinlock.h index 4894d322d2584..636a4436191c1 100644 --- a/include/linux/spinlock.h +++ b/include/linux/spinlock.h @@ -380,6 +380,20 @@ static __always_inline int spin_trylock_irq(spinlock_t *lock) raw_spin_trylock_irqsave(spinlock_check(lock), flags); \ }) +/** + * spin_is_locked() - Check whether a spinlock is locked. + * @lock: Pointer to the spinlock. + * + * This function is NOT required to provide any memory ordering + * guarantees; it could be used for debugging purposes or, when + * additional synchronization is needed, accompanied with other + * constructs (memory barriers) enforcing the synchronization. + * + * Return: 1, if @lock is (found to be) locked; 0, otherwise. + * + * Remark that this primitve can return a fixed value + * under certain !SMP configurations. + */ static __always_inline int spin_is_locked(spinlock_t *lock) { return raw_spin_is_locked(&lock->rlock); -- 2.7.4 > > David