- 1. Introduction
- 2. Report an Issue
- 3. Supported Hardware
- 4. Setup Host OS
- 5. Create TD Image
- 6. Boot TD
- 7. Verify TD
- 8. Setup Remote Attestation on Host OS and Inside TD
- 9. Perform Remote Attestation Using Intel Tiber Trust Services CLI
- 10. Build Packages From Source
- 11. Build Kernel From Source
- 12. Run Tests
- 13. Troubleshooting Tips
Intel® TDX is a Confidential Computing technology which deploys hardware-isolated, Virtual Machines (VMs) called Trust Domains (TDs). It protects TDs from a broad range of software attacks by isolating them from the Virtual-Machine Manager (VMM), hypervisor, and other non-TD software on the host platform. As a result, Intel TDX enhances a platform user’s control of data security and IP protection. Also, it enhances the Cloud Service Providers’ (CSP) ability to provide managed cloud services without exposing tenant data to adversaries. For more information, see the Intel TDX overview.
This tech preview of Intel TDX on Ubuntu provides base host OS, guest OS, and remote attestation functionalities. Two Ubuntu releases are currently supported for base host OS and guest OS:
- Ubuntu Noble 24.04 LTS
- Ubuntu Oracular 24.10
Follow these instructions to set up the Intel TDX host, create a TD, boot the TD, and attest the integrity of the TD's execution environment.
The host OS and TD setup can be customized by editing the global configuration file: setup-tdx-config
.
First, check the Troubleshooting Tips section.
If your issue can't be resolved, then submit an issue here and we'll get back to you ASAP.
To help us with the debugging process, run the system-report.sh
tool and attach the report.
This release works with these Intel® Xeon® Processors:
Processor | Code Name | TDX Module Version |
---|---|---|
4th Gen Intel® Xeon® Scalable Processors (select SKUs with Intel® TDX) | Sapphire Rapids | 1.5.x |
5th Gen Intel® Xeon® Scalable Processors | Emerald Rapids | 1.5.x |
Intel® Xeon® 6 Processors with P-Cores | Granite Rapids | 2.0.x |
To help identify which processor you have, please visit ark.intel.com and search for the part number. Then, look for "Code Name" and "Intel® Trust Domain Extensions (Intel® TDX)".
In this section, you will install a generic Ubuntu 24.04 server image, install necessary packages to turn the host OS into an Intel TDX-enabled host OS, optionally install remote attestation components, and enable Intel TDX settings in the BIOS.
Download and install appropriate Ubuntu Server on the host machine:
-
Download this repository by downloading an asset file from the releases page on GitHub or by cloning the repository (at the appropriate tag/branch).
For example, to clone the development branch (replace
main
by a release tag if you want a specific release):git clone -b main https://github.com/canonical/tdx.git
-
Customize the setup of the host and TD by editing the configuration file
setup-tdx-config
.
By default, remote attestation components are not installed on the host and inside the TD.
You can choose to automatically install remote attestation packages provided by Canonical by settingTDX_SETUP_ATTESTATION=1
.
In this case, you can skip step 8.2.1 and step 8.3.3. -
Run the
setup-tdx-host.sh
script.NOTE: If you're behind a proxy, use
sudo -E
to preserve user environment.cd tdx sudo ./setup-tdx-host.sh
-
Reboot.
-
Go into the host's BIOS.
NOTE: The following is a sample BIOS configuration. The necessary BIOS settings or the menus might differ based on the platform that is used. Please reach out to your OEM/ODM or independent BIOS vendor for instructions dedicated for your BIOS.
-
Go to
Socket Configuration > Processor Configuration > TME, TME-MT, TDX
.- Set
Memory Encryption (TME)
toEnable
- Set
Total Memory Encryption Bypass
toEnable
(Optional setting for best host OS and regular VM performance.) - Set
Total Memory Encryption Multi-Tenant (TME-MT)
toEnable
- Set
TME-MT memory integrity
toDisable
- Set
Trust Domain Extension (TDX)
toEnable
- Set
TDX Secure Arbitration Mode Loader (SEAM Loader)
toEnable
. (NOTE: This allows loading Intel TDX Loader and Intel TDX Module from the ESP or BIOS.) - Set
TME-MT/TDX key split
to a non-zero value
- Set
-
Go to
Socket Configuration > Processor Configuration > Software Guard Extension (SGX)
.- Set
SW Guard Extensions (SGX)
toEnable
- Set
-
Save the BIOS settings and boot up.
Verify that Intel TDX is enabled using the dmesg
command:
sudo dmesg | grep -i tdx
The message virt/tdx: module initialized
proves that Intel TDX has initialized properly. Here is an example output:
...
[ 5.205693] virt/tdx: BIOS enabled: private KeyID range [64, 128)
[ 29.884504] virt/tdx: 1050644 KB allocated for PAMT
[ 29.884513] virt/tdx: module initialized
...
In this section, you will create an Ubuntu-based TD image from scratch or convert an existing VM image into a TD image. This can be performed on any Ubuntu 22.04 or newer system - an Intel TDX-specific environment is not required.
- The base image is an Ubuntu cloud image.
- By default, the Ubuntu generic kernel is used for the TD guest. The
-intel
kernel, which may have non-upstreamed and/or under-development features, can be selected by setting the variableTDX_SETUP_INTEL_KERNEL=1
in thesetup-tdx-config
configuration file.
A TD image based on Ubuntu 24.10 can be generated with the following commands:
cd tdx/guest-tools/image/
sudo ./create-td-image.sh -v 24.10
You can pass 24.04
to the -v
to generate a TD image based on Ubuntu 24.04.
The resulting image will be based on an (Ubuntu cloud image
),
the default root password is 123456
, and other default settings are used.
Please note the most important options described after the commands and take a look at the create-td-image.sh
script for more available options.
Important options for TD image creation:
- If you're behind a proxy, use
sudo -E
to preserve user environment. - The used kernel type (
generic
orintel
) will be reflected in the name of the resulting image so it is easy to distinguish.
If you have an existing Ubuntu (24.04
or 24.10
) VM image, you can enable the Intel TDX feature using the following steps:
-
Boot up your guest, i.e., your regular VM.
-
Download this repository by downloading an asset file from the releases page on GitHub or by cloning the repository (at the appropriate tag/branch).
-
Run the following script.
cd tdx sudo ./setup-tdx-guest.sh
-
Shutdown the guest.
Now that you have a TD image, let’s boot it using one of the following two ways:
- Boot using QEMU
- Boot using virsh
NOTE: The script provided for the virsh method supports running multiple TDs simultaneously. The script provided for the QEMU method supports running only a single instance.
Boot TD with the provided script.
By default, the script will use an image with a generic kernel located at
./image/tdx-guest-ubuntu-<24.04|24.10>-generic.qcow2
. A different qcow2
image (e.g., one with an intel kernel) can be used by setting the TD_IMG
command-line variable.
NOTE: It is recommended that you run the script as a non-root user.
cd tdx/guest-tools
./run_td.sh
An example output:
TD, PID: 111924, SSH : ssh -p 10022 root@localhost
-
[Recommended] Configure libvirt to be usable as non-root user.
-
Apply the following settings to the file
/etc/libvirt/qemu.conf
.user = <your_user_name> group = <your_group> dynamic_ownership = 0
-
Restart the
libvirtd
servicesudo systemctl restart libvirtd
-
-
Boot TD using the following commands.
cd tdx/guest-tools ./tdvirsh new
Details about
tdvirsh
:-
To manage the lifecycle of TDs, we developed a wrapper around the
virsh
tool. This newtdvirsh
tool extendsvirsh
with new capabilities to create/remove TDs. -
By default,
tdvirsh
will use an image located at./image/tdx-guest-ubuntu-<24.04|24.10>-generic.qcow2
with thegeneric
Ubuntu kernel. A different qcow2 image (e.g., one with anintel
kernel) can be used by using the command-line option-i IMAGE_PATH
. -
By default,
tdvirsh
will use a XML libvirt template located at./trust_domain.xml.template
. A different XML libvirt template can be used by using the command-line option-t XML_PATH
. -
All VMs can be listed with the following command:
./tdvirsh list --all
Example output:
Id Name State --------------------------------------------------------------------------- 1 tdvirsh-trust_domain-f7210c2b-2657-4f30-adf3-639b573ea39f running (ip:192.168.122.212, hostfwd:32855, cid:3)
NOTE:
32855
inhostfwd:32855
is the port number a user can use to connect to the TD viassh -p 32855 root@localhost
. You can also connect to the guest using its IP address :ssh [email protected]
. -
A TD can be removed with the following command:
./tdvirsh delete [domain]
-
All available options can be displayed with the following command:
./tdvirsh -h
-
We provide a libvirt template (trust_domain-sb.xml.template
) that shows how a TD can be booted with secure boot.
As a result, you can easily boot a TD with secure boot enabled using the following commands:
cd tdx/guest-tools
./tdvirsh new -t trust_domain-sb.xml.template
-
Log into the TD using one of the following commands.
NOTE: If you booted your TD with
td_virsh_tool.sh
, you will likely need a different port number from the one below. The tool will print the appropriate port to use after it has successfully booted the TD.- From localhost
ssh -p 10022 root@localhost
- From remote host
ssh -p 10022 root@<host_ip>
-
Verify Intel TDX is enabled in the TD:
dmesg | grep -i tdx
An example output:
[ 0.000000] tdx: Guest detected [ 0.000000] DMI: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 2023.05-2+tdx1.0~ubuntu23.10.1 10/17/2023 [ 0.395218] process: using TDX aware idle routine [ 0.395218] Memory Encryption Features active: Intel TDX
-
Verify quote generation provider:
mkdir -p /sys/kernel/config/tsm/report/testreport0 cat /sys/kernel/config/tsm/report/testreport0/provider
Should give the following output:
tdx_guest
Attestation is a process in which the attester requests the verifier (e.g., Intel Tiber Trust Services) to confirm that a TD is operating in a secure and trusted environment. This process involves the attester generating a "TD Quote", which contains measurements of the Trusted Execution Environment (TEE) and other cryptographic evidence. The TD Quote is sent to the verifier who then confirms its validity against reference values and policies. If confirmed, the verifier returns an attestation token. The attester can then send the token to a relying party who will validate it. For more on the basics of attestation, see Attestation overview.
For attestation to work, you need Production hardware. Run the check-production.sh
script to verify.
cd tdx/attestation
sudo ./check-production.sh
-
Install the required DCAP packages from Canonical's PPA on the host OS.
NOTE 1: If you have already installed the attestation components as part of the host OS setup (see step 2 in section 4.2), you can continue with step 3.
NOTE 2: If you're behind a proxy, use
sudo -E
to preserve user environment.cd tdx/attestation sudo ./setup-attestation-host.sh
-
Reboot the system.
-
Verify the Intel SGX devices belong to these groups and have proper permissions.
NOTE: These devices are needed as Intel TDX's attestation flow is based on the Intel SGX attestation flow.
ls -l /dev/sgx_*
Expected result:
crw-rw---- 1 root sgx 10, 125 Apr 3 21:14 /dev/sgx_enclave crw-rw---- 1 root sgx_prv 10, 126 Apr 3 21:14 /dev/sgx_provision crw-rw---- 1 root sgx 10, 124 Apr 3 21:14 /dev/sgx_vepc
-
Verify the QGS service is running properly:
sudo systemctl status qgsd
-
Verify the PCCS service is running properly:
sudo systemctl status pccs
-
To set up the PCCS in the next step, you need a subscription key for the Intel PCS.
- If you did not request such a subscription key before, subscribe to Intel PCS, which requires to log in (or create an account). Two subscription keys are generated (for key rotation) and both can be used for the following step.
- If you did request such a subscription key before, retrieve one of your keys, which requires to log in. You have two subscription keys (for key rotation) and both can be used for the following step.
-
Configure the PCCS service:
sudo /usr/bin/pccs-configure
An example configuration:
Checking nodejs version ... nodejs is installed, continue... Checking cracklib-runtime ... Set HTTPS listening port [8081] (1024-65535) : Set the PCCS service to accept local connections only? [Y] (Y/N) : Set your Intel PCS API key (Press ENTER to skip) : <Enter your Intel PCS subscription key here> Choose caching fill method : [LAZY] (LAZY/OFFLINE/REQ) : Set PCCS server administrator password: <pccs-admin-password> Re-enter administrator password: <pccs-admin-password> Set PCCS server user password: <pccs-server-user-password> Re-enter user password: <pccs-server-user-password> Do you want to generate insecure HTTPS key and cert for PCCS service? [Y] (Y/N) :N
NOTE 1: The resulting config file is located at
/opt/intel/sgx-dcap-pccs/config/default.json
.NOTE 2: If you're behind a proxy, add your proxy URL in the
default.json
file. -
Restart the PCCS service:
sudo systemctl restart pccs
-
Verify the PCCS service is running properly:
sudo systemctl status pccs
-
Register the platform.
NOTE 1: There are multiple alternatives to perform platform registration with different trade-offs and they are explained in detail in Intel's Intel TDX Enabling Guide.
NOTE 2: If you're behind a proxy, add your proxy URL in
/etc/mpa_registration.conf
like the following example:proxy type = manual proxy url = http://<proxy-url>:<port>
In the following, we focus on the direct registration variant that uses the Multi-package Registration Agent (MPA). This agent is executed on system start up, registers the platform (if necessary), and gets deactivated. Please check the following two logs to confirm successful registration:
-
Check the log of the MPA service:
sudo systemctl status mpa_registration_tool
Example output:
mpa_registration_tool.service - Intel MPA Registration Loaded: loaded (/usr/lib/systemd/system/mpa_registration_tool.service; enabled; preset: enabled) Active: inactive (dead) since Tue 2024-04-09 22:54:50 UTC; 11h ago Duration: 46ms Main PID: 3409 (code=exited, status=0/SUCCESS) CPU: 21ms Apr 09 22:54:50 right-glider-515046 systemd[1]: Started mpa_registration_tool.service - Intel MPA Registratio> Apr 09 22:54:50 right-glider-515046 systemd[1]: mpa_registration_tool.service: Deactivated successfully.
-
Check the log file of the MPA:
cat /var/log/mpa_registration.log
An example output of successful registration:
[04-06-2024 03:05:53] INFO: SGX Registration Agent version: 1.20.100.2 [04-06-2024 03:05:53] INFO: Starts Registration Agent Flow. [04-06-2024 03:05:54] INFO: Registration Flow - PLATFORM_ESTABLISHMENT or TCB_RECOVERY passed successfully. [04-06-2024 03:05:54] INFO: Finished Registration Agent Flow.
If an error is reported, re-do the registration from scratch with these steps:
- Remove the MPA log file:
sudo rm /var/log/mpa_registration.log
. - Reboot.
- Go into the BIOS.
- Navigate to
Socket Configuration > Processor Configuration > Software Guard Extension (SGX)
. - Set these:
SGX Factory Reset
toEnable
SGX Auto MP Registration
toEnable
- Remove the MPA log file:
-
8.3 Setup Intel Tiber Trust Services CLI Inside TD
NOTE: If you have already installed the attestation components as part of the TD image creation, you proceed to step 4.
-
Boot a TD and connect to it.
-
Download this repository by downloading an asset file from the releases page on GitHub or by cloning the repository (at the appropriate tag/branch).
-
Install the Intel Tiber Trust Service CLI.
cd tdx/attestation ./setup-attestation-guest.sh
-
Verify presence of Intel Tiber Trust Service CLI by printing its version.
trustauthority-cli version
An example output:
Intel® Trust Authority CLI for TDX Version: 1.5.0- Build Date: 2024-07-08T09:53:15+00:00
-
Boot a TD and connect to it.
-
Inside the TD, generate a sample TD Quote to prove the Quote Generation Service is working properly.
trustauthority-cli quote
An example output of a successful quote generation:
[4 0 2 0 129 0 0 0 0 0 0 0 147 154 114 51 247 156 76 169 148 10 13 179 149 127 6 7 153 37 33 114 143 8 198 185 144 222 132 242 244 129 151 76 0 0 0 0 5 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 28 198 161 122 183 153 233 166 147 250 199 83 107 230 28 18 238 30 15 171 173 168 45 12 153 15 8 204 238 42 168 109 231 123 8 112 245 88 197 112 231 255 229 93 109 71 250 4 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 16 0 0 0 0 231 2 6 0 0 0 0 0 71 161 204 7 75 145 77 248 89 107 173 14 209 61 80 213 97 173 30 255 199 247 204 83 10 184 109 167 234 73 255 192 62 87 231 218 130 159 140 18 156 98 156 57 112 80 83 35 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .... .... .... 15 43 88 111 53 111 47 115 88 54 79 57 81 87 120 72 82 65 118 90 85 71 79 100 82 81 55 99 118 113 82 88 97 113 73 61 10 45 45 45 45 45 69 78 68 32 67 69 82 84 73 70 73 67 65 84 69 45 45 45 45 45 10 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
-
Attest with the Intel Tiber Trust Service.
-
Subscribe to the Intel Tiber Trust Service free trial.
-
Obtain an Attestation API key following this tutorial.
-
Create a
config.json
file like the example below:{ "trustauthority_url": "https://portal.trustauthority.intel.com", "trustauthority_api_url": "https://api.trustauthority.intel.com", "trustauthority_api_key": "<Your Intel Tiber Trust Service Attestation API key>" }
-
Use the Intel Tiber Trust Service CLI to generation an attestation token. Under the hood, the CLI will generate a TD Quote using the CPU, send the TD Quote to the external Intel Tiber Trust Service for TD Quote verification, and receive an attestation token on success.
trustauthority-cli token -c config.json
An example of a successful attestation token generation:
2024/04/30 22:55:17 [DEBUG] GET https://api.trustauthority.intel.com/appraisal/v1/nonce 2024/04/30 22:55:18 [DEBUG] POST https://api.trustauthority.intel.com/appraisal/v1/attest Trace Id: U5sA2GNVoAMEPkQ= eyJhbGciOiJQUzM4NCIsImprdSI6Imh0dHBzOi8vYW1iZXItdGVzdDEtdXNlcjEucHJvamVjdC1hbWJlci1zbWFzLmN ..... ..... ..... DRctLIeN4MioXztymyK7qsT1p7n7Dh56-HmDQH47MVgrEL_S-wRYDQioEkUvtuA_3pGk
-
One of the key components of remote attestation is the runtime measurement. The runtime measurement values are stored in the RTMRs registers for each TD by the TDX module. During the system boot, each component of the boot process (binary or conf) is measured into a digest. This digest value is extended to the RTMR's current value. The digest of the result value becomes the new value of the RTMR.
If you want to inspect the event log and RTMR values, you can use the program tdeventlog
available in the guest.
And furthermore, to see how the boot chain can impact the contents and the size of the boot event log, please take a look at
the boot methods section.
Even though the Intel TDX components live in a separate PPA from the rest of the Ubuntu packages, they follow the Ubuntu standards and offer users the same facilities for code source access and building.
You can find generic instructions on how to build a package from source here: https://wiki.debian.org/BuildingTutorial. The core idea of building a package from source code is to be able to edit the source code (see https://wiki.debian.org/BuildingTutorial#Edit_the_source_code).
Here are example instructions for building QEMU (for normal user with sudo rights):
-
Install Ubuntu 24.04 or 24.10 (or use an existing Ubuntu system).
-
Install build dependencies:
sudo apt update sudo apt install --no-install-recommends --yes software-properties-common \ build-essential \ fakeroot \ devscripts \ wget \ git \ equivs \ liblz4-tool \ sudo \ unzip \ curl \ xz-utils \ cpio \ gawk
-
Download package's source:
sudo apt install -y ubuntu-dev-tools pull-ppa-source --ppa ppa:kobuk-team/tdx-release qemu
This command will create several files and a folder, the folder is the qemu source code.
-
Rebuild
cd <qemu-source-code> sudo apt build-dep ./ dpkg-buildpackage -us -uc -b
The resulting debian packages are available in the parent folder.
-
Install the packages.
For details, you can refer to https://wiki.debian.org/BuildingTutorial#Installing_and_testing_the_modified_package
-
Initialize a matching build environment.
git clone https://kernel.ubuntu.com/gitea/kernel/kteam-tools.git sudo apt install schroot devscripts ubuntu-dev-tools python3-ruamel.yaml sbuild # Create the chroot 24.04 (`noble`) OS for kernel build # A session restart might be required at next step to take permission changes into account, in this case # you might need to run the following command twice. kteam-tools/cranky/cranky chroot create-base "noble" kteam-tools/cranky/cranky chroot create-session noble:linux
-
Clone the kernel source.
kteam-tools/cranky/cranky checkout noble:linux-intel
-
Build the kernel.
cd <kernel repository> <path-to-kteam-tools>/cranky/cranky fdr clean binary
-
Install the kernel.
Example of kernel installation:
sudo dpkg -i ../linux-image-unsigned-6.8.0-1011-intel_6.8.0-1011.18_amd64.deb ../linux-modules-6.8.0-1011-intel_6.8.0-1011.18_amd64.deb
Please follow tests/README to run Intel TDX tests.
Issue # | Description | Suggestions |
---|---|---|
1 | Performance is poor | Ensure you're using the latest TDX module. You can check the current version with dmesg (the version line looks like: virt/tdx: TDX module: attributes 0x0, vendor_id 0x8086, major_version 1, minor_version 5, build_date 20240129, build_num 698 ). See link on ways to update your TDX module. NOTE: If you chose to "Update Intel TDX Module via Binary Deployment", make sure you're using the correct TDX module version for your hardware. See the Supported Hardware table. |
2 | TDX is not enabled on the host | 1. Ensure your installation of the TDX host components using setup-tdx-host.sh did not have any errors. 2. Ensure BIOS settings are correct. See step 4.3 |
3 | Installation seems to hang | 1. Verify you can get out to the Internet. 2. If you're behind a proxy, make sure you have proper proxy settings. 3. If you're behind a proxy, use sudo -E to preserve user environment. |