diff options
Diffstat (limited to 'src/vendorcode/google')
-rw-r--r-- | src/vendorcode/google/chromeos/chromeos.h | 2 | ||||
-rw-r--r-- | src/vendorcode/google/chromeos/vbnv.c | 22 |
2 files changed, 19 insertions, 5 deletions
diff --git a/src/vendorcode/google/chromeos/chromeos.h b/src/vendorcode/google/chromeos/chromeos.h index ec0f3b733a..37630a69bc 100644 --- a/src/vendorcode/google/chromeos/chromeos.h +++ b/src/vendorcode/google/chromeos/chromeos.h @@ -29,6 +29,8 @@ void save_chromeos_gpios(void); /* functions implemented in vbnv.c: */ int get_recovery_mode_from_vbnv(void); +int vboot_wants_oprom(void); +extern int oprom_is_loaded; /* functions implemented in chromeos.c: */ int developer_mode_enabled(void); diff --git a/src/vendorcode/google/chromeos/vbnv.c b/src/vendorcode/google/chromeos/vbnv.c index 2129461fc1..3f333f7211 100644 --- a/src/vendorcode/google/chromeos/vbnv.c +++ b/src/vendorcode/google/chromeos/vbnv.c @@ -38,6 +38,8 @@ #define BOOT_OFFSET 1 #define BOOT_DEBUG_RESET_MODE 0x80 +#define BOOT_DISABLE_DEV_REQUEST 0x40 +#define BOOT_OPROM_NEEDED 0x20 #define BOOT_TRY_B_COUNT_MASK 0x0F #define RECOVERY_OFFSET 2 @@ -45,11 +47,7 @@ #define DEV_FLAGS_OFFSET 4 #define DEV_BOOT_USB_MASK 0x01 - -#define FIRMWARE_FLAGS_OFFSET 5 -#define FIRMWARE_TEST_ERR_FUNC_MASK 0x38 -#define FIRMWARE_TEST_ERR_FUNC_SHIFT 3 -#define FIRMWARE_TEST_ERR_NUM_MASK 0x07 +#define DEV_BOOT_SIGNED_ONLY_MASK 0x02 #define KERNEL_FIELD_OFFSET 11 #define CRC_OFFSET 15 @@ -107,3 +105,17 @@ int get_recovery_mode_from_vbnv(void) vbnv_setup(); return vbnv[RECOVERY_OFFSET]; } + +int vboot_wants_oprom(void) +{ + if (!vbnv_initialized) + vbnv_setup(); + + /* FIXME(crosbug.com/p/8789). The following commented-out line does the + * right thing, assuming that vboot has requested the option ROM and + * rebooted if it finds that it's needed but not loaded. At the moment, + * it doesn't yet do that, so we must always say we want it. */ + + /* return (vbnv[BOOT_OFFSET] & BOOT_OPROM_NEEDED) ? 1 : 0; */ + return 1; +} |