Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp1271041lqz; Mon, 1 Apr 2024 00:07:35 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVSNYtCP6b1X45hVh/OJ3cRkzwWTIVbnZ83iHK2rgkaIFanJlgqIYNMGd3jDkUZoIhArnp2mmO4bvoPtUaKPTkUKddeIAj6MzgJyo1Nbg== X-Google-Smtp-Source: AGHT+IFNwC1zCXXIOGeZ/+N3OvjC4tXmugIg6lBmBgxO9iF9lH8BeT9YvoaVihCriyMSWCuBjtLM X-Received: by 2002:a05:620a:5361:b0:78a:3a92:1438 with SMTP id op33-20020a05620a536100b0078a3a921438mr10033783qkn.44.1711955255413; Mon, 01 Apr 2024 00:07:35 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711955255; cv=pass; d=google.com; s=arc-20160816; b=uvT/aPxpLixNa14DQPTrOXRSgAgZ+vcvgW4m8HzEj632UHJ9FVH90hsDdQ5yuRYmqP YDXJ8nufCBlQO/kXeLl9wlGqKLMOuXd0T2eYMJDeRZ+1hgfpo2jASgQ0FLj+q+toaRvy M9wWMGfe/jqGiPwcyulS4X65Wg5m2pKyWacUMegwhFof1t8EyQuz72jLi3MvjhsfY7ED NBtZGo/oqwXP/QDKSpmVfxDUy0T8eIGeHWa2fkTcnvsIXVhObup8InG5kmtXK3Mpoo5x Y4dyijn1Sk8p8G5KuBPua2PHKA7teTiHMVLXHCODdVm0PcL9STIqZh9CVQ2Dqx8WChNH P/cQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=shaKaWUFyUvMU73hwDNd21PpiNXoWR2z4zBcpwYN25M=; fh=CaCirtQ4JLSH68Jca+Aqc95+yGD6xihe1TobOoku/uY=; b=TMftC4fycsr5i5nZHBB5H992b1Tdcab3UGAMN48iV619EGDsVLnyJW9TRMcOhqKiSK TaC9t6UEPkVjPYF8+EnBi9WidrmHZUFnRN94srB6T1JCo3GgFRlmejUjCM9027lb5UgH LwsvDLZjd9o2DlXgbZDR9hfAH6YNCxdKpZX7a4BegiYI6HYVOjyKL+uCKbnhbxA1+Yvf PG6ONu06RvcVKYuwG8IM47jH3TV66yfYr3Cbd7m6kKWQvQYEO+t0UQx2qiIfoqEYWI5g qPC2kHRYIvxMuJ281opOSaK8M5UB1InY3Y4AX0g+zR2tNxvZYpdEsrVDcCgSF1WpL6Vk prPg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=iIbxlKgQ; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-126487-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-126487-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id h7-20020a05620a21c700b007883eac4395si8989687qka.490.2024.04.01.00.07.35 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Apr 2024 00:07:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-126487-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=iIbxlKgQ; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-126487-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-126487-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 2A2F71C20619 for ; Mon, 1 Apr 2024 07:07:35 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 28743BA29; Mon, 1 Apr 2024 07:07:26 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="iIbxlKgQ" Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.15]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B9E719473; Mon, 1 Apr 2024 07:07:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=192.198.163.15 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711955245; cv=none; b=NsYCoBZ3scHbcj5dA8Ui8H8x+5Oo8q4k9Cot0yJJDEpuGO/Wpax/XIxeIto9TuApvJ6pZI9s2XBgpVG4qTY5VcT46WwfI9QM59+bPs0y982Viq/211Reyh9RT0AIEdERjpTttPfDXSJwhOKDtq0QkyP+RZZ0p8lTmbs0QKoP9GM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711955245; c=relaxed/simple; bh=a16RU2Hu1GS33HCADY7Bnjo7ilQmCDcPkDOhMwQFHo0=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=L5ddS8/c+CQ+pwKZc85NVTDCpmRgAE8vyigxMLs4KjUaEVn2ntdlSzhcgx/EhpkRwulLLbXzRbgM+eWLOcVH8UygKCkuzLhaeTWmLQlBUcoLMWrOG915c1h5zhc5wXJSIzgUHMkIVLGx7KmMW1YZMtlolMhl3GwT9b73j6lp1kA= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=iIbxlKgQ; arc=none smtp.client-ip=192.198.163.15 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1711955244; x=1743491244; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=a16RU2Hu1GS33HCADY7Bnjo7ilQmCDcPkDOhMwQFHo0=; b=iIbxlKgQ2XKg4+yTQsuB3iifstZeW43qy2wy3/tqPKgKuiDepLZyz7jT EFnXpaorQPANTcOj7pfS0lbLprgBbSmjQFT9w8Y2UX63nKQYzOtPF4wBY XGWohZfopqwGBAQem3DDlmA7o7iJ7va+RxEUZgIOgDN+gXLXXSxmLx6XV 1vmUGVQuaud27Ix1JlS6NnyujEK3sgiZQXw6nPaTOQIqgs/SghtTPk388 QW/2R12aJECpyLdrhmnVeLFmiVLlNZFzDF7a30QP25CQMN01Rl6O1Cyj6 Z6eGWrQdvWOm7BIj7wKJ9EgzNQyk7hN1iQaKrHyT0ud3J8meoVcG9sqXJ Q==; X-CSE-ConnectionGUID: xHMqWG8KS6e2eMfmANIh8A== X-CSE-MsgGUID: 9M4qxnjrRLytLtV7WIgUxQ== X-IronPort-AV: E=McAfee;i="6600,9927,11030"; a="7262612" X-IronPort-AV: E=Sophos;i="6.07,171,1708416000"; d="scan'208";a="7262612" Received: from orviesa006.jf.intel.com ([10.64.159.146]) by fmvoesa109.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Apr 2024 00:07:22 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.07,171,1708416000"; d="scan'208";a="18085110" Received: from xiaoyaol-hp-g830.ccr.corp.intel.com (HELO [10.124.224.7]) ([10.124.224.7]) by orviesa006-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Apr 2024 00:07:17 -0700 Message-ID: <1e063b73-0f9a-4956-9634-2552e6e63ee1@intel.com> Date: Mon, 1 Apr 2024 15:07:13 +0800 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v6 8/9] KVM: VMX: Open code VMX preemption timer rate mask in its accessor To: Sean Christopherson , Zhao Liu Cc: Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , x86@kernel.org, Paolo Bonzini , Andy Lutomirski , Peter Zijlstra , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, Shan Kang , Kai Huang , Xin Li References: <20240309012725.1409949-1-seanjc@google.com> <20240309012725.1409949-9-seanjc@google.com> Content-Language: en-US From: Xiaoyao Li In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit On 3/16/2024 1:54 AM, Sean Christopherson wrote: > On Fri, Mar 15, 2024, Zhao Liu wrote: >> On Fri, Mar 08, 2024 at 05:27:24PM -0800, Sean Christopherson wrote: >>> Use vmx_misc_preemption_timer_rate() to get the rate in hardware_setup(), >>> and open code the rate's bitmask in vmx_misc_preemption_timer_rate() so >>> that the function looks like all the helpers that grab values from >>> VMX_BASIC and VMX_MISC MSR values. > > ... > >>> -#define VMX_MISC_PREEMPTION_TIMER_RATE_MASK GENMASK_ULL(4, 0) >>> #define VMX_MISC_SAVE_EFER_LMA BIT_ULL(5) >>> #define VMX_MISC_ACTIVITY_HLT BIT_ULL(6) >>> #define VMX_MISC_ACTIVITY_SHUTDOWN BIT_ULL(7) >>> @@ -162,7 +161,7 @@ static inline u32 vmx_basic_vmcs_mem_type(u64 vmx_basic) >>> >>> static inline int vmx_misc_preemption_timer_rate(u64 vmx_misc) >>> { >>> - return vmx_misc & VMX_MISC_PREEMPTION_TIMER_RATE_MASK; >>> + return vmx_misc & GENMASK_ULL(4, 0); >>> } >> >> I feel keeping VMX_MISC_PREEMPTION_TIMER_RATE_MASK is clearer than >> GENMASK_ULL(4, 0), and the former improves code readability. >> >> May not need to drop VMX_MISC_PREEMPTION_TIMER_RATE_MASK? > > I don't necessarily disagree, but in this case I value consistency over one > individual case. As called out in the changelog, the motivation is to make > vmx_misc_preemption_timer_rate() look like all the surrounding helpers. > > _If_ we want to preserve the mask, then we should add #defines for vmx_misc_cr3_count(), > vmx_misc_max_msr(), etc. > > I don't have a super strong preference, though I think my vote would be to not > add the masks and go with this patch. These helpers are intended to be the _only_ > way to access the fields, i.e. they effectively _are_ the mask macros, just in > function form. > +1. However, it seems different for vmx_basic_vmcs_mem_type() in patch 5, that I just recommended to define the MASK. Because we already have #define VMX_BASIC_MEM_TYPE_SHIFT 50 and it has been used in vmx/nested.c, static inline u32 vmx_basic_vmcs_mem_type(u64 vmx_basic) { return (vmx_basic & GENMASK_ULL(53, 50)) >> VMX_BASIC_MEM_TYPE_SHIFT; } looks not intuitive than original patch.