aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch
diff options
context:
space:
mode:
authorFlorian Fainelli <florian@openwrt.org>2010-06-13 09:54:01 +0000
committerFlorian Fainelli <florian@openwrt.org>2010-06-13 09:54:01 +0000
commit10e325d73682c436b53896c6f25b51ea64edf5bc (patch)
treec63d28aa2f3de25307d778e63e22ae8f940905b0 /target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch
parent368745c06aea192306cc53407334099e09a91ae0 (diff)
downloadupstream-10e325d73682c436b53896c6f25b51ea64edf5bc.tar.gz
upstream-10e325d73682c436b53896c6f25b51ea64edf5bc.tar.bz2
upstream-10e325d73682c436b53896c6f25b51ea64edf5bc.zip
rename 014-samsung_flash -> 014-samsung_flash.patch
SVN-Revision: 21776
Diffstat (limited to 'target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch')
-rw-r--r--target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch50
1 files changed, 50 insertions, 0 deletions
diff --git a/target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch b/target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch
new file mode 100644
index 0000000000..1b028edd98
--- /dev/null
+++ b/target/linux/generic-2.6/patches-2.6.35/014-samsung_flash.patch
@@ -0,0 +1,50 @@
+--- a/drivers/mtd/chips/cfi_cmdset_0002.c
++++ b/drivers/mtd/chips/cfi_cmdset_0002.c
+@@ -372,6 +372,8 @@ static struct cfi_fixup fixup_table[] =
+ static void cfi_fixup_major_minor(struct cfi_private *cfi,
+ struct cfi_pri_amdstd *extp)
+ {
++ // manufacturers defined in include/linux/mtd/cfi.h
++
+ if (cfi->mfr == CFI_MFR_SAMSUNG && cfi->id == 0x257e &&
+ extp->MajorVersion == '0')
+ extp->MajorVersion = '1';
+@@ -404,6 +406,9 @@ struct mtd_info *cfi_cmdset_0002(struct
+
+ mtd->reboot_notifier.notifier_call = cfi_amdstd_reboot;
+
++ printk(" CFI mfr 0x%08x\n", cfi->mfr); // TODO: Is there a more general place to print this info?
++ printk(" CFI id 0x%08x\n", cfi->id);
++
+ if (cfi->cfi_mode==CFI_MODE_CFI){
+ unsigned char bootloc;
+ __u16 adr = primary?cfi->cfiq->P_ADR:cfi->cfiq->A_ADR;
+@@ -417,16 +422,24 @@ struct mtd_info *cfi_cmdset_0002(struct
+ */
+ cfi_fixup_major_minor(cfi, extp);
+
+- if (extp->MajorVersion != '1' ||
+- (extp->MinorVersion < '0' || extp->MinorVersion > '4')) {
++ // valid primary extension versions are: 1.0, 1.1, 1.2, 1.3
++ // see: http://www.amd.com/us-en/assets/content_type/DownloadableAssets/cfi_r20.pdf, page 19 and on
++ // http://www.amd.com/us-en/assets/content_type/DownloadableAssets/cfi_100_20011201.pdf
++ if (extp->MajorVersion < '1' ||
++ extp->MajorVersion > '1' ||
++ (extp->MajorVersion == '1' && ( extp->MinorVersion < '0' || extp->MinorVersion > '3'))) {
+ printk(KERN_ERR " Unknown Amd/Fujitsu Extended Query "
+- "version %c.%c.\n", extp->MajorVersion,
+- extp->MinorVersion);
++ "version %c.%c (0x%02x/0x%02x).\n",
++ extp->MajorVersion, extp->MinorVersion,
++ extp->MajorVersion, extp->MinorVersion);
+ kfree(extp);
+ kfree(mtd);
+ return NULL;
+ }
+
++ printk(" Amd/Fujitsu Extended Query version %c.%c.\n",
++ extp->MajorVersion, extp->MinorVersion);
++
+ /* Install our own private info structure */
+ cfi->cmdset_priv = extp;
+