Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1837817ybt; Thu, 2 Jul 2020 15:29:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzmfIfufop2QE1/x7KZwEbD56xB5yHhE1Vi5O8TANpBuL0c0q7wsg+feQqWB2jwQIISpbBd X-Received: by 2002:aa7:d744:: with SMTP id a4mr37007238eds.94.1593728966691; Thu, 02 Jul 2020 15:29:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593728966; cv=none; d=google.com; s=arc-20160816; b=rMMCKUuxj8bYRvstgOdaSPWk5e82Xj8Se0XNIVdwIjJrwtnFoTVZic9dzrJZ5hILzP EGnNF7PxsSfq//WPMkMo59EZ1j2u/JUqCJG9WboOh9AfNtwKwPHmK7jSrMYavky6vqmI 3aeUJQ8x8GY6kigCB0vnuMNCWc/d6zBVzvKcLBxTWNcyZTAe4ZI3atTaHkuAmxRZ/89B IUy2PDMaPRDpU2CISn/fLBaHCNv1l2fM7XANVi48svNW5Viy4Sc/FgYdVrmwkpbsEwY7 mDVsriNAvs3/iNO4uLTcooAWvOtgNRxgxuVAWtL/HJ+1U+4JC6c9aRzXmjEWjeIorD3H nhmg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:ironport-sdr:ironport-sdr; bh=6cvbKg01+mou4nU/iI23FdhNpflgpSwwp5CLdkiXtTE=; b=WM460kd4EcbsPPFH0fRAphw1oj6xpFqCPlvxv42JCKqeAWOTaleprrvChSr2U+bnbw WxeChHJcDoBeOpgkbt8ZNMiLf1j26JX6yAY3/r1H73ErSgUgt8AC+T5tc6ifttx1JB1C czd5Q1dYZjDBgjLWydrHXs/+dmJSZ6W73Umfr+OAOKHghikCTL13cwQSNq7j9rIYjNZk j+CN7BbetDwPGrcRJrV5da2T6d5okWSU/kfFdhUFapR6+dlsEXJJbMqUt2gxdHUWJdsQ 1LtFI5mYFzxi7CXSXDyg0NQtVODr6VwBkL4syDOx3gd2mXwYj1U5ckMbbkN/pRhHPrY4 ZURw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w16si6800956ejq.299.2020.07.02.15.29.03; Thu, 02 Jul 2020 15:29:26 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726304AbgGBW2p (ORCPT + 99 others); Thu, 2 Jul 2020 18:28:45 -0400 Received: from mga07.intel.com ([134.134.136.100]:50847 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726110AbgGBW2o (ORCPT ); Thu, 2 Jul 2020 18:28:44 -0400 IronPort-SDR: q1svIC/YizTQ8ydy7ch0L9qAarSa0Odr+qyCSqeC4fZzQFI9WTj2xylQf1VoRGb51u6IE4Z/gB Mei0qIZRNJzQ== X-IronPort-AV: E=McAfee;i="6000,8403,9670"; a="212067387" X-IronPort-AV: E=Sophos;i="5.75,305,1589266800"; d="scan'208";a="212067387" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 Jul 2020 15:28:43 -0700 IronPort-SDR: +1ViAuCQOuQdfSMX2B6BmxcYDEibA9bsT17rtsST1DOrzyDSk9PLkOOWAwW4iNwPFAZTNXqp4R I+2QHHdq2MVA== X-IronPort-AV: E=Sophos;i="5.75,305,1589266800"; d="scan'208";a="426100146" Received: from xiaoyaol-mobl.ccr.corp.intel.com (HELO [10.255.31.34]) ([10.255.31.34]) by orsmga004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 Jul 2020 15:28:41 -0700 Subject: Re: [PATCH v2 2/7] KVM: X86: Go on updating other CPUID leaves when leaf 1 is absent To: Sean Christopherson Cc: Paolo Bonzini , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , kvm@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200623115816.24132-1-xiaoyao.li@intel.com> <20200623115816.24132-3-xiaoyao.li@intel.com> <20200702185403.GH3575@linux.intel.com> <20200702190237.GK3575@linux.intel.com> From: Xiaoyao Li Message-ID: <54c1cea0-75d5-c38f-c3e5-a8a0679c5fcf@intel.com> Date: Fri, 3 Jul 2020 06:28:39 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.9.0 MIME-Version: 1.0 In-Reply-To: <20200702190237.GK3575@linux.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/3/2020 3:02 AM, Sean Christopherson wrote: > On Thu, Jul 02, 2020 at 11:54:03AM -0700, Sean Christopherson wrote: >> On Tue, Jun 23, 2020 at 07:58:11PM +0800, Xiaoyao Li wrote: >>> As handling of bits other leaf 1 added over time, kvm_update_cpuid() >>> should not return directly if leaf 1 is absent, but should go on >>> updateing other CPUID leaves. >>> >>> Signed-off-by: Xiaoyao Li >> >> This should probably be marked for stable. >> >>> --- >>> arch/x86/kvm/cpuid.c | 23 +++++++++++------------ >>> 1 file changed, 11 insertions(+), 12 deletions(-) >>> >>> diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c >>> index 1d13bad42bf9..0164dac95ef5 100644 >>> --- a/arch/x86/kvm/cpuid.c >>> +++ b/arch/x86/kvm/cpuid.c >>> @@ -60,22 +60,21 @@ int kvm_update_cpuid(struct kvm_vcpu *vcpu) >>> struct kvm_lapic *apic = vcpu->arch.apic; >>> >>> best = kvm_find_cpuid_entry(vcpu, 1, 0); >>> - if (!best) >>> - return 0; >> >> Rather than wrap the existing code, what about throwing it in a separate >> helper? That generates an easier to read diff and also has the nice >> property of getting 'apic' out of the common code. > > Hrm, that'd be overkill once the apic code is moved in a few patches. > What if you keep the cpuid updates wrapped (as in this patch), but then > do > > if (best && apic) { > } > > for the apic path? That'll minimize churn for code that is disappearing, > e.g. will make future git archaeologists happy :-). Sure. I'll do it in next version. >>> - >>> - /* Update OSXSAVE bit */ >>> - if (boot_cpu_has(X86_FEATURE_XSAVE) && best->function == 0x1) >>> - cpuid_entry_change(best, X86_FEATURE_OSXSAVE, >>> + if (best) { >>> + /* Update OSXSAVE bit */ >>> + if (boot_cpu_has(X86_FEATURE_XSAVE)) >>> + cpuid_entry_change(best, X86_FEATURE_OSXSAVE, >>> kvm_read_cr4_bits(vcpu, X86_CR4_OSXSAVE)); >>> >>> - cpuid_entry_change(best, X86_FEATURE_APIC, >>> + cpuid_entry_change(best, X86_FEATURE_APIC, >>> vcpu->arch.apic_base & MSR_IA32_APICBASE_ENABLE); >>> >>> - if (apic) { >>> - if (cpuid_entry_has(best, X86_FEATURE_TSC_DEADLINE_TIMER)) >>> - apic->lapic_timer.timer_mode_mask = 3 << 17; >>> - else >>> - apic->lapic_timer.timer_mode_mask = 1 << 17; >>> + if (apic) { >>> + if (cpuid_entry_has(best, X86_FEATURE_TSC_DEADLINE_TIMER)) >>> + apic->lapic_timer.timer_mode_mask = 3 << 17; >>> + else >>> + apic->lapic_timer.timer_mode_mask = 1 << 17; >>> + } >>> } >>> >>> best = kvm_find_cpuid_entry(vcpu, 7, 0); >>> -- >>> 2.18.2 >>>