From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from mail-pl0-x22a.google.com ([2607:f8b0:400e:c01::22a]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1fs07f-00005C-4P for barebox@lists.infradead.org; Tue, 21 Aug 2018 06:26:36 +0000 Received: by mail-pl0-x22a.google.com with SMTP id p4-v6so4740164pll.8 for ; Mon, 20 Aug 2018 23:26:26 -0700 (PDT) From: Andrey Smirnov Date: Mon, 20 Aug 2018 23:25:43 -0700 Message-Id: <20180821062603.17393-3-andrew.smirnov@gmail.com> In-Reply-To: <20180821062603.17393-1-andrew.smirnov@gmail.com> References: <20180821062603.17393-1-andrew.smirnov@gmail.com> List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "barebox" Errors-To: barebox-bounces+u.kleine-koenig=pengutronix.de@lists.infradead.org Subject: [PATCH 02/22] filetype: Add code to detect i.MX image v1 To: barebox@lists.infradead.org Cc: Andrey Smirnov Modify file_detect_type() and add code needed to be able to detect i.MX boot images with v1 header. Signed-off-by: Andrey Smirnov --- common/filetype.c | 7 +++++++ include/filetype.h | 1 + 2 files changed, 8 insertions(+) diff --git a/common/filetype.c b/common/filetype.c index c5f2384a6..f68a83bec 100644 --- a/common/filetype.c +++ b/common/filetype.c @@ -29,6 +29,8 @@ #include #include +#include <../mach-imx/include/mach/imx-header.h> + struct filetype_str { const char *name; /* human readable filetype */ const char *shortname; /* short string without spaces for shell scripts */ @@ -71,6 +73,7 @@ static const struct filetype_str filetype_str[] = { [filetype_android_sparse] = { "Android sparse image", "sparse" }, [filetype_arm64_linux_image] = { "ARM aarch64 Linux image", "aarch64-linux" }, [filetype_elf] = { "ELF", "elf" }, + [filetype_imx_image_v1] = { "i.MX image (v1)", "imx-image-v1" }, }; const char *file_type_to_string(enum filetype f) @@ -250,6 +253,7 @@ enum filetype file_detect_type(const void *_buf, size_t bufsize) const u64 *buf64 = _buf; const u8 *buf8 = _buf; const u16 *buf16 = _buf; + const struct imx_flash_header *imx_flash_header = _buf; enum filetype type; if (bufsize < 9) @@ -361,6 +365,9 @@ enum filetype file_detect_type(const void *_buf, size_t bufsize) if (strncmp(buf8, ELFMAG, 4) == 0) return filetype_elf; + if (imx_flash_header->dcd_barker == DCD_BARKER) + return filetype_imx_image_v1; + return filetype_unknown; } diff --git a/include/filetype.h b/include/filetype.h index 237ed3fbe..e2df5fabf 100644 --- a/include/filetype.h +++ b/include/filetype.h @@ -43,6 +43,7 @@ enum filetype { filetype_android_sparse, filetype_arm64_linux_image, filetype_elf, + filetype_imx_image_v1, filetype_max, }; -- 2.17.1 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox