systemd-pcrphase.service(8) — Linux manual page

NAME | SYNOPSIS | DESCRIPTION | OPTIONS | FILES | SEE ALSO | NOTES | COLOPHON

SYSTEMD-....SERVICE(8)  systemd-pcrphase.service  SYSTEMD-....SERVICE(8)

NAME         top

       systemd-pcrphase.service, systemd-pcrphase-sysinit.service,
       systemd-pcrphase-initrd.service, systemd-pcrmachine.service,
       systemd-pcrfs-root.service, systemd-pcrfs@.service, systemd-
       pcrextend - Measure boot phase into TPM2 PCR 11, machine ID and
       file system identity into PCR 15

SYNOPSIS         top

       systemd-pcrphase.service

       systemd-pcrphase-sysinit.service

       systemd-pcrphase-initrd.service

       systemd-pcrmachine.service

       systemd-pcrfs-root.service

       systemd-pcrfs@.service

       /usr/lib/systemd/systemd-pcrextend [STRING]

DESCRIPTION         top

       systemd-pcrphase.service, systemd-pcrphase-sysinit.service, and
       systemd-pcrphase-initrd.service are system services that measure
       specific strings into TPM2 PCR 11 during boot at various
       milestones of the boot process.

       systemd-pcrmachine.service is a system service that measures the
       machine ID (see machine-id(5)) into PCR 15.

       systemd-pcrfs-root.service and systemd-pcrfs@.service are
       services that measure file system identity information (i.e.
       mount point, file system type, label and UUID, partition label
       and UUID) into PCR 15.  systemd-pcrfs-root.service does so for
       the root file system, systemd-pcrfs@.service is a template unit
       that measures the file system indicated by its instance
       identifier instead.

       These services require systemd-stub(7) to be used in a unified
       kernel image (UKI). They execute no operation when the stub has
       not been used to invoke the kernel. The stub will measure the
       invoked kernel and associated vendor resources into PCR 11 before
       handing control to it; once userspace is invoked these services
       then will extend TPM2 PCR 11 with certain literal strings
       indicating phases of the boot process. During a regular boot
       process PCR 11 is extended with the following strings:

        1. "enter-initrd" — early when the initrd initializes, before
           activating system extension images for the initrd. It acts as
           a barrier between the time where the kernel initializes and
           where the initrd starts operating and enables system
           extension images, i.e. code shipped outside of the UKI. (This
           extension happens when the systemd-pcrphase-initrd.service(8)
           service is started.)

        2. "leave-initrd" — when the initrd is about to transition into
           the host file system. It acts as barrier between initrd code
           and host OS code. (This extension happens when the
           systemd-pcrphase-initrd.service service is stopped.)

        3. "sysinit" — when basic system initialization is complete
           (which includes local file systems having been mounted), and
           the system begins starting regular system services. (This
           extension happens when the
           systemd-pcrphase-sysinit.service(8) service is started.)

        4. "ready" — during later boot-up, after remote file systems
           have been activated (i.e. after remote-fs.target), but before
           users are permitted to log in (i.e. before
           systemd-user-sessions.service). It acts as barrier between
           the time where unprivileged regular users are still
           prohibited to log in and where they are allowed to log in.
           (This extension happens when the systemd-pcrphase.service
           service is started.)

        5. "shutdown" — when the system shutdown begins. It acts as
           barrier between the time the system is fully up and running
           and where it is about to shut down. (This extension happens
           when the systemd-pcrphase.service service is stopped.)

        6. "final" — at the end of system shutdown. It acts as barrier
           between the time the service manager still runs and when it
           transitions into the final shutdown phase where service
           management is not available anymore. (This extension happens
           when the systemd-pcrphase-sysinit.service(8) service is
           stopped.)

       During a regular system lifecycle, PCR 11 is extended with the
       strings "enter-initrd", "leave-initrd", "sysinit", "ready",
       "shutdown", and "final".

       Specific phases of the boot process may be referenced via the
       series of strings measured, separated by colons (the "phase
       path"). For example, the phase path for the regular system
       runtime is "enter-initrd:leave-initrd:sysinit:ready", while the
       one for the initrd is just "enter-initrd". The phase path for the
       boot phase before the initrd is an empty string; because that's
       hard to pass around a single colon (":") may be used instead.
       Note that the aforementioned six strings are just the default
       strings and individual systems might measure other strings at
       other times, and thus implement different and more fine-grained
       boot phases to bind policy to.

       By binding policy of TPM2 objects to a specific phase path it is
       possible to restrict access to them to specific phases of the
       boot process, for example making it impossible to access the root
       file system's encryption key after the system transitioned from
       the initrd into the host root file system.

       Use systemd-measure(1) to pre-calculate expected PCR 11 values
       for specific boot phases (via the --phase= switch).

       systemd-pcrfs-root.service and systemd-pcrfs@.service are
       automatically pulled into the initial transaction by
       systemd-gpt-auto-generator(8) for the root and /var/ file
       systems.  systemd-fstab-generator(8) will do this for all mounts
       with the x-systemd.pcrfs mount option in /etc/fstab.

OPTIONS         top

       The /usr/lib/systemd/system-pcrextend executable may also be
       invoked from the command line, where it expects the word to
       extend into PCR 11, as well as the following switches:

       --bank=
           Takes the PCR banks to extend the specified word into. If not
           specified the tool automatically determines all enabled PCR
           banks and measures the word into all of them.

           Added in version 252.

       --pcr=
           Takes the index of the PCR to extend. If --machine-id or
           --file-system= are specified defaults to 15, otherwise
           defaults to 11.

           Added in version 255.

       --tpm2-device=PATH
           Controls which TPM2 device to use. Expects a device node path
           referring to the TPM2 chip (e.g.  /dev/tpmrm0). Alternatively
           the special value "auto" may be specified, in order to
           automatically determine the device node of a suitable TPM2
           device (of which there must be exactly one). The special
           value "list" may be used to enumerate all suitable TPM2
           devices currently discovered.

           Added in version 252.

       --graceful
           If no TPM2 firmware, kernel subsystem, kernel driver or
           device support is found, exit with exit status 0 (i.e.
           indicate success). If this is not specified any attempt to
           measure without a TPM2 device will cause the invocation to
           fail.

           Added in version 253.

       --machine-id
           Instead of measuring a word specified on the command line
           into PCR 11, measure the host's machine ID into PCR 15.

           Added in version 253.

       --file-system=
           Instead of measuring a word specified on the command line
           into PCR 11, measure identity information of the specified
           file system into PCR 15. The parameter must be the path to
           the established mount point of the file system to measure.

           Added in version 253.

       -h, --help
           Print a short help text and exit.

       --version
           Print a short version string and exit.

FILES         top

       /run/log/systemd/tpm2-measure.log
           Measurements are logged into an event log file maintained in
           /run/log/systemd/tpm2-measure.log, which contains a
           JSON-SEQ[1] series of objects that follow the general
           structure of the TCG Canonical Event Log Format (CEL-JSON)[2]
           event objects (but lack the "recnum" field).

           A LOCK_EX BSD file lock (flock(2)) on the log file is
           acquired while the measurement is made and the file is
           updated. Thus, applications that intend to acquire a
           consistent quote from the TPM with the associated snapshot of
           the event log should acquire a LOCK_SH lock while doing so.

           Added in version 252.

SEE ALSO         top

       systemd(1), systemd-stub(7), systemd-measure(1),
       systemd-gpt-auto-generator(8), systemd-fstab-generator(8), TPM2
       PCR Measurements Made by systemd[3]

NOTES         top

        1. JSON-SEQ
           https://www.rfc-editor.org/rfc/rfc7464.html

        2. TCG Canonical Event Log Format (CEL-JSON)
           https://trustedcomputinggroup.org/resource/canonical-event-log-format/

        3. TPM2 PCR Measurements Made by systemd
           https://systemd.io/TPM2_PCR_MEASUREMENTS

COLOPHON         top

       This page is part of the systemd (systemd system and service
       manager) project.  Information about the project can be found at
       ⟨http://www.freedesktop.org/wiki/Software/systemd⟩.  If you have
       a bug report for this manual page, see
       ⟨http://www.freedesktop.org/wiki/Software/systemd/#bugreports⟩.
       This page was obtained from the project's upstream Git repository
       ⟨https://github.com/systemd/systemd.git⟩ on 2024-06-14.  (At that
       time, the date of the most recent commit that was found in the
       repository was 2024-06-13.)  If you discover any rendering
       problems in this HTML version of the page, or you believe there
       is a better or more up-to-date source for the page, or you have
       corrections or improvements to the information in this COLOPHON
       (which is not part of the original manual page), send a mail to
       man-pages@man7.org

systemd 257~devel                                 SYSTEMD-....SERVICE(8)

Pages that refer to this page: systemd-cryptenroll(1)systemd-measure(1)ukify(1)systemd.mount(5)systemd.pcrlock(5)systemd.directives(7)systemd.index(7)systemd-gpt-auto-generator(8)systemd-pcrlock(8)systemd-pcrphase.service(8)