This reworkds TPM2 based creds a bit. Instead of mapping the key type "tpm2" directly to a TPM2 key without PK, let's map it to an "automatic" key type that either picks PK or doesn't, depending on what's available. That should make things easier to grok for people, as the nitty gritty details of PK or not PK are made autmatic. Moreover it gives us more leverage to change the TPM2 enrollment types later (for example, we definitely want to start pinning SRK, and hook up pcrlock too, for creds, which we currently don't). This hence adds a new _CRED_AUTO_TPM2 pseudo-type we automatically maps to CRED_AES256_GCM_BY_TPM2_HMAC_WITH_PK or CRED_AES256_GCM_BY_TPM2_HMAC depending if PK as available. Similar, _CRED_AUTO_HOST_AND_TPM2 is added, which does the same for the host/nonhost cred type. This does not introduce any new type on the wire, it just changes how we select the right key type. To make the code more readable this also adds some categorization macros for the keys, instead of repeating the list of key types at multiple places.
System and Service Manager
Details
Most documentation is available on systemd's web site.
Assorted, older, general information about systemd can be found in the systemd Wiki.
Information about build requirements is provided in the README file.
Consult our NEWS file for information about what's new in the most recent systemd versions.
Please see the Code Map for information about this repository's layout and content.
Please see the Hacking guide for information on how to hack on systemd and test your modifications.
Please see our Contribution Guidelines for more information about filing GitHub Issues and posting GitHub Pull Requests.
When preparing patches for systemd, please follow our Coding Style Guidelines.
If you are looking for support, please contact our mailing list, join our IRC channel #systemd on libera.chat or Matrix channel
Stable branches with backported patches are available in the stable repo.
We have a security bug bounty program sponsored by the Sovereign Tech Fund hosted on YesWeHack
Repositories with distribution packages built from git main are available on OBS
