Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(478)

Side by Side Diff: src/platform/vboot_reference/vboot_firmware/include/rollback_index.h

Issue 2344002: Add recovery mode protection to new NVRAM locking scheme. (Closed) Base URL: ssh://git@chromiumos-git/chromeos
Patch Set: typo in comment Created 10 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* Copyright (c) 2010 The Chromium OS Authors. All rights reserved. 1 /* Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
2 * Use of this source code is governed by a BSD-style license that can be 2 * Use of this source code is governed by a BSD-style license that can be
3 * found in the LICENSE file. 3 * found in the LICENSE file.
4 * 4 *
5 * Functions for querying, manipulating and locking rollback indices 5 * Functions for querying, manipulating and locking rollback indices
6 * stored in the TPM NVRAM. 6 * stored in the TPM NVRAM.
7 */ 7 */
8 8
9 #ifndef VBOOT_REFERENCE_ROLLBACK_INDEX_H_ 9 #ifndef VBOOT_REFERENCE_ROLLBACK_INDEX_H_
10 #define VBOOT_REFERENCE_ROLLBACK_INDEX_H_ 10 #define VBOOT_REFERENCE_ROLLBACK_INDEX_H_
11 11
12 #include <stdint.h> 12 #include <stdint.h>
13 13
14 extern uint16_t g_firmware_key_version; 14 extern uint16_t g_firmware_key_version;
15 extern uint16_t g_firmware_version; 15 extern uint16_t g_firmware_version;
16 extern uint16_t g_kernel_key_version; 16 extern uint16_t g_kernel_key_version;
17 extern uint16_t g_kernel_version; 17 extern uint16_t g_kernel_version;
18 18
19 /* Rollback version types. */ 19 /* Rollback version types. */
20 #define FIRMWARE_KEY_VERSION 0 20 #define FIRMWARE_VERSIONS 0
21 #define FIRMWARE_VERSION 1 21 #define KERNEL_VERSIONS 1
22 #define KERNEL_KEY_VERSION 2
23 #define KERNEL_VERSION 3
24 22
25 /* TPM NVRAM location indices. */ 23 /* TPM NVRAM location indices. */
26 #define FIRMWARE_KEY_VERSION_NV_INDEX 0x1001 24 #define FIRMWARE_VERSIONS_NV_INDEX 0x1001
27 #define FIRMWARE_VERSION_NV_INDEX 0x1002 25 #define KERNEL_VERSIONS_NV_INDEX 0x1002
28 #define KERNEL_KEY_VERSION_NV_INDEX 0x1003 26 #define TPM_IS_INITIALIZED_NV_INDEX 0x1003
29 #define KERNEL_VERSION_NV_INDEX 0x1004 27 #define KERNEL_VERSIONS_BACKUP_NV_INDEX 0x1004
28 #define KERNEL_BACKUP_IS_VALID_NV_INDEX 0x1005
29
30 30
31 void SetupTPM(void); 31 void SetupTPM(void);
32 uint16_t GetStoredVersion(int type); 32 void GetStoredVersions(int type, uint16_t* key_version, uint16_t* version);
33 int WriteStoredVersion(int type, uint16_t version); 33 int WriteStoredVersions(int type, uint16_t key_version, uint16_t version);
34 void LockFirmwareVersions(); 34 void LockFirmwareVersions();
35 void LockKernelVersionsByLockingPP(); 35 void LockKernelVersionsByLockingPP();
36 36
37 #endif /* VBOOT_REFERENCE_ROLLBACK_INDEX_H_ */ 37 #endif /* VBOOT_REFERENCE_ROLLBACK_INDEX_H_ */
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698