Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1122044yba; Tue, 2 Apr 2019 02:46:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqxljTEdcQvI+rHeV98u/yxW6rlYHPVsEO4Vdi5ZJjZZ0HIbpG28X269lC2VFgvdF9Msrd4E X-Received: by 2002:a63:750c:: with SMTP id q12mr32649759pgc.133.1554198395366; Tue, 02 Apr 2019 02:46:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554198395; cv=none; d=google.com; s=arc-20160816; b=Mcp6BRHlZp0IEnzQKsSYZsqCQon6FwlESUjqB/X4SOrIO96NjDzVxHEV5NDqZ1wh2F 2iMvAk1cyI8OJKmgik3Dj103WkiATFoz6cUPuJqRe/QnJLhJebz4JCYt4ZW/6NxtxXe9 wg33DqILPM713Qu9o2RcmeSo0or/XAEElqmSgG2EzC7fkbN8nIZFdCuC9P5TRlChGTtD h3zpgHU0iY0HSgf5wi957n2kcQ2zjOLdOv3T4YAhfTiI4jJz5nBzzWaVVa4WduKkhLq5 CK5BCPTnrisV8jdT+t2SxMG5oLYFTxMxZ493neeBSCgPhy7eizmiV8ieKJll5cem8QhZ D+ew== 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; bh=S8MQn98qOqgzAiCgSbcL7hpe7vaijewxBXYXQRkz4Fw=; b=N2lRFLpRbvwPFDbYebCP6ibYcm2GitOpHaXv2SUan8z69jkt2X5BdIE/Gu7+4aAwfA VGCId3ze3N4J6g28zFwUQ/X4QXvHl0BvewY6QBJQQxnOLFYE7W6Gu8fPkNCz9xw5zWD8 5mELTz7NaPu6sN9YhGw1wGm9Qp8rUCFR3K6Mhii8FxDaD8+oErrqPTOOSb9TjDi2qhD+ tmRCss/R78K/L7OgaYuTvJhF9Aixb5bSnGQcw0Pwj7lNRNS9OJ3UZANnVFczvKSBB7fG mZxhgp/u4pOighF3az0hIBNVI/BjqptsP/efyM7cUWWrUglGsOYqjMoWkeuonftgMrn2 TBnA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=merlin.20170209 header.b=pVEmyxPF; 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 j1si237062pgp.557.2019.04.02.02.46.19; Tue, 02 Apr 2019 02:46: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=fail header.i=@infradead.org header.s=merlin.20170209 header.b=pVEmyxPF; 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 S1729544AbfDBJnp (ORCPT + 99 others); Tue, 2 Apr 2019 05:43:45 -0400 Received: from merlin.infradead.org ([205.233.59.134]:53958 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726496AbfDBJnn (ORCPT ); Tue, 2 Apr 2019 05:43:43 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=merlin.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=S8MQn98qOqgzAiCgSbcL7hpe7vaijewxBXYXQRkz4Fw=; b=pVEmyxPFNEFM12bnA5XRPUND2 OZQd7bb7DLg5q6Iis1XoUbheAb1ETIdBMrUxgDQkb3vnTxzo2tNgAmbN+9346Fofd34mrz3a4cvlt aLuRVLEAY6wgnLBGtLAotY+iCvqePMmqjhMZErkk6/ZVIChOJlrPVQa0vHv7tlwFYkFQR/p519qgn 3bQjf1HgT3TtdwY8awLyl8Bzf4JdUzyfAvLQRQVD8dakzZJ5yY7G/NmtlNJGTRfH65im8I0sLKuOs pKFXH/Lz3XLQ5dHBpelMqH0A8B0Ey7j0ucJNxzZ8iOeBK78HwU7zvWGYUsNRNMlSejoMv3rQLXcwt E+fG1qvBA==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by merlin.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1hBFww-0000nk-PF; Tue, 02 Apr 2019 09:43:23 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 2E5572871E77C; Tue, 2 Apr 2019 11:43:20 +0200 (CEST) Date: Tue, 2 Apr 2019 11:43:20 +0200 From: Peter Zijlstra To: Waiman Long Cc: Alex Kogan , linux@armlinux.org.uk, mingo@redhat.com, will.deacon@arm.com, arnd@arndb.de, linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, tglx@linutronix.de, bp@alien8.de, hpa@zytor.com, x86@kernel.org, steven.sistare@oracle.com, daniel.m.jordan@oracle.com, dave.dice@oracle.com, rahul.x.yadav@oracle.com Subject: Re: [PATCH v2 3/5] locking/qspinlock: Introduce CNA into the slow path of qspinlock Message-ID: <20190402094320.GM11158@hirez.programming.kicks-ass.net> References: <20190329152006.110370-1-alex.kogan@oracle.com> <20190329152006.110370-4-alex.kogan@oracle.com> <60a3a2d8-d222-73aa-2df1-64c9d3fa3241@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <60a3a2d8-d222-73aa-2df1-64c9d3fa3241@redhat.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Apr 01, 2019 at 10:36:19AM -0400, Waiman Long wrote: > On 03/29/2019 11:20 AM, Alex Kogan wrote: > > +config NUMA_AWARE_SPINLOCKS > > + bool "Numa-aware spinlocks" > > + depends on NUMA > > + default y > > + help > > + Introduce NUMA (Non Uniform Memory Access) awareness into > > + the slow path of spinlocks. > > + > > + The kernel will try to keep the lock on the same node, > > + thus reducing the number of remote cache misses, while > > + trading some of the short term fairness for better performance. > > + > > + Say N if you want absolute first come first serve fairness. > > + > > The patch that I am looking for is to have a separate > numa_queued_spinlock_slowpath() that coexists with > native_queued_spinlock_slowpath() and > paravirt_queued_spinlock_slowpath(). At boot time, we select the most > appropriate one for the system at hand. Agreed; and until we have static_call, I think we can abuse the paravirt stuff for this. By the time we patch the paravirt stuff: check_bugs() alternative_instructions() apply_paravirt() we should already have enumerated the NODE topology and so nr_node_ids() should be set. So if we frob pv_ops.lock.queued_spin_lock_slowpath to numa_queued_spin_lock_slowpath before that, it should all get patched just right. That of course means the whole NUMA_AWARE_SPINLOCKS thing depends on PARAVIRT_SPINLOCK, which is a bit awkward...