Skip to content

Commit

Permalink
tpm2: use first PCR algorithm bank supported by TPM as default
Browse files Browse the repository at this point in the history
The default is `sha1`, which is not always supported (it is legacy and
optional for implementation). Make this more future-proof and use the first
bank with non-empty set of PCRs, which is returned from TPM by
`tpm2_getcap pcrs`.

The swtpm by default does not create sha1 bank, so this fixes usage with
swtpm.

Signed-off-by: Oldřich Jedlička <oldium.pro@gmail.com>
  • Loading branch information
oldium authored and sergio-correia committed Oct 17, 2024
1 parent 4b754bd commit 8490a70
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 6 deletions.
12 changes: 10 additions & 2 deletions src/pins/tpm2/clevis-encrypt-tpm2
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ if [ -t 0 ]; then
echo
echo " key: <string> Algorithm type for the generated key (default: ecc)"
echo
echo " pcr_bank: <string> PCR algorithm bank to use for policy (default: sha1)"
echo " pcr_bank: <string> PCR algorithm bank to use for policy (default: first supported by TPM)"
echo
echo " pcr_ids: <string> PCR list used for policy. If not present, no policy is used"
echo
Expand Down Expand Up @@ -130,7 +130,15 @@ hash="$(jose fmt -j- -Og hash -u- <<< "$cfg")" || hash="sha256"

key="$(jose fmt -j- -Og key -u- <<< "$cfg")" || key="ecc"

pcr_bank="$(jose fmt -j- -Og pcr_bank -u- <<< "$cfg")" || pcr_bank="sha1"
pcr_bank="$(jose fmt -j- -Og pcr_bank -u- <<< "$cfg")" || {
if ! pcr_bank=$(tpm2_getcap pcrs |
awk '/^[[:space:]]*-[[:space:]]*([^:]+):[[:space:]]*\[[[:space:]]*[^][:space:]]/ \
{found=1; split($0, m, /[-:[:space:]]+/); print m[2]; exit}
END {exit !found}'); then
echo "Unable to find non-empty PCR algorithm bank, please check output of tpm2_getcap pcrs" >&2
exit 1
fi
}

# Trim the spaces from the config, so that we will not have issues parsing
# the PCR IDs.
Expand Down
8 changes: 6 additions & 2 deletions src/pins/tpm2/clevis-encrypt-tpm2.1.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -91,13 +91,17 @@ This command uses the following configuration properties:
- *symcipher*

* *pcr_bank* (string) :
PCR algorithm bank to use for policy (default: sha1)
PCR algorithm bank to use for policy (default: first supported by TPM)

It must be one of the following:
Examples of PCR algorithm banks, support depends on TPM chip:

- *sha1*
- *sha256*

For the full list of algorithms supported by the TPM chip check output of
`tpm2_getcap pcrs` and use the algorithm which shows non-empty list of PCR
numbers.

* *pcr_ids* (string) :
Comma separated list of PCR used for policy. If not present, no policy is used

Expand Down
6 changes: 4 additions & 2 deletions src/pins/tpm2/pin-tpm2
Original file line number Diff line number Diff line change
Expand Up @@ -142,8 +142,10 @@ test_pcr_ids "${orig}" '{"key": "ecc"}' "" || exit 1
# arrays and check if we get the expected pcr_ids.

# Let's first make sure this would be a valid configuration.
_default_pcr_bank="sha1"
if validate_pcrs "${_default_pcr_bank}" "4,16"; then
_default_pcr_bank=$(tpm2_getcap pcrs |
awk '/^[[:space:]]*-[[:space:]]*([^:]+):[[:space:]]*\[[[:space:]]*[^][:space:]]/ \
{split($0, m, /[-:[:space:]]+/); print m[2]; exit}')
if [ -n "$_default_pcr_bank" ] && validate_pcrs "${_default_pcr_bank}" "4,16"; then
test_pcr_ids "${orig}" '{"pcr_ids": "16"}' "16" || exit 1
test_pcr_ids "${orig}" '{"pcr_ids": ["16"]}' "16" || exit 1
test_pcr_ids "${orig}" '{"pcr_ids": "4, 16"}' "4,16" || exit 1
Expand Down

0 comments on commit 8490a70

Please sign in to comment.