Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4808734ybl; Tue, 4 Feb 2020 02:19:21 -0800 (PST) X-Google-Smtp-Source: APXvYqyhy1QXkLeTpz47Idd7CEqgh35c9M69UWrA+r/Avbs8HooHtXVf0B+58Tvg0L2zAgDoIEYa X-Received: by 2002:a9d:7f81:: with SMTP id t1mr20306085otp.95.1580811560897; Tue, 04 Feb 2020 02:19:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580811560; cv=none; d=google.com; s=arc-20160816; b=BromrycgHbkPzbAlO0El+lBVvIvOw7sktdbn2vIAKsAIgvnZqdn5h2kJW7npR8nJXl B71IuIJB2ouJJt2xZ0YyAtrEE1/Dz+ucXyDFHL1PmiHfNpuQMitZszojKVbrtDNXhvzX 5GmQD2iXypGR6SfcBeJSLIM3ZR3Pd6999XBhqnohIj8i8GmVSTdP67FEeF7CvhiZCxzB Os5URmaYgqba6PF5CTXfC+pq9lOLa4TFE8tQuGu2Wwy0mFLzKnRPZvR1QHX8qylBdu4J PoI9yxVXV8X15LybuEKDJ/TOVY+5aYCRP25YfxDEMusSmteqRVOiMgtnWpQEcFCbkplM OMDg== 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:in-reply-to :mime-version:user-agent:date:message-id:from:references:cc:to :subject; bh=Zbv43Javdgb9vfJYzjQoUv+J/hq93Pl3dgpeIyJK+Z0=; b=hxU3mx4fLhJ7Iowc2QavQJRwso7YtFj7yQqlWCZE6jZpRn1d4rMoszlHqAt5e0k9ZR A6kf3oQJbXNJVDrtdBlFJkkb+XlngWlSgEAxqJ0ogHEH35BSpSOMnVcisZuGeDdhq9P0 xQh5MIKX6yucPTV48kBTsjhUmZkXyBHn9eWn3MxFa4tMjOLbejrvxGb6+Crw8qmXgdMo FLOc0wyOfFCxevJ04I1NdQBLWFaevqcsaoFozAwI8RVuSKcLNRK1PkhXyZC7vAoJE4aH ZIanJ4KzWSFsL9A63xbgKvF1Ar2+uMx2jIGBNjGUfGPpMV3L8H9n9ZY77fIUekSKRr4L b2BA== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y23si11149867oti.65.2020.02.04.02.19.07; Tue, 04 Feb 2020 02:19:20 -0800 (PST) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726688AbgBDKSK (ORCPT + 99 others); Tue, 4 Feb 2020 05:18:10 -0500 Received: from out30-56.freemail.mail.aliyun.com ([115.124.30.56]:41231 "EHLO out30-56.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726554AbgBDKSJ (ORCPT ); Tue, 4 Feb 2020 05:18:09 -0500 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R171e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01f04396;MF=alex.shi@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0Tp874Rw_1580811484; Received: from IT-FVFX43SYHV2H.local(mailfrom:alex.shi@linux.alibaba.com fp:SMTPD_---0Tp874Rw_1580811484) by smtp.aliyun-inc.com(127.0.0.1); Tue, 04 Feb 2020 18:18:05 +0800 Subject: Re: [PATCH] locking/rtmutex: remove unused cmpxchg_relaxed To: Thomas Gleixner , Davidlohr Bueso Cc: Peter Zijlstra , Ingo Molnar , Will Deacon , linux-kernel@vger.kernel.org References: <1579595686-251535-1-git-send-email-alex.shi@linux.alibaba.com> <20200131173922.hjvugxuybrn2wbsn@linux-p48b> <87r1zfxtne.fsf@nanos.tec.linutronix.de> From: Alex Shi Message-ID: <87c1cdbc-6af0-3f56-e986-b9df894fe4da@linux.alibaba.com> Date: Tue, 4 Feb 2020 18:18:04 +0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <87r1zfxtne.fsf@nanos.tec.linutronix.de> Content-Type: text/plain; charset=gbk Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ?? 2020/2/1 ????4:23, Thomas Gleixner ะด??: > Davidlohr Bueso writes: >> On Tue, 21 Jan 2020, Alex Shi wrote: > > Subject: locking/rtmutex: remove unused cmpxchg_relaxed > > should be > > Subject: locking/rtmutex: Remove unused rt_mutex_cmpxchg_relaxed() > > You're not removing cmpxchg_relaxed, right? > >>> No one use this macro after it was introduced. Better to remove it? > > Please make that factual. > > The macro was never used at all. Remove it. > >> You also need to remove it for the CONFIG_DEBUG_RT_MUTEXES=y case. > > Yes. > >> Hmm unrelated, but do we want CCAS for rtmutex fastpath? Ie: >> >> (l->owner == c && cmpxchg_acquire(&l->owner, c, n) == c) >> >> That would optimize for the contended case and avoid the cmpxchg - it would >> also help if we ever do the top-waiter spin thing. > > Not sure if it buys much, but it kinda makes sense. > > Thanks, > > tglx > Thanks Thomas and David! Is this following patch ok? Thanks Alex --- From 4cf9e38a73c67c6894f3addb2ddca26bb51b1a28 Mon Sep 17 00:00:00 2001 From: Alex Shi Date: Tue, 21 Jan 2020 15:03:33 +0800 Subject: [PATCH v2] locking/rtmutex: optimize rt_mutex_cmpxchg_xxx series func rt_mutex_cmpxchg_relexed isn't interested by anyone, so remove it. And Davidlohr Bueso suggests check l->owner before cmpxchg to reduce lock contention. Signed-off-by: Alex Shi Cc: Thomas Gleixner Cc: Davidlohr Bueso Cc: Ingo Molnar Cc: Will Deacon Cc: linux-kernel@vger.kernel.org --- kernel/locking/rtmutex.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/kernel/locking/rtmutex.c b/kernel/locking/rtmutex.c index 851bbb10819d..eb26f4e57ce4 100644 --- a/kernel/locking/rtmutex.c +++ b/kernel/locking/rtmutex.c @@ -141,9 +141,10 @@ static void fixup_rt_mutex_waiters(struct rt_mutex *lock) * set up. */ #ifndef CONFIG_DEBUG_RT_MUTEXES -# define rt_mutex_cmpxchg_relaxed(l,c,n) (cmpxchg_relaxed(&l->owner, c, n) == c) -# define rt_mutex_cmpxchg_acquire(l,c,n) (cmpxchg_acquire(&l->owner, c, n) == c) -# define rt_mutex_cmpxchg_release(l,c,n) (cmpxchg_release(&l->owner, c, n) == c) +# define rt_mutex_cmpxchg_acquire(l,c,n) \ + (l->owner == c && cmpxchg_acquire(&l->owner, c, n) == c) +# define rt_mutex_cmpxchg_release(l,c,n) \ + (l->owner == c && cmpxchg_release(&l->owner, c, n) == c) /* * Callers must hold the ->wait_lock -- which is the whole purpose as we force @@ -202,7 +203,6 @@ static inline bool unlock_rt_mutex_safe(struct rt_mutex *lock, } #else -# define rt_mutex_cmpxchg_relaxed(l,c,n) (0) # define rt_mutex_cmpxchg_acquire(l,c,n) (0) # define rt_mutex_cmpxchg_release(l,c,n) (0) -- 1.8.3.1