summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2019-08-15 10:58:11 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2019-08-15 10:58:11 +0200
commita3e62ffc7341254fd754886e560865556bc731c8 (patch)
tree927d7536f9a66998b807d8943b05f3242dab6dd2 /common
parenta6aab0ebab471e91beb4e14c2d305b326ac18928 (diff)
parentd15760e59897f71252294b2bea8fe986efdcb1b8 (diff)
downloadbarebox-a3e62ffc7341254fd754886e560865556bc731c8.tar.gz
barebox-a3e62ffc7341254fd754886e560865556bc731c8.tar.xz
Merge branch 'for-next/stm32'
Diffstat (limited to 'common')
-rw-r--r--common/filetype.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/common/filetype.c b/common/filetype.c
index 329f5144bf..825bf25ad1 100644
--- a/common/filetype.c
+++ b/common/filetype.c
@@ -79,6 +79,7 @@ static const struct filetype_str filetype_str[] = {
[filetype_layerscape_qspi_image] = { "Layerscape QSPI image", "layerscape-qspi-PBL" },
[filetype_ubootvar] = { "U-Boot environmemnt variable data",
"ubootvar" },
+ [filetype_stm32_image_v1] = { "STM32 image (v1)", "stm32-image-v1" },
};
const char *file_type_to_string(enum filetype f)
@@ -355,6 +356,14 @@ enum filetype file_detect_type(const void *_buf, size_t bufsize)
if (buf8[0] == 'M' && buf8[1] == 'Z')
return filetype_exe;
+ if (bufsize < 256)
+ return filetype_unknown;
+
+ if (strncmp(buf8, "STM\x32", 4) == 0) {
+ if (buf8[74] == 0x01)
+ return filetype_stm32_image_v1;
+ }
+
if (bufsize < 512)
return filetype_unknown;