kernel: move old firmware uimage splitter into separated patch
[openwrt.git] / target / linux / generic / patches-3.14 / 407-mtd-old-firmware-uimage-splitter.patch
1 --- a/drivers/mtd/Kconfig
2 +++ b/drivers/mtd/Kconfig
3 @@ -27,6 +27,11 @@ config MTD_SPLIT_FIRMWARE_NAME
4         depends on MTD_SPLIT_FIRMWARE
5         default "firmware"
6  
7 +config MTD_UIMAGE_SPLIT
8 +       bool "Enable split support for firmware partitions containing a uImage"
9 +       depends on MTD_SPLIT_FIRMWARE
10 +       default y
11 +
12  source "drivers/mtd/mtdsplit/Kconfig"
13  
14  config MTD_SPLIT
15 --- a/drivers/mtd/mtdpart.c
16 +++ b/drivers/mtd/mtdpart.c
17 @@ -668,6 +668,32 @@ mtd_pad_erasesize(struct mtd_info *mtd,
18         return len;
19  }
20  
21 +#define UBOOT_MAGIC    0x27051956
22 +
23 +static void split_uimage(struct mtd_info *master, struct mtd_part *part)
24 +{
25 +       struct {
26 +               __be32 magic;
27 +               __be32 pad[2];
28 +               __be32 size;
29 +       } hdr;
30 +       size_t len;
31 +
32 +       if (mtd_read(master, part->offset, sizeof(hdr), &len, (void *) &hdr))
33 +               return;
34 +
35 +       if (len != sizeof(hdr) || hdr.magic != cpu_to_be32(UBOOT_MAGIC))
36 +               return;
37 +
38 +       len = be32_to_cpu(hdr.size) + 0x40;
39 +       len = mtd_pad_erasesize(master, part->offset, len);
40 +       if (len + master->erasesize > part->mtd.size)
41 +               return;
42 +
43 +       __mtd_add_partition(master, "rootfs", part->offset + len,
44 +                           part->mtd.size - len, false);
45 +}
46 +
47  #ifdef CONFIG_MTD_SPLIT_FIRMWARE_NAME
48  #define SPLIT_FIRMWARE_NAME    CONFIG_MTD_SPLIT_FIRMWARE_NAME
49  #else
50 @@ -676,7 +702,14 @@ mtd_pad_erasesize(struct mtd_info *mtd,
51  
52  static void split_firmware(struct mtd_info *master, struct mtd_part *part)
53  {
54 -       run_parsers_by_type(part, MTD_PARSER_TYPE_FIRMWARE);
55 +       int ret;
56 +
57 +       ret = run_parsers_by_type(part, MTD_PARSER_TYPE_FIRMWARE);
58 +       if (ret > 0)
59 +               return;
60 +
61 +       if (config_enabled(CONFIG_MTD_UIMAGE_SPLIT))
62 +               split_uimage(master, part);
63  }
64  
65  void __weak arch_split_mtd_part(struct mtd_info *master, const char *name,