X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fstaging%2Fyousong.git;a=blobdiff_plain;f=target%2Flinux%2Fbrcm63xx%2Fpatches-2.6.35%2F040-bcm963xx_flashmap.patch;h=c1b424d5d8157dca26019575c8d5a96644dc38f0;hp=ad7d73ad1cf8af6bbb8b8ef903ad10e92b3fbcfa;hb=31f7259e3ef8e22109216901c9e13c1868049501;hpb=b1362f94bcc99a2190b0d6778c41e8a21d21aa02 diff --git a/target/linux/brcm63xx/patches-2.6.35/040-bcm963xx_flashmap.patch b/target/linux/brcm63xx/patches-2.6.35/040-bcm963xx_flashmap.patch index ad7d73ad1c..c1b424d5d8 100644 --- a/target/linux/brcm63xx/patches-2.6.35/040-bcm963xx_flashmap.patch +++ b/target/linux/brcm63xx/patches-2.6.35/040-bcm963xx_flashmap.patch @@ -73,7 +73,7 @@ Signed-off-by: Axel Gembe +obj-$(CONFIG_MTD_BCM963XX) += bcm963xx-flash.o --- /dev/null +++ b/drivers/mtd/maps/bcm963xx-flash.c -@@ -0,0 +1,267 @@ +@@ -0,0 +1,314 @@ +/* + * Copyright (C) 2006-2008 Florian Fainelli + * Mike Albon @@ -101,6 +101,8 @@ Signed-off-by: Axel Gembe +#include +#include +#include ++#include ++#include + +#include +#include @@ -110,6 +112,12 @@ Signed-off-by: Axel Gembe + +#define PFX KBUILD_MODNAME ": " + ++struct squashfs_super_block { ++ __le32 s_magic; ++ __le32 pad0[9]; ++ __le64 bytes_used; ++}; ++ +extern int parse_redboot_partitions(struct mtd_info *master, struct mtd_partition **pparts, unsigned long fis_origin); +static struct mtd_partition *parsed_parts; + @@ -120,7 +128,6 @@ Signed-off-by: Axel Gembe + .bankwidth = BUSWIDTH, +}; + -+ +static int parse_cfe_partitions( struct mtd_info *master, struct mtd_partition **pparts) +{ + int nrparts = 3, curpart = 0; /* CFE,NVRAM and global LINUX are always present. */ @@ -131,9 +138,10 @@ Signed-off-by: Axel Gembe + unsigned int rootfsaddr, kerneladdr, spareaddr; + unsigned int rootfslen, kernellen, sparelen, totallen; + int namelen = 0; -+ int i; ++ int i, offset; + char *boardid; -+ char *tagversion; ++ char *tagversion; ++ struct squashfs_super_block sb; + + /* Allocate memory for buffer */ + buf = vmalloc(sizeof(struct bcm_tag)); @@ -157,9 +165,48 @@ Signed-off-by: Axel Gembe + + kerneladdr = kerneladdr - EXTENDED_SIZE; + rootfsaddr = kerneladdr + kernellen; ++ ++ // offset = master->erasesize + sizeof(struct bcm_tag) + kernellen; ++ offset = rootfsaddr; ++ ret = master->read(master, offset, sizeof(sb), &retlen, (void *) &sb); ++ if (ret || (retlen != sizeof(sb))) { ++ printk(KERN_ALERT PFX "parse_cfe_partitions: error occured while reading " ++ "from \"%s\"\n", master->name); ++ return -EINVAL; ++ } ++ ++ // if (SQUASHFS_MAGIC != le32_to_cpu(sb.s_magic) ) { ++ printk(KERN_DEBUG PFX "Squash magic %08lx: Found: %08lx\n", (long unsigned int)SQUASHFS_MAGIC, (long unsigned int)le32_to_cpu(sb.s_magic)); ++ if ((uint32_t)SQUASHFS_MAGIC != (uint32_t)le32_to_cpu(sb.s_magic) ) { ++ /* Not a squashfs image */ ++ printk(KERN_DEBUG PFX "No squashfs image in \"%s\"\n", master->name); ++ printk(KERN_DEBUG PFX "Jffs magic %04x: Found: %04x\n", (uint16_t)(JFFS2_MAGIC_BITMASK), *(uint16_t *)(&sb)); ++ if (*(uint16_t *)(&sb) == JFFS2_MAGIC_BITMASK) { ++ printk(KERN_DEBUG PFX "jffs image in \"%s\"\n", master->name); ++ /* Is JFFS2 so have rootfslen so that true length gets calculated */ ++ rootfslen = master->size - master->erasesize - offset; ++ } else { ++ /* We only recognize squashfs and jffs2. If it's not either of these, ++ don't create a rootfs partition. */ ++ printk(KERN_INFO PFX "No known root filesystem in \"%s\"\n", master->name); ++ rootfslen = 0; ++ } ++ } else { ++ /* Is a squash image so find where the squash ends */ ++ if (le64_to_cpu((sb.bytes_used)) <= 0) { ++ printk(KERN_ALERT PFX "split_squashfs: squashfs is empty in \"%s\"\n", ++ master->name); ++ return 0; ++ } ++ ++ rootfslen = (u32) le64_to_cpu(sb.bytes_used); ++ } ++ ++ rootfslen = ( ( rootfslen % master->erasesize ) > 0 ? (((rootfslen / master->erasesize) + 1 ) * master->erasesize) : rootfslen); ++ totallen = rootfslen + kernellen + sizeof(struct bcm_tag); ++ + spareaddr = roundup(totallen, master->erasesize) + master->erasesize; + sparelen = master->size - spareaddr - master->erasesize; -+ rootfslen = spareaddr - rootfsaddr; + + /* Determine number of partitions */ + namelen = 8;