sevctl
is a command line utility for managing the AMD Secure Encrypted Virtualization (SEV) platform.
It currently supports the entire management API for the Naples generation of processors.
Every sevctl
(sub)command comes with a quick --help
option for a reference on its use. For example:
$ sevctl --help
or
$ sevctl show --help
Exports the SEV certificate chain to the provided file path.
$ sevctl export /path/to/where/you/want/the-certificate
Generates a new (self-signed) OCA certificate and key.
$ sevctl generate ~/my-cert ~/my-key
Probes processor, sysfs, and KVM for AMD SEV, SEV-ES, and SEV-SNP related features on the host and emits the results.
$ sevctl ok {sev, es, snp} // Probes support for the generation specified.
$ sevctl ok // Probes support for the host hardware's generation.
Installs the operator-provided OCA certificate to take ownership of the platform.
$ sevctl provision ~/owners-cert ~/owners-private-key
Resets the SEV platform. This will clear all persistent data managed by the platform.
$ sevctl reset
Rotates the Platform Diffie-Hellman (PDH).
$ sevctl rotate
Given a certificate chain file and 32-bit policy, generates base64-encoded GODH and launch session files; as well as encoded (not base64) TIK and TEK files.
$ sevctl session --name {name} {/pdh/cert/path} {policy}
Describes the state of the SEV platform.
$ sevctl show flags
$ sevctl show guests
Verifies the full SEV/CA certificate chain. File paths to these certificates can be supplied as command line arguments if they are stored on the local filesystem. If they are not supplied, the well-known public components will be downloaded from their remote locations.
$ sevctl verify
Build a VMSA binary blob and save to the specified filename.
$ sevctl vmsa build NEW-VMSA0.bin --userspace qemu --family 25 --stepping 1 --model 1 --firmware /path/to/OVMF.amdsev.fd --cpu 0
Update an existing VMSA binary file in place, with the passed options.
$ sevctl vmsa build EXISTING-VMSA0.bin --userspace qemu --family 25 --stepping 1 --model 1 --firmware /path/to/OVMF.amdsev.fd --cpu 0
Print an existing VMSA binary file as JSON
$ sevctl vmsa show EXISTING-VMSA0.bin
License: Apache-2.0