diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2025-03-06 11:06:04 -0500 | 
|---|---|---|
| committer | Paolo Bonzini <pbonzini@redhat.com> | 2025-03-14 14:26:27 -0400 | 
| commit | 0d20742b8e6bd94a3a335c061557ec9592a3444b (patch) | |
| tree | bcbdba2d1d5481b6cd156655fd746a3ba9077ceb /rust/helpers/task.c | |
| parent | 74c1807f6c4feddb3c3cb1056c54531d4adbaea6 (diff) | |
| parent | 7c035bea94074b19ed560a4f23a76c5a6c8e594f (diff) | |
Merge branch 'kvm-tdx-initialization' into HEAD
This series kicks off the actual interaction of KVM with the TDX module.
This series encompasses the basic setup for using the TDX module from KVM,
and the creation of TD VMs and vCPUs.
The TDX Module is a software component that runs in a special CPU mode
called SEAM (Secure Arbitration Mode). Loading it is mostly handled
outside of KVM by the core kernel. Once it’s loaded  KVM can interact with
the TDX Module via a new instruction called SEAMCALL to virtualize a TD
guests. This instruction can be used to make various types of seamcalls,
with names organized into a hierarchy. The format is TDH.[AREA].[ACTION],
where “TDH” stands for “Trust Domain Host”, and differentiates from
another set of calls that can be done by the guest “TDG”. The KVM relevant
areas of SEAMCALLs are:
   SYS    – TDX module management, static metadata reading.
   MNG    – TD management. VM scoped things that operate on a TDX module
            controlled structure called the TDCS.
   VP     – vCPU management. vCPU scoped things that operate on TDX module
            controlled structures called the TDVPS.
   PHYMEM - Operations related to physical memory management (page
            reclaiming, cache operations, etc).
This series introduces some TDX specific KVM APIs and stops short of
fully “finalizing” the creation of a TD VM. The part of initializing
a guest where initial private memory is loaded is left to a separate
MMU related series.
Diffstat (limited to 'rust/helpers/task.c')
0 files changed, 0 insertions, 0 deletions
