~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/arch/x86/amd-memory-encryption.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 .. SPDX-License-Identifier: GPL-2.0
  2 
  3 =====================
  4 AMD Memory Encryption
  5 =====================
  6 
  7 Secure Memory Encryption (SME) and Secure Encrypted Virtualization (SEV) are
  8 features found on AMD processors.
  9 
 10 SME provides the ability to mark individual pages of memory as encrypted using
 11 the standard x86 page tables.  A page that is marked encrypted will be
 12 automatically decrypted when read from DRAM and encrypted when written to
 13 DRAM.  SME can therefore be used to protect the contents of DRAM from physical
 14 attacks on the system.
 15 
 16 SEV enables running encrypted virtual machines (VMs) in which the code and data
 17 of the guest VM are secured so that a decrypted version is available only
 18 within the VM itself. SEV guest VMs have the concept of private and shared
 19 memory. Private memory is encrypted with the guest-specific key, while shared
 20 memory may be encrypted with hypervisor key. When SME is enabled, the hypervisor
 21 key is the same key which is used in SME.
 22 
 23 A page is encrypted when a page table entry has the encryption bit set (see
 24 below on how to determine its position).  The encryption bit can also be
 25 specified in the cr3 register, allowing the PGD table to be encrypted. Each
 26 successive level of page tables can also be encrypted by setting the encryption
 27 bit in the page table entry that points to the next table. This allows the full
 28 page table hierarchy to be encrypted. Note, this means that just because the
 29 encryption bit is set in cr3, doesn't imply the full hierarchy is encrypted.
 30 Each page table entry in the hierarchy needs to have the encryption bit set to
 31 achieve that. So, theoretically, you could have the encryption bit set in cr3
 32 so that the PGD is encrypted, but not set the encryption bit in the PGD entry
 33 for a PUD which results in the PUD pointed to by that entry to not be
 34 encrypted.
 35 
 36 When SEV is enabled, instruction pages and guest page tables are always treated
 37 as private. All the DMA operations inside the guest must be performed on shared
 38 memory. Since the memory encryption bit is controlled by the guest OS when it
 39 is operating in 64-bit or 32-bit PAE mode, in all other modes the SEV hardware
 40 forces the memory encryption bit to 1.
 41 
 42 Support for SME and SEV can be determined through the CPUID instruction. The
 43 CPUID function 0x8000001f reports information related to SME::
 44 
 45         0x8000001f[eax]:
 46                 Bit[0] indicates support for SME
 47                 Bit[1] indicates support for SEV
 48         0x8000001f[ebx]:
 49                 Bits[5:0]  pagetable bit number used to activate memory
 50                            encryption
 51                 Bits[11:6] reduction in physical address space, in bits, when
 52                            memory encryption is enabled (this only affects
 53                            system physical addresses, not guest physical
 54                            addresses)
 55 
 56 If support for SME is present, MSR 0xc00100010 (MSR_AMD64_SYSCFG) can be used to
 57 determine if SME is enabled and/or to enable memory encryption::
 58 
 59         0xc0010010:
 60                 Bit[23]   0 = memory encryption features are disabled
 61                           1 = memory encryption features are enabled
 62 
 63 If SEV is supported, MSR 0xc0010131 (MSR_AMD64_SEV) can be used to determine if
 64 SEV is active::
 65 
 66         0xc0010131:
 67                 Bit[0]    0 = memory encryption is not active
 68                           1 = memory encryption is active
 69 
 70 Linux relies on BIOS to set this bit if BIOS has determined that the reduction
 71 in the physical address space as a result of enabling memory encryption (see
 72 CPUID information above) will not conflict with the address space resource
 73 requirements for the system.  If this bit is not set upon Linux startup then
 74 Linux itself will not set it and memory encryption will not be possible.
 75 
 76 The state of SME in the Linux kernel can be documented as follows:
 77 
 78         - Supported:
 79           The CPU supports SME (determined through CPUID instruction).
 80 
 81         - Enabled:
 82           Supported and bit 23 of MSR_AMD64_SYSCFG is set.
 83 
 84         - Active:
 85           Supported, Enabled and the Linux kernel is actively applying
 86           the encryption bit to page table entries (the SME mask in the
 87           kernel is non-zero).
 88 
 89 SME can also be enabled and activated in the BIOS. If SME is enabled and
 90 activated in the BIOS, then all memory accesses will be encrypted and it
 91 will not be necessary to activate the Linux memory encryption support.
 92 
 93 If the BIOS merely enables SME (sets bit 23 of the MSR_AMD64_SYSCFG),
 94 then memory encryption can be enabled by supplying mem_encrypt=on on the
 95 kernel command line.  However, if BIOS does not enable SME, then Linux
 96 will not be able to activate memory encryption, even if configured to do
 97 so by default or the mem_encrypt=on command line parameter is specified.
 98 
 99 Secure Nested Paging (SNP)
100 ==========================
101 
102 SEV-SNP introduces new features (SEV_FEATURES[1:63]) which can be enabled
103 by the hypervisor for security enhancements. Some of these features need
104 guest side implementation to function correctly. The below table lists the
105 expected guest behavior with various possible scenarios of guest/hypervisor
106 SNP feature support.
107 
108 +-----------------+---------------+---------------+------------------+
109 | Feature Enabled | Guest needs   | Guest has     | Guest boot       |
110 | by the HV       | implementation| implementation| behaviour        |
111 +=================+===============+===============+==================+
112 |      No         |      No       |      No       |     Boot         |
113 |                 |               |               |                  |
114 +-----------------+---------------+---------------+------------------+
115 |      No         |      Yes      |      No       |     Boot         |
116 |                 |               |               |                  |
117 +-----------------+---------------+---------------+------------------+
118 |      No         |      Yes      |      Yes      |     Boot         |
119 |                 |               |               |                  |
120 +-----------------+---------------+---------------+------------------+
121 |      Yes        |      No       |      No       | Boot with        |
122 |                 |               |               | feature enabled  |
123 +-----------------+---------------+---------------+------------------+
124 |      Yes        |      Yes      |      No       | Graceful boot    |
125 |                 |               |               | failure          |
126 +-----------------+---------------+---------------+------------------+
127 |      Yes        |      Yes      |      Yes      | Boot with        |
128 |                 |               |               | feature enabled  |
129 +-----------------+---------------+---------------+------------------+
130 
131 More details in AMD64 APM[1] Vol 2: 15.34.10 SEV_STATUS MSR
132 
133 Secure VM Service Module (SVSM)
134 ===============================
135 SNP provides a feature called Virtual Machine Privilege Levels (VMPL) which
136 defines four privilege levels at which guest software can run. The most
137 privileged level is 0 and numerically higher numbers have lesser privileges.
138 More details in the AMD64 APM Vol 2, section "15.35.7 Virtual Machine
139 Privilege Levels", docID: 24593.
140 
141 When using that feature, different services can run at different protection
142 levels, apart from the guest OS but still within the secure SNP environment.
143 They can provide services to the guest, like a vTPM, for example.
144 
145 When a guest is not running at VMPL0, it needs to communicate with the software
146 running at VMPL0 to perform privileged operations or to interact with secure
147 services. An example fur such a privileged operation is PVALIDATE which is
148 *required* to be executed at VMPL0.
149 
150 In this scenario, the software running at VMPL0 is usually called a Secure VM
151 Service Module (SVSM). Discovery of an SVSM and the API used to communicate
152 with it is documented in "Secure VM Service Module for SEV-SNP Guests", docID:
153 58019.
154 
155 (Latest versions of the above-mentioned documents can be found by using
156 a search engine like duckduckgo.com and typing in:
157 
158   site:amd.com "Secure VM Service Module for SEV-SNP Guests", docID: 58019
159 
160 for example.)

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php