From: "gaoliming" <gaoliming@byosoft.com.cn>
To: "'Min Xu'" <min.m.xu@intel.com>, <devel@edk2.groups.io>
Cc: "'Michael D Kinney'" <michael.d.kinney@intel.com>,
"'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>,
"'Tom Lendacky'" <thomas.lendacky@amd.com>
Subject: 回复: [PATCH V3 0/7] Introduce CcProbe in MdePkg
Date: Sun, 17 Apr 2022 11:30:50 +0800 [thread overview]
Message-ID: <000301d8520b$895497d0$9bfdc770$@byosoft.com.cn> (raw)
In-Reply-To: <cover.1650163941.git.min.m.xu@intel.com>
Min:
The change in MdePkg is good to me. Reviewed-by: Liming Gao
<gaoliming@byosoft.com.cn>
Thanks
Liming
> -----邮件原件-----
> 发件人: Min Xu <min.m.xu@intel.com>
> 发送时间: 2022年4月17日 11:01
> 收件人: devel@edk2.groups.io
> 抄送: Min Xu <min.m.xu@intel.com>; 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>; Tom Lendacky <thomas.lendacky@amd.com>
> 主题: [PATCH V3 0/7] Introduce CcProbe in MdePkg
>
> 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>
>
> 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
>
> --
> 2.29.2.windows.2
next prev parent reply other threads:[~2022-04-17 3:30 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 [this message]
2022-04-18 15:27 ` Lendacky, Thomas
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='000301d8520b$895497d0$9bfdc770$@byosoft.com.cn' \
--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