From d92420ef563a25a44cdcbee0ce9634ce653817ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andreas=20F=C3=A4rber?= Date: Fri, 21 Apr 2017 19:59:56 +0200 Subject: [PATCH] fiptool: Add --pad command line option MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Allow each image to reserve some padding space before alignment. Use case is --align 0x4000 --pad 64 to make sure sufficient room is available to prepend (or append) vendor-specific headers. Helps resolve afaerber/meson-tools#3. Change-Id: I31e59456600b72cd30cde0f653ec6523480a5823 Signed-off-by: Andreas Färber Signed-off-by: Dimitris Papastamos --- tools/fiptool/fiptool.c | 55 ++++++++++++++++++++++++++++++++--------- 1 file changed, 44 insertions(+), 11 deletions(-) diff --git a/tools/fiptool/fiptool.c b/tools/fiptool/fiptool.c index 4d80f2f166..a4ebeb6065 100644 --- a/tools/fiptool/fiptool.c +++ b/tools/fiptool/fiptool.c @@ -28,6 +28,7 @@ #define OPT_TOC_ENTRY 0 #define OPT_PLAT_TOC_FLAGS 1 #define OPT_ALIGN 2 +#define OPT_PAD 3 static int info_cmd(int argc, char *argv[]); static void info_usage(void); @@ -488,7 +489,8 @@ static void info_usage(void) exit(1); } -static int pack_images(const char *filename, uint64_t toc_flags, unsigned long align) +static int pack_images(const char *filename, uint64_t toc_flags, + unsigned long align, unsigned long padding) { FILE *fp; image_desc_t *desc; @@ -523,7 +525,7 @@ static int pack_images(const char *filename, uint64_t toc_flags, unsigned long a if (image == NULL) continue; payload_size += image->toc_e.size; - entry_offset = (entry_offset + align - 1) & ~(align - 1); + entry_offset = (entry_offset + padding + align - 1) & ~(align - 1); image->toc_e.offset_address = entry_offset; *toc_entry++ = image->toc_e; entry_offset += image->toc_e.size; @@ -630,6 +632,19 @@ static unsigned long get_image_align(char *arg) return align; } +static unsigned long get_image_padding(char *arg) +{ + char *endptr; + unsigned long padding; + + errno = 0; + padding = strtoul(arg, &endptr, 0); + if (*endptr != '\0' || errno != 0) + log_errx("Invalid padding: %s", arg); + + return padding; +} + static void parse_blob_opt(char *arg, uuid_t *uuid, char *filename, size_t len) { char *p; @@ -650,7 +665,7 @@ static int create_cmd(int argc, char *argv[]) struct option *opts = NULL; size_t nr_opts = 0; unsigned long long toc_flags = 0; - unsigned long align = 1; + unsigned long align = 1, padding = 0; if (argc < 2) create_usage(); @@ -659,6 +674,8 @@ static int create_cmd(int argc, char *argv[]) opts = add_opt(opts, &nr_opts, "plat-toc-flags", required_argument, OPT_PLAT_TOC_FLAGS); opts = add_opt(opts, &nr_opts, "align", required_argument, OPT_ALIGN); + opts = add_opt(opts, &nr_opts, "pad", required_argument, + OPT_PAD); opts = add_opt(opts, &nr_opts, "blob", required_argument, 'b'); opts = add_opt(opts, &nr_opts, NULL, 0, 0); @@ -683,6 +700,9 @@ static int create_cmd(int argc, char *argv[]) case OPT_ALIGN: align = get_image_align(optarg); break; + case OPT_PAD: + padding = get_image_padding(optarg); + break; case 'b': { char name[_UUID_STR_LEN + 1]; char filename[PATH_MAX] = { 0 }; @@ -718,7 +738,7 @@ static int create_cmd(int argc, char *argv[]) update_fip(); - pack_images(argv[0], toc_flags, align); + pack_images(argv[0], toc_flags, align, padding); return 0; } @@ -729,7 +749,8 @@ static void create_usage(void) printf("fiptool create [opts] FIP_FILENAME\n"); printf("\n"); printf("Options:\n"); - printf(" --align \t\tEach image is aligned to (default: 1).\n"); + printf(" --align \t\tEach image is aligned to (default: 1).\n"); + printf(" --pad \t\t\tEach image is padded by (default: 0).\n"); printf(" --blob uuid=...,file=...\tAdd an image with the given UUID pointed to by file.\n"); printf(" --plat-toc-flags \t16-bit platform specific flag field occupying bits 32-47 in 64-bit ToC header.\n"); printf("\n"); @@ -747,7 +768,7 @@ static int update_cmd(int argc, char *argv[]) char outfile[PATH_MAX] = { 0 }; fip_toc_header_t toc_header = { 0 }; unsigned long long toc_flags = 0; - unsigned long align = 1; + unsigned long align = 1, padding = 0; int pflag = 0; if (argc < 2) @@ -755,6 +776,8 @@ static int update_cmd(int argc, char *argv[]) opts = fill_common_opts(opts, &nr_opts, required_argument); opts = add_opt(opts, &nr_opts, "align", required_argument, OPT_ALIGN); + opts = add_opt(opts, &nr_opts, "pad", required_argument, + OPT_PAD); opts = add_opt(opts, &nr_opts, "blob", required_argument, 'b'); opts = add_opt(opts, &nr_opts, "out", required_argument, 'o'); opts = add_opt(opts, &nr_opts, "plat-toc-flags", required_argument, @@ -805,6 +828,9 @@ static int update_cmd(int argc, char *argv[]) case OPT_ALIGN: align = get_image_align(optarg); break; + case OPT_PAD: + padding = get_image_padding(optarg); + break; case 'o': snprintf(outfile, sizeof(outfile), "%s", optarg); break; @@ -831,7 +857,7 @@ static int update_cmd(int argc, char *argv[]) update_fip(); - pack_images(outfile, toc_flags, align); + pack_images(outfile, toc_flags, align, padding); return 0; } @@ -842,7 +868,8 @@ static void update_usage(void) printf("fiptool update [opts] FIP_FILENAME\n"); printf("\n"); printf("Options:\n"); - printf(" --align \t\tEach image is aligned to (default: 1).\n"); + printf(" --align \t\tEach image is aligned to (default: 1).\n"); + printf(" --pad \t\t\tEach image is padded by (default: 0).\n"); printf(" --blob uuid=...,file=...\tAdd or update an image with the given UUID pointed to by file.\n"); printf(" --out FIP_FILENAME\t\tSet an alternative output FIP file.\n"); printf(" --plat-toc-flags \t16-bit platform specific flag field occupying bits 32-47 in 64-bit ToC header.\n"); @@ -997,7 +1024,7 @@ static int remove_cmd(int argc, char *argv[]) char outfile[PATH_MAX] = { 0 }; fip_toc_header_t toc_header; image_desc_t *desc; - unsigned long align = 1; + unsigned long align = 1, padding = 0; int fflag = 0; if (argc < 2) @@ -1005,6 +1032,8 @@ static int remove_cmd(int argc, char *argv[]) opts = fill_common_opts(opts, &nr_opts, no_argument); opts = add_opt(opts, &nr_opts, "align", required_argument, OPT_ALIGN); + opts = add_opt(opts, &nr_opts, "pad", required_argument, + OPT_PAD); opts = add_opt(opts, &nr_opts, "blob", required_argument, 'b'); opts = add_opt(opts, &nr_opts, "force", no_argument, 'f'); opts = add_opt(opts, &nr_opts, "out", required_argument, 'o'); @@ -1028,6 +1057,9 @@ static int remove_cmd(int argc, char *argv[]) case OPT_ALIGN: align = get_image_align(optarg); break; + case OPT_PAD: + padding = get_image_padding(optarg); + break; case 'b': { char name[_UUID_STR_LEN + 1], filename[PATH_MAX]; uuid_t uuid = { 0 }; @@ -1090,7 +1122,7 @@ static int remove_cmd(int argc, char *argv[]) } } - pack_images(outfile, toc_header.flags, align); + pack_images(outfile, toc_header.flags, align, padding); return 0; } @@ -1101,7 +1133,8 @@ static void remove_usage(void) printf("fiptool remove [opts] FIP_FILENAME\n"); printf("\n"); printf("Options:\n"); - printf(" --align \tEach image is aligned to (default: 1).\n"); + printf(" --align \tEach image is aligned to (default: 1).\n"); + printf(" --pad \t\tEach image is padded by (default: 0).\n"); printf(" --blob uuid=...\tRemove an image with the given UUID.\n"); printf(" --force\t\tIf the output FIP file already exists, use --force to overwrite it.\n"); printf(" --out FIP_FILENAME\tSet an alternative output FIP file.\n");