[PATCH v3 00/10] Support TDX guests on Hyper-V (the Hyper-V specific part)

Dexuan Cui posted 10 patches 2 years, 3 months ago
arch/x86/hyperv/hv_apic.c          |  15 +-
arch/x86/hyperv/hv_init.c          |  59 ++++-
arch/x86/hyperv/ivm.c              | 374 ++++++++++++++++++-----------
arch/x86/include/asm/hyperv-tlfs.h |   3 +-
arch/x86/include/asm/mshyperv.h    |  43 +++-
arch/x86/kernel/cpu/mshyperv.c     |  65 ++++-
drivers/hv/connection.c            |  15 +-
drivers/hv/hv.c                    |  78 +++++-
drivers/hv/hv_common.c             |  43 +++-
drivers/hv/hyperv_vmbus.h          |  11 +
include/asm-generic/mshyperv.h     |   5 +-
11 files changed, 505 insertions(+), 206 deletions(-)
[PATCH v3 00/10] Support TDX guests on Hyper-V (the Hyper-V specific part)
Posted by Dexuan Cui 2 years, 3 months ago
Hyper-V provides two modes for running Intel TDX VMs:

1) TD Partitioning mode with a paravisor (see [1]).
2) In "fully enlightened" mode with normal TDX shared bit control
   over page encryption, and no paravisor

The first mode is similar to AMD SEV-SNP's vTOM mode.
The second is similar to AMD SEV-SNP's C-bit mode.

For #2, the v6 patchset was [2], which is later split into 2 parts:
the generic TDX part (see [3][4]), and the Hyper-V specific part, i.e.
the first 5 patches of this patchset. For the second part, I rebased
the patches to Tianyu's fully enlighted SNP patchset (which has been
in the Hyper-V tree's hyperv-next branch). Since this is mostly a
straightforward rebasing, I keep the existing Acked-by and
Reviewed-by in the v6 patchset [2].

The next 3 patches of this patchset add the support for #1.

The last 2 patches (the 9th and the 10th) just make some cleanup.

Please review all the 10 patches, which are also on my github
branch [5]. The patches can apply cleanly on hyperv-next.

I tested the patches for a regular VM, a VBS VM, a SNP VM
with the paravisor, and a TDX VM with the paravisor and a TDX
VM without the paravisor, and an ARM64 VM. All the VMs worked
as expected.

Thanks,
Dexuan

References:
[1] Intel TDX Module v1.5 TD Partitioning Architecture Specification
[2] https://lwn.net/ml/linux-kernel/20230504225351.10765-1-decui@microsoft.com/
[3] https://lwn.net/ml/linux-kernel/20230811214826.9609-1-decui%40microsoft.com/
[4] https://github.com/dcui/tdx/commits/decui/mainline/x86/tdx/v10
[5] https://github.com/dcui/tdx/commits/decui/mainline/x86/hyperv/tdx-v3

Dexuan Cui (10):
  x86/hyperv: Add hv_isolation_type_tdx() to detect TDX guests
  x86/hyperv: Support hypercalls for fully enlightened TDX guests
  Drivers: hv: vmbus: Support fully enlightened TDX guests
  x86/hyperv: Fix serial console interrupts for fully enlightened TDX
    guests
  Drivers: hv: vmbus: Support >64 VPs for a fully enlightened TDX/SNP VM
  x86/hyperv: Introduce a global variable hyperv_paravisor_present
  Drivers: hv: vmbus: Bring the post_msg_page back for TDX VMs with the
    paravisor
  x86/hyperv: Use TDX GHCI to access some MSRs in a TDX VM with the
    paravisor
  x86/hyperv: Remove hv_isolation_type_en_snp
  x86/hyperv: Move the code in ivm.c around to avoid unnecessary ifdef's

 arch/x86/hyperv/hv_apic.c          |  15 +-
 arch/x86/hyperv/hv_init.c          |  59 ++++-
 arch/x86/hyperv/ivm.c              | 374 ++++++++++++++++++-----------
 arch/x86/include/asm/hyperv-tlfs.h |   3 +-
 arch/x86/include/asm/mshyperv.h    |  43 +++-
 arch/x86/kernel/cpu/mshyperv.c     |  65 ++++-
 drivers/hv/connection.c            |  15 +-
 drivers/hv/hv.c                    |  78 +++++-
 drivers/hv/hv_common.c             |  43 +++-
 drivers/hv/hyperv_vmbus.h          |  11 +
 include/asm-generic/mshyperv.h     |   5 +-
 11 files changed, 505 insertions(+), 206 deletions(-)

-- 
2.25.1
Re: [PATCH v3 00/10] Support TDX guests on Hyper-V (the Hyper-V specific part)
Posted by Wei Liu 2 years, 3 months ago
On Thu, Aug 24, 2023 at 01:07:02AM -0700, Dexuan Cui wrote:
> Dexuan Cui (10):
>   x86/hyperv: Add hv_isolation_type_tdx() to detect TDX guests
>   x86/hyperv: Support hypercalls for fully enlightened TDX guests
>   Drivers: hv: vmbus: Support fully enlightened TDX guests
>   x86/hyperv: Fix serial console interrupts for fully enlightened TDX
>     guests
>   Drivers: hv: vmbus: Support >64 VPs for a fully enlightened TDX/SNP VM
>   x86/hyperv: Introduce a global variable hyperv_paravisor_present
>   Drivers: hv: vmbus: Bring the post_msg_page back for TDX VMs with the
>     paravisor
>   x86/hyperv: Use TDX GHCI to access some MSRs in a TDX VM with the
>     paravisor
>   x86/hyperv: Remove hv_isolation_type_en_snp
>   x86/hyperv: Move the code in ivm.c around to avoid unnecessary ifdef's
> 
>  arch/x86/hyperv/hv_apic.c          |  15 +-
>  arch/x86/hyperv/hv_init.c          |  59 ++++-
>  arch/x86/hyperv/ivm.c              | 374 ++++++++++++++++++-----------
>  arch/x86/include/asm/hyperv-tlfs.h |   3 +-
>  arch/x86/include/asm/mshyperv.h    |  43 +++-
>  arch/x86/kernel/cpu/mshyperv.c     |  65 ++++-
>  drivers/hv/connection.c            |  15 +-
>  drivers/hv/hv.c                    |  78 +++++-
>  drivers/hv/hv_common.c             |  43 +++-
>  drivers/hv/hyperv_vmbus.h          |  11 +
>  include/asm-generic/mshyperv.h     |   5 +-
>  11 files changed, 505 insertions(+), 206 deletions(-)

Applied to hyperv-next, thanks!