From 2fb3636316c976bc630b13c9a215c5388db1e050 Mon Sep 17 00:00:00 2001 From: Piotr Dymacz Date: Tue, 4 Jul 2017 15:40:43 +0200 Subject: [PATCH] firmware-utils: mktplinkfw: add option for endianness swap This adds command line option in "mktplinkfw" tool for endianness swap in kernel load address and entry point fields. As in "mktplinkfw2" tool, we will need this for little-endian targets, like "ramips". Signed-off-by: Piotr Dymacz --- src/mktplinkfw.c | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/src/mktplinkfw.c b/src/mktplinkfw.c index fbf8960..93db441 100644 --- a/src/mktplinkfw.c +++ b/src/mktplinkfw.c @@ -19,6 +19,8 @@ #include #include /* for getopt() */ #include +#include +#include #include #include @@ -123,6 +125,7 @@ static uint32_t reserved_space; static struct file_info inspect_info; static int extract = 0; +static bool endian_swap = false; static const char md5salt_normal[MD5SUM_LEN] = { 0xdc, 0xd7, 0x3a, 0xa5, 0xc3, 0x95, 0x98, 0xfb, @@ -256,6 +259,7 @@ static void usage(int status) "\n" "Options:\n" " -c use combined kernel image\n" +" -e swap endianness in kernel load address and entry point\n" " -E overwrite kernel entry point with (hexval prefixed with 0x)\n" " -L overwrite kernel load address with (hexval prefixed with 0x)\n" " -H use hardware id specified with \n" @@ -521,6 +525,11 @@ static void fill_header(char *buf, int len) ); } + if (endian_swap) { + hdr->kernel_la = bswap_32(hdr->kernel_la); + hdr->kernel_ep = bswap_32(hdr->kernel_ep); + } + get_md5(buf, len, hdr->md5sum1); } @@ -805,7 +814,7 @@ int main(int argc, char *argv[]) while ( 1 ) { int c; - c = getopt(argc, argv, "a:H:E:F:L:m:V:N:W:C:ci:k:r:R:o:xX:hsSjv:"); + c = getopt(argc, argv, "a:H:E:F:L:m:V:N:W:C:ci:k:r:R:o:xX:ehsSjv:"); if (c == -1) break; @@ -873,6 +882,9 @@ int main(int argc, char *argv[]) case 'x': extract = 1; break; + case 'e': + endian_swap = true; + break; case 'h': usage(EXIT_SUCCESS); break; -- 2.30.2