2014-08-07 22:41:19 +08:00
|
|
|
--- a/drivers/mtd/mtdpart.c
|
|
|
|
+++ b/drivers/mtd/mtdpart.c
|
2014-09-11 05:40:19 +08:00
|
|
|
@@ -795,8 +795,11 @@ static void split_uimage(struct mtd_info
|
2014-08-07 22:41:19 +08:00
|
|
|
{
|
|
|
|
struct {
|
|
|
|
__be32 magic;
|
|
|
|
- __be32 pad[2];
|
|
|
|
+ __be32 pad0[2];
|
|
|
|
__be32 size;
|
|
|
|
+ __be32 pad1[4];
|
|
|
|
+ __be32 name[7];
|
|
|
|
+ __be32 kern_size;
|
|
|
|
} hdr;
|
|
|
|
size_t len;
|
|
|
|
|
2014-09-11 05:40:19 +08:00
|
|
|
@@ -806,7 +809,11 @@ static void split_uimage(struct mtd_info
|
2014-08-07 22:41:19 +08:00
|
|
|
if (len != sizeof(hdr) || hdr.magic != cpu_to_be32(UBOOT_MAGIC))
|
|
|
|
return;
|
|
|
|
|
|
|
|
- len = be32_to_cpu(hdr.size) + 0x40;
|
|
|
|
+ if (hdr.kern_size != 0 && hdr.name[0] == 0)
|
|
|
|
+ len = be32_to_cpu(hdr.kern_size);
|
|
|
|
+ else
|
|
|
|
+ len = be32_to_cpu(hdr.size) + 0x40;
|
|
|
|
+
|
|
|
|
__mtd_add_partition(master, "rootfs", part->offset + len,
|
|
|
|
part->mtd.size - len, false);
|
|
|
|
}
|