xref: /aosp_15_r20/external/vboot_reference/host/lib/file_keys.c (revision 8617a60d3594060b7ecbd21bc622a7c14f3cf2bc)
1*8617a60dSAndroid Build Coastguard Worker /* Copyright 2011 The ChromiumOS Authors
2*8617a60dSAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
3*8617a60dSAndroid Build Coastguard Worker  * found in the LICENSE file.
4*8617a60dSAndroid Build Coastguard Worker  *
5*8617a60dSAndroid Build Coastguard Worker  * Utility functions for file and key handling.
6*8617a60dSAndroid Build Coastguard Worker  */
7*8617a60dSAndroid Build Coastguard Worker 
8*8617a60dSAndroid Build Coastguard Worker #include <fcntl.h>
9*8617a60dSAndroid Build Coastguard Worker #include <stdio.h>
10*8617a60dSAndroid Build Coastguard Worker #include <stdlib.h>
11*8617a60dSAndroid Build Coastguard Worker #include <string.h>
12*8617a60dSAndroid Build Coastguard Worker #include <sys/stat.h>
13*8617a60dSAndroid Build Coastguard Worker #include <sys/types.h>
14*8617a60dSAndroid Build Coastguard Worker #include <unistd.h>
15*8617a60dSAndroid Build Coastguard Worker 
16*8617a60dSAndroid Build Coastguard Worker #include "2common.h"
17*8617a60dSAndroid Build Coastguard Worker #include "2sha.h"
18*8617a60dSAndroid Build Coastguard Worker #include "2sysincludes.h"
19*8617a60dSAndroid Build Coastguard Worker #include "file_keys.h"
20*8617a60dSAndroid Build Coastguard Worker #include "host_common.h"
21*8617a60dSAndroid Build Coastguard Worker #include "signature_digest.h"
22*8617a60dSAndroid Build Coastguard Worker 
DigestFile(char * input_file,enum vb2_hash_algorithm alg,uint8_t * digest,uint32_t digest_size)23*8617a60dSAndroid Build Coastguard Worker vb2_error_t DigestFile(char *input_file, enum vb2_hash_algorithm alg,
24*8617a60dSAndroid Build Coastguard Worker 		       uint8_t *digest, uint32_t digest_size)
25*8617a60dSAndroid Build Coastguard Worker {
26*8617a60dSAndroid Build Coastguard Worker 	int input_fd, len;
27*8617a60dSAndroid Build Coastguard Worker 	uint8_t data[VB2_SHA1_BLOCK_SIZE];
28*8617a60dSAndroid Build Coastguard Worker 	struct vb2_digest_context ctx;
29*8617a60dSAndroid Build Coastguard Worker 
30*8617a60dSAndroid Build Coastguard Worker 	if ((input_fd = open(input_file, O_RDONLY)) == -1) {
31*8617a60dSAndroid Build Coastguard Worker 		fprintf(stderr, "Couldn't open %s\n", input_file);
32*8617a60dSAndroid Build Coastguard Worker 		return VB2_ERROR_UNKNOWN;
33*8617a60dSAndroid Build Coastguard Worker 	}
34*8617a60dSAndroid Build Coastguard Worker 	vb2_digest_init(&ctx, false, alg, 0);
35*8617a60dSAndroid Build Coastguard Worker 	while ((len = read(input_fd, data, sizeof(data))) == sizeof(data))
36*8617a60dSAndroid Build Coastguard Worker 		vb2_digest_extend(&ctx, data, len);
37*8617a60dSAndroid Build Coastguard Worker 	if (len != -1)
38*8617a60dSAndroid Build Coastguard Worker 		vb2_digest_extend(&ctx, data, len);
39*8617a60dSAndroid Build Coastguard Worker 	close(input_fd);
40*8617a60dSAndroid Build Coastguard Worker 
41*8617a60dSAndroid Build Coastguard Worker 	return vb2_digest_finalize(&ctx, digest, digest_size);
42*8617a60dSAndroid Build Coastguard Worker }
43