OLD | NEW |
1 /* Copyright (c) 2011 The Chromium OS Authors. All rights reserved. | 1 /* Copyright (c) 2011 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 | 5 |
6 /* Non-volatile storage routines. | 6 /* Non-volatile storage routines. |
7 */ | 7 */ |
8 | 8 |
9 #include "utility.h" | 9 #include "utility.h" |
10 #include "vboot_common.h" | 10 #include "vboot_common.h" |
11 #include "vboot_nvstorage.h" | 11 #include "vboot_nvstorage.h" |
12 | 12 |
13 /* Constants for NV storage. We use this rather than structs and | 13 /* Constants for NV storage. We use this rather than structs and |
14 * bitfields so the data format is consistent across platforms and | 14 * bitfields so the data format is consistent across platforms and |
15 * compilers. */ | 15 * compilers. */ |
16 #define HEADER_OFFSET 0 | 16 #define HEADER_OFFSET 0 |
17 #define HEADER_MASK 0xC0 | 17 #define HEADER_MASK 0xC0 |
18 #define HEADER_SIGNATURE 0x40 | 18 #define HEADER_SIGNATURE 0x40 |
19 #define HEADER_FIRMWARE_SETTINGS_RESET 0x20 | 19 #define HEADER_FIRMWARE_SETTINGS_RESET 0x20 |
20 #define HEADER_KERNEL_SETTINGS_RESET 0x10 | 20 #define HEADER_KERNEL_SETTINGS_RESET 0x10 |
21 | 21 |
22 #define BOOT_OFFSET 1 | 22 #define BOOT_OFFSET 1 |
23 #define BOOT_DEBUG_RESET_MODE 0x80 | 23 #define BOOT_DEBUG_RESET_MODE 0x80 |
24 #define BOOT_TRY_B_COUNT 0x0F | 24 #define BOOT_TRY_B_COUNT 0x0F |
25 | 25 |
26 #define RECOVERY_OFFSET 2 | 26 #define RECOVERY_OFFSET 2 |
27 #define LOCALIZATION_OFFSET 3 | 27 #define LOCALIZATION_OFFSET 3 |
28 | 28 |
29 #define FIRMWARE_FLAGS_OFFSET 5 | 29 #define FIRMWARE_FLAGS_OFFSET 5 |
30 #define FIRMWARE_FW_USED_TRY_B 0x80 | 30 #define FIRMWARE_TRIED_FIRMWARE_B 0x80 |
31 #define FIRMWARE_FW_VERIFIED_KERNEL_KEY 0x40 | 31 #define FIRMWARE_FW_VERIFIED_KERNEL_KEY 0x40 |
32 | 32 |
33 #define KERNEL_FIELD_OFFSET 11 | 33 #define KERNEL_FIELD_OFFSET 11 |
34 #define CRC_OFFSET 15 | 34 #define CRC_OFFSET 15 |
35 | 35 |
36 | 36 |
37 /* Return CRC-8 of the data, using x^8 + x^2 + x + 1 polynomial. A | 37 /* Return CRC-8 of the data, using x^8 + x^2 + x + 1 polynomial. A |
38 * table-based algorithm would be faster, but for only 15 bytes isn't | 38 * table-based algorithm would be faster, but for only 15 bytes isn't |
39 * worth the code size. */ | 39 * worth the code size. */ |
40 static uint8_t Crc8(const uint8_t* data, int len) { | 40 static uint8_t Crc8(const uint8_t* data, int len) { |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
118 *dest = raw[LOCALIZATION_OFFSET]; | 118 *dest = raw[LOCALIZATION_OFFSET]; |
119 return 0; | 119 return 0; |
120 | 120 |
121 case VBNV_KERNEL_FIELD: | 121 case VBNV_KERNEL_FIELD: |
122 *dest = (raw[KERNEL_FIELD_OFFSET] | 122 *dest = (raw[KERNEL_FIELD_OFFSET] |
123 | (raw[KERNEL_FIELD_OFFSET + 1] << 8) | 123 | (raw[KERNEL_FIELD_OFFSET + 1] << 8) |
124 | (raw[KERNEL_FIELD_OFFSET + 2] << 16) | 124 | (raw[KERNEL_FIELD_OFFSET + 2] << 16) |
125 | (raw[KERNEL_FIELD_OFFSET + 3] << 24)); | 125 | (raw[KERNEL_FIELD_OFFSET + 3] << 24)); |
126 return 0; | 126 return 0; |
127 | 127 |
128 case VBNV_FW_USED_TRY_B: | 128 case VBNV_TRIED_FIRMWARE_B: |
129 *dest = (raw[FIRMWARE_FLAGS_OFFSET] & FIRMWARE_FW_USED_TRY_B ? 1 : 0); | 129 *dest = (raw[FIRMWARE_FLAGS_OFFSET] & FIRMWARE_TRIED_FIRMWARE_B ? 1 : 0); |
130 return 0; | 130 return 0; |
131 | 131 |
132 case VBNV_FW_VERIFIED_KERNEL_KEY: | 132 case VBNV_FW_VERIFIED_KERNEL_KEY: |
133 *dest = (raw[FIRMWARE_FLAGS_OFFSET] & FIRMWARE_FW_VERIFIED_KERNEL_KEY ? | 133 *dest = (raw[FIRMWARE_FLAGS_OFFSET] & FIRMWARE_FW_VERIFIED_KERNEL_KEY ? |
134 1 : 0); | 134 1 : 0); |
135 return 0; | 135 return 0; |
136 | 136 |
137 default: | 137 default: |
138 return 1; | 138 return 1; |
139 } | 139 } |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
194 raw[LOCALIZATION_OFFSET] = (uint8_t)value; | 194 raw[LOCALIZATION_OFFSET] = (uint8_t)value; |
195 break; | 195 break; |
196 | 196 |
197 case VBNV_KERNEL_FIELD: | 197 case VBNV_KERNEL_FIELD: |
198 raw[KERNEL_FIELD_OFFSET] = (uint8_t)(value); | 198 raw[KERNEL_FIELD_OFFSET] = (uint8_t)(value); |
199 raw[KERNEL_FIELD_OFFSET + 1] = (uint8_t)(value >> 8); | 199 raw[KERNEL_FIELD_OFFSET + 1] = (uint8_t)(value >> 8); |
200 raw[KERNEL_FIELD_OFFSET + 2] = (uint8_t)(value >> 16); | 200 raw[KERNEL_FIELD_OFFSET + 2] = (uint8_t)(value >> 16); |
201 raw[KERNEL_FIELD_OFFSET + 3] = (uint8_t)(value >> 24); | 201 raw[KERNEL_FIELD_OFFSET + 3] = (uint8_t)(value >> 24); |
202 break; | 202 break; |
203 | 203 |
204 case VBNV_FW_USED_TRY_B: | 204 case VBNV_TRIED_FIRMWARE_B: |
205 if (value) | 205 if (value) |
206 raw[FIRMWARE_FLAGS_OFFSET] |= FIRMWARE_FW_USED_TRY_B; | 206 raw[FIRMWARE_FLAGS_OFFSET] |= FIRMWARE_TRIED_FIRMWARE_B; |
207 else | 207 else |
208 raw[FIRMWARE_FLAGS_OFFSET] &= ~FIRMWARE_FW_USED_TRY_B; | 208 raw[FIRMWARE_FLAGS_OFFSET] &= ~FIRMWARE_TRIED_FIRMWARE_B; |
209 break; | 209 break; |
210 | 210 |
211 case VBNV_FW_VERIFIED_KERNEL_KEY: | 211 case VBNV_FW_VERIFIED_KERNEL_KEY: |
212 if (value) | 212 if (value) |
213 raw[FIRMWARE_FLAGS_OFFSET] |= FIRMWARE_FW_VERIFIED_KERNEL_KEY; | 213 raw[FIRMWARE_FLAGS_OFFSET] |= FIRMWARE_FW_VERIFIED_KERNEL_KEY; |
214 else | 214 else |
215 raw[FIRMWARE_FLAGS_OFFSET] &= ~FIRMWARE_FW_VERIFIED_KERNEL_KEY; | 215 raw[FIRMWARE_FLAGS_OFFSET] &= ~FIRMWARE_FW_VERIFIED_KERNEL_KEY; |
216 break; | 216 break; |
217 | 217 |
218 default: | 218 default: |
219 return 1; | 219 return 1; |
220 } | 220 } |
221 | 221 |
222 /* Need to regenerate CRC, since the value changed. */ | 222 /* Need to regenerate CRC, since the value changed. */ |
223 context->regenerate_crc = 1; | 223 context->regenerate_crc = 1; |
224 return 0; | 224 return 0; |
225 } | 225 } |
OLD | NEW |