OLD | NEW |
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 generating and manipulating a verified boot firmware image. | 5 * Functions for generating and manipulating a verified boot firmware image. |
6 */ | 6 */ |
7 | 7 |
8 #include "firmware_image.h" | 8 #include "firmware_image.h" |
9 | 9 |
10 #include <sys/types.h> | 10 #include <sys/types.h> |
11 #include <sys/stat.h> | 11 #include <sys/stat.h> |
12 #include <fcntl.h> | 12 #include <fcntl.h> |
13 #include <unistd.h> | 13 #include <unistd.h> |
14 | 14 |
15 #include "cryptolib.h" | 15 #include "cryptolib.h" |
16 #include "file_keys.h" | 16 #include "file_keys.h" |
17 #include "signature_digest.h" | 17 #include "signature_digest.h" |
18 #include "utility.h" | 18 #include "stateful_util.h" |
19 | 19 |
20 /* Macro to determine the size of a field structure in the FirmwareImage | 20 /* Macro to determine the size of a field structure in the FirmwareImage |
21 * structure. */ | 21 * structure. */ |
22 #define FIELD_LEN(field) (sizeof(((FirmwareImage*)0)->field)) | 22 #define FIELD_LEN(field) (sizeof(((FirmwareImage*)0)->field)) |
23 | 23 |
24 FirmwareImage* FirmwareImageNew(void) { | 24 FirmwareImage* FirmwareImageNew(void) { |
25 FirmwareImage* image = (FirmwareImage*) Malloc(sizeof(FirmwareImage)); | 25 FirmwareImage* image = (FirmwareImage*) Malloc(sizeof(FirmwareImage)); |
26 if (image) { | 26 if (image) { |
27 image->firmware_sign_key = NULL; | 27 image->firmware_sign_key = NULL; |
28 image->preamble_signature = NULL; | 28 image->preamble_signature = NULL; |
(...skipping 443 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
472 Free(firmware_buf); | 472 Free(firmware_buf); |
473 return 0; | 473 return 0; |
474 } | 474 } |
475 image->firmware_signature = (uint8_t*) Malloc(signature_len); | 475 image->firmware_signature = (uint8_t*) Malloc(signature_len); |
476 Memcpy(image->firmware_signature, firmware_signature, signature_len); | 476 Memcpy(image->firmware_signature, firmware_signature, signature_len); |
477 Free(firmware_signature); | 477 Free(firmware_signature); |
478 Free(firmware_buf); | 478 Free(firmware_buf); |
479 Free(preamble_blob); | 479 Free(preamble_blob); |
480 return 1; | 480 return 1; |
481 } | 481 } |
OLD | NEW |