coreboot-kgpe-d16/src/vboot
Aaron Durbin eeb77379e0 vboot/tpm2: enable nvmem commits on cr50 when writing firmware secdata
cr50 by default delays nvmem commits internally from the point of
reset to accumulate change state. However, the factory process can
put a board into dev mode through the recovery screen. This state
is stored in the TPM's nvmem space. When the factory process is
complete a disable_dev_request and battery_cutoff_request is performed.
This leads to disabling the dev mode in TPM, but the battery is
subsequently cut off so the nvmem contents never stick. Therefore,
whenever antirollback_write_space_firmware() is called we know there
was a change in secdata so request cr50 to immediately enable nvmem
commits going forward. This allows state changes to happen immediately.

The fallout from this is that when secdata is changed that current
boot will take longer because every transaction that writes to TPM
nvmem space will perform a write synchronously. All subsequent boots
do not have that effect.

It should also be noted that this approach to the implementation is
a pretty severe layering violation. However, the current TPM APIs
don't lend themselves well to extending commands or re-using code
outside of the current routines which inherently assume all knowledge
of every command (in conflict with vendor commands since those are
vendor-specific by definition).

BUG=b:35775104
BRANCH=reef
TEST=Confirmed disablement of dev mode sticks in the presence of:
crossystem disable_dev_request=1; crossystem
battery_cutoff_request=1; reboot;

Change-Id: I3395db9cbdfea45da1f5cb994c6570978593b944
Signed-off-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-on: https://review.coreboot.org/18681
Reviewed-by: Duncan Laurie <dlaurie@chromium.org>
Tested-by: build bot (Jenkins)
2017-03-09 19:15:03 +01:00
..
bootmode.c lib/cbmem: allow anyone to use cbmem_possibly_online() 2016-12-15 23:11:13 +01:00
common.c src/vboot: Capitalize RAM and CPU 2016-07-31 19:31:41 +02:00
Kconfig vboot: Add support for recovery hash space in TPM 2016-11-10 18:10:42 +01:00
Makefile.inc build system: mark sub-make invocations as parallelizable 2017-01-31 18:51:55 +01:00
misc.h
secdata_mock.c vboot: Add mock functions for recovery space read/write 2017-01-30 17:45:36 +01:00
secdata_tpm.c vboot/tpm2: enable nvmem commits on cr50 when writing firmware secdata 2017-03-09 19:15:03 +01:00
symbols.h
vbnv.c vboot: Clear battery cutoff flags when vbnv_cmos loads backup VBNV. 2017-01-03 22:14:42 +01:00
vbnv.h vboot: Clear battery cutoff flags when vbnv_cmos loads backup VBNV. 2017-01-03 22:14:42 +01:00
vbnv_cmos.c vboot: Clear battery cutoff flags when vbnv_cmos loads backup VBNV. 2017-01-03 22:14:42 +01:00
vbnv_ec.c
vbnv_flash.c vboot/vbnv_flash: Binary search to find last used entry 2016-09-20 21:50:27 +02:00
vbnv_layout.h vboot: Clear battery cutoff flags when vbnv_cmos loads backup VBNV. 2017-01-03 22:14:42 +01:00
vboot_common.c vboot/vboot_common: actually provide a writable region_device 2016-08-24 00:09:16 +02:00
vboot_common.h vboot: Add support for recovery mode with forced memory retraining 2016-11-10 00:44:02 +01:00
vboot_handoff.c commonlib/include: remove NEED_VB20_INTERNALS 2016-11-19 16:57:27 +01:00
vboot_loader.c vboot: consolidate google_chromeec_early_init() calls 2016-08-25 22:50:17 +02:00
vboot_logic.c vboot: vb2ex_printf() ignores null function name 2017-01-24 09:34:58 +01:00
verstage.c