aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2016-02-23 14:40:40 +0000
committerRafał Miłecki <zajec5@gmail.com>2016-02-23 14:40:40 +0000
commit7053f748ef7fb23d0797c37fb79144b1c2c327cf (patch)
treebd1f950336691b1cba8efbcb30d7611093e76933
parent94167891e8d8d3898be792599793b73c0e37f249 (diff)
downloadmaster-187ad058-7053f748ef7fb23d0797c37fb79144b1c2c327cf.tar.gz
master-187ad058-7053f748ef7fb23d0797c37fb79144b1c2c327cf.tar.bz2
master-187ad058-7053f748ef7fb23d0797c37fb79144b1c2c327cf.zip
kernel: mtdsplit: add missing digest field to Seama header
Seama format has 2 similar headers: container (seal) header and entity header. The first one has size always set to 0 and doesn't contain MD5 digest. When dealing with Seama on a flash we deal directly with an entity. You can see mtdsplit_parse_seama reads from offset 0 and expects entity to be there. Seama container is used by bootloader / interface only which extract entity out of it and flash it. That said we should fix our header struct. This is important as we calculate possible rootfs offset assuming it may be placed right after Seama entity. So far calculate offset was always 16B too low. Signed-off-by: Rafał Miłecki <zajec5@gmail.com> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@48754 3c298f89-4303-0410-b956-a3cf2f4a3e73
-rw-r--r--target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_seama.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_seama.c b/target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_seama.c
index f8ddee7ce0..ee0444a43e 100644
--- a/target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_seama.c
+++ b/target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_seama.c
@@ -26,6 +26,7 @@ struct seama_header {
__be16 reserved; /* reserved for */
__be16 metasize; /* size of the META data */
__be32 size; /* size of the image */
+ u8 md5[16]; /* digest */
};
static int mtdsplit_parse_seama(struct mtd_info *master,