From: "Lendacky, Thomas" <thomas.lendacky@amd.com>
To: Min Xu <min.m.xu@intel.com>, devel@edk2.groups.io
Cc: Michael D Kinney <michael.d.kinney@intel.com>,
Liming Gao <gaoliming@byosoft.com.cn>,
Zhiguang Liu <zhiguang.liu@intel.com>,
James Bottomley <jejb@linux.ibm.com>,
Jiewen Yao <jiewen.yao@intel.com>,
Gerd Hoffmann <kraxel@redhat.com>,
Brijesh Singh <brijesh.singh@amd.com>,
Erdem Aktas <erdemaktas@google.com>
Subject: Re: [PATCH V3 0/7] Introduce CcProbe in MdePkg
Date: Mon, 18 Apr 2022 10:27:14 -0500 [thread overview]
Message-ID: <5cabaafd-94c0-2347-ae71-2a8a7c2f610b@amd.com> (raw)
In-Reply-To: <cover.1650163941.git.min.m.xu@intel.com>
On 4/16/22 22:01, Min Xu wrote:
> BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3902
>
> Bad IO performance in SEC phase is observed after TDX features was
> introduced. (after commit b6b2de884864 - "MdePkg: Support mmio for
> Tdx guest in BaseIoLibIntrinsic").
>
> This is because IsTdxGuest() will be called in each MMIO operation.
> It is trying to cache the result of the probe in the efi data segment.
> However, that doesn't work in SEC, because the data segment is read only
> (so the write seems to succeed but a read will always return the
> original value), leading to us calling TdIsEnabled() check for every
> mmio we do, which is causing the slowdown because it's very expensive.
>
> CcProbe is introduced in this patch-set. It is called in
> BaseIoLibIntrinsicSev instead of IsTdxGuest. There are 2 versions of
> the CcProbeLib. Null instance of CcProbe always returns
> CCGuestTypeNonEncrypted. Its OvmfPkg version checks the Ovmf work area
> and returns the CC guest type.
>
> In this patch-set another issue is fixed with CcProbe as well. If the
> working guest is SEV and in the beginning of SecMain.c TdIsEnabled()
> was called. At this point, exception handling is not established and
> a CPUID instruction will generate a #VC and cause the booting SEV guest
> to crash. Patch #7 is to fix this broken.
>
> Code is at: https://github.com/mxu9/edk2/tree/cc_probe.v3
>
> v3 changes:
> - Fix the broken issue in SEV guest at SecMain.c. Please refer to
> Patch #7.
>
> v2 changes:
> - Rename TdProbe to CcProbe to make the lib work for Confidential
> Computing guests.
> - Rename the GUEST_TYPE to CC_GUEST_TYPE and move it from
> WorkArea.h@OvmfPkg to ConfidentialComputingGuestAttr.h@MdePkg.
> This is because CcProbeLib is designed to return the CC Guest
> type and the lib is located at MdePkg.
> - Rename the CC_GUEST_TYPE's fields name to Camel style. See the
> commit message in patch #1.
>
> Cc: Michael D Kinney <michael.d.kinney@intel.com>
> Cc: Liming Gao <gaoliming@byosoft.com.cn>
> Cc: Zhiguang Liu <zhiguang.liu@intel.com>
> Cc: James Bottomley <jejb@linux.ibm.com>
> Cc: Jiewen Yao <jiewen.yao@intel.com>
> Cc: Gerd Hoffmann <kraxel@redhat.com>
> Cc: Brijesh Singh <brijesh.singh@amd.com>
> Cc: Erdem Aktas <erdemaktas@google.com>
> Cc: Tom Lendacky <thomas.lendacky@amd.com>
> Signed-off-by: Min Xu <min.m.xu@intel.com>
After working around the PCI library issue (for which Min will be
submitting a patch), this series boots successfully for SEV, SEV-ES and
SEV-SNP when built as X64. I documented the issue that SEV has with
Ia32X64 in patch 5/7 and I'll have to decide what to do there. So...
Reviewed-by: Tom Lendacky <thomas.lendacky@amd.com>
>
> Min Xu (7):
> MdePkg: Add CC_GUEST_TYPE in ConfidentialComputingGuestAttr.h
> OvmfPkg: Replace GUEST_TYPE with CC_GUEST_TYPE
> MdePkg: Add CcProbeLib
> OvmfPkg: Add CcProbeLib
> OvmfPkg: Add CcProbeLib in *.dsc
> MdePkg: Probe Cc guest in BaseIoLibIntrinsicSev
> OvmfPkg: Call CcProbe in SecMain.c instead of TsIsEnabled
>
> .../Include/ConfidentialComputingGuestAttr.h | 11 ++++++-
> MdePkg/Include/Library/CcProbeLib.h | 26 ++++++++++++++++
> .../BaseIoLibIntrinsicSev.inf | 1 +
> .../BaseIoLibIntrinsic/IoLibInternalTdx.c | 13 ++------
> .../Library/CcProbeLibNull/CcProbeLibNull.c | 26 ++++++++++++++++
> .../Library/CcProbeLibNull/CcProbeLibNull.inf | 21 +++++++++++++
> MdePkg/MdePkg.dec | 5 +++
> MdePkg/MdePkg.dsc | 1 +
> OvmfPkg/AmdSev/AmdSevX64.dsc | 1 +
> OvmfPkg/Bhyve/BhyveX64.dsc | 1 +
> OvmfPkg/CloudHv/CloudHvX64.dsc | 1 +
> OvmfPkg/Include/WorkArea.h | 9 +-----
> OvmfPkg/IntelTdx/IntelTdxX64.dsc | 1 +
> OvmfPkg/IntelTdx/Sec/SecMain.c | 6 ++--
> OvmfPkg/IntelTdx/Sec/SecMain.inf | 1 +
> .../PeiMemEncryptSevLibInternal.c | 2 +-
> .../SecMemEncryptSevLibInternal.c | 2 +-
> OvmfPkg/Library/CcProbeLib/CcProbeLib.c | 31 +++++++++++++++++++
> OvmfPkg/Library/CcProbeLib/CcProbeLib.inf | 25 +++++++++++++++
> OvmfPkg/Library/QemuFwCfgLib/QemuFwCfgPei.c | 2 +-
> OvmfPkg/Microvm/MicrovmX64.dsc | 1 +
> OvmfPkg/OvmfPkgIa32.dsc | 1 +
> OvmfPkg/OvmfPkgIa32X64.dsc | 1 +
> OvmfPkg/OvmfPkgX64.dsc | 1 +
> OvmfPkg/OvmfXen.dsc | 1 +
> OvmfPkg/Sec/AmdSev.c | 2 +-
> OvmfPkg/Sec/SecMain.c | 5 +--
> OvmfPkg/Sec/SecMain.inf | 1 +
> 28 files changed, 170 insertions(+), 29 deletions(-)
> create mode 100644 MdePkg/Include/Library/CcProbeLib.h
> create mode 100644 MdePkg/Library/CcProbeLibNull/CcProbeLibNull.c
> create mode 100644 MdePkg/Library/CcProbeLibNull/CcProbeLibNull.inf
> create mode 100644 OvmfPkg/Library/CcProbeLib/CcProbeLib.c
> create mode 100644 OvmfPkg/Library/CcProbeLib/CcProbeLib.inf
>
next prev parent reply other threads:[~2022-04-18 15:27 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-04-17 3:01 [PATCH V3 0/7] Introduce CcProbe in MdePkg Min Xu
2022-04-17 3:01 ` [PATCH V3 1/7] MdePkg: Add CC_GUEST_TYPE in ConfidentialComputingGuestAttr.h Min Xu
2022-04-18 13:47 ` Lendacky, Thomas
2022-04-18 14:01 ` Min Xu
2022-04-19 6:48 ` Gerd Hoffmann
2022-04-17 3:01 ` [PATCH V3 2/7] OvmfPkg: Replace GUEST_TYPE with CC_GUEST_TYPE Min Xu
2022-04-17 3:01 ` [PATCH V3 3/7] MdePkg: Add CcProbeLib Min Xu
2022-04-17 3:01 ` [PATCH V3 4/7] OvmfPkg: " Min Xu
2022-04-17 3:01 ` [PATCH V3 5/7] OvmfPkg: Add CcProbeLib in *.dsc Min Xu
2022-04-18 15:01 ` Lendacky, Thomas
2022-04-17 3:01 ` [PATCH V3 6/7] MdePkg: Probe Cc guest in BaseIoLibIntrinsicSev Min Xu
2022-04-17 3:01 ` [PATCH V3 7/7] OvmfPkg: Call CcProbe in SecMain.c instead of TsIsEnabled Min Xu
2022-04-17 3:22 ` [PATCH V3 0/7] Introduce CcProbe in MdePkg Yao, Jiewen
2022-04-17 3:30 ` 回复: " gaoliming
2022-04-18 15:27 ` Lendacky, Thomas [this message]
2022-04-18 23:49 ` [edk2-devel] " Min Xu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-list from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5cabaafd-94c0-2347-ae71-2a8a7c2f610b@amd.com \
--to=devel@edk2.groups.io \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox