Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp844119pxf; Thu, 1 Apr 2021 15:26:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzAEkbLCLI0Qa97dQigJS9TVeXKs8yUfeBVKaVoQAhkvncwMSSdz2Mik5ZETuNhe6PDTfxt X-Received: by 2002:a92:c644:: with SMTP id 4mr8454151ill.154.1617316016910; Thu, 01 Apr 2021 15:26:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617316016; cv=none; d=google.com; s=arc-20160816; b=bw+mLNR876kvMcLcD2ykpygL0wIPiRDV3YRk6mBz8KtSZstVYSG7unz++sgpXj9SB6 mEL1uxFDRTmYD7lMmvzeCrZUkJ66N0HHujqK4GF8k8a4hvRe7THLpYE1gYCVGYU03JkH fJUKNX0enrQh49FjIf5/jLAmmh60uhj72WbFjA5GeLL7a78Y6MgAC7JDUMBNinZPzVt/ Twwpnpl3Eksgieej60XRcGgObcXFYZPnsSqNDixpg/+8gjL1IZ+Dy2USMhwPPrOtUJj5 YBE52MRy2q0sVH4WUgNeQ7Yu3yCbMNhROOz46pKUjva1rjKy7V0GXlXWXmNxokLAE21l YFZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence: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=ClmhOeCbBlS6Mz1J06M9Enhild+WeoQX1SMq2lPV118=; b=QkaapGC7OsXpvDfMsbPE/aE3Ef0paheRjmx0+fpettWZyINBAgo+daD5F0NlDOFBPb jHCVZw4MmqRWX2CY0hJ4JGw3cFY9SEhfCTIhd516QKSVGHF/NfK2IcaTLDmkQ01qE4X3 4mdTkYfWrbfm2H95fU2B4nvoV5IB14QB9wHLABZDCH+WW0jx8PykTCEoyWO1OEaIzC/T zHGClbtcksJ6grMMLe7jMT/1WnNsWgjISEikx2usj2zaD7RDg8ppQUdLQMCH2dhKs8jp i8TAC3B8xTtXlCcn9Kv9j87TziNzpA9gDUsOLwkUVUhVb2hOE7wKXG9m+X0vpZmPSzpS BEmw== 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 y23si6128217jai.77.2021.04.01.15.26.42; Thu, 01 Apr 2021 15:26:56 -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 S234835AbhDAWZY (ORCPT + 99 others); Thu, 1 Apr 2021 18:25:24 -0400 Received: from mga09.intel.com ([134.134.136.24]:15743 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233789AbhDAWZY (ORCPT ); Thu, 1 Apr 2021 18:25:24 -0400 IronPort-SDR: DiuTLWy5ks/iutoT3DkEKk/wwWWukTz5/IDHb70ZswwrhjuBB22NmbEzqnX/zFGPv8FQ+Zs88f OoVj3rVdzK4Q== X-IronPort-AV: E=McAfee;i="6000,8403,9941"; a="192446191" X-IronPort-AV: E=Sophos;i="5.81,296,1610438400"; d="scan'208";a="192446191" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Apr 2021 15:25:24 -0700 IronPort-SDR: H7wg1ZKmAqZo2RE31j8BZztOdcTcVFJ9QTcXyjzYgyev32YuHTWndqIo1usOEM36PbC3U1lZMo h+NSZdNDlS5Q== X-IronPort-AV: E=Sophos;i="5.81,296,1610438400"; d="scan'208";a="419389337" Received: from maorache-mobl.amr.corp.intel.com (HELO skuppusw-mobl5.amr.corp.intel.com) ([10.213.170.140]) by orsmga008-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Apr 2021 15:25:23 -0700 Subject: Re: [RFC v1 03/26] x86/cpufeatures: Add is_tdx_guest() interface To: Dave Hansen , Peter Zijlstra , Andy Lutomirski Cc: Andi Kleen , Kirill Shutemov , Kuppuswamy Sathyanarayanan , Dan Williams , Raj Ashok , Sean Christopherson , linux-kernel@vger.kernel.org, Sean Christopherson References: <83c8fcff9ac09f73924104cfb534258747e98bff.1612563142.git.sathyanarayanan.kuppuswamy@linux.intel.com> <0116481d-581b-9433-3641-47e39550b99a@intel.com> <8f0bd4e5-195b-7e65-f780-f5e31d72cfe8@linux.intel.com> <3aee61d5-9cc2-2c3c-00ea-f3ec7d5f7e04@intel.com> From: "Kuppuswamy, Sathyanarayanan" Message-ID: Date: Thu, 1 Apr 2021 15:25:20 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <3aee61d5-9cc2-2c3c-00ea-f3ec7d5f7e04@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/1/21 2:19 PM, Dave Hansen wrote: > On 4/1/21 2:15 PM, Kuppuswamy, Sathyanarayanan wrote: >> On 4/1/21 2:08 PM, Dave Hansen wrote: >>> On 2/5/21 3:38 PM, Kuppuswamy Sathyanarayanan wrote: >>>> +bool is_tdx_guest(void) >>>> +{ >>>> +    return static_cpu_has(X86_FEATURE_TDX_GUEST); >>>> +} >>> >>> Why do you need is_tdx_guest() as opposed to calling >>> cpu_feature_enabled(X86_FEATURE_TDX_GUEST) everywhere? >> >> is_tdx_guest() is also implemented/used in compressed >> code (which uses native_cpuid calls). I don't think >> we can use cpu_feature_enabled(X86_FEATURE_TDX_GUEST) in >> compressed code right? Also is_tdx_guest() looks easy >> to read and use. > > OK, but how many of the is_tdx_guest() uses are in the compressed code? > Why has its use spread beyond that? Its only used in handling in/out instructions in compressed code. But this code shared with in/out handling on non-compressed code. #define __out(bwl, bw) \ do { \ if (is_tdx_guest()) { \ asm volatile("call tdg_out" #bwl : : \ "a"(value), "d"(port)); \ } else { \ asm volatile("out" #bwl " %" #bw "0, %w1" : : \ "a"(value), "Nd"(port)); \ } \ } while (0) #define __in(bwl, bw) \ do { \ if (is_tdx_guest()) { \ asm volatile("call tdg_in" #bwl : \ "=a"(value) : "d"(port)); \ } else { \ asm volatile("in" #bwl " %w1, %" #bw "0" : \ "=a"(value) : "Nd"(port)); \ } \ } while (0) > -- Sathyanarayanan Kuppuswamy Linux Kernel Developer