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