Skip to main content

No project description provided

Project description

TDX Measurement Tool

The measurement tool runs within TD guest to get RTMR value from TDREPORT via Linux attestation driver, and gets the full TD event log from CCEL ACPI table. Then it uses the TD event log to verify the RTMR value or change.

CSP or tenant developer could use it to analyze and debug the TDX measurement before providing the TDX guest VM.

Overview

The RTMR stands for Run-time Measurement Register, recording measurement for the component participating in the booting process. As of 2023.4, TDX supports four RTMRs, including RTMR[0], RTMR[1], RTMR[2] and RTMR[3].

The same RTMR may store measurement for different section in direct boot or grub boot.

  1. Direct boot
  • RTMR[0]: It stores the measurement for the TDVF configuration. Changes on a part of the tdvm launch parameters, such memory size, will affect the final measurement.
  • RTMR[1]: It stores the measurement for the kernel and cmdline passed to the kernel.
  • RTMR[2] and RTMR[3]: They are reserved and can be used by the guest software to extend the measurement.
  1. Grub boot
  • RTMR[0]: It works as it does in the direct boot.
  • RTMR[1]: It stores the measurement for the OS loader, such as grub.
  • RTMR[2]: It works as it does in the direct boot.
  • RTMR[3]: It is reserved and can be used by the guest software to extend the measurement.

More details can be found in the Articles-906357 and Commit 9d2b64a

Prerequisites

The Log Area Start Address (LASA) is from ACPI CCEL table. Please see GHCI specification.

Run

  1. Get Event Log

    ./tdx_eventlogs
    

    The example output for the event log in grub boot and direct boot

  2. Get TD Report

    ./tdx_tdreport
    
  3. Verify the RTMR

    ./tdx_verify_rtmr
    
  4. Extend the RTMR

    ./tdx_extend_rtmr -s 'test_extend_rtmr' -i 3
    

    User can extend RTMR register with different kinds of data, including raw data(with '-r', must be 48B length), string data(with '-s', will be converted to SHA384 digest) and SHA384 digest string(with '-d'). User can also change the index of RTMR register by using '-i'.

Installation

Build and install TDX Measurement Tool:

python3 setup.py bdist_wheel
pip3 install dist/*.whl --force-reinstall

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

pytdxmeasure-0.0.9-py3-none-any.whl (24.7 kB view details)

Uploaded Python 3

File details

Details for the file pytdxmeasure-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: pytdxmeasure-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 24.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for pytdxmeasure-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 cba566746e8c4088d5c20b9259fa4df6cb50b88a7b1fb8c5f1e7c4684593ee1d
MD5 ef963d2e95b5be2cbef878cdb139a08a
BLAKE2b-256 f9abea547814ed56aa025ded132a9f13b605bd0601964f2e4266fd8a118575e2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page