Received: by 10.223.164.202 with SMTP id h10csp241744wrb; Tue, 7 Nov 2017 05:48:53 -0800 (PST) X-Google-Smtp-Source: ABhQp+Q/1H81m68sb6MC84LocXf1x1DkoRSbyb9PRIvhWXX+zyNhoeG3Z5plQRYF7KN5Z98UFyPi X-Received: by 10.99.117.74 with SMTP id f10mr18749479pgn.27.1510062533059; Tue, 07 Nov 2017 05:48:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510062533; cv=none; d=google.com; s=arc-20160816; b=vStZ8cjMYu6ZaiOp8yg6pPhAiKHa9JnfLDiRiHTm+GXL8aKGWJOCIArDjGG4BRenfO ma2LvxG29WWmuCD8n44ZfagjlJGgPCQsdEXmLUqAfx19m45BHmPFDjrJ/o81EBT6CeKS WMcMDDkvEPRIy7WcfuxQhJUOJEVCfANiPrEmw7ptf0H1bA0wObuS07vqZL70DdLCO5rs L7ywwj6IvJW+TE6UGvttQghcYbU84cGTZTPQtuyTaEwj6eYCVRJjAAyKFJ1DK566w7ro 9yECARIhBngiTr2B/cV5QcZdmOaOzANbXeKT9CoW+YblnUZwWS5c0AQChw4Wc5VGuBeA cnTQ== 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-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=ruApng3fFSlyLoBaGCnHz7sojc1I1fo1uJ6p/W0+/CQ=; b=kpqRtw4SaBsf/2Y0LowjQXHSJ2qXWmQ3+luJukopZkFFS/eKDgFKX0OK6Tf76cN1pl jhIUR8w5/9w05+4KWRy/jGo/zeLdh7hpcwdt+Nnk5sAaeC2URmiFM9IK1oJI6+2se2km 45J2U7m+5G4/A3PtaGPywCXlF3BeQd9hM6BTYLxQGvXprlwHupTAzwo9RfZa4EhKqA1Q 3VbP4btBPWCZ2fUHkLw+7BHYplXNJ92uLikyedAiP0h/UKLYmiIrqrfq/yO1UC9U6KKu NrZbuITEZPz5gyBncYNx1y8M3bVMHGfuVciyiD0ZW2u7qSTXeDaOdv9J4W2dbUbeSPiA XGZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amazon.com header.s=amazon201209 header.b=E1YQf/iI; 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=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amazon.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e14si1245602pgf.310.2017.11.07.05.48.39; Tue, 07 Nov 2017 05:48:53 -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; dkim=pass header.i=@amazon.com header.s=amazon201209 header.b=E1YQf/iI; 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=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amazon.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751739AbdKGMji (ORCPT + 91 others); Tue, 7 Nov 2017 07:39:38 -0500 Received: from smtp-fw-4101.amazon.com ([72.21.198.25]:14484 "EHLO smtp-fw-4101.amazon.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750939AbdKGMjf (ORCPT ); Tue, 7 Nov 2017 07:39:35 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amazon.com; i=@amazon.com; q=dns/txt; s=amazon201209; t=1510058375; x=1541594375; h=date:from:to:cc:subject:message-id:references: mime-version:content-transfer-encoding:in-reply-to; bh=ruApng3fFSlyLoBaGCnHz7sojc1I1fo1uJ6p/W0+/CQ=; b=E1YQf/iIDPuk7gSFI0h9mHO8HuZ7rv2I2JjRAXii6t2g72M7GVzDhQuR 91/p1t/XIc5+mBATrZxNlbR0ng6d+ahBtgLQOrqfj+HcOBoaWo9TnA9UA sObE6pb8tClDVtVV+6mSu5pe/kGHXmqREJmse4AOtWTqDjrUawEuplz/t s=; X-IronPort-AV: E=Sophos;i="5.44,358,1505779200"; d="scan'208";a="692589399" Received: from iad12-co-svc-p1-lb1-vlan3.amazon.com (HELO email-inbound-relay-2c-2225282c.us-west-2.amazon.com) ([10.43.8.6]) by smtp-border-fw-out-4101.iad4.amazon.com with ESMTP/TLS/DHE-RSA-AES256-SHA; 07 Nov 2017 12:39:25 +0000 Received: from EX13MTAUWB001.ant.amazon.com (pdx1-ws-svc-p6-lb9-vlan2.pdx.amazon.com [10.236.137.194]) by email-inbound-relay-2c-2225282c.us-west-2.amazon.com (8.14.7/8.14.7) with ESMTP id vA7CdNv8008423 (version=TLSv1/SSLv3 cipher=AES256-SHA bits=256 verify=FAIL); Tue, 7 Nov 2017 12:39:24 GMT Received: from EX13D05UWB002.ant.amazon.com (10.43.161.50) by EX13MTAUWB001.ant.amazon.com (10.43.161.249) with Microsoft SMTP Server (TLS) id 15.0.1236.3; Tue, 7 Nov 2017 12:39:23 +0000 Received: from EX13MTAUWB001.ant.amazon.com (10.43.161.207) by EX13D05UWB002.ant.amazon.com (10.43.161.50) with Microsoft SMTP Server (TLS) id 15.0.1236.3; Tue, 7 Nov 2017 12:39:23 +0000 Received: from localhost (10.28.86.64) by mail-relay.amazon.com (10.43.161.249) with Microsoft SMTP Server id 15.0.1236.3 via Frontend Transport; Tue, 7 Nov 2017 12:39:22 +0000 Date: Tue, 7 Nov 2017 04:39:22 -0800 From: Eduardo Valentin To: Paolo Bonzini CC: Eduardo Valentin , , Matt Wilson , Jonathan Corbet , Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , , Peter Zijlstra , Waiman Long , , , , "Jan H . Schoenherr" , Anthony Liguori Subject: Re: [PATCHv3 1/1] locking/qspinlock/x86: Avoid test-and-set when PV_DEDICATED is set Message-ID: <20171107123922.GA6336@u40b0340c692b58f6553c.ant.amazon.com> References: <1509999980-10828-1-git-send-email-eduval@amazon.com> <593c8cc3-f532-1868-c80f-7ef2511c7e15@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <593c8cc3-f532-1868-c80f-7ef2511c7e15@redhat.com> 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, Nov 07, 2017 at 01:23:56PM +0100, Paolo Bonzini wrote: > On 06/11/2017 21:26, Eduardo Valentin wrote: > > Currently, the existing qspinlock implementation will fallback to > > test-and-set if the hypervisor has not set the PV_UNHALT flag. > > > > This patch gives the opportunity to guest kernels to select > > between test-and-set and the regular queueu fair lock implementation > > based on the PV_DEDICATED KVM feature flag. When the PV_DEDICATED > > flag is not set, the code will still fall back to test-and-set, > > but when the PV_DEDICATED flag is set, the code will use > > the regular queue spinlock implementation. > > > > With this patch, when in autoselect mode, the guest will > > use the default spinlock implementation based on host feature > > flags as follows: > > > > PV_DEDICATED = 1, PV_UNHALT = anything: default is qspinlock > > PV_DEDICATED = 0, PV_UNHALT = 1: default is pvqspinlock > > PV_DEDICATED = 0, PV_UNHALT = 0: default is tas > > Hi Eduardo, > > besides the suggestion to use a separate word than the one for features, Ok. I will take a look. > is this still needed after Waiman's patch to adaptively switch between > tas and pvqspinlock? Can you please point me to it ? Is it already in tip/master? > > Paolo > > > Cc: Paolo Bonzini > > Cc: "Radim Krčmář" > > Cc: Jonathan Corbet > > Cc: Thomas Gleixner > > Cc: Ingo Molnar > > Cc: "H. Peter Anvin" > > Cc: x86@kernel.org > > Cc: Peter Zijlstra > > Cc: Waiman Long > > Cc: kvm@vger.kernel.org > > Cc: linux-doc@vger.kernel.org > > Cc: linux-kernel@vger.kernel.org > > Cc: Jan H. Schoenherr > > Cc: Anthony Liguori > > Suggested-by: Matt Wilson > > Signed-off-by: Eduardo Valentin > > --- > > V3: > > - When PV_DEDICATED is set (1), qspinlock is selected, > > regardless of the value of PV_UNHAULT. Suggested by Paolo Bonzini. > > - Refreshed on top of tip/master. > > V2: > > - rebase on top of tip/master > > > > Documentation/virtual/kvm/cpuid.txt | 6 ++++++ > > arch/x86/include/asm/qspinlock.h | 4 ++++ > > arch/x86/include/uapi/asm/kvm_para.h | 1 + > > arch/x86/kernel/kvm.c | 2 ++ > > 4 files changed, 13 insertions(+) > > > > diff --git a/Documentation/virtual/kvm/cpuid.txt b/Documentation/virtual/kvm/cpuid.txt > > index 3c65feb..117066a 100644 > > --- a/Documentation/virtual/kvm/cpuid.txt > > +++ b/Documentation/virtual/kvm/cpuid.txt > > @@ -54,6 +54,12 @@ KVM_FEATURE_PV_UNHALT || 7 || guest checks this feature bit > > || || before enabling paravirtualized > > || || spinlock support. > > ------------------------------------------------------------------------------ > > +KVM_FEATURE_PV_DEDICATED || 8 || guest checks this feature bit > > + || || to determine if they run on > > + || || dedicated vCPUs, allowing opti- > > + || || mizations such as usage of > > + || || qspinlocks. > > +------------------------------------------------------------------------------ > > KVM_FEATURE_CLOCKSOURCE_STABLE_BIT || 24 || host will warn if no guest-side > > || || per-cpu warps are expected in > > || || kvmclock. > > diff --git a/arch/x86/include/asm/qspinlock.h b/arch/x86/include/asm/qspinlock.h > > index 5e16b5d..de42694 100644 > > --- a/arch/x86/include/asm/qspinlock.h > > +++ b/arch/x86/include/asm/qspinlock.h > > @@ -3,6 +3,8 @@ > > #define _ASM_X86_QSPINLOCK_H > > > > #include > > +#include > > + > > #include > > #include > > #include > > @@ -58,6 +60,8 @@ static inline bool virt_spin_lock(struct qspinlock *lock) > > if (!static_branch_likely(&virt_spin_lock_key)) > > return false; > > > > + if (kvm_para_has_feature(KVM_FEATURE_PV_DEDICATED)) > > + return false; > > /* > > * On hypervisors without PARAVIRT_SPINLOCKS support we fall > > * back to a Test-and-Set spinlock, because fair locks have > > diff --git a/arch/x86/include/uapi/asm/kvm_para.h b/arch/x86/include/uapi/asm/kvm_para.h > > index 554aa8f..85a9875 100644 > > --- a/arch/x86/include/uapi/asm/kvm_para.h > > +++ b/arch/x86/include/uapi/asm/kvm_para.h > > @@ -25,6 +25,7 @@ > > #define KVM_FEATURE_STEAL_TIME 5 > > #define KVM_FEATURE_PV_EOI 6 > > #define KVM_FEATURE_PV_UNHALT 7 > > +#define KVM_FEATURE_PV_DEDICATED 8 > > > > /* The last 8 bits are used to indicate how to interpret the flags field > > * in pvclock structure. If no bits are set, all flags are ignored. > > diff --git a/arch/x86/kernel/kvm.c b/arch/x86/kernel/kvm.c > > index 8bb9594..dacd7cf 100644 > > --- a/arch/x86/kernel/kvm.c > > +++ b/arch/x86/kernel/kvm.c > > @@ -642,6 +642,8 @@ void __init kvm_spinlock_init(void) > > { > > if (!kvm_para_available()) > > return; > > + if (kvm_para_has_feature(KVM_FEATURE_PV_DEDICATED)) > > + return; > > /* Does host kernel support KVM_FEATURE_PV_UNHALT? */ > > if (!kvm_para_has_feature(KVM_FEATURE_PV_UNHALT)) > > return; > > > > -- All the best, Eduardo Valentin From 1583413679504267089@xxx Tue Nov 07 13:22:38 +0000 2017 X-GM-THRID: 1583352031107436177 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread