Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1407809pxb; Fri, 26 Feb 2021 09:54:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJwKcj2/KR1DgwnN2XLa/s1+7jgsBOZe5VZgSelDJeokA6T9aZTY7H9V5CYtLO71e/pw93lA X-Received: by 2002:a17:906:2314:: with SMTP id l20mr4761451eja.178.1614362090000; Fri, 26 Feb 2021 09:54:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614362089; cv=none; d=google.com; s=arc-20160816; b=PzR4kJbRJVpZoimFKqfQbFKIB3rEsowGZJUg4lvtJwNR0X8DNICNUBH89D9DNY+eKt eJ4OTqeSeHGuszVpBC2PpC3DPu4MzU82ZkEOmLsU7UyuwjCixQPUjYrE8qWP7X6lTnJO txHjmuaOY2oPhjYkfmOZidiY9Uf6XRG5Z4gDhdsPpO3Yf7mro43JIpHVQ2x0o+WhmzTq mZdE+U7Sz/lO8QQRvWsr/qw3LMaln1rxYqFMILHx3pZHEdY0fdBdJKJiLKo1+5ZHW4Up h8ZSLFczEVhi83B/y9lMOrn0eD0MDCBwzsjQs6MtTu7F7GSVhExzwIC8PPYPPWNAeJZk SpZw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=mtkuWPJThf2aOBxwtXZylIiMj/l1qOK9VyUKhDUJCBU=; b=YCTDCdktB+pUzBoLB9XKmbiPfQF/3zuwi5eEV7g9L2NkL2murFInq+qxcO+jeUIpQK +2Xpy4Gp1BBY+3jeviBfLWdgZ2O3/wYvowWQn3Fik/Kd874T5HBc/IXvj0QdaQi74Jxe j6L5p61DipBsb6oZIrsRv6O6vMKQTjRR/GqfgzvN7cdnKlBzIfFnC/TYH/ABYt7NqW9h Tx7R897lUAzQ6vQ5yM21E26K0tEm8YsXZS6avIw/gE3bez0qLmU5b/5PWxtUXB44H6qu TSG4YFOtApG66d2oNFTwNWzhK+DlfP1NkVonjmCYq1K78mbzGhfQtR33x8aKxUGs3HOT dJKA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id va27si6318365ejb.548.2021.02.26.09.54.26; Fri, 26 Feb 2021 09:54:49 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230177AbhBZRwM (ORCPT + 99 others); Fri, 26 Feb 2021 12:52:12 -0500 Received: from mx2.suse.de ([195.135.220.15]:54826 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230019AbhBZRvr (ORCPT ); Fri, 26 Feb 2021 12:51:47 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 5C637AFE6; Fri, 26 Feb 2021 17:51:06 +0000 (UTC) From: Davidlohr Bueso To: tglx@linutronix.de Cc: mingo@redhat.com, peterz@infradead.org, dvhart@infradead.org, dave@stgolabs.net, linux-kernel@vger.kernel.org, Davidlohr Bueso Subject: [PATCH 3/4] kernel/futex: Move hb unlock out of unqueue_me_pi() Date: Fri, 26 Feb 2021 09:50:28 -0800 Message-Id: <20210226175029.50335-3-dave@stgolabs.net> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20210226175029.50335-1-dave@stgolabs.net> References: <20210226175029.50335-1-dave@stgolabs.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This improves the code readability, and the locking more obvious as it becomes symmetric for the caller. Signed-off-by: Davidlohr Bueso --- kernel/futex.c | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/kernel/futex.c b/kernel/futex.c index ee09995d707b..dcd6132485e1 100644 --- a/kernel/futex.c +++ b/kernel/futex.c @@ -2318,19 +2318,15 @@ static int unqueue_me(struct futex_q *q) /* * PI futexes can not be requeued and must remove themself from the - * hash bucket. The hash bucket lock (i.e. lock_ptr) is held on entry - * and dropped here. + * hash bucket. The hash bucket lock (i.e. lock_ptr) is held. */ static void unqueue_me_pi(struct futex_q *q) - __releases(q->lock_ptr) { __unqueue_futex(q); BUG_ON(!q->pi_state); put_pi_state(q->pi_state); q->pi_state = NULL; - - spin_unlock(q->lock_ptr); } static int __fixup_pi_state_owner(u32 __user *uaddr, struct futex_q *q, @@ -2913,8 +2909,8 @@ static int futex_lock_pi(u32 __user *uaddr, unsigned int flags, if (res) ret = (res < 0) ? res : 0; - /* Unqueue and drop the lock */ unqueue_me_pi(&q); + spin_unlock(q.lock_ptr); goto out; out_unlock_put_key: @@ -3290,8 +3286,8 @@ static int futex_wait_requeue_pi(u32 __user *uaddr, unsigned int flags, if (res) ret = (res < 0) ? res : 0; - /* Unqueue and drop the lock. */ unqueue_me_pi(&q); + spin_unlock(q.lock_ptr); } if (ret == -EINTR) { -- 2.26.2