Changelog

All notable changes to this project will be documented in this file.

Starting with release 5.4, The format is based on Keep a Changelog.

5.7-rc0 - 2024-03-26

Fixed

  • tpm2_sessionconfig: fix handling of --disable-continue session so that the subsequent command will not fail when attempting to context save a flushed session.
  • detection of functions within libcrypto when CRYPTO_LIBS is set and system has install libcrypto.
  • tpm2_send: fix EOF detection on input stream.
  • tpm2_policy.c fix compilation error caused by format directive for size_t on 32 bit systems.
  • tpm2_nvread: fix input handling no nv index.
  • Auth file: Ensure 0-termination when reading auths from a file.
  • configure.ac: fix bashisms. configure scripts need to be runnable with a POSIX-compliant /bin/sh.
  • cirrus.yml fix tss compilation with libtpms for FreeBSD.
  • tpm2_tool.c Fix missing include for basename to enable compilation on netbsd.
  • options: fix TCTI handling to avoid failures for commands that should work with no options.
  • tpm2_getekcertificate.c Fix leak. ek_uri was not freed if get_ek_server_address failed.

Added

  • Add the possibility for autoflush (environment variable "TPM2TOOLS_AUTOFLUSH", or -R option)

Removed

  • Testing on Ubuntu 18.04 as it's near EOL (May 2023).m2_policy.c fix compilation error caused by format directive for size_t on 32 bit systems.
  • tpm2_nvread: fix input handling no nv index.

5.6 - 2023-11-08

   - Add safe directory in config

5.6-rc0 - 2023-09-26

  • tpm2_eventlog:

    • add H-CRTM event support
    • add support of efivar versions less than 38
    • Add support to check for efivar/efivar.h manually
    • Minor formatting fixes
    • tpm2_eventlog: add support for replay with different StartupLocality
    • Fix pcr extension for EV_NO_ACTION
    • Extend test of yaml string representation
    • Use helper for printing a string dump
    • Fix upper bound on unique data size
    • Fix YAML string formatting
  • tpm2_policy:

    • Add support for parsing forward seal TPM values
    • Use forward seal values in creating policies
    • Move dgst_size in evaluate_populate_pcr_digests()
    • Allow more than 8 PCRs for sealing
    • Move dgst_size in evaluate_populate_pcr_digests
    • Allow more than 8 PCRs for sealing
    • Make __wrap_Esys_PCR_Read() more dynamic to enable testing more PCRs
  • tpm2_encryptdecrypt: Fix pkcs7 padding stripping

  • tpm2_duplicate:

    • Support -a option for attributes
    • Add --key-algorithm option
  • tpm2_encodeobject: Use the correct -O option instead of -C

  • tpm2_unseal: Add qualifier static to enhance the privacy of unseal function

  • tpm2_sign:

    • Remove -m option which was added mistakenly
    • Revert sm2 sign and verifysignature
  • tpm2_createek:

    • Correct man page example
    • Fix usage of nonce
    • Fix integrating nonce
  • tpm2_clear: add more details about the action

  • tpm2_startauthsession: allow the file attribute for policy authorization.

  • tpm2_getekcertificate: Add AMD EK support

  • tpm2_ecdhzgen: Add public-key parameter

  • tpm2_nvreadpublic: Prevent free of unallocated pointers on failure

  • Bug-fixes:

    • The readthedocs build failed with module 'jinja2' has no attribute 'contextfilter' a requirement file was added to fix this problem

    • An error caused by the flags -flto -_FORTIFY_SOURCE=3 in kdfa implementation. This error can be avoided by switching off the optimization with pragma

    • Changed wrong function name of "Esys_Load" to "Esys_Load"

    • Function names beginning with Esys_ are wrongly written as Eys_

    • Reading and writing a serialized persistent ESYS_TR handles

    • cirrus-ci update image-family to freebsd-13-2 from 13-1

  • misc:

    • Change the default Python version to Python3 in the helper's code

    • Skip test which uses the sign operator for comparison in abrmd_policynv.sh

    • tools/tr_encode: Add a tool that can encode serialized ESYS_TR for persistent handles from the TPM2B_PUBLIC and the raw persistent TPM2_HANDLE

5.5 - 2022-02-13

Added

  • tpm2_createek:

    • SM2 EK Support
  • misc:

    • SM2 support to internal OSSL format key routines. Fixes --format flags for conversions.

Fixed:

  • echo_tcti.py: set to use python3 named executable in shebang.

5.4 - 2022-12-05

Added:

  • tpm2_policyrestart:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyRestart.
  • tpm2_policynvwritten:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyNvWritten.
  • tpm2_policylocality:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyLocality.
  • tpm2_policycountertimer:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyCounterTimer.
  • tpm2_policycommandcode:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyCommandCode.
  • tpm2_policypassword:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyPassword.
  • tpm2_policyauthvalue:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyAuthValue.
  • tpm2_policyauthorize:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyAuthorize.
  • tpm2_print:

    • Support printing serialized ESYS_TR's
  • tpm2_create:

    • Add a clarifying message to usage of -c when TPM2_CreateLoaded is not supported.
  • tpm2_getcap:

    • Add support for vendor agnostic capabilites. Requires tpm2-tss version 4.0 and higher to enable.
  • Add a script, check_endorsement_cert.sh, to validate the endorsement certificate chain. It takes two inputs - A TPM2B_PUBLIC format EKpublic and a PEM format EKcertificate specified in that order as arguments.

5.3 2022-09-27

  • .ci/download-deps.sh: update tpm2-abrmd dependency version to 2.4.1

  • .cirrus.yml: updated the freebsd version to 13.1 in the CI.

### 5.3-rc1 2022-09-12

  • tools/tpm2_pcrreset.c: fix build errors in 32bit systems.

  • Fix tssprivkey formatted PEM generation and load errors on 32 bit systems.

  • CI: Add testing of 32bit systems with multiarch/qemu-user-static containers.

  • Known issue: FAPI tools will not work on 32bit user-static qemu on 64bit host because readdir returns NULL. Follow the issue on https://gitlab.com/qemu-project/qemu/-/issues/263

### 5.3-rc0 2022-08-02

  • tpm2_nvextend: fix for including ESYS_TR handle to calculate object name.

  • tpm2_nv(read/write): allow policy authorization only for single iterations for a maximum buffer size of TPM2_PT_NV_BUFFER_MAX.

  • tpm2_policylocality: fix logical inversion that caused any argument to be interpreted as zero, except "zero" would be interpreted as one.

  • tpm2_nvdefine: fixed to set TPMA_NV_PLATFORMCREATE attribute default when authorizing with platform hierarchy.

  • tpm2_getekcertificate: fixed the url/link for retrieving ek certificates from ekop.intel.com.

  • tools/tpm2_tool.c: fix an issue where LOG_WARN messages were displayed despite setting the quite flag.

  • tpm2_import: fix an issue where openssl load function resets a specified scheme with TPM2_ALG_NULL.

  • tpm2_sign, tpm2_verifysignature: fixes for sm2 signing and verification.

  • Support alternative ECC curves for which default EK templates exist (NIST_P256, NIST_P384, NIST_P521, and SM2_P256).

  • tools/misc/tpm2_checkquote: add sm2 verification of signature.

  • tpm2_startauthsession:

    • Added option -G, --key-algorithm=ALGORITHM to specify the symmetric algorithm used in parameter encryption/decryption.
  • tpm2_certify:

    • Added option --scheme=ALGORITHM for supporting signature schemes. Signing schemes should follow the "formatting standards", see section "Algorithm Specifiers".
  • tpm2_getcommandauditdigest:

    • Added option --scheme=ALGORITHM for supporting signature schemes. Signing schemes should follow the "formatting standards", see section "Algorithm Specifiers".
  • tpm2_getsessionauditdigest:

    • Added option --scheme=ALGORITHM for supporting signature schemes. Signing schemes should follow the "formatting standards", see section "Algorithm Specifiers".
  • tpm2_quote:

    • Added option --scheme=ALGORITHM for supporting signature schemes. Signing schemes should follow the "formatting standards", see section "Algorithm Specifiers".
  • lib/tpm2.c: flushcontext cphash calculation workaround for a system api bug where in the flush handle was erroneously placed in the handle area instead of parameter area.

  • tpm2_flushcontext: options -t, -l, -s can now be simultaneously specified.

  • tpm2_import: support restricted parent with an aes128cfb symmetric parameter.

  • tpm2_nvreadpublic: drop ntoh on attributes because they get marshalled to the correct endianness by libmu to begin with.

  • tpm2_print: remove unused -i option.

  • tpm2_policyor: fix segfault when no options or arguments to specify the list of policies to be compounded.

  • tpm2_certify: fix man page for short options and add tests The short options for the signing-key-auth and certified-key-auth were swapped. The case fix in the man page makes it less intuitive but have to go through with the change so that we don't break any existing scripts. This change does not affect the long options. Tests have been added to ensure the functionality.

  • .cirrus.yml: updated the freebsd version to 13.

  • VERSION: add version file - Generate the version file with bootstrap and include in the DIST tarball so endusers can call autoreconf on a dist tarball which doesn't have git. This alleviates git describe errors on release tarballs in the autoreconf case.

  • tpm2_clear:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Clear.
  • tpm2_dictionarylockout:

    • Added option --cphash to output the cpHash for the command TPM2_CC_DictionaryAttackLockReset and TPM2_CC_DictionaryAttackParameters.
  • tpm2_clearcontrol:

    • Added option --cphash to output the cpHash for the command TPM2_CC__ClearControl.
  • tpm2_sign:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Sign.
  • tpm2_setprimarypolicy:

    • Added option --cphash to output the cpHash for the command TPM2_CC_SetPrimaryPolicy.
  • tpm2_setclock:

    • Added option --cphash to output the cpHash for the command TPM2_CC_ClockSet.
  • tpm2_rsadecrypt:

    • Added option --cphash to output the cpHash for the command TPM2_CC_RSA_Decrypt.
  • tpm2_duplicate:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Duplicate.
  • tpm2_clockrateadjust:

    • Added option --cphash to output the cpHash for the command TPM2_CC_ClockRateAdjust.
  • tpm2_createprimary:

    • Added option --cphash to output the cpHash for the command TPM2_CC_CreatePrimary.
  • tpm2_quote:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Quote.
  • tpm2_policysecret:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicySecret
  • tpm2_policynv:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyNV.
  • tpm2_policyauthorizenv:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PolicyAuthorizeNV.
  • tpm2_import:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Import.
  • tpm2_hmac:

    • Added option --cphash to output the cpHash for the command TPM2_CC_HMAC.
  • tpm2_hierarchycontrol:

    • Added option --cphash to output the cpHash for the command TPM2_CC_HierarchyControl.
  • tpm2_load:

    • Added option --cphash to output the cpHash for the command TPM2_CC_Load.
  • tpm2_gettime:

    • Added option --cphash to output the cpHash for the command TPM2_CC_GetTime.
  • tpm2_evictcontrol:

    • Added option --cphash to output the cpHash for the command TPM2_CC_EvictControl.
  • tpm2_encryptdecrypt:

    • Added option --cphash to output the cpHash for the command TPM2_CC_EncryptDecrypt.
  • tpm2_getpolicydigest:

    • Added option --cphash to output the cpHash for the command TPM2_CC_GetPolicyDigest.
  • tpm2_loadexternal:

    • Added option --cphash to output the cpHash for the command TPM2_CC_LoadExternal.
  • tpm2_pcrreset:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PCR_Reset.
  • tpm2_pcrread:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PCR_Read.
  • tpm2_pcrevent:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PCR_Event.
  • tpm2_pcrallocate:

    • Added option --cphash to output the cpHash for the command TPM2_CC_PCR_Allocate.
  • tpm2_loadexternal:

    • Added support to tpm2_loadexternal for parsing and loading the public portion of a TSS2 Privkey PEM file. The path to the PEM file must be specified using the -r option while skipping the -G option for key type.
  • tpm2_print:

    • Added capability to parse out and print the public portion of a TSS Private Key in the PEM format with the arg option TSSPRIVKEY_OBJ.
  • tpm2_geteccparameters:

    • Added option --cphash to output the cpHash for the command TPM2_CC_ECC_Parameters.
  • tpm2_flushcontext:

    • Added option --cphash to output the cpHash for the command TPM2_CC_FlushContext.
  • tpm2_ecephemeral:

    • Added option --cphash to output the cpHash for the command TPM2_CC_EC_Ephemeral.
  • tpm2_ecdhzgen:

    • Added option --cphash to output the cpHash for the command TPM2_CC_ECDH_ZGen.
  • tpm2_load:

    • Added capability to load pem files in TSS2-Private-Key format for interoperability with tpm2-tss-engine, tpm2-openssl provider, tpm2-pkcs11, and tpm2-pytss.
  • tpm2_ecdhkeygen:

    • Added option to output the cpHash for the command TPM2_CC_ECDH_KeyGen.
  • tpm2_commit:

    • Added option to output the cpHash for the command TPM2_CC_Commit.
  • tpm2:

    • Added option to specify --help=no-man
  • tpm2_nvreadpublic:

    • Added option --cphash=FILE to specify file path to record hash of the command parameters. This is commonly termed as cpHash.
    • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
    • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM ie when --tcti=none
  • tpm2_nvundefine:

    • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
    • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM.
    • Added option --with-policydelete when calculating cpHash with --tcti=none there is no way to know if the attribute TPMA_NV_POLICYDELETE has been set from the NV index name alone.
  • tpm2_nvreadlock:

    • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
    • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM.
  • tpm2_nvwritelock:

    • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_nvincrement:

    • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_nvcertify:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
    • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM.
    • Added option -signer-name to specify the signer name in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM.
  • tpm2_nvwrite:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
    • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash is calculated without dispatching the TPM2_NV_Write command to the TPM.
  • Minimum tpm2-tss version is now 3.2.0 to support openssl3 migration.

  • Fix test harness leaving tpm servers running after a make check. Fixes sporadic hangs in testing.

5.2 2021-09-28

5.2-rc0 2021-09-01

  • tpm2_nvextend:

  • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash ought to be calculated without dispatching the TPM2_NV_Extend command to the TPM.

  • tpm2_nvread:

  • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.

  • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash ought to be calculated without dispatching the TPM2_NVRead command to the TPM.
  • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.

  • tpm2_nvsetbits:

  • Added option --rphash=FILE to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.

  • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • Added option -n, --name to specify the name of the nvindex in hex bytes. This is used when cpHash ought to be calculated without dispatching the TPM2_NV_SetBits command to the TPM.

  • tpm2_createprimary:

  • Support public-key output at creation time in various public-key formats.

  • tpm2_create:

  • Support public-key output at creation time in various public-key formats.

  • tpm2_print:

  • Support outputing public key in various public key formats over the default YAML output. Supports taking -u output from tpm2_create and converting it to a PEM or DER file format.

  • tpm2_import:

  • Add support for importing keys with sealed-data-blobs.

  • tpm2_rsaencrypt, tpm2_rsadecrypt:

  • Add support for specifying the hash algorithm with oaep.

  • tpm2_pcrread, tpm2_quote:

  • Add option -F, --pcrs_format to specify PCR format selection for the binary blob in the PCR output file. 'values' will output a binary blob of the PCR values. 'serialized' will output a binary blob of the PCR values in the form of serialized data structure in little endian format.

  • tpm2_eventlog:

  • Add support for decoding StartupLocality.

  • Add support for printing the partition information.
  • Add support for reading eventlogs longer than 64kb including from /sys/kernel/security/tpm0/binary_bios-measurements.

  • tpm2_duplicate:

  • Add option -L, --policy to specify an authorization policy to be associated with the duplicated object.

  • Added support for external key duplication without needing the TCTI.

  • tools:

  • Enhance error message on invalid passwords when sessions cannot be used.

  • lib/tpm2_options:

  • Add option to specify fake tcti which is required in cases where sapi ctx is required to be initialized for retrieving command parameters without invoking the tcti to talk to the TPM.

  • openssl:

  • Dropped support for OpenSSL < 1.1.0

  • Add support for OpenSSL 3.0.0

  • Support added to make the repository documentation and man pages available live on readthedocs.

  • Bug-fixes:

  • tpm2_import: Don't allow setting passwords for imported object with -p option as the tool doesn't modify the TPM2B_SENSITIVE structure. Added appropriate logging to indicate using tpm2_changeauth after import.

  • lib/tpm2_util.c: The function to calculate pHash algorithm returned error when input session is a password session and the only session in the command.

  • lib/tpm2_alg_util.c: Fix an error where oaep was parsed under ECC.

  • tpm2_sign: Fix segfaults when tool does not find TPM resources (TPM or RM).

  • tpm2_makecredential: Fix an issue where reading input from stdin could result in unsupported data size larger than the largest digest size.

  • tpm2_loadexternal: Fix an issue where restricted attribute could not be set.

  • lib/tpm2_nv_util.h: The NV index size is dependent on different data sets read from the GetCapability structures because there is a dependency on the NV operation type: Define vs Read vs Write vs Extend. Fix a sane default in the case where GetCapability fails or fails to report the specific property/ data set. This is especially true because some properties are TPM implementation dependent.

  • tpm2_createpolicy: Fix an issue where tool exited silently without reporting an error if wrong pcr string is specified.

  • lib/tpm2_alg_util: add error message on public init to prevent tools from dying silently, add an error message.

  • tpm2_import: fix an issue where an imported hmac object scheme was NULL. While allowed, it was inconsistent with other tools like tpm2_create which set the scheme as hmac->sha256 when generating a keyedhash object.

5.1.1 2021-06-21

  • tpm2_import: fix fixed AES key CVE-2021-3565
    • tpm2_import used a fixed AES key for the inner wrapper, which means that a MITM attack would be able to unwrap the imported key. To fix this, ensure the key size is 16 bytes or bigger and use OpenSSL to generate a secure random AES key.

5.1 2021-05-24

  • Build

    • Dependency-update: Minimum tpm2-tss version dependency bumped to 3.1.0
    • Dependency-update: Minimum tpm2-abrmd version dependency bumped to 2.4.0
    • tpm2_eventlog: Fix build errors on 64 bit arm systems.
    • tpm2_checkquote: Fix build on 32b little-endian platforms.
    • Fixes builds on CentOS 7 which notably has an ancient version of GCC: 4.8.5 and an older version of OSSL, 1.0.2
    • Configure handles searching for python executable more gracefully, thus just having python3, will work.
    • Moved to GitHub Actions for CI testing.
    • Added fedora-32 to CI testing configurations and related fixes.
    • FreeBSD testing is bumped up to version 12.2
    • Fix compiler and packaging warnings for OpenSuse builds.
    • configure: make build gnu99.
    • configure: make -Wbool-compare non fatal.
    • configure: only use -Werror for non-release builds
  • tss2:

    • Support in tools for PolicyRef inclusion in policy search per latest TSS.
    • Support to use TPM objects protected by a policy with PolicySigned.
    • Enable backward compatibility to old Fapi callback API.
    • Fix PCR selection for tss2 quote.
    • Support policy signed policies by implementing Fapi_SetSignCB.
  • Command/ response parameter support for auditing and pHash policies:

    • lib/tpm2_util.c: Add method to determine hashing alg for cp/rphash
    • Add support to calculate rphash for tpm2_create, tpm2_activatecredential, tpm2_certify, tpm2_certifycreation, tpm2_changeauth, tpm2_changeeps, tpm2_changepps, tpm2_nvdefine, tpm2_nvextend, tpm2_unseal
    • Add support to calculate cphash for tpm2_changeeps, tpm2_changepps.
  • Session-support:

    • tpm2_sessionconfig: Add tool to display and configure session attributes.
    • tpm2_getrandom: Fix— session input was hardcoded for audit-only
    • tpm2_startauthsession: Add option to specify the bind object and its authorization value.
    • tpm2_startauthsession: support for bounded-only session.
    • tpm2_startauthsession: support for salted-only session.
    • tpm2_startauthsession: add option to specify an hmac session type.
    • Add support for specifying non-authorization sessions for audit and parameter encryption for tpm2_getrandom, tpm2_create, tpm2_nvextend, tpm2_nvdefine, tpm2_unseal, tpm2_activatecredential, tpm2_certify, tpm2_certifycreation, tpm2_changeauth, tpm2_changeeps, tpm2_changepps.
  • tpm2_eventlog:

    • Support for event type: EV_IPL extensively used by the Shim and Grub.
    • Support for event type: EV_EFI_GPT_EVENT to parse. UEFI_PARTITION_TABLE_HEADER and UEFI_PARTITION_ENTRY.
    • Support for event type: EFI_SIGNATURE_LIST, which contains one or more EFI_SIGNATURE_DATA.
    • Support for event type EV_EFI_VARIABLE_AUTHORITY.
    • Parse UEFI_PLATFORM_FIRMWARE_BLOB structure that the CRTM MUST put into the Event Log entry TCG_PCR_EVENT2.event field for event types EV_POST_CODE, EV_S_CRTM_CONTENTS, and EV_EFI_PLATFORM_FIRMWARE_BLOB.
    • Parse secureboot variable to indicate enable as 'Yes'.
    • Parse BootOrder variable to a more readable format.
    • Parse Boot variables per EFI_LOAD_OPTION described in more details in UEFI Spec Section 3.1.3
    • Parse Device-path in a readable format using the efivar library.
    • Support for logs longer than 64 kilobytes.
    • Perform verification for event types where digest can be verified from their event payload.
    • Better support for multiline strings.
    • Fix handling of event log EV_POST_CODE data where field is empty and len is specified.
  • scripts/utils: Add a utility to read the cert chain of embedded CA.

  • tpm2_getekcertificate: Fix tool failing to return error/non-zero for HTTP 404.

  • tpm2_nvdefine: allow setting hash algorithm by command line parameter for NV indices set in extend mode.

  • tpm2_duplicate, tpm2_import: support duplicating non-TPM keys to a remote TPM without first requiring them to be loaded to a local TPM.

  • tpm2_dictionarylockout: Fix issue where setting value for one parameter caused to reset the others.

  • tpm2_getpolicydigest: Add new tool to enable TPM2_CC_PolicyGetDigest.

  • Fix segfault where optind > argc.

  • tools/tpm2_checkquote: fix missing initializer

  • tpm2_convert: fix EVP_EncodeUpdate usage for OSSL < 1.1.0

  • openssl: fix EVP_ENCODE_CTX_(new|free)

  • test: Add support for swTPM simulator to the testing framework and make it the default if mssim isn't available.

  • tpm2_unseal:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_nvextend:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_nvdefine:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_changepps:

    • Added option --cphash=FILE to specify ile path to record the hash of the command parameters. This is commonly termed as cpHash.
    • Added option --rphash=FILE to specify ile path to record the hash
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_changeeps:

    • Added option --cphash=FILE to specify ile path to record the hash of the command parameters. This is commonly termed as cpHash.
    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_changeauth:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_certifycreation:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_certify:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_activatecredential:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_create:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_unseal:

    • Added option -S, --session to specify auxiliary sessions for audit and encryption.
  • tpm2_nvdefine:

    • Added option -S, --session to specify auxiliary sessions for audit and encryption.
  • tpm2_nvextend:

    • Added option -S, --session to specify auxilary sessions for audit and encryption.

5.1-rc1 2021-05-19

  • scripts/utils: Add a utility to read the cert chain of embedded CA
  • .ci/download-deps.sh: Bump tpm2-tss version to 3.1.0
  • build: only use -Werror for non-release builds

5.1-rc0 2021-04-20

  • Build

    • Dependency-update: Minimum tpm2-tss version dependency bumped to 3.0.3
    • Dependency-update: Minimum tpm2-abrmd version dependency bumped to 2.4.0
    • tpm2_eventlog: Fix build errors on 64 bit arm systems.
    • tpm2_checkquote: Fix build on 32b little-endian platforms.
    • Fixes builds on CentOS 7 which notably has an ancient version of GCC: 4.8.5 and an older version of OSSL, 1.0.2
    • Configure handles searching for python executable more gracefully, thus just having python3, will work.
    • Moved to GitHub Actions for CI testing.
    • Added fedora-32 to CI testing configurations and related fixes.
    • FreeBSD testing is bumped up to version 12.2
    • Fix compiler and packaging warnings for OpenSuse builds.
    • configure: make build gnu99.
    • configure: make -Wbool-compare non fatal.
  • tss2:

    • Support in tools for PolicyRef inclusion in policy search per latest TSS.
    • Support to use TPM objects protected by a policy with PolicySigned.
    • Enable backward compatibility to old Fapi callback API.
    • Fix PCR selection for tss2 quote.
    • Support policy signed policies by implementing Fapi_SetSignCB.
  • Command/ response parameter support for auditing and pHash policies:

    • lib/tpm2_util.c: Add method to determine hashing alg for cp/rphash
    • Add support to calculate rphash for tpm2_create, tpm2_activatecredential, tpm2_certify, tpm2_certifycreation, tpm2_changeauth, tpm2_changeeps, tpm2_changepps, tpm2_nvdefine, tpm2_nvextend, tpm2_unseal
    • Add support to calculate cphash for tpm2_changeeps, tpm2_changepps.
  • Session-support:

    • tpm2_sessionconfig: Add tool to display and configure session attributes.
    • tpm2_getrandom: Fix— session input was hardcoded for audit-only
    • tpm2_startauthsession: Add option to specify the bind object and its authorization value.
    • tpm2_startauthsession: support for bounded-only session.
    • tpm2_startauthsession: support for salted-only session.
    • tpm2_startauthsession: add option to specify an hmac session type.
    • Add support for specifying non-authorization sessions for audit and parameter encryption for tpm2_getrandom, tpm2_create, tpm2_nvextend, tpm2_nvdefine, tpm2_unseal, tpm2_activatecredential, tpm2_certify, tpm2_certifycreation, tpm2_changeauth, tpm2_changeeps, tpm2_changepps.
  • tpm2_eventlog:

    • Support for event type: EV_IPL extensively used by the Shim and Grub.
    • Support for event type: EV_EFI_GPT_EVENT to parse. UEFI_PARTITION_TABLE_HEADER and UEFI_PARTITION_ENTRY.
    • Support for event type: EFI_SIGNATURE_LIST, which contains one or more EFI_SIGNATURE_DATA.
    • Support for event type EV_EFI_VARIABLE_AUTHORITY.
    • Parse UEFI_PLATFORM_FIRMWARE_BLOB structure that the CRTM MUST put into the Event Log entry TCG_PCR_EVENT2.event field for event types EV_POST_CODE, EV_S_CRTM_CONTENTS, and EV_EFI_PLATFORM_FIRMWARE_BLOB.
    • Parse secureboot variable to indicate enable as 'Yes'.
    • Parse BootOrder variable to a more readable format.
    • Parse Boot variables per EFI_LOAD_OPTION described in more details in UEFI Spec Section 3.1.3
    • Parse Device-path in a readable format using the efivar library.
    • Support for logs longer than 64 kilobytes.
    • Perform verification for event types where digest can be verified from their event payload.
    • Better support for multiline strings.
    • Fix handling of event log EV_POST_CODE data where field is empty and len is specified.
  • tpm2_getekcertificate: Fix tool failing to return error/non-zero for HTTP 404.

  • tpm2_nvdefine: allow setting hash algorithm by command line parameter for NV indices set in extend mode.

  • tpm2_duplicate, tpm2_import: support duplicating non-TPM keys to a remote TPM without first requiring them to be loaded to a local TPM.

  • tpm2_dictionarylockout: Fix issue where setting value for one parameter caused to reset the others.

  • tpm2_getpolicydigest: Add new tool to enable TPM2_CC_PolicyGetDigest.

  • Fix segfault where optind > argc.

  • tools/tpm2_checkquote: fix missing initializer

  • tpm2_convert: fix EVP_EncodeUpdate usage for OSSL < 1.1.0

  • openssl: fix EVP_ENCODE_CTX_(new|free)

  • test: Add support for swTPM simulator to the testing framework and make it the default if mssim isn't available.

  • tpm2_unseal:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_nvextend:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_nvdefine:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_changepps:

    • Added option --cphash=FILE to specify ile path to record the hash of the command parameters. This is commonly termed as cpHash.
    • Added option --rphash=FILE to specify ile path to record the hash
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_changeeps:

    • Added option --cphash=FILE to specify ile path to record the hash of the command parameters. This is commonly termed as cpHash.
    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_changeauth:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_certifycreation:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_certify:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_activatecredential:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added option -S, --session to specify to specify an auxiliary session for auditing and or encryption/decryption of the parameters.
  • tpm2_create:

    • Added option --rphash=FILE to specify ile path to record the hash of the response parameters. This is commonly termed as rpHash.
  • tpm2_unseal:

    • Added option -S, --session to specify auxiliary sessions for audit and encryption.
  • tpm2_nvdefine:

    • Added option -S, --session to specify auxiliary sessions for audit and encryption.
  • tpm2_nvextend:

    • Added option -S, --session to specify auxilary sessions for audit and encryption.

5.0 - 2020-11-16

Non Backwards Compatible Changes

  • Default hash algorithm is now sha256. Prior versions claimed sha1, but were inconsistent in choice. Best practice is to specify the hash algorithm to avoid suprises.

  • tpm2_tools and tss2_tools are now a busybox style commandlet. Ie tpm2_getrandom becomes tpm2 getrandom. make install will install symlinks to the old tool names and the tpm2 commandlet will interogate argv[0] for the command to run. This will provide backwards compatibility if they are installed. If you wish to use the old names not installed system wide, set DESTDIR during install to a seperate path and set the proper directory on PATH.

  • tpm2_eventlog's output changed to be YAML compliant. The output before was intended to be YAML compliant but was never properly checked and tested.

  • umask set to 0117 for all tools.

  • tpm2_getekcertificate now outputs the INTC EK certificates in PEM format by default. In order to output the URL safe variant of base64 encoded output of the INTC EK certificate use the added option --raw.

Dependency update

  • Update tpm2-tss dependency version to 3.0.1

  • Update tpm2-abrmd dependency version to 2.3.3

New tools and features

  • tpm2_zgen2phase:

    • Add new tool to support command TPM2_CC_ZGen_2Phase.
  • tpm2_ecdhzgen:

    • Add new tool to support command TPM2_CC_ECDH_ZGen.
  • tpm2_ecdhkeygen:

    • Add new tool to support command TPM2_CC_ECDH_KeyGen.
  • tpm2_commit:

    • Add new tool to support command TPM2_CC_Commit.
  • tpm2_ecephemeral:

    • Add new tool to support command TPM2_CC_EC_Ephemeral.
  • tpm2_geteccparameters:

    • Add new tool to support command TPM2_CC_ECC_Parameters.
  • tpm2_setcommandauditstatus:

    • Added new tool to support command TPM2_CC_SetCommandCodeAuditStatus.
  • tpm2_getcommandauditstatus:

    • Added new tool to support command TPM2_CC_GetCommandAuditDigest.
  • tpm2_getsessionauditdigest:

    • Added new tool to support command TPM2_CC_GetSessionAuditDigest.
  • tpm2_certifyX509certutil:

    • Added new tool for creating partial x509 certrificates required to support the TPM2_CC_CertifyX509 command.
  • tpm2_policysigned:

    • Added option --cphash-input to specify the command parameter hash (cpHashA), enforcing the TPM command to be authorized as well as its handle and parameter values.
  • tpm2_createprimary:

    • Added option to specify the unique data from the stdin by adding provision for specifying the option value for unique file as -.
  • tpm2_startauthsession:

    • Added new feature/option --audit-session to start an HMAC session to be used as an audit session.
  • tpm2_getrandom:

    • Added new feature/option -S, --session to specify a HMAC session to be used as an audit session. This adds support for auditing the command using an audit session.
    • Added new feature/option --rphash to specify file path to record the hash of the response parameters. This is commonly termed as rpHash.
    • Added new feature/option --cphash to specify a file path to record the hash of the command parameters. This is commonly termed as cpHash. NOTE: In absence of --rphash option, when this option is selected, The tool will not actually execute the command, it simply returns a cpHash.
  • tpm2_getcap:

    • tpm2_getcap was missing raw on a property TPM2_PT_REVISION, and it should always be specified.
  • tpm2_sign:

    • Add option --commit-index to specify the commit index to use when performing an ECDAA signature.
    • Add support for ECDAA signature.
  • tpm2_getekcertificate:

    • Add option --raw to output EK certificate in URL safe variant base64 encoded format. By default it outputs a PEM formatted certificate.
    • The tool can now output INTC and non INTC EK certificates from NV indices specified by the TCG EK profile specification.
  • tpm2_activatecredential:

    • The secret data input can now be specified as stdin with -s option.
    • The public key used for encryption can be specified as -u to make it similar to rest of the tools specifying a public key. The old -e option is retained for backwards compatibility.
    • Add option to specify the key algorithm when the input public key is in PEM format using the new option -G, --key-algorithm. Can specify either RSA/ECC. When this option is used, input public key is expected to be in PEM format and the default TCG EK template is used for the key properties.
  • tpm2_checkqoute:

    • Add EC support.
    • Support loading tss signatures.
    • Support loading tpm2 pcrread PCR values by specifying the PCR selection using the new option -l, --pcr-list.
    • Added support for automatically detecting the signature format. With this -F, --format option is retained for backwards compatibility but it is deprecated.
  • tpm2_createak:

    • add option to output qualified name with new option -q, --ak-qualified-name.
  • tpm2_policypcr:

    • Add option for specifying cumulative hash of PCR's as an argument.
  • tpm2_readpublic:

    • Add option to output qualified name using the new option -q, --qualified-name.
  • tpm2_print:

    • Support printing TPM2B_PUBLIC data structures.
    • Support printing TPMT_PUBLIC data structures.
  • tpm2_send:

    • Add support for handling sending and receiving command and response buffer for multiple commands.
  • tpm2_verifysignature:

    • Added support for verifying RSA-PSS signatures.
  • tpm2_eventlog:

    • Add handling of sha1 log format.
    • Add fixes for eventlog output to be proper YAML.
    • Add support for sha384, sha512, sm3_256 PCR hash algorithms.
    • Add support for computing PCR values based on the events.
  • tpm2_tools (all):

    • Set stdin/stdout to non-buffering.
    • Added changes for FreeBSD portability.

Bug fixes

  • Fix printing short options when no ascii character is used.

  • OpenSSL: Fix deprecated OpenSSL functions. ECC Functions with suffix GFp will become deprecated (DEPRECATED_1_2_0).

  • tpm2_eventlog: output EV_POST_CODE as string not firmware blob to be compliant with TCG PC Client FPF section 2.3.4.1 and 9.4.12.3.4.1

  • Fix missing handle maps for ESY3 handle breaks. See #1994.

  • tpm2_rsaencrypt: fix OAEP RSA encryption failing to invalid hash selection.

  • tpm2_rsadecrypt: fix OAEP RSA decryption failing to invalid hash selection.

  • tpm2_sign: fix for signing failures with restricted signing keys when input data to sign is not a digest, rather the full message. The validation ticket creation process defaults to the owner hierarchy and so in order to choose other hierarchies the tpm2_hash tool should be used instead.

  • tpm2_print: fix segfault when -t option is omitted by appropriately warning of the required option.

  • tpm2_nvdefine: fix for default size when size is not specified by invoking TPM2_CC_GetCapability.

  • Fix for an issue where the return code for unsupported algorithms was tool_rc_general instead of tool_rc_unsupported in tpm2_create and tpm2_createprimary tools.

  • Fix for an issue where RSA_PSS signature verification caused failures.

  • tpm2_nvreadpublic, tpm2_kdfa, tpm2_checkquote, tpm2_quote: Fixes for issues with interoperability of the attestation tools between big and little endian platforms.

  • tss2_*:

    • Fix bash-completion for tss2_pcrextend and tss2_verifysignature
    • Add force option to tss2_list
    • Make force option consistent in all fapi tools
    • Do not decode non-TPM errors
    • Enhance integration tests to test changes of optional/mandatory parameters
    • Add --hex parameter to tss2_getrandom
    • Fix autocompletion issue
    • Switch tss2_* to with-"="-style
    • Add size parameter to tss2_createseal
    • References to the cryptographic profile (fapi-profile(5)) and config file (fapi-config(5)) man pages from all relevant tss2_* man pages.
    • Fix policy branch selection menu item from 1 to 0.

CI changes

  • Travis-CI

    • Drop Ubuntu-16.04 and add Ubuntu-20.04.
    • Added unit/integration test instance to verify we are not breaking tool options and or maintaining backwards compatibility with 4.X version.
  • Cirrus-CI:

    • Added support for testing on FreeBSD.

Documentation

  • wiki pages have been removed and data has been migrated to tpm2-software.github.io portal's tutorial section.

  • Fix the problem with man and no-man help output for tools were not correctly displayed.

  • man:

    • tpm2_create: Correct max seal data size from 256 bytes to 128 bytes.

    • tpm2_nvread: Fix manpage example.

    • tpm2_nvwrite: Added missing information on how to specify the NV index as an argument.

    • tpm2_unseal: Add end-to-end example.

    • tpm2_nvincrement: Fix incorrect commands in example section.

    • tpm2_hmac: Fix the example section.

4.3.0 - 2020-08-24

  • tss2_*: Fix double-free errors in commands asking for password authorization

  • tss2_*: Fix shorthand command -f that was falsely requiring an argument

  • tss2_*: Update tss2_encrypt to the new FAPI interface

  • The argument 'policyPath' is removed which was never read anyway

  • tss2_*: Remove the additional '\n' that was appended when redirecting to stdout

  • tss2_*: Update mandatory vs optional treatment of arguments according to latest Fapi spec

  • tss2_*: tss2_getinfo now retrieves the correct FAPI version from Fapi_GetInfo

  • tss2_*: Fix the error handling in case of multiple inputs and/or outputs from stdin/stdout

  • tss2_*: Fix syntax errors and update content of man pages according to latest Fapi spec

  • tss2_*: Add parameter types to all man page

  • tss2_*: tss2_setappdata now reads from file or stdin allowing to store also binary data

  • tss2_*: Memory leaks are fixed in cases when a returned empty non-char output value was passed to file output

  • tss2_pcrextend: fix extending PCR 0

  • tss2_quote: fix unused TSS2_RC in LOG_ERR

4.2.1 - 2020-05-25

  • Fix missing handle maps for ESY3 handle breaks. See #1994.

  • Bump ESYS minimum dependency version from 2.3.0 to 2.4.0.

  • Fix for loop declarations build error.

4.2 2020-04-08

  • Fix various issues reported by static analysis tools.

  • Add integration test for ECC based getekcertificate.

  • Fix for issue #1959 where ARM builds were failing.

  • Add a check in autotools to add "expect" as a package dependency for fapi tools.

  • tpm2_createek: Drop the unused -p or --ek-auth option

  • tpm2_policyor: List of policy files should be specified as an argument instead of -l option. The -l option is still retained for backwards compatibility. See issue#1894.

  • tpm2_eventlog: add a tool for parsing and displaying the event log.

  • tpm2_createek: Fix an issue where the template option looked for args

  • tpm2_hierarchycontrol: Fixed bug where tool operation failed silently

  • tpm2_nvdefine: Fixed an issue where text output suggested failures as passes

  • tpm2_certify: Add an example usage in man page

  • tpm2_policyor: Fix a bug where tool failed silently when no input were given

  • tpm2_getekcertificate: Intel (R) PTT EK cert web portal is set as default address

  • tpm2_alg_util.c: Fix a bug where string rsa3072 was not parsed

  • .ci/download-deps.sh: Change tss dependency to 2.4.0 to acquire SAPI handles for cpHash calculations

  • tpm2_policycphash: Add a tool to implement enhanced authorization with cpHash of a command

  • Add options to tools to enable cpHash outputs: tpm2_nvsetbits, tpm2_nvextend, tpm2_nvincrement, tpm2_nvread, tpm2_nvreadlock, tpm2_writelock, tpm2_nvdefine, tpm2_nvundefine, tpm2_nvcertify, tpm2_policynv, tpm2_policyauthorizenv, tpm2_policysecret, tpm2_create, tpm2_load, tpm2_activatecredential, tpm2_unseal, tpm2_changeauth, tpm2_duplicate, tpm2_import, tpm2_rsadecrypt, tpm2_certify, tpm2_certifycreation, tpm2_hierarchycontrol, tpm2_setprimarypolicy, tpm2_clearcontrol, tpm2_dictionarylockout, tpm2_evictcontrol, tpm2_setclock, tpm2_clockrateadjust, tpm2_clear, tpm2_nvwrite, tpm2_encryptdecrypt, tpm2_hmac.

  • tpm2_import: Fix an issue where the imported key always required to have a policy

  • tpm2_policysecret: Fix an issue where authorization model was fixed to password only

  • Feature API (FAPI) tools added. These additional set of tools implement utilities using the FAPI which was added to the tpm2-tss v2.4.4: tss2_decrypt, tss2_encrypt, tss2_list, tss2_changeauth, tss2_delete, tss2_import, tss2_getinfo, tss2_createkey, tss2_createseal, tss2_exportkey, tss2_getcertificate, tss2_getplatformcertificates, tss2_gettpmblobs, tss2_getappdata, tss2_setappdata, tss2_setcertificate, tss2_sign, tss2_verifysignature, tss2_verifyquote, tss2_createnv, tss2_nvextend, tss2_nvincrement, tss2_nvread, tss2_nvsetbits, tss2_nvwrite, tss2_getdescription, tss2_setdescription, tss2_pcrextend, tss2_quote, tss2_pcrread, tss2_authorizepolicy, tss2_exportpolicy, tss2_import, tss2_provision, tss2_getrandom, tss2_unseal, tss2_writeauthorizenv

  • tpm2_policycountertimer: Fix an issue where operandB array was reversed causing faulty comparisons.

4.1.3 - 2020-06-02

  • tpm2_create: Fix issue with userauth attribute being cleared if policy is specified.

4.1.2 - 2020-05-18

  • Fix missing handle maps for ESY3 handle breaks. See #1994.

4.1.1 - 2020-01-21

  • tpm2_certify: Fix output of attestation data including size field. Now outputs just bytes.
  • tpm2_certifycreation: Fix tool to match manpage where the code had the -C and -c options reversed.
  • tpm2_gettime: Fix output of attestation data including size field. Now outputs just bytes.
  • tpm2_nvcertify: Fix output of attestation data including size field. Now outputs just bytes.
  • tpm2_nvreadpublic: add name hash output.
  • tpm2_import: Support object policies when importing raw key material.
  • Fix overflow in pcrs.h where sizeof() was used instead of ARRAY_LEN().
  • build:
  • Fix compilation issue: lib/tpm2_hash.c:17:19: note: 'left' was declared here.
  • man:
    • Fix manpage examples that have "sha" instead of "sha1"
    • tpm2_shutdown manpage was missing, add it to build.
    • Fix manpage example for tpm2_createak's tpm2_evictcontrol example.

4.1 2019-11-25

  • tpm2_certifycreation: New tool enabling command TPM2_CertifyCreation.

  • tpm2_checkquote:

  • Fix YAML output bug.
  • -g option for specifying hash algorithm is optional and defaults to sha256.

  • tpm2_changeeps: A new tool for changing the Endorsement hierarchy primary seed.

  • tpm2_changepps: A new tool for changing the Platform hierarchy primary seed.

  • tpm2_clockrateadjust: Add a new tool for modifying the period on the TPM.

  • tpm2_create: Add tool options for specifying output data for use in certification

  • --creation-data to save the creation data
  • --creation-ticket or -t to save the creation ticket
  • --creation-hash or -d to save the creation hash
  • --template-data for saving the template data of the key
  • --outside-info or -q for specifying unique data to include in creation data.
  • --pcr-list or -l Add option to specify pcr list to add to creation data.

  • tpm2_createprimary: Add tool options for specifying output data for use in certification

  • --creation-data to save the creation data
  • --creation-ticket or -t to save the creation ticket
  • --creation-hash or -d to save the creation hash
  • --template-data for saving the template data of the key
  • --outside-info or -q for specifying unique data to include in creation data.
  • --pcr-list or -l Add option to specify pcr list to add to creation data.

  • tpm2_evictcontrol:

    • Fix bug in automatic persistent handle selection when hierarchy is platform.
    • Fix bug in YAML key action where action was wrong when using ESYS_TR.
  • tpm2_getcap: clean up remanenats of -c option in manpages and tool output.

  • tpm2_gettime: Add a new tool for retrieving a signed timestamp from a TPM.

  • tpm2_nvcertify: Add a new tool for certifying the contents of an NV index.

  • tpm2_nvdefine:

  • Support default set of attributes so -a is not mandatory.
  • Support searching for free index if an index isn't specified.

  • tpm2_nvextend: Add a new tool for extending an NV index similair to a PCR.

  • tpm2_nvreadpublic:

  • Support specifying nv index to read public data from as argument.

  • tpm2_nvsetbits: Add a new tool for setting the values of PCR with type "bits".

  • tpm2_nvundefine: Add support for deleting NV indices with attribute TPMA_NV_POLICY_DELETE set using NV Undefine Special command.

  • tpm2_nvwritelock: Add a new tool for setting a write lock on an NV index or globally locking nv indices with TPMA_NV_GLOBALLOCK.

  • tpm2_policyauthorizenv: New tool enabling signed, revocable policies.

  • tpm2_policyauthvalue: New tool enabling authorization to be bound to the authorization of another object.

  • tpm2_policycountertimer: Add a new tool for enabling policy bound to TPM clock or timer values.

  • tpm2_policynamehash: Add a new tool for specifying policy based on object name.

  • tpm2_policynv: Add a new tool for specifying policy based on NV contents.

  • tpm2_nvwritten: Add a new tool for specifying policy based on whether or not an NV index was written to.

  • tpm2_policysecret: Add tool options for specifying

  • --expiration or -t
  • --ticket
  • --timeout
  • --nonce-tpm or -x
  • --qualification or -q

  • tpm2_policysigned: New tool enabling policy command TPM2_PolicySigned.

  • tpm2_policytemplate: New tool enabling policy command TPM2_PolicyTemplate.

  • tpm2_policyticket: New tool enabling policy command TPM2_PolicyTicket.

  • tpm2_readclock: Add a new tool for reading the TPM clock.

  • tpm2_setclock: Add a new tool for setting the TPM clock.

  • tpm2_setprimarypolicy: New tool setting policy on hierarchies.

  • tpm2_shutdown: Add a new tool for issuing a TPM shutdown command.

  • misc:

  • Support "tpmt" as a public key output format that only saves the TPMT structure.
  • Qualifying data or extra data in many tools can be hex array string or binary file.
  • Add support for specifying NV index type when specifying NV attributes.
  • Support added for tools to run on FreeBSD.
  • Skip and notify of action that man pages will not install if the package pandoc is missing.
  • Fix precedence issue with bitwise operator order int tpm2_getcap
  • travis: bump abrmd version 2.3.0
  • tpm2_util.c: Fix an issue int variable size was checked against uint
  • pcr.c: Fix buffer length issue to support all defined hash algorithm

4.0.1 - 2019-10-28

tpm2_checkquote: Fix YAML output bug.

3.2.1 - 2019-10-10

  • Fix invalid memcpy when extracting ECDSA plain signatures.
  • Fix resource leak on FILE * in hashing routine.
  • Correct PCR logic to prevent memory corruption bug.
  • Errata handler fix.

4.0 - 2019-09-09

  • tpm2_activatecredential:
  • --context is now --credentialedkey-context.
  • --key-context is now --credentialkey-context.
  • --Password is now --credentialedkey-auth.
  • --endorse-passwd is now --credentialkey-auth.
  • --in-file is now --credential-secret.
  • --out-file is now --certinfo-data.
  • -f becomes -i.
  • -k becomes -C.
  • -e becomes -E.

  • tpm2_certify:

  • --halg is now --hash-algorithm.
  • --obj-context is now --certifiedkey-context.
  • --key-context is now --signingkey-context.
  • --pwdo is now --certifiedkey-auth.
  • --pwdk is now --signingkey-auth.
  • -a becomes -o.
  • -k becomes -p.
  • -c becomes -C.
  • -k becomes -K.

  • tpm2_changeauth:

  • New tool for changing the authorization values of:
    • Hierarchies
    • NV
    • Objects
  • Replaces tpm2_takeownership with more generic functionality.

  • tpm2_checkquote:

  • --halg is now --hash-algorithm.
  • --pcr-input-file is now --pcr.
  • --pubfile is now --public.
  • --qualify-data is now --qualification.
  • -f becomes -F.
  • -F becomes -f.
  • -G becomes -g.

  • tpm2_clear:

  • --lockout-passwd is now --auth-lockout.

  • tpm2_clearcontrol:

  • New tool for enabling or disabling tpm2_clear commands.

  • tpm2_create

  • --object-attributes is now --attributes.
  • --pwdp is now --parent-auth.
  • --pwdo is now --key-auth.
  • --in-file is now --sealing-input.
  • --policy-file is now --policy.
  • --pubfile is now --public.
  • --privfile is now --private.
  • --out-context is now --key-context.
  • --halg is now --hash-algorithm.
  • --kalg is now --key-algorithm.
  • -o becomes -c.
  • -K becomes -p.
  • -A becomes -b.
  • -I becomes -i.
  • -g becomes an optional option.
  • -G becomes an optional option.
  • Supports TPM command CreateLoaded via -c.

  • tpm2_createak:

  • Renamed from tpm2_getpubak

  • tpm2_createek:

  • renamed from tpm2_getpubek

  • tpm2_createpolicy:

  • --out-policy-file is now --policy.
  • --policy-digest-alg is now --policy-algorithm.
  • --auth-policy-session is now --policy-session.
  • -L becomes -l.
  • -F becomes -f.
  • -f becomes -o.
  • Removed option --set-list with short option -L.
  • Removed option --pcr-input-file with short option -F.
  • Pcr policy options replaced with pcr password mini language.
  • Removed short option a for specifying auth session. Use long option --policy-session.
  • Removed short option -P for specifying pcr policy. Use long option --policy-pcr.

  • tpm2_createprimary:

  • --object-attributes is now --attributes.
  • -o is now -c
  • --pwdp is now --hierarchy-auth.
  • --pwdk is now --key-auth.
  • --halg is now --hash-algorithm.
  • --kalg is now --key-algorithm.
  • --context-object is now --key-context.
  • --policy-file is now --policy.
  • support for unique field when creating objects via -u
  • saves a context file for the generated primary's handle to disk via -c.
  • -A becomes -a.
  • -K becomes -p.
  • -H becomes -C.
  • -g becomes optional.
  • -G becomes optional.

  • tpm2_dictionarylockout:

  • --lockout-passwd is now --auth.
  • -P becomes -p.

  • tpm2_duplicate:

  • New tool for duplicating TPM objects.

  • tpm2_encryptdecrypt:

  • --pwdk is now --auth.
  • --out-file is now --output.
  • -D becomes -d.
  • -I becomes an argument.
  • -P becomes -p.
  • Support IVs via -t or --iv.
  • Support modes via -G.
  • Support padding via -e or --pad.
  • Supports input and output to stdin and stdout respectively.

  • tpm2_evictcontrol:

  • --auth is now --hierarchy.
  • --context is now --object-context.
  • --pwda is now --auth.
  • --persistent with short option -S is now an argument.
  • -A becomes -C.
  • Added option --output -o to serialize handle to disk.
  • Removed option --handle with short option -H.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Removed option --input-session-handle with short option -i.
  • Authorization session is now part of password mini language.

  • tpm2_getcap:

  • -c becomes an argument.
  • Most instances of value replaced with raw in YAML output.
  • TPM2_PT_MANUFACTURER displays string value and raw value.
  • Supports --pcr option for listing hash algorithms and bank numbers.

  • tpm2_getekcertificate:

  • Renamed from tpm2_getmanufec

  • tpm2_getmanufec:

  • Renamed the tool to tpm2_getekcertificate.
  • Removed ek key creation and management logic.
  • Added option for getting ek cert for offline platform via -x.
  • Support for ECC keys.
  • --ec-cert is now --ek-certificate,
  • --untrusted is now --allow-unverified,
  • --output is now --ek-public,
  • -U is now -X.
  • -O is now -x.
  • -f becomes -o.
  • Removed option -P or --endorse-passwd.
  • Removed option -p or --ek-passwd.
  • Removed option -w or --owner-passwd.
  • Removed option -H or --persistent-handle.
  • Removed option -G or --key-algorithm.
  • Removed option -N or --non-persistent.
  • Removed option -O or --offline.

  • tpm2_getpubak:

  • renamed to tpm2_createak.
  • -f becomes -p and -f is used for format of public key output.
  • --auth-endorse is now --eh-auth.
  • --auth-ak is now --ak-auth.
  • --halg is now --hash-algorithm.
  • --kalg is now --key-algorithm.
  • -e becomes -P.
  • -P becomes -p.
  • -D becomes -g.
  • -p becomes -u.
  • --context becomes --ak-context.
  • --algorithm becomes --kalg.
  • --digest-alg becomes --halg.
  • --privfile becomes --private.
  • remove -k persistant option. Use tpm2_evictcontrol.
  • Fix -o option to -w.
  • now saves a context file for the generated primary's handle to disk.
  • -E becomes -e.
  • -g changes to -G.
  • support for non-persistent AK generation.

  • tpm2_getpubek:

  • renamed to tpm2_createek
  • --endorse-passwd is now --eh-auth.
  • --owner-passwd is now --owner-auth.
  • --ek-passwd is now --ek-auth.
  • --file is now --public.
  • --context is now --ek-context.
  • --algorithm is now --key-algorithm.
  • -e is now -P.
  • -P is now -p.
  • -p is now -u.
  • -o is now -w.
  • -g is now -G.
  • Support for saving a context file for the generated primary keys handle to disk.
  • support for non-persistent EK generation.
  • -f is now -p.
  • -f support for format of public key output.

  • tpm2_getrandom:

  • change default output to binary.
  • add --hex option for output to hex format.
  • --out-file is now --output.
  • bound input request on max hash size per spec, allow -f to override this.

  • tpm_gettestresult:

  • new tool for getting test results.

  • tpm2_hash:

  • add --hex for specifying hex output.
  • default output of hash to stdout.
  • default output of hash as binary.
  • remove output of ticket to stdout.
  • --halg is now --hash-algorithm.
  • --out-file is now --output.
  • -a is now -C.
  • -H is now -a.

  • tpm2_hmac:

  • add -t option for specifying ticket result.
  • --out-file is now --output.
  • --auth-key is now --auth. ---algorithm is now --hash-algorithm.
  • --pwdk is now --auth-key.
  • -C is now -c.
  • -P is now -p.

  • tpm2_hierarchycontrol:

  • new tool added for enabling or disabling the use of a hierarchy and its associated NV storage.

  • tpm2_import:

  • --object-attributes is now --attributes.
  • --auth-parent is now --parent-auth.
  • --auth-key is now --key-auth.
  • --algorithm is now --key-algorithm.
  • --in-file is now --input.
  • --parent-key is now --parent-context.
  • --privfile is now --private.
  • --pubfile is now --public.
  • --halg is now --hash-algorithm.
  • --policy-file is now --policy.
  • --sym-alg-file is now --encryption-key.
  • -A is now -b.
  • -k is now -i.
  • support OSSL style -passin argument as --passin for PEM file passwords.
  • support additional import key types:
    • RSA1024/2048.
    • AES128/192/256.
  • -q changes to -u to align with tpm2_loads public/private output arguments.
  • Supports setting object name algorithm via -g.
  • support specifying parent key with a context file.
  • --parent-key-handle/-H becomes --parent-key/-C
  • Parent public data option is optional and changes from -K to -U.
  • Supports importing external RSA 2048 keys via pem files.
  • Supports ECC Parent keys.

  • tpm2_incrementalselftest:

  • Add tool to test support of specific algorithms.

  • tpm2_listpersistent:

  • deleted as tpm2_getcap and tpm2_readpublic can be used instead.

  • tpm2_load:

  • -o is now -c.
  • --context-parent is now --parent-context.
  • --auth-parent is now --auth.
  • --pubfile is now --public.
  • --privfile is now --private.
  • --out-context is now --key-context.
  • now saves a context file for the generated primary's handle to disk.
  • Option --pwdp changes to --auth-parent.

  • tpm2_loadexternal:

  • --object-attributes is now --attributes.
  • -o is now -c
  • --key-alg is now --key-algorithm.
  • --pubfile is now --public.
  • --privfile is now --private.
  • --auth-key is now --auth.
  • --policy-file is now --policy.
  • --halg is now --hash-algorithm.
  • --out-context is now --key-context.
  • Remove unused -P option.
  • -H is now -a.
  • Fix -A option to -b for attributes.
  • now saves a context file for the generated primary's handle to disk.
  • support OSSL style -passin argument as --passin for PEM file passwords.
  • name output to file and stdout. Changes YAML stdout output.
  • ECC Public and Private PEM support.
  • AES Public and Private "raw file" support.
  • RSA Public and Private PEM support.
  • Object Attribute support.
  • Object authorization support.
  • Default hierarchy changes to the null hierarchy.

  • tpm2_makecredential:

  • --out-file is now --credential-blob
  • --enckey is now --encryption-key.
  • Option --sec changes to --secret.

  • tpm2_nvdefine:

  • --handle-passwd is now --hierarchy-auth.
  • --index-passwd is now --index-auth.
  • --policy-file is now --policy.
  • --auth-handle is now --hierarchy.
  • -a becomes -C.
  • -t becomes -a.
  • -I becomes -p.
  • Removed option --index with short option -x. It is now an argument.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.

  • tpm2_nvincrement:

  • New tool to increment value of a Non-Volatile (NV) index setup as a counter.

  • tpm2_nvlist:

  • tpm2_nvlist is now tpm2_nvreadpublic.

  • tpm2_nvread:

  • --handle-passwd is now --auth.
  • --auth-handle is now --hierarchy.
  • -a becomes -C.
  • Removed option --index with short option -x. It is now an argument.
  • Removed short option -o for specifying offset. Use long option --offset.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.
  • Removed option --set-list with short option -L.
  • Removed option --pcr-input-file with short option -F.
  • Pcr policy options replaced with pcr password mini language.
  • fix a buffer overflow.

  • tpm2_nvreadlock:

  • --handle-passwd is now --auth.
  • --auth-handle is now --hierarchy.
  • -a becomes -C.
  • Removed option --index with short option -x. It is now an argument.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.

  • tpm2_nvwrite:

  • --handle-passwd is now --auth.
  • --auth-handle is now --hierarchy.
  • -a becomes -C.
  • Removed option --index with short option -x. It is now an argument.
  • Removed short option -o for specifying offset. Use long option --offset.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.
  • Removed option --set-list with short option -L.
  • Removed option --pcr-input-file with short option -F.
  • Pcr policy options replaced with pcr password mini language.

  • tpm2_nvrelease:

  • --handle-passwd is now --auth.
  • --auth-handle is now --hierarchy.
  • -a becomes -C.
  • Removed option --index with short option -x. It is now an argument.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.

  • tpm2_nvundefine:

  • Renamed from tpm2_nvrelease.

  • tpm2_pcrallocate:

  • New tool for changing the allocated PCRs of a TPM.

  • tpm2_pcrevent:

  • --password is now --auth.
  • Removed option --pcr-index with short option -i.
  • PCR index is now specified as an argument.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.

  • tpm2_pcrlist:

  • -gls options go away with -g and -l becoming a single argument.

  • tpm2_pcrread:

  • Renamed from tpm2_pcrlist.

  • tpm2_print:

  • New tool that decodes a TPM data structure and prints enclosed elements to stdout as YAML.

  • tpm2_policyauthorize:

  • New tool that allows for policies to change by associating the policy to a signing authority essentially allowing the auth policy to change.

  • tpm2_policycommandcode:

  • New tool to restricts TPM object authorization to specific TPM commands.

  • tpm2_policyduplicationselect:

  • New tool for creating a policy to restrict duplication to a new parent and or duplicable object.

  • tpm2_policylocality:

  • New tool for creating a policy restricted to a locality.

  • tpm2_policypcr:

  • New tool to generate a pcr policy event that bounds auth to specific PCR values in user defined pcr banks and indices.

  • tpm2_policyor:

  • New tool to compound multiple policies in a logical OR fashion to allow multiple auth methods using a policy session.

  • tpm2_policypassword:

  • New tool to mandate specifying of the object password in clear using a policy session.

  • tpm2_policysecret:

  • New tool to associate auth of a reference object as the auth of the new object using a policy session.

  • tpm2_quote:

  • --ak-context is now --key-context.
  • --ak-password is now --auth.
  • --sel-list is now --pcr-list.
  • --qualify-data is now --qualification-data.
  • --pcrs is now --pcr.
  • --sig-hash-algorithm is now --hash-algorithm.
  • -P becomes -p
  • -L becomes -l.
  • -p becomes -o.
  • -G becomes -g.
  • -g becomes optional.
  • Removed option --id-list with short option -l.
  • Removed option --ak-handle with short option -k.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.

  • tpm2_readpublic:

  • --opu is now --output.
  • --context-object is now --object-context.
  • Removed option --object with short option -H.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Added --serialized-handle for saving serialized ESYS_TR handle to disk.
  • Added --name with short option -n for saving the binary name.
  • Supports ECC pem and der file generation.

  • tpm2_rsadecrypt:

  • --pwdk is now --auth.
  • --out-file is now --output.
  • -P becomes -p.
  • Added --label with short option -l for specifying label.
  • Added --scheme with short option -s for specifying encryption scheme.
  • Removed option -I or in-file input option and make argument.
  • Removed option --key-handle with short option -k.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.

  • tpm2_rsaencrypt:

  • --out-file is now --output.
  • Added --scheme with short option -s for specifying encryption scheme.
  • Added --label with -l for specifying label.
  • Removed option --key-handle with short option -k.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • make output binary either stdout or file based on -o.

  • tpm2_selftest:

  • New tool for invoking tpm selftest.

  • tpm2_send:

  • --out-file is now --output.

  • tpm2_sign:

  • --pwdk is now --auth.
  • --halg is now --hash-algorithm.
  • --sig is now --signature.
  • -P becomes -p.
  • -s becomes -o.
  • Added --digest with short option -d.
  • Added --scheme with short option -s.
  • Supports rsapss.
  • Removed option --key-handle with short option -k.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Removed option --msg with short option -m.
  • Make -d toggle if input is a digest.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.
  • Supports signing a pre-computed hash via -d.

  • tpm2_startauthsession:

  • New tool to start/save a trial-policy-session (default) or policy- authorization-session with command line option --policy-session.

  • tpm2_stirrandom:

  • new command for injecting entropy into the TPM.

  • tpm2_takeownership:

  • split into tpm2_clear and tpm2_changeauth

  • tpm2_testparms:

  • new tool for querying tpm for supported algorithms.

  • tpm2_unseal:

  • --pwdk is now --auth.
  • --outfile is now --output.
  • --item-context is now --object-context.
  • -P becomes -p
  • Removed option --item with short option -H.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Removed option --input-session-handle with short option -S.
  • Authorization session is now part of password mini language.
  • Removed option --set-list with short option -L.
  • Removed option --pcr-input-file with short option -F.
  • Pcr policy options replaced with pcr password mini language.

  • tpm2_verifysignature:

  • --halg is now --hash-algorithm.
  • --msg is now --message.
  • --sig is now --signature.
  • -D becomes -d.
  • -t becomes optional.
  • Issue warning when ticket is specified for a NULL hierarchy.
  • Added option --format with short option -f.
  • Removed option --raw with short option -r.
  • Removed option --key-handle with short option -k.
  • Raw object-handles and object-contexts are commonly handled with object handling logic.
  • Support routines for OpenSSL compatible format of public keys (PEM, DER) and plain signature data without TSS specific headers.

  • misc:

  • cmac algorithm support.
  • Add support for reading authorisation passwords from a file.
  • Ported all tools from SAPI to ESAPI.
  • Load TCTI's by SONAME, not raw .so file.
  • system tests are now run with make check when --enable-unit is used in configure.
  • Libre SSL builds fixed.
  • Dynamic TCTIS. Support for pluggable TCTI modules via the -T or --tcti options.
  • test: system testing scripts moved into subordinate test directory.
  • configure: enable code coverage option.
  • env: add TPM2TOOLS_ENABLE_ERRATA to control the -Z or errata option. affects all tools.
  • Fix parsing bug in PCR mini-language.
  • Fix misspelling of TPM2_PT_HR constants which effects tpm2_getcap output.
  • configure option --with-bashcompdir for specifying bash completion directory.

3.2.0 - 2019-06-19

  • fix configure bug for linking against libmu.
  • tpm2_changeauth: Support changing platform hierarchy auth.
  • tpm2_flushcontext: Introduce new tool for flushing handles from the TPM.
  • tpm2_checkquote: Introduce new tool for checking validity of quotes.
  • tpm2_quote: Add ability to output PCR values for quotes.
  • tpm2_makecredential: add support for executing tool off-TPM.
  • tpm2_pcrreset: introduce new tool for resetting PCRs.
  • tpm2_quote: Fix AK auth password not being used.

3.1.4 - 2019-03-14

  • Fix various man pages
  • tpm2_getmanufec: fix OSSL build warnings
  • Fix broken -T option
  • Various build compatibility fixes
  • Fix some unit tests
  • Update build for recent autoconf-archive versions
  • Install m4 files

3.1.3 - 2018-10-15

  • Restore support for the TPM2TOOLS_* env vars for TCTI configuration, in addition to supporting the new unified TPM2TOOLS_ENV_TCTI
  • Fix tpm2_getcap to print properties with the TPM_PT prefix, rather than TPM2_PT
  • Make test_tpm2_activecredential Python 3 compatible
  • Fix tpm2_takeownership to only attempt to change the specified hierarchies

3.1.2 - 2018-08-14

  • Revert the change to use user supplied object attributes exclusively. This is an inappropriate behavioural change for a MINOR version number increment.
  • Fix inclusion of object attribute specifiers section in tpm2_create and tpm2_createprimary man pages.
  • Use better object attribute defaults for authentication, preventing an empty password being used for authentication when a policy is set.

3.1.1 - 2018-07-09

  • Allow man page installation without pandoc being available

3.1.0 - 2018-06-21

  • Update to use TSS version 2.0
  • When user supplies nv attributes use those exclusively, not in addition to the defaults
  • When user supplies object attributes use those exclusively, not in addition to the defaults
  • Load TCTI's by SONAME, not raw .so file

3.0.4 - 2018-05-30

  • Fix save and load for TPM2B_PRIVATE object.
  • Use a default buffer size for tpm2_nv{read,write} if the TPM reports a 0 size.
  • Fix --verbose and --version options crossover.
  • Generate man pages from markdown and include them in the distribution tarball.
  • Print usage summary if tools are executed with no options or man page can't be displayed.

3.0.3 - 2017-15-18

  • Tools that don't need a TPM to work no longer request a TPM connection. Namely, tpm2_rc_decode
  • Fix undefined references in libmarshal port.

3.0.2 - 2017-12-18

  • configure: enable code coverage option.
  • build: enable silent rules options.
  • Add system tests to dist tarball.
  • tpm2_nv(read|write): fix buffer overflows.

3.0.1 - 2017-12-11

  • Makefile: add missing LICENSE and markdown files.

3.0 - 2017-12-08

  • tpm2_getmanufec: -O as a flag for -f has changed. -O is for existing EK public structure and -f is only for generated EK public output.
  • tpm2_nvlist: output in yaml format.
  • tpm2_makecredential format changes to the -o output file.
  • tpm2-quote: -o option removed.
  • tpm2_rsaencrypt: -I is now an argument and input defaults to stdin. -o is optional and defaults to stdout.
  • tpm2_listpersistent: output friendly object attributes.
  • tpm2_createprimary: support friendly object attributes via -A. -H becomes auth hierarchy.
  • tpm2_create: support friendly object attributes via -A.
  • tpm2_nvwrite and tpm2_nvread have support for satisfying PCR policies.
  • tpm2_encryptdecrypt: has support for EncryptDecrypt2 command.
  • tpm2_nvwrite: -f option removed, support for stdin data supported. Support for starting index to write to.
  • errata framework added for dealing with spec errata.
  • tpm2_quote: -G option for signature hash algorithm specification.
  • tpm2_dump_capability: renamed to tpm2_getcap.
  • tpm2_send_command: renamed to tpm2_send and the input file is now an argument vs using -i.
  • tpm2_dump_capability: outputs human readable command codes.
  • camelCase options are now all lower case. For example, --camelCase becomes --camel-case.
  • tpm2_quote,readpublic, and sign now have support for pem/der output/inputs. See the respective man pages for more details.
  • tpm2_nvread: Has an output file option, -f.
  • manpages: Are now in Markdown and converted to roff using pandoc.
  • tpm2_create - options 'o' and 'O' changed to 'u' and 'r' respectively.
  • tpm2_pcrlist: support yaml output for parsing.
  • tpm2_pcrevent: new tool for hashing and extending pcrs.
  • Make tpm2_{createprimary,create,load,pcrlist,hmac} tools to support the --quiet option.
  • Support for a --quiet option to suppress messages printed by tools to standard output.
  • tpm2_hmac: support for files greater than 1024 bytes, changes in options and arguments.
  • tpm2_hash: support for files greater than 1024 bytes, changes in options and arguments.
  • Install is now to bin vs sbin. Ensure that sbin tools get removed!
  • make dist and distcheck are now working.
  • installation into customized locations are now working, see issue #402 for details.
  • tpm2_pcrlist: renamed from tpm2_listpcrs.
  • tpm2_pcrextend: new tool for extending PCRs.
  • tpm2_getmanufec: -E option no longer required, defaults to stdout.
  • tpm2_nvlist: Support for friendly nv attributes in output.
  • Support for friendly algorithm names for algorithm identifiers.
  • tpm2_nvread: The option, -s, or size option is no longer required.
  • tpm2_nvwrite: fixed to write files larger than 1024 in size.
  • tpm2_nvread: fixed to read files larger than 1024 in size.
  • tpm2_nvdefine supports "nice-names" for nv space attributes.
  • Support using PCR Policy directly with tpm2_unseal tool.
  • Support PCR policy creation in tpm2_createpolicy
  • Support using a policy session as input to tools that may need to satisfy complex policies other than password.
  • tpm2_unseal: supports output to stdoud.
  • tpm2_create: enforce policy based authorization.
  • tpm2_createprimary: add ability to create objects with policy based authorization.
  • tpm2_nvdefine: add ability to create nv indexes with policy based authorization.
  • Support Clang Build.
  • tpm2_unseal test uses endorsement hierarchy as platform hierarchy is unavailable on a real tpm.
  • Numerous cleanups and minor bug fixes.

v2.0 - 2017-03-29

  • Tracked on the milestone: https://github.com/tpm2-software/tpm2-tools/milestone/2
  • Reworked all the tools to support configurable TCTIs, based on build time configuration, one can specify the tcti via the --tcti (-T) option to all tools.
  • tpm2_getrandom interface made -s a positional argument.
  • Numerous bug fixes.

v1.1 - 2016-11-04

  • travis ci support.
  • Allow for unit tests to be enabled selectively.
  • tpm2_rc_decode tool: Decode TPM_RC error codes.
  • Android Make file
  • tpm2_listpersistent: list all persistent objects
  • test scripts for tpm2-tools
  • tpm2_nvreadlock
  • tpm2_getmanufec: retrieve EC from tpm manufacturer server.
  • Copy 'common' and 'sample' code from the TPM2.0-TSS repo.

Modified

  • tpm2_takeownership: update option -c to use lockout password to clear.
  • tpm2_listpcrs: add options -L and -s, rewrite to increase performance.
  • tpm2_quote: added -L option to support selection of multiple banks.
  • tpm2_quote: add -q option to get qualifying data.
  • configure: Use pkg-config to get info about libcurl and libcrypto.
  • configure: Use pkg-config to locate SAPI and TCTI headers / libraries.
  • tpm2_x: Add -X option to enable password input in Hex format.
  • tpm2_nvdefine: Change -X option to -I.
  • tpm2-nvwrite: fix for unable to write 1024B+ data.
  • tpm2_getmanufec: Fix base64 encoding.
  • tpm2_x: fixed a lot of TPM2B failures caused by wrong initialization.
  • tpm2_getmanufec: let configure handle libs.
  • tpm2_getmanufec: Convert from dos to unix format.
  • build: Check for TSS2 library @ configure time.
  • build: Detect required TSS2 and TCTI headers.
  • build: Use libtool to build the common library
  • build: Install all binaries into sbin.
  • build: Build common sources into library.
  • build: Move all source files to 'src'.
  • Makefile.am: Move all build rules into single Makefile.am.
  • everything: Use new TCTI headers and fixup API calls.
  • everything: Update source to cope with sapi header cleanup.
  • tpm2_activatecredential: Updated to support TCG compatible EK
  • tpm2_getpubak: Updated to use TCG compatible EK
  • tpm2_getpubek: fix ek creation to follow TCG EK profile spec.

Removed

  • Windows related code
  • dependency on the TPM2.0-TSS repo source code

v1.0 - 2015-10-19

  • 1.0 release
  • 29 tools included