diff options
| author | davidcunado-arm <david.cunado@arm.com> | 2017-10-16 08:51:18 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-10-16 08:51:18 +0100 | 
| commit | 8ac544e44b9747c1c59b42e4708607f2e8077c6f (patch) | |
| tree | 74af4f769ca309829faf4e639186ba89bf3806a2 | |
| parent | 9679297faed7087fa3b84bc52dd7ff211a468583 (diff) | |
| parent | 9685111407907a81a27afa75557aef0ff88edbc4 (diff) | |
Merge pull request #1122 from EvanLloyd/ejll/62_fiptool1
fiptool: Precursor changes for Visual Studio
| -rw-r--r-- | tools/fiptool/fiptool.c | 15 | ||||
| -rw-r--r-- | tools/fiptool/fiptool.h | 2 | ||||
| -rw-r--r-- | tools/fiptool/fiptool_platform.h | 29 | 
3 files changed, 37 insertions, 9 deletions
| diff --git a/tools/fiptool/fiptool.c b/tools/fiptool/fiptool.c index 02223d99..1dcb7e8e 100644 --- a/tools/fiptool/fiptool.c +++ b/tools/fiptool/fiptool.c @@ -9,18 +9,12 @@  #include <assert.h>  #include <errno.h> -#include <getopt.h>  #include <limits.h>  #include <stdarg.h>  #include <stdint.h>  #include <stdio.h>  #include <stdlib.h>  #include <string.h> -#include <unistd.h> - -#include <openssl/sha.h> - -#include <firmware_image_package.h>  #include "fiptool.h"  #include "tbbr_config.h" @@ -161,7 +155,7 @@ static void set_image_desc_action(image_desc_t *desc, int action,  {  	assert(desc != NULL); -	if (desc->action_arg != DO_UNSPEC) +	if (desc->action_arg != (char *)DO_UNSPEC)  		free(desc->action_arg);  	desc->action = action;  	desc->action_arg = NULL; @@ -278,7 +272,7 @@ static void uuid_from_str(uuid_t *u, const char *s)  static int parse_fip(const char *filename, fip_toc_header_t *toc_header_out)  { -	struct stat st; +	struct BLD_PLAT_STAT st;  	FILE *fp;  	char *buf, *bufend;  	fip_toc_header_t *toc_header; @@ -370,11 +364,12 @@ static int parse_fip(const char *filename, fip_toc_header_t *toc_header_out)  static image_t *read_image_from_file(const uuid_t *uuid, const char *filename)  { -	struct stat st; +	struct BLD_PLAT_STAT st;  	image_t *image;  	FILE *fp;  	assert(uuid != NULL); +	assert(filename != NULL);  	fp = fopen(filename, "rb");  	if (fp == NULL) @@ -469,6 +464,7 @@ static int info_cmd(int argc, char *argv[])  		       (unsigned long long)image->toc_e.offset_address,  		       (unsigned long long)image->toc_e.size,  		       desc->cmdline_name); +#ifndef _MSC_VER	/* We don't have SHA256 for Visual Studio. */  		if (verbose) {  			unsigned char md[SHA256_DIGEST_LENGTH]; @@ -476,6 +472,7 @@ static int info_cmd(int argc, char *argv[])  			printf(", sha256=");  			md_print(md, sizeof(md));  		} +#endif  		putchar('\n');  	} diff --git a/tools/fiptool/fiptool.h b/tools/fiptool/fiptool.h index 4b5cdd91..d8a5d2ca 100644 --- a/tools/fiptool/fiptool.h +++ b/tools/fiptool/fiptool.h @@ -13,6 +13,8 @@  #include <firmware_image_package.h>  #include <uuid.h> +#include "fiptool_platform.h" +  #define NELEM(x) (sizeof (x) / sizeof *(x))  enum { diff --git a/tools/fiptool/fiptool_platform.h b/tools/fiptool/fiptool_platform.h new file mode 100644 index 00000000..bfdd1efc --- /dev/null +++ b/tools/fiptool/fiptool_platform.h @@ -0,0 +1,29 @@ +/* + * Copyright (c) 2016-2017, ARM Limited and Contributors. All rights reserved. + * + * SPDX-License-Identifier: BSD-3-Clause + * + * Build platform specific handling. + * This allows for builds on non-Posix platforms + * e.g. Visual Studio on Windows + */ + +#ifndef __FIPTOOL_PLATFORM_H__ +#	define __FIPTOOL_PLATFORM_H__ + +#	ifndef _MSC_VER + +		/* Not Visual Studio, so include Posix Headers. */ +#		include <getopt.h> +#		include <openssl/sha.h> +#		include <unistd.h> + +#		define  BLD_PLAT_STAT stat + +#	else + +		/* Visual Studio. */ + +#	endif + +#endif /* __FIPTOOL_PLATFORM_H__ */ | 
