On Mon, Oct 21, 2024 at 04:07:11PM +0800, Gary Lin wrote:
> Update the user manual to address TPM2 key protector including the two
> related commands, tpm2_key_protector_init and tpm2_key_protector_clear,
> and the user-space utility: grub-protect.
>
> Signed-off-by: Gary Lin <g...@suse.com>
> ---
>  docs/grub.texi | 514 +++++++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 514 insertions(+)
>
> diff --git a/docs/grub.texi b/docs/grub.texi
> index fdd49d62e..5fccc1145 100644
> --- a/docs/grub.texi
> +++ b/docs/grub.texi
> @@ -6443,6 +6443,8 @@ you forget a command, you can run the command 
> @command{help}
>  * smbios::                      Retrieve SMBIOS information
>  * source::                      Read a configuration file in same context
>  * test::                        Check file types and compare values
> +* tpm2_key_protector_init::     Initialize the TPM2 key protector
> +* tpm2_key_protector_clear::    Clear the TPM2 key protector
>  * true::                        Do nothing, successfully
>  * trust::                       Add public key to list of trusted keys
>  * unset::                       Unset an environment variable
> @@ -8001,6 +8003,56 @@ either @var{expression1} or @var{expression2} is true
>  @end table
>  @end deffn
>
> +@node tpm2_key_protector_init
> +@subsection tpm2_key_protector_init
> +
> +@deffn Command tpm2_key_protector_init [@option{-m} mode] | [@option{-p} 
> pcrlist] | [@option{-b} pcrbank] | [ [@option{-T} tpm2key_file] | 
> [@option{-k} keyfile] ] | [@option{-s} handle] | [@option{-a} srk_type] | 
> [@option{-n} nv_index]
> +Initialize the TPM2 key protector to unseal the key for the 
> @command{cryptomount}
> +(@pxref{cryptomount}) command. There are two supported modes,
> +SRK(@kbd{srk}) and NV index(@kbd{nv}), to be specified by the option
> +@option{-m}. The default mode is SRK. The main difference between SRK mode
> +and NV index mode is the storage of the sealed key. For SRK mode, the sealed
> +key is stored in a file while NV index mode stores the sealed key in the
> +non-volatile memory inside TPM with a given NV index.
> +
> +The @option{-p} and @option{-b} options are used to supply the PCR list and
> +bank that the key is sealed with. The PCR list is a comma-separated list, 
> e.g.,
> +'0,2,4,7,9', to represent the involved PCRs, and the default is '7'. The PCR
> +bank is chosen by selecting a hash algorithm. The current supported PCR banks
> +are SHA1, SHA256, SHA384, and SHA512, and the default is SHA256.
> +
> +There are some options only available for the specific mode. The SRK-specific
> +options are @option{-T}, @option{-k}, @option{-a}, and @option{-s}. On the
> +other hand, the NV index-specific option is @option{-n}.
> +
> +The key file for SRK mode can be supplied with either @option{-T} or
> +@option{-k}. The @option{-T} option is for the path to the key file in
> +TPM 2.0 Key File. Since the parameters for the TPM commands are written in

s/TPM 2.0 Key File/TPM 2.0 Key File format/?

> +the file, there is no need to set the PCR list(@option{-p}) and
> +bank(@option{-b}) when using the @option{-T} option. The @option{-k} option
> +is for the key file in the raw format, and the @option{-p} and @option{-b}
> +options are necessary for the non-default PCR list or bank.
> +
> +Besides the key file, there are two options, @option{-a} and @option{-s}, to
> +tweak the TPM Storage Root Key (SRK). The SRK can be either created at
> +runtime or stored in the non-volatile memory. When creating SRK at runtime,
> +GRUB provides the SRK template to TPM to create the key. There are two SRK
> +templates, ECC and RSA, for the @option{-a} option and the default is ECC.

s/templates, ECC and RSA, for the @option{-a} option/templates for the 
@option{-a} option, ECC and RSA,/?

> +If the SRK is stored in a specific handle, e.g. @code{0x81000001}, the
> +@option{-s} option can be used to set the handle to notify GRUB to load
> +the SRK from the given handle.
> +
> +The only nvindex-specific option is the option @option{-n} which is used to

s/option @option{-n}/@option{-n} option/

> +set the NV index containing the sealed key, so that GRUB can load the sealed

s/, so that/. Then/

> +key and unseal it with the given PCR list and bank.
> +@end deffn
> +
> +@node tpm2_key_protector_clear
> +@subsection tpm2_key_protector_clear
> +
> +@deffn Command tpm2_key_protector_clear
> +Clear the TPM2 key protector if previously initialized.
> +@end deffn
>
>  @node true
>  @subsection true
> @@ -8529,6 +8581,7 @@ environment variables and commands are listed in the 
> same order.
>  * Secure Boot Advanced Targeting::   Embedded information for generation 
> number based revocation
>  * Measured Boot::                    Measuring boot components
>  * Lockdown::                         Lockdown when booting on a secure setup
> +* TPM2 key protector::               Managing disk key with TPM2 key 
> protector
>  @end menu
>
>  @node Authentication and authorisation
> @@ -8772,6 +8825,299 @@ be restricted and some operations/commands cannot be 
> executed.
>  The @samp{lockdown} variable is set to @samp{y} when the GRUB is locked down.
>  Otherwise it does not exit.
>
> +@node TPM2 key protector
> +@section TPM2 key protector in GRUB
> +
> +TPM2 key protector extends measured boot to unlock the encrypted partition
> +without user intervention. It uses the TPM Storage Root Key (SRK) to seal
> +the disk key with a given set of PCR values. If the system state matches,
> +i.e. PCR values match the sealed PCR set, TPM2 key protector unseals the
> +disk key for @command{cryptomount} (@pxref{cryptomount}) to unlock the
> +encrypted partition. (In case the unsealed key fails to unlock the
> +partition, @command{cryptomount} falls back to the passphrase prompt.)

Please drop parenthesis. They are not needed here.

> +There are two supported modes to store the sealed key, SRK and NV index,

s/,$/./

> +and the details will be addressed in later sections.

s/and the/The/

> +TPM2 key protector is currently only supported on EFI and EMU platforms.
> +
> +@subsection TPM PCR usage
> +
> +Since TPM2 key protector relies on PCRs to check the system state, it is
> +important to decide which PCRs to seal the key with. The following table
> +shows the users of PCRs and the measured objects on EFI platforms.

s/shows the users/list uses/

> +@multitable @columnfractions 0.1 0.2 0.7
> +@headitem PCR @tab Used by @tab Measured Objects
> +@item 0
> +@tab Firmware
> +@tab Core system firmware executable code
> +@item 1
> +@tab Firmware
> +@tab Core system firmware data/host platform configuration; typically
> +contains serial and model numbers
> +@item 2
> +@tab Firmware
> +@tab Extended or pluggable executable code; includes option ROMs on
> +pluggable hardware
> +@item 3
> +@tab Firmware
> +@tab Extended or pluggable firmware data; includes information about
> +pluggable hardware
> +@item 4
> +@tab Firmware
> +@tab Boot loader and additional drivers; binaries and extensions loaded
> +by the boot loader
> +@item 5
> +@tab Firmware
> +@tab GPT/Partition table
> +@item 7
> +@tab Firmware
> +@tab SecureBoot state
> +@item 8
> +@tab GRUB
> +@tab Commands and kernel command line
> +@item 9
> +@tab GRUB
> +@tab All files read (including kernel image)
> +@item 9
> +@tab Linux Kernel
> +@tab All passed initrds (when the new LOAD_FILE2 initrd protocol is used)
> +@item 10
> +@tab Linux Kernel
> +@tab Protection of the IMA measurement log
> +@item 14
> +@tab shim
> +@tab “MOK” certificates and hashes
> +@end multitable
> +
> +PCR 0, 2, 4, and 7 can be used to check the integrity of the firmware code
> +and bootloaders. PCR 8 and 9 are useful to check the file and data processed
> +by GRUB. PCRs 10, 11, 12, 13, and 15 are controlled by the operating system,
> +so those PCRs are usually still in the initial state when GRUB is running.
> +
> +In general, it is nice to include PCR 0, 2, 4, and 7 to ensure the integrity
> +of the firmware and bootloaders. For PCR 8 and 9, a sophisticated tool is
> +required to examine the GRUB configuration files and the files to be loaded
> +to calculate the correct PCR values.
> +
> +Please note that PCRs are sensitive to any change, so an update of a 
> component
> +could invalidate the sealed key, due to the so-called PCR brittleness. For 
> the
> +bootloader update, PCR 4 may be affected. This can be mitigated by extracting
> +the events from the TPM event log and predict the value with the updated
> +bootloader binary. On the other hand, it is difficult to predict PCR 0~7 
> after
> +a firmware update since the content of the code and the order of drivers may
> +not follow the TPM event log from the previous firmware version, so it is
> +necessary to reboot the system to update the measurement results of PCR 0~7
> +and seal or sign the sealed key again.
> +
> +Reference: 
> @url{https://uapi-group.org/specifications/specs/linux_tpm_pcr_registry/, 
> Linux TPM PCR Registry}
> +
> +@subsection Setting up the extra disk key
> +
> +Instead of using the existing password, it is recommended to seal a new
> +random disk key and use the existing password for recovery.
> +
> +Here are the sample commands to create a 128 random bytes key file and
> +enroll the key into the target partition (sda2).
> +
> +@example
> +# @kbd{dd if=/dev/urandom of=luks.key bs=1 count=128}
> +# @kbd{cryptsetup luksAddKey /dev/sda2 luks.key --pbkdf=pbkdf2 --hash=sha512}
> +@end example
> +
> +@subsection SRK mode
> +
> +To unlock the partition with SRK mode, assume that the sealed key is in
> +@file{(hd0,gpt1)/efi/grub/sealed.tpm}, the following GRUB commands
> +unseal the disk key with SRK mode and supply it to @command{cryptomount}.
> +
> +@example
> +@kbd{tpm2_key_protector_init --keyfile=(hd0,gpt1)/efi/grub/sealed.tpm}
> +@kbd{cryptomount -u <UUID> -P tpm2}
> +@end example
> +
> +There are two programs to create the sealed key for SRK mode: 
> @command{grub-protect}
> +and @command{pcr-oracle} (@url{https://github.com/okirch/pcr-oracle}).
> +
> +The following sample command uses @command{grub-protect} to seal the random
> +key, @file{luks.key}, with PCR 0, 2, 4 and 7 in TPM 2.0 Key File.
> +
> +@example
> +@group
> +# @kbd{grub-protect --action=add \
> +               --protector=tpm2 \
> +               --tpm2-pcrs=0,2,4,7 \
> +               --tpm2key \
> +               --tpm2-keyfile=luks.key \
> +               --tpm2-outfile=/boot/efi/efi/grub/sealed.tpm}
> +@end group
> +@end example
> +
> +@command{grub-protect} only seals the key with the current PCR values.
> +Therefore, when a boot component, such as shim or GRUB, is updated, it is
> +neccessary to reboot the system to update the measurement results and seal
> +the key again. That means the random disk key has to be stored in cleartext
> +for the next key sealing. Besides this, the measurement result of some PCRs
> +may differ between boot time and OS runtime. For example, PCR 9 measures the
> +files loaded by GRUB including the Linux kernel and initrd. To unlock the 
> disk
> +containing the kernel and initrd, the key has to be sealed with PCR 9 value
> +before loading the kernel and initrd. However, PCR 9 changes after GRUB
> +loading the kernel and initrd, so PCR 9 at OS runtime cannot be used directly
> +for key sealing.
> +
> +To solve these problems, @command{pcr-oracle} takes a different approach. It
> +reads the TPM eventlog and predicts the PCR values. Besides,
> +@command{pcr-oracle} also supports ``authorized policy'' which allows the
> +PCR policy to be updated with a valid signature, so that the user only seals
> +the random disk key once. If at some later time the PCR values change due to
> +an update of the system firmware, bootloader, or config file, the user just
> +needs to update the signature of PCR policy.
> +
> +To seal the key with the authorized policy, the first thing is to generate
> +the RSA policy key, @file{policy-key.pem}, and the authorized policy file,
> +@file{authorized.policy}. In this example, PCR 0, 2, 4, 7 and 9 are chosen
> +for key sealing.
> +
> +@example
> +@group
> +# @kbd{pcr-oracle --rsa-generate-key \
> +             --private-key policy-key.pem \
> +             --auth authorized.policy \
> +             create-authorized-policy 0,2,4,7,9}
> +@end group
> +@end example
> +
> +Then, we seal the random disk key, @file{luks.key}, with the authorized
> +policy file and save the sealed key in @file{sealed.key}.
> +
> +@example
> +@group
> +# @kbd{pcr-oracle --key-format tpm2.0 \
> +             --auth authorized.policy \
> +             --input luks.key \
> +             --output sealed.key \
> +             seal-secret}
> +@end group
> +@end example
> +
> +Since we now have the sealed key, we can remove the random disk key file
> +@file{lukes.key}.
> +
> +The last step is to sign the predicted PCR policy and save the final key
> +file, @file{sealed.tpm}.
> +
> +@example
> +@group
> +# @kbd{pcr-oracle --key-format tpm2.0 \
> +             --private-key policy-key.pem \
> +             --from eventlog \
> +             --stop-event "grub-file=grub.cfg" \
> +             --after \
> +             --input sealed.key \
> +             --output /boot/efi/efi/grub/sealed.tpm \
> +             sign 0,2,4,7,9}
> +@end group
> +@end example
> +
> +Here we also set a stop event for the prediction. With
> +@kbd{--stop-event grub-file=grub.cfg --after}, @command{pcr-oracle} stops
> +the calculation of PCR values right after GRUB loads @file{grub.cfg}.
> +
> +When shim or GRUB updates, it only requires to run the last 
> @command{pcr-oracle}
> +command to update the predicted PCR policy.
> +
> +@subsection NV index mode
> +
> +Instead of storing the sealed key in a file, NV index mode uses the TPM
> +non-volatile memory to store the sealed key.
> +
> +The following sample commands use tpm2-tools 
> (@url{https://github.com/tpm2-software/tpm2-tools})
> +commands to seal @file{luks.key} into the specific NV index: 
> @kbd{0x81000000}.
> +
> +First, we need to create the object file for the primary key, i.e. storage
> +root key (SRK) with the default key settings in GRUB: SHA256 hash algorithm
> +and ECC key algorithm.
> +
> +@example
> +# @kbd{tpm2_createprimary -C o -g sha256 -G ecc -c primary.ctx}
> +@end example
> +
> +The next commands collect the current values of PCR 0, 2, 4, and 7 and saves
> +them in @file{pcr.dat}.
> +
> +@example
> +# @kbd{tpm2_startauthsession -S session.dat}
> +# @kbd{tpm2_policypcr -S session.dat -l sha256:0,2,4,7 -f pcrs.dat -L 
> policy.dat}
> +# @kbd{tpm2_flushcontext session.dat}
> +@end example
> +
> +The last commands seal @file{luks.key} with the primary key and stores the
> +result in @kbd{0x81000000}.
> +
> +@example
> +# @kbd{cat luks.key | tpm2_create -C primary.ctx -u key.pub -r key.priv -L 
> policy.dat -i-}
> +# @kbd{tpm2_load -C primary.ctx -u key.pub -r key.priv -n sealing.name -c 
> sealing.ctx}
> +# @kbd{tpm2_evictcontrol -C o -c sealing.ctx 0x81000000}
> +@end example
> +
> +To unseal the key, we have to specify the mode, @kbd{nv}, the NV index,
> +@kbd{0x81000000}, and the PCRs, @kbd{0,2,4,7} for 
> @command{tpm2_key_protector_init}
> +command.
> +
> +@example
> +@kbd{tpm2_key_protector_init --mode=nv --nvindex=0x81000000 --pcrs=0,2,4,7}
> +@kbd{cryptomount -u <UUID> --protector tpm2}
> +@end example

I think you should precisely describe which commands are executed from
running OS and which ones from the GRUB.

> +@subsection Setting up software TPM for EMU platform
> +
> +In order to test TPM2 key protector and TPM2 Software Stack (TSS2), it is
> +handy to set up a software TPM (swtpm) instance and run the commands on the
> +EMU platform.
> +
> +Here are the commands to start a swtpm instance which provides a character
> +device interface. To store the TPM states, the directory, @file{swtpm-state},
> +is created before the @command{swtpm} command.  All the messages are stored
> +in @file{swtpm.log} including the name of the character device.
> +
> +@example
> +# @kbd{mkdir swtpm-state}
> +@group
> +# @kbd{swtpm chardev --vtpm-proxy --tpmstate dir=swtpm-state \
> +        --tpm2 --ctrl type=unixio,path="swtpm-state/ctrl" \
> +        --flags startup-clear --daemon > swtpm.log}
> +@end group
> +@end example
> +
> +Then, we extract the name of the character device from @file{swtpm.log} and
> +save it to the variable, @samp{tpm2dev}.
> +
> +@example
> +# @kbd{tpm2dev=$(grep "New TPM device" swtpm.log | cut -d' ' -f 4)}
> +@end example
> +
> +Now we can start @kbd{grub-emu} with @kbd{--tpm-device $tpm2dev} to interact
> +with the swtpm instance.
> +
> +@example
> +# @kbd{grub-emu --tpm-device $tpm2dev}
> +@end example
> +
> +On the host, the tpm2-tools commands can interact with the swtpm instance by
> +setting @samp{TPM2TOOLS_TCTI}.
> +
> +@example
> +# @kbd{export TPM2TOOLS_TCTI="device:$tpm2dev"}
> +@end example
> +
> +When the test is done, use @kbd{swtpm_ioctl} to send the shutdown
> +command through the swtpm control channel.
> +
> +@example
> +# @kbd{swtpm_ioctl -s --unix swtpm-state/ctrl}
> +@end example
> +
>  @node Platform limitations
>  @chapter Platform limitations
>
> @@ -9212,6 +9558,7 @@ bootability on other machines.
>  * Invoking grub-mkrescue::      Make a GRUB rescue image
>  * Invoking grub-mount::         Mount a file system using GRUB
>  * Invoking grub-probe::         Probe device information for GRUB
> +* Invoking grub-protect::       Protect a disk key with a key protector
>  * Invoking grub-script-check::  Check GRUB script file for syntax errors
>  @end menu
>
> @@ -9594,6 +9941,173 @@ Print verbose messages.
>  @end table
>
>
> +@node Invoking grub-protect
> +@section Invoking grub-protect
> +
> +The program @command{grub-protect} protects a disk encryption key with
> +a specified key protector.
> +
> +@table @option
> +@item --help
> +Print a summary of the command-line options and exit.
> +
> +@item --version
> +Print the version number of GRUB and exit.
> +
> +@item -a

s/-a/-a add|remove/

> +@itemx --action=add|remove
> +Add or remove a key protector to or from a key.
> +
> +@item -p
> +@itemx --protector=@var{protector}
> +Set the key protector. Currently, @samp{tpm2} is the only supported key
> +protector.
> +
> +@item --tpm2-asymmetric=@var{type}
> +Choose the the type of SRK. The valid options are @samp{RSA} (@samp{RSA2048})
> +and @samp{ECC} (@samp{ECC_NIST_P256}).(default: @samp{ECC})
> +
> +@item --tpm2-bank=@var{alg}
> +Choose bank of PCRs used to authorize key release: @samp{SHA1}, 
> @samp{SHA256},
> +@samp{SHA384}, or @samp{SHA512}. (default: @samp{SHA256})
> +
> +@item --tpm2-device=@var{device}
> +Set the path to the TPM2 device. (default: @samp{/dev/tpm0})
> +
> +@item --tpm2-evict
> +Evict a previously persisted SRK from the TPM, if any.
> +
> +@item --tpm2-keyfile=@var{file}
> +Set the path to a file that contains the cleartext key to protect.
> +
> +@item --tpm2-outfile=@var{file}
> +Set the path to the file that will contain the key after sealing
> +(must be accessible to GRUB during boot).
> +
> +@item --tpm2-pcrs=@var{pcrs}
> +Set a comma-separated list of PCRs used to authorize key release e.g., 
> @samp{7,11}.
> +Please be aware that PCR 0~7 are used by the firmware and the measurement 
> result
> +may change after a firmware update (for baremetal systems) or a package
> +(OVMF/SeaBIOS/SLOF) update in the VM host. This may lead to the failure of 
> key
> +unsealing. (default: @samp{7})
> +
> +@item --tpm2-srk=@var{handle}
> +Set the SRK handle, e.g. @samp{0x81000000}, if the SRK is to be made 
> persistent.
> +
> +@item --tpm2key
> +Use TPM 2.0 Key File instead of the raw format.
> +
> +@end table
> +
> +Before sealing the key, please check the TPM PCR usage
> +(@pxref{TPM2 key protector, TPM PCR usage}) to choose a proper set of PCRs.
> +
> +Assume that there is a key file, @file{luks.key}, to be sealed with PCR 0, 2,
> +4, and 7, and here is the @command{grub-protect} command to create the sealed
> +key file:
> +
> +@example
> +@group
> +# @kbd{grub-protect --action=add \
> +               --protector=tpm2 \
> +               --tpm2-pcrs=0,2,4,7 \
> +               --tpm2key \
> +               --tpm2-keyfile=luks.key \
> +               --tpm2-outfile=/boot/efi/efi/grub/sealed.tpm}
> +@end group
> +@end example
> +
> +Then, GRUB can unlock the target partition with the following commands:
> +
> +@example
> +@kbd{tpm2_key_protector_init --keyfile=(hd0,gpt1)/efi/grub/sealed.tpm}
> +@kbd{cryptomount -u <UUID> -P tpm2}
> +@end example

Which commands are executed where?

> +In most of cases, the user only needs to create the key with the `add' 
> action.
> +If auto-unlocking is unwanted, just remove the file and restore the GRUB
> +commands.

What do you mean by "restore the GRUB commands"?

> +The only case for the `remove' action is when the SRK is made persistent.
> +
> +There are two supported SRKs in @command{grub-protect}: @samp{RSA} and 
> @samp{ECC}.
> +Due to slower key generation, some users of the @samp{RSA} SRK would prefer
> +making it persistent so that the TPM can skip the SRK generation when GRUB 
> tries
> +to unseal the key.
> +
> +The available persistent handles can be checked with @command{tpm2_getcap}.
> +
> +@example
> +@group
> +# @kbd{tpm2_getcap properties-variable}
> +...
> +TPM2_PT_HR_PERSISTENT: 0x0
> +TPM2_PT_HR_PERSISTENT_AVAIL: 0x41
> +...
> +@end group
> +@end example
> +
> +In this system, there is no persistent handle. A TPM handle is an unsigned
> +32-bit integer, and the persistent handles starts with @samp{0x81}. Here
> +we choose the well-known persistent handle: @samp{0x81000000}.
> +
> +@example
> +@group
> +# @kbd{grub-protect --action=add \
> +               --protector=tpm2 \
> +               --tpm2-pcrs=0,2,4,7 \
> +               --tpm2-asymmetric=RSA \
> +               --tpm2-srk=0x81000000 \
> +               --tpm2key \
> +               --tpm2-keyfile=luks.key \
> +               --tpm2-outfile=/boot/efi/efi/grub/sealed.tpm}
> +@end group
> +@end example
> +
> +The additional @kbd{--tpm2-asymmetric=RSA} and @kbd{--tpm2-srk=0x81000000}
> +options are used to make the key sealed with the RSA SRK and store the SRK
> +in @samp{0x81000000}.
> +
> +For the @command{tpm2_key_protector_init} command, the additional @kbd{-s 
> 0x81000000}
> +informs the TPM2 key protector to fetch the SRK from @samp{0x81000000}.
> +
> +@example
> +@kbd{tpm2_key_protector_init -s 0x81000000 
> --keyfile=(hd0,gpt1)/efi/grub/sealed.tpm}
> +@kbd{cryptomount -u <UUID> -P tpm2}
> +@end example
> +
> +After making the SRK handle persistent, we can check the status of the
> +persistent handles with @command{tpm2_getcap}.
> +
> +@example
> +@group
> +# @kbd{tpm2_getcap properties-variable}
> +...
> +TPM2_PT_HR_PERSISTENT: 0x1
> +TPM2_PT_HR_PERSISTENT_AVAIL: 0x40
> +...
> +# @kbd{tpm2_getcap handles-persistent}
> +- 0x81000000
> +@end group
> +@end example
> +
> +In case the user doesn't want to use the TPM2 key protector anymore, besides
> +removing the sealed key file, here is the command to remove the persistent

Hmmm... The "persistent" what?

> +The sealed key can be remove once the user does not want to use the TPM2 key

s/remove/removed/

> +protector anymore. Here is the command to remove the persistent SRK handle
> +(@samp{0x81000000}) with @kbd{--tpm2-srk} and @kbd{--tpm2-evict}.
> +
> +@example
> +@group
> +# @kbd{grub-protect --action=remove \
> +               --protector=tpm2 \
> +               --tpm2-srk 0x81000000 \
> +               --tpm2-evict}
> +@end group
> +@end example

Daniel

_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to