xref: /aosp_15_r20/external/vboot_reference/futility/futility.h (revision 8617a60d3594060b7ecbd21bc622a7c14f3cf2bc)
1*8617a60dSAndroid Build Coastguard Worker /* Copyright 2013 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 
6*8617a60dSAndroid Build Coastguard Worker #ifndef VBOOT_REFERENCE_FUTILITY_H_
7*8617a60dSAndroid Build Coastguard Worker #define VBOOT_REFERENCE_FUTILITY_H_
8*8617a60dSAndroid Build Coastguard Worker 
9*8617a60dSAndroid Build Coastguard Worker #include <stdint.h>
10*8617a60dSAndroid Build Coastguard Worker 
11*8617a60dSAndroid Build Coastguard Worker #include "2common.h"
12*8617a60dSAndroid Build Coastguard Worker #include "host_key.h"
13*8617a60dSAndroid Build Coastguard Worker 
14*8617a60dSAndroid Build Coastguard Worker /* This program */
15*8617a60dSAndroid Build Coastguard Worker #define MYNAME "futility"
16*8617a60dSAndroid Build Coastguard Worker 
17*8617a60dSAndroid Build Coastguard Worker /* Version string (autogenerated) */
18*8617a60dSAndroid Build Coastguard Worker extern const char futility_version[];
19*8617a60dSAndroid Build Coastguard Worker 
20*8617a60dSAndroid Build Coastguard Worker /* Bitfields indicating the struct/format versions supported by a command */
21*8617a60dSAndroid Build Coastguard Worker enum vboot_version  {
22*8617a60dSAndroid Build Coastguard Worker 	/*
23*8617a60dSAndroid Build Coastguard Worker 	 * v1.0 is the original structs used since the dawn of time.
24*8617a60dSAndroid Build Coastguard Worker 	 * v2.0 can verify the firmware in smaller chunks, but there's
25*8617a60dSAndroid Build Coastguard Worker 	 * no difference in the on-device structs, so it's only
26*8617a60dSAndroid Build Coastguard Worker 	 * meaningful for the firmware API. Futility doesn't care.
27*8617a60dSAndroid Build Coastguard Worker 	 */
28*8617a60dSAndroid Build Coastguard Worker 	VBOOT_VERSION_1_0 = 0x00000001,
29*8617a60dSAndroid Build Coastguard Worker 
30*8617a60dSAndroid Build Coastguard Worker 	/*
31*8617a60dSAndroid Build Coastguard Worker 	 * v2.1 uses new and different structs, and is what v2.0 would have
32*8617a60dSAndroid Build Coastguard Worker 	 * been if someone hadn't started using it before it was ready.
33*8617a60dSAndroid Build Coastguard Worker 	 */
34*8617a60dSAndroid Build Coastguard Worker 	VBOOT_VERSION_2_1 = 0x00000002,
35*8617a60dSAndroid Build Coastguard Worker 
36*8617a60dSAndroid Build Coastguard Worker 	/*
37*8617a60dSAndroid Build Coastguard Worker 	 * Everything we know about to date.
38*8617a60dSAndroid Build Coastguard Worker 	 */
39*8617a60dSAndroid Build Coastguard Worker 	VBOOT_VERSION_ALL = 0x00000003,
40*8617a60dSAndroid Build Coastguard Worker };
41*8617a60dSAndroid Build Coastguard Worker 
42*8617a60dSAndroid Build Coastguard Worker /* What's our preferred API & data format? */
43*8617a60dSAndroid Build Coastguard Worker extern enum vboot_version vboot_version;
44*8617a60dSAndroid Build Coastguard Worker 
45*8617a60dSAndroid Build Coastguard Worker /* Here's a structure to define the commands that futility implements. */
46*8617a60dSAndroid Build Coastguard Worker struct futil_cmd_t {
47*8617a60dSAndroid Build Coastguard Worker 	/* String used to invoke this command */
48*8617a60dSAndroid Build Coastguard Worker 	const char *const name;
49*8617a60dSAndroid Build Coastguard Worker 	/* Function to do the work. Returns 0 on success.
50*8617a60dSAndroid Build Coastguard Worker 	 * Called with argv[0] == "name".
51*8617a60dSAndroid Build Coastguard Worker 	 * It should handle its own "--help" option. */
52*8617a60dSAndroid Build Coastguard Worker 	int (*const handler) (int argc, char **argv);
53*8617a60dSAndroid Build Coastguard Worker 	/* Supported ABIs */
54*8617a60dSAndroid Build Coastguard Worker 	enum vboot_version version;
55*8617a60dSAndroid Build Coastguard Worker 	/* One-line summary of what it does */
56*8617a60dSAndroid Build Coastguard Worker 	const char *const shorthelp;
57*8617a60dSAndroid Build Coastguard Worker };
58*8617a60dSAndroid Build Coastguard Worker 
59*8617a60dSAndroid Build Coastguard Worker /* Macro to define a command */
60*8617a60dSAndroid Build Coastguard Worker #define DECLARE_FUTIL_COMMAND(NAME, HANDLER, VERSION, SHORTHELP)	\
61*8617a60dSAndroid Build Coastguard Worker 	const struct futil_cmd_t __cmd_##NAME = {			\
62*8617a60dSAndroid Build Coastguard Worker 		.name = #NAME,						\
63*8617a60dSAndroid Build Coastguard Worker 		.handler = HANDLER,					\
64*8617a60dSAndroid Build Coastguard Worker 		.version = VERSION,					\
65*8617a60dSAndroid Build Coastguard Worker 		.shorthelp = SHORTHELP,					\
66*8617a60dSAndroid Build Coastguard Worker 	}
67*8617a60dSAndroid Build Coastguard Worker 
68*8617a60dSAndroid Build Coastguard Worker /* This is the list of pointers to all commands. */
69*8617a60dSAndroid Build Coastguard Worker extern const struct futil_cmd_t *const futil_cmds[];
70*8617a60dSAndroid Build Coastguard Worker 
71*8617a60dSAndroid Build Coastguard Worker /* Size of an array */
72*8617a60dSAndroid Build Coastguard Worker #ifndef ARRAY_SIZE
73*8617a60dSAndroid Build Coastguard Worker #define ARRAY_SIZE(array) (sizeof(array)/sizeof(array[0]))
74*8617a60dSAndroid Build Coastguard Worker #endif
75*8617a60dSAndroid Build Coastguard Worker 
76*8617a60dSAndroid Build Coastguard Worker /* Fatal error (print error message and exit). */
77*8617a60dSAndroid Build Coastguard Worker #define FATAL(format, ...) do { \
78*8617a60dSAndroid Build Coastguard Worker 		fprintf(stderr, "FATAL: %s: " format, __func__, \
79*8617a60dSAndroid Build Coastguard Worker 			##__VA_ARGS__ ); \
80*8617a60dSAndroid Build Coastguard Worker 		exit(1); \
81*8617a60dSAndroid Build Coastguard Worker 	} while (0)
82*8617a60dSAndroid Build Coastguard Worker 
83*8617a60dSAndroid Build Coastguard Worker /* Print error messages (won't exit). */
84*8617a60dSAndroid Build Coastguard Worker #define ERROR(format, ...) fprintf(stderr, "ERROR: %s: " format, __func__, \
85*8617a60dSAndroid Build Coastguard Worker 				   ##__VA_ARGS__ )
86*8617a60dSAndroid Build Coastguard Worker #define WARN(format, ...) fprintf(stderr, "WARNING: %s: " format, __func__, \
87*8617a60dSAndroid Build Coastguard Worker 				  ##__VA_ARGS__ )
88*8617a60dSAndroid Build Coastguard Worker #define INFO(format, ...) fprintf(stderr, "INFO: %s: " format, __func__, \
89*8617a60dSAndroid Build Coastguard Worker 				  ##__VA_ARGS__ )
90*8617a60dSAndroid Build Coastguard Worker #define STATUS(format, ...) fprintf(stderr, ">> " format, ##__VA_ARGS__ )
91*8617a60dSAndroid Build Coastguard Worker 
92*8617a60dSAndroid Build Coastguard Worker extern const char *ft_print_header;
93*8617a60dSAndroid Build Coastguard Worker extern const char *ft_print_header2;
94*8617a60dSAndroid Build Coastguard Worker 
95*8617a60dSAndroid Build Coastguard Worker /*
96*8617a60dSAndroid Build Coastguard Worker  * `futility show` supports two kinds of output: human readable and machine
97*8617a60dSAndroid Build Coastguard Worker  * parseable. To keep the code simple, there is mostly a 1-to-1 relationship
98*8617a60dSAndroid Build Coastguard Worker  * between lines of human readable and lines of machine parseable output. The
99*8617a60dSAndroid Build Coastguard Worker  * FT_PRINT() macro should be used in those cases to define both output types
100*8617a60dSAndroid Build Coastguard Worker  * for a given line in one statement. In rare cases where lines do not match
101*8617a60dSAndroid Build Coastguard Worker  * 1-to-1, FT_READABLE_PRINT() and FT_PARSEABLE_PRINT() can be used to only
102*8617a60dSAndroid Build Coastguard Worker  * print to one or the other format.
103*8617a60dSAndroid Build Coastguard Worker  *
104*8617a60dSAndroid Build Coastguard Worker  * The requirements for machine parseable output are as follows and must be
105*8617a60dSAndroid Build Coastguard Worker  * strictly followed to ensure backwards-compatibility with tools using it:
106*8617a60dSAndroid Build Coastguard Worker  *
107*8617a60dSAndroid Build Coastguard Worker  * * Each line consists of a string of prefix tokens and one or more data
108*8617a60dSAndroid Build Coastguard Worker  *   values, separated by double colon delimiters (`::`).
109*8617a60dSAndroid Build Coastguard Worker  *
110*8617a60dSAndroid Build Coastguard Worker  *   * Output lines are independent of each other. No information may be encoded
111*8617a60dSAndroid Build Coastguard Worker  *     by the position of one output line relative to another (e.g. no
112*8617a60dSAndroid Build Coastguard Worker  *     "headings" which apply to all following lines).
113*8617a60dSAndroid Build Coastguard Worker  *
114*8617a60dSAndroid Build Coastguard Worker  *   * Tokens should form a hierarchy that groups related values together.
115*8617a60dSAndroid Build Coastguard Worker  *
116*8617a60dSAndroid Build Coastguard Worker  *     * Do not just use delimiters to separate words. Each token should
117*8617a60dSAndroid Build Coastguard Worker  *       represent a real layer in the hierarchy (e.g.
118*8617a60dSAndroid Build Coastguard Worker  *       `preamble::firmware_version` instead of `preamble::firmware::version`
119*8617a60dSAndroid Build Coastguard Worker  *       since "firmware" isn't a real hierarchical layer within the preamble).
120*8617a60dSAndroid Build Coastguard Worker  *
121*8617a60dSAndroid Build Coastguard Worker  *     * The toplevel token should be the same for all output lines and
122*8617a60dSAndroid Build Coastguard Worker  *       represent the futility file type being displayed (e.g. `bios`).
123*8617a60dSAndroid Build Coastguard Worker  *
124*8617a60dSAndroid Build Coastguard Worker  *   * Neither tokens nor values may contain the colon character (`:`) or a
125*8617a60dSAndroid Build Coastguard Worker  *     line break (`\n`).
126*8617a60dSAndroid Build Coastguard Worker  *
127*8617a60dSAndroid Build Coastguard Worker  *   * All integer values (even memory addresses) should be output in decimal.
128*8617a60dSAndroid Build Coastguard Worker  *
129*8617a60dSAndroid Build Coastguard Worker  *   * Every line should represent one single piece of information (i.e. no
130*8617a60dSAndroid Build Coastguard Worker  *     aggregate lines that e.g. show both the offset and size of something in
131*8617a60dSAndroid Build Coastguard Worker  *     the same line).
132*8617a60dSAndroid Build Coastguard Worker  *
133*8617a60dSAndroid Build Coastguard Worker  *     * If a single piece of information can be represented in multiple ways
134*8617a60dSAndroid Build Coastguard Worker  *       (e.g. hash algorithm by name and numerical ID), and it is useful to
135*8617a60dSAndroid Build Coastguard Worker  *       output both of them, they should be both output on the same line
136*8617a60dSAndroid Build Coastguard Worker  *       separated by `::`.
137*8617a60dSAndroid Build Coastguard Worker  *
138*8617a60dSAndroid Build Coastguard Worker  *   * Values should generally be simple. For very complex values and those that
139*8617a60dSAndroid Build Coastguard Worker  *     need to contain the disallowed characters or raw binary data (like the
140*8617a60dSAndroid Build Coastguard Worker  *     kernel command line), consider just creating a separate command to
141*8617a60dSAndroid Build Coastguard Worker  *     extract them specifically (e.g. `futility dump_kernel_config`).
142*8617a60dSAndroid Build Coastguard Worker  *
143*8617a60dSAndroid Build Coastguard Worker  *   * When a line represents a set (e.g. flags in textual representation), the
144*8617a60dSAndroid Build Coastguard Worker  *     individual set items should be separated by single colons (`:`). Callers
145*8617a60dSAndroid Build Coastguard Worker  *     should make no assumptions about the order of items listed in a set.
146*8617a60dSAndroid Build Coastguard Worker  *
147*8617a60dSAndroid Build Coastguard Worker  * * The parseable output is considered a stable API. Once an output line has
148*8617a60dSAndroid Build Coastguard Worker  *   been added, futility must forever return the exact same format (same prefix
149*8617a60dSAndroid Build Coastguard Worker  *   tokens, same data values in the same notation) on the same input file.
150*8617a60dSAndroid Build Coastguard Worker  *
151*8617a60dSAndroid Build Coastguard Worker  *   * Output lines are independent. Callers must make no assumption about the
152*8617a60dSAndroid Build Coastguard Worker  *     order of output lines, and additional lines may be added in the future.
153*8617a60dSAndroid Build Coastguard Worker  *
154*8617a60dSAndroid Build Coastguard Worker  *   * For values representing a set, new items may become possible for the set
155*8617a60dSAndroid Build Coastguard Worker  *     in future versions as long as the existing ones are still represented in
156*8617a60dSAndroid Build Coastguard Worker  *     the same way.
157*8617a60dSAndroid Build Coastguard Worker  *
158*8617a60dSAndroid Build Coastguard Worker  *   * When input files themselves change in a way that certain output lines no
159*8617a60dSAndroid Build Coastguard Worker  *     longer make sense for them (e.g. switching from raw area signing to
160*8617a60dSAndroid Build Coastguard Worker  *     metadata hash signing), some of the output lines that used to appear for
161*8617a60dSAndroid Build Coastguard Worker  *     the old version of that file type may no longer appear for the new
162*8617a60dSAndroid Build Coastguard Worker  *     version. But the lines that do appear must still follow the same
163*8617a60dSAndroid Build Coastguard Worker  *     format as they did for the old version.
164*8617a60dSAndroid Build Coastguard Worker  *
165*8617a60dSAndroid Build Coastguard Worker  *   * When there's a strong need to change the existing way something is
166*8617a60dSAndroid Build Coastguard Worker  *     represented, a new output line should be added that represents it in a
167*8617a60dSAndroid Build Coastguard Worker  *     better way. The old output line should be marked deprecated in a code
168*8617a60dSAndroid Build Coastguard Worker  *     comment but not removed or altered in any way from the output. (This
169*8617a60dSAndroid Build Coastguard Worker  *     means that as changes accrue information may be displayed in multiple
170*8617a60dSAndroid Build Coastguard Worker  *     redundant ways.)
171*8617a60dSAndroid Build Coastguard Worker  *
172*8617a60dSAndroid Build Coastguard Worker  *   * If one day the burden of accumulated deprecated output lines becomes too
173*8617a60dSAndroid Build Coastguard Worker  *     high, we may consider a permanent deprecation and removal plan. But this
174*8617a60dSAndroid Build Coastguard Worker  *     would be done over a long time frame with plenty of heads-up notice to
175*8617a60dSAndroid Build Coastguard Worker  *     `futility show` consumers to ensure they have migrated to the new format.
176*8617a60dSAndroid Build Coastguard Worker  *     Consumers are meant to be able to trust that they can hardcode parsing
177*8617a60dSAndroid Build Coastguard Worker  *     for a certain output line and it will remain working without futility
178*8617a60dSAndroid Build Coastguard Worker  *     suddenly pulling the rug out from under them.
179*8617a60dSAndroid Build Coastguard Worker  */
180*8617a60dSAndroid Build Coastguard Worker 
181*8617a60dSAndroid Build Coastguard Worker /* futility print helpers to handle parseable prints */
182*8617a60dSAndroid Build Coastguard Worker #define FT_READABLE_PRINT(fmt, args...) do { \
183*8617a60dSAndroid Build Coastguard Worker 		if (!show_option.parseable) \
184*8617a60dSAndroid Build Coastguard Worker 			printf(fmt, ##args); \
185*8617a60dSAndroid Build Coastguard Worker 	} while (0)
186*8617a60dSAndroid Build Coastguard Worker 
187*8617a60dSAndroid Build Coastguard Worker #define FT_PARSEABLE_PRINT(fmt, args...) do { \
188*8617a60dSAndroid Build Coastguard Worker 		if (!show_option.parseable) \
189*8617a60dSAndroid Build Coastguard Worker 			break; \
190*8617a60dSAndroid Build Coastguard Worker 		if (ft_print_header != NULL) \
191*8617a60dSAndroid Build Coastguard Worker 			printf("%s::", ft_print_header); \
192*8617a60dSAndroid Build Coastguard Worker 		if (ft_print_header2 != NULL) \
193*8617a60dSAndroid Build Coastguard Worker 			printf("%s::", ft_print_header2); \
194*8617a60dSAndroid Build Coastguard Worker 		printf(fmt, ##args); \
195*8617a60dSAndroid Build Coastguard Worker 	} while (0)
196*8617a60dSAndroid Build Coastguard Worker 
197*8617a60dSAndroid Build Coastguard Worker #define FT_PRINT_RAW(normal_fmt, parse_fmt, args...) \
198*8617a60dSAndroid Build Coastguard Worker 	printf(show_option.parseable ? parse_fmt : normal_fmt, ##args)
199*8617a60dSAndroid Build Coastguard Worker 
200*8617a60dSAndroid Build Coastguard Worker #define FT_PRINT(normal_fmt, parse_fmt, args...) do { \
201*8617a60dSAndroid Build Coastguard Worker 		FT_READABLE_PRINT(normal_fmt, ##args); \
202*8617a60dSAndroid Build Coastguard Worker 		FT_PARSEABLE_PRINT(parse_fmt, ##args); \
203*8617a60dSAndroid Build Coastguard Worker 	} while (0)
204*8617a60dSAndroid Build Coastguard Worker 
205*8617a60dSAndroid Build Coastguard Worker /* Debug output (off by default) */
206*8617a60dSAndroid Build Coastguard Worker extern int debugging_enabled;
207*8617a60dSAndroid Build Coastguard Worker 
208*8617a60dSAndroid Build Coastguard Worker /* Returns true if this looks enough like a GBB header to proceed. */
209*8617a60dSAndroid Build Coastguard Worker int futil_looks_like_gbb(struct vb2_gbb_header *gbb, uint32_t len);
210*8617a60dSAndroid Build Coastguard Worker 
211*8617a60dSAndroid Build Coastguard Worker /*
212*8617a60dSAndroid Build Coastguard Worker  * Returns true if the gbb header is valid (and optionally updates *maxlen).
213*8617a60dSAndroid Build Coastguard Worker  * This doesn't verify the contents, though.
214*8617a60dSAndroid Build Coastguard Worker  */
215*8617a60dSAndroid Build Coastguard Worker int futil_valid_gbb_header(struct vb2_gbb_header *gbb, uint32_t len,
216*8617a60dSAndroid Build Coastguard Worker 			   uint32_t *maxlen);
217*8617a60dSAndroid Build Coastguard Worker 
218*8617a60dSAndroid Build Coastguard Worker /* Sets the HWID string field inside a GBB header. */
219*8617a60dSAndroid Build Coastguard Worker int futil_set_gbb_hwid(struct vb2_gbb_header *gbb, const char *hwid);
220*8617a60dSAndroid Build Coastguard Worker 
221*8617a60dSAndroid Build Coastguard Worker /* For GBB v1.2 and later, update the hwid_digest */
222*8617a60dSAndroid Build Coastguard Worker void update_hwid_digest(struct vb2_gbb_header *gbb);
223*8617a60dSAndroid Build Coastguard Worker 
224*8617a60dSAndroid Build Coastguard Worker /* For GBB v1.2 and later, print the stored digest of the HWID (and whether
225*8617a60dSAndroid Build Coastguard Worker  * it's correct). Return true if it is correct. */
226*8617a60dSAndroid Build Coastguard Worker int print_hwid_digest(struct vb2_gbb_header *gbb, const char *banner);
227*8617a60dSAndroid Build Coastguard Worker 
228*8617a60dSAndroid Build Coastguard Worker /* Copies a file. */
229*8617a60dSAndroid Build Coastguard Worker int futil_copy_file(const char *infile, const char *outfile);
230*8617a60dSAndroid Build Coastguard Worker 
231*8617a60dSAndroid Build Coastguard Worker /* Possible file operation errors */
232*8617a60dSAndroid Build Coastguard Worker enum futil_file_err {
233*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_NONE,
234*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_STAT,
235*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_SIZE,
236*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_MMAP,
237*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_MSYNC,
238*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_MUNMAP,
239*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_OPEN,
240*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_CLOSE,
241*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_DIR,
242*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_CHR,
243*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_FIFO,
244*8617a60dSAndroid Build Coastguard Worker 	FILE_ERR_SOCK,
245*8617a60dSAndroid Build Coastguard Worker };
246*8617a60dSAndroid Build Coastguard Worker 
247*8617a60dSAndroid Build Coastguard Worker enum file_mode {
248*8617a60dSAndroid Build Coastguard Worker 	FILE_RO,
249*8617a60dSAndroid Build Coastguard Worker 	FILE_RW,
250*8617a60dSAndroid Build Coastguard Worker };
251*8617a60dSAndroid Build Coastguard Worker 
252*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_open_file(const char *infile, int *fd,
253*8617a60dSAndroid Build Coastguard Worker 				    enum file_mode mode);
254*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_close_file(int fd);
255*8617a60dSAndroid Build Coastguard Worker 
256*8617a60dSAndroid Build Coastguard Worker /* Wrapper for mmap/munmap. Skips stupidly large files. */
257*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_map_file(int fd, enum file_mode mode, uint8_t **buf,
258*8617a60dSAndroid Build Coastguard Worker 				   uint32_t *len);
259*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_unmap_file(int fd, enum file_mode mode, uint8_t *buf,
260*8617a60dSAndroid Build Coastguard Worker 				     uint32_t len);
261*8617a60dSAndroid Build Coastguard Worker 
262*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_open_and_map_file(const char *infile, int *fd,
263*8617a60dSAndroid Build Coastguard Worker 					    enum file_mode mode, uint8_t **buf,
264*8617a60dSAndroid Build Coastguard Worker 					    uint32_t *len);
265*8617a60dSAndroid Build Coastguard Worker enum futil_file_err futil_unmap_and_close_file(int fd, enum file_mode mode,
266*8617a60dSAndroid Build Coastguard Worker 					       uint8_t *buf, uint32_t len);
267*8617a60dSAndroid Build Coastguard Worker 
268*8617a60dSAndroid Build Coastguard Worker /*
269*8617a60dSAndroid Build Coastguard Worker  * Parse input string as a hex representation of size len, exit with error if
270*8617a60dSAndroid Build Coastguard Worker  *  the string is not a valid hex string or is of a wrongs size.
271*8617a60dSAndroid Build Coastguard Worker  */
272*8617a60dSAndroid Build Coastguard Worker void parse_digest_or_die(uint8_t *buf, int len, const char *str);
273*8617a60dSAndroid Build Coastguard Worker 
274*8617a60dSAndroid Build Coastguard Worker /*
275*8617a60dSAndroid Build Coastguard Worker  * Print provided buffer as hex string
276*8617a60dSAndroid Build Coastguard Worker  */
277*8617a60dSAndroid Build Coastguard Worker void print_bytes(const void *ptr, size_t len);
278*8617a60dSAndroid Build Coastguard Worker 
279*8617a60dSAndroid Build Coastguard Worker /* The CPU architecture is occasionally important */
280*8617a60dSAndroid Build Coastguard Worker enum arch_t {
281*8617a60dSAndroid Build Coastguard Worker 	ARCH_UNSPECIFIED,
282*8617a60dSAndroid Build Coastguard Worker 	ARCH_X86,
283*8617a60dSAndroid Build Coastguard Worker 	ARCH_ARM,
284*8617a60dSAndroid Build Coastguard Worker 	ARCH_MIPS
285*8617a60dSAndroid Build Coastguard Worker };
286*8617a60dSAndroid Build Coastguard Worker 
287*8617a60dSAndroid Build Coastguard Worker /*
288*8617a60dSAndroid Build Coastguard Worker  * Write size bytes from start into filename. Print "%msg %filename" to stdout
289*8617a60dSAndroid Build Coastguard Worker  * on success, if msg is non-NULL. Writes messages to stderr on failure.
290*8617a60dSAndroid Build Coastguard Worker  * Returns 0 on success.
291*8617a60dSAndroid Build Coastguard Worker  */
292*8617a60dSAndroid Build Coastguard Worker int write_to_file(const char *msg, const char *filename, uint8_t *start,
293*8617a60dSAndroid Build Coastguard Worker 		  size_t size);
294*8617a60dSAndroid Build Coastguard Worker 
295*8617a60dSAndroid Build Coastguard Worker #endif  /* VBOOT_REFERENCE_FUTILITY_H_ */
296