mirror of https://github.com/hak5/openwrt.git
fix kernel oops in the redboot partition parser when CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED is set and there is some free space after the rootfs partition
SVN-Revision: 11948lede-17.01
parent
c385ca9c81
commit
129fcaffb3
|
@ -15,15 +15,15 @@
|
||||||
+ parts[i].size = fl->next->img->flash_base;
|
+ parts[i].size = fl->next->img->flash_base;
|
||||||
+ parts[i].size &= ~(master->erasesize - 1);
|
+ parts[i].size &= ~(master->erasesize - 1);
|
||||||
+ parts[i].size -= parts[i].offset;
|
+ parts[i].size -= parts[i].offset;
|
||||||
+ }
|
|
||||||
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
||||||
+ else {
|
+ nrparts--;
|
||||||
|
+ } else {
|
||||||
+ i++;
|
+ i++;
|
||||||
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
||||||
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
||||||
+ parts[i].name = nullname;
|
+ parts[i].name = nullname;
|
||||||
+ }
|
|
||||||
#endif
|
#endif
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
tmp_fl = fl;
|
tmp_fl = fl;
|
||||||
fl = fl->next;
|
fl = fl->next;
|
||||||
|
|
|
@ -15,15 +15,15 @@
|
||||||
+ parts[i].size = fl->next->img->flash_base;
|
+ parts[i].size = fl->next->img->flash_base;
|
||||||
+ parts[i].size &= ~(master->erasesize - 1);
|
+ parts[i].size &= ~(master->erasesize - 1);
|
||||||
+ parts[i].size -= parts[i].offset;
|
+ parts[i].size -= parts[i].offset;
|
||||||
+ }
|
|
||||||
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
||||||
+ else {
|
+ nrparts--;
|
||||||
|
+ } else {
|
||||||
+ i++;
|
+ i++;
|
||||||
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
||||||
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
||||||
+ parts[i].name = nullname;
|
+ parts[i].name = nullname;
|
||||||
+ }
|
|
||||||
#endif
|
#endif
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
tmp_fl = fl;
|
tmp_fl = fl;
|
||||||
fl = fl->next;
|
fl = fl->next;
|
||||||
|
|
|
@ -15,15 +15,15 @@
|
||||||
+ parts[i].size = fl->next->img->flash_base;
|
+ parts[i].size = fl->next->img->flash_base;
|
||||||
+ parts[i].size &= ~(master->erasesize - 1);
|
+ parts[i].size &= ~(master->erasesize - 1);
|
||||||
+ parts[i].size -= parts[i].offset;
|
+ parts[i].size -= parts[i].offset;
|
||||||
+ }
|
|
||||||
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
||||||
+ else {
|
+ nrparts--;
|
||||||
|
+ } else {
|
||||||
+ i++;
|
+ i++;
|
||||||
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
||||||
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
||||||
+ parts[i].name = nullname;
|
+ parts[i].name = nullname;
|
||||||
+ }
|
|
||||||
#endif
|
#endif
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
tmp_fl = fl;
|
tmp_fl = fl;
|
||||||
fl = fl->next;
|
fl = fl->next;
|
||||||
|
|
|
@ -15,15 +15,15 @@
|
||||||
+ parts[i].size = fl->next->img->flash_base;
|
+ parts[i].size = fl->next->img->flash_base;
|
||||||
+ parts[i].size &= ~(master->erasesize - 1);
|
+ parts[i].size &= ~(master->erasesize - 1);
|
||||||
+ parts[i].size -= parts[i].offset;
|
+ parts[i].size -= parts[i].offset;
|
||||||
+ }
|
|
||||||
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
+#ifdef CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED
|
||||||
+ else {
|
+ nrparts--;
|
||||||
|
+ } else {
|
||||||
+ i++;
|
+ i++;
|
||||||
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
+ parts[i].offset = parts[i-1].size + parts[i-1].offset;
|
||||||
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
+ parts[i].size = fl->next->img->flash_base - parts[i].offset;
|
||||||
+ parts[i].name = nullname;
|
+ parts[i].name = nullname;
|
||||||
+ }
|
|
||||||
#endif
|
#endif
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
tmp_fl = fl;
|
tmp_fl = fl;
|
||||||
fl = fl->next;
|
fl = fl->next;
|
||||||
|
|
Loading…
Reference in New Issue