Received: by 10.213.65.68 with SMTP id h4csp1011247imn; Fri, 6 Apr 2018 12:52:23 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+RMEiGJbgfTcJynjUZy55GizIEdAJjvxRpWYuQ9t/IKJJL/qjDQS1hlEZlbTDb+S0sSxcr X-Received: by 10.98.194.26 with SMTP id l26mr21413124pfg.47.1523044343754; Fri, 06 Apr 2018 12:52:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523044343; cv=none; d=google.com; s=arc-20160816; b=cAf6bmJEFHGNa0zSf0aM6XuUadSRCjS5FZvay1w+PMIrZyiss4QnUJWcp159YJLoI0 VIx4Idua7BR+Z+Q3E9/btf1ScE/Lj5AKcQJIzgmqkMpcuiq+CPYqkGBzvou7qszx8icO 4IIpCcQBIfmW9smikuzPoqAeZ0TEf5fONZZ5DeKEaM691Ztj8s0qkbg3F+mRsMBPLT9F 3ri6jQCma6gwSt8q3v5iecG2UurnXK+bwVEY4V7v+G6ycpru7tPpzU9tV2L85zdGMyfZ ho5IX/4e6quZjcfBQ8FAgBvj7c6UdtKNsMaV1/1QWD0VZDdoMf6CM0tjxfs6vCZlo1px UQ8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=1U/a03CjoIUc3Ro0NPnj4qG3e0PVnmrp48B9gcg8Aps=; b=KdOaZrAfAmeo9euBvXg+08Qt1PbvLyNFmb9Aes4w2cJkaWsgUBdvH3uYg7ijKYhKbB FTu6aklgu2BSAE4DFvKdhNRwSdu4sfVKWuXNPncneZw0CBNFolQaglGrJ+U7bHvcC54i kPODOyWOXtC5Jy/snk56OtDyPq4rhTs0iesjAWnzzj1ft1o9TnPPgRoppJGjrZ5hUMdG FuewjibJmVegFnKi/sN0kYMk04K1z6YEZA3qxEzf0KRQXZ2BfG55/cn6mnFYJqVefUjT lpXd08PCNnfw5ZtwJ9xzW9I+7u1WEJ6XG2wid4GQOAF99fM5gXUgTuod/IU9lS1Y4/Z7 PiDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=Ai/N7w9f; 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 l13si7350069pgn.481.2018.04.06.12.51.22; Fri, 06 Apr 2018 12:52:23 -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=Ai/N7w9f; 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 S1751598AbeDFTsN (ORCPT + 99 others); Fri, 6 Apr 2018 15:48:13 -0400 Received: from mail-wm0-f65.google.com ([74.125.82.65]:50681 "EHLO mail-wm0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751329AbeDFTsL (ORCPT ); Fri, 6 Apr 2018 15:48:11 -0400 Received: by mail-wm0-f65.google.com with SMTP id t67so5635145wmt.0 for ; Fri, 06 Apr 2018 12:48:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=1U/a03CjoIUc3Ro0NPnj4qG3e0PVnmrp48B9gcg8Aps=; b=Ai/N7w9f7Mr9L8Bfc4Bs9fMa5ypBkdtwt1GPqGef7KciTx04yl4bvb0Wk9TFEwDZvg IzD6fFJ96n880ran8Wdw7sMz5O7u9l2HjnIaIu1KKPuebdBU2284jTjMTowKmMCJCvid DgT2Or/hvmdhmXG5uzoTo9AEpxJG80rZOeBtY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=1U/a03CjoIUc3Ro0NPnj4qG3e0PVnmrp48B9gcg8Aps=; b=m4wtpfzoAQ6kEaKHI5AjjuFo94cQDBozhxE6b/+FklNM0c11YH6MhJDlOZzR/qLMmu qMQ3kEw+hhXX0hQuQRBKswyuCBbH2N989Xv8GlibVmphKeknMH1QK6tZKo1x+NYaUJUi wTgvO78iNpnZk0rQMMLbwz5VS0VR5aWy/0Q0s+ElmuPETVaSadqRgJi++gWkymAguXG1 HHAIV1ls9zCMpsa/3KRMlf8eC28/NqJeypK574xli0K/E9fgxKTwIAAAK5ZHxPCZbUQl m4AtPHsIhYDHPfN6L129n5vlRfhuU18HvIEW43MvnKeKnrm/WYgboRfuj66BxVdwiGxA 5T9w== X-Gm-Message-State: AElRT7F1nghb2F4xVWP9+0kJLuxVe9Kkar5+NvKR6X6wSwWdBAUKOYV1 yjSD/ljdP105cfYdiqPTVJnwXA== X-Received: by 10.28.143.199 with SMTP id r190mr13133250wmd.132.1523044090567; Fri, 06 Apr 2018 12:48:10 -0700 (PDT) Received: from localhost.localdomain (host187-49-dynamic.250-95-r.retail.telecomitalia.it. [95.250.49.187]) by smtp.gmail.com with ESMTPSA id h9sm6542258wmc.13.2018.04.06.12.48.08 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 06 Apr 2018 12:48:09 -0700 (PDT) From: Andrea Parri To: paulmck@linux.vnet.ibm.com Cc: linux-kernel@vger.kernel.org, Alan Stern , David Howells , Andrea Parri , Will Deacon , Peter Zijlstra , Boqun Feng , Nicholas Piggin , Jade Alglave , Luc Maranget , Akira Yokosawa , Ingo Molnar Subject: [PATCH v4 1/3] locking: Document the semantics of spin_is_locked() Date: Fri, 6 Apr 2018 21:47:39 +0200 Message-Id: <1523044060-5568-1-git-send-email-andrea.parri@amarulasolutions.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1522600912-6208-2-git-send-email-andrea.parri@amarulasolutions.com> References: <1522600912-6208-2-git-send-email-andrea.parri@amarulasolutions.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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(). Also, describe behaviors specific to certain CONFIG_SMP=n builds. [1] https://marc.info/?l=linux-kernel&m=151981440005264&w=2 https://marc.info/?l=linux-kernel&m=152042843808540&w=2 https://marc.info/?l=linux-kernel&m=152043346110262&w=2 Co-Developed-by: Andrea Parri Co-Developed-by: Alan Stern Co-Developed-by: David Howells Signed-off-by: Andrea Parri Signed-off-by: Alan Stern Signed-off-by: David Howells Cc: Will Deacon Cc: Peter Zijlstra Cc: Boqun Feng Cc: Nicholas Piggin Cc: Jade Alglave Cc: Luc Maranget Cc: "Paul E. McKenney" Cc: Akira Yokosawa Cc: Ingo Molnar --- include/linux/spinlock.h | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/include/linux/spinlock.h b/include/linux/spinlock.h index 4894d322d2584..1e8a464358384 100644 --- a/include/linux/spinlock.h +++ b/include/linux/spinlock.h @@ -380,6 +380,24 @@ 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. + * + * Returns: 1 if @lock is locked, 0 otherwise. + * + * Note that the function only tells you that the spinlock is + * seen to be locked, not that it is locked on your CPU. + * + * Further, on CONFIG_SMP=n builds with CONFIG_DEBUG_SPINLOCK=n, + * the return value is always 0 (see include/linux/spinlock_up.h). + * Therefore you should not rely heavily on the return value. + */ static __always_inline int spin_is_locked(spinlock_t *lock) { return raw_spin_is_locked(&lock->rlock); -- 2.7.4