linux-mtd.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM NOR chips
@ 2010-12-08 16:00 Guillaume LECERF
  2010-12-08 16:00 ` [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC " Guillaume LECERF
  2010-12-08 16:32 ` [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM " Wolfram Sang
  0 siblings, 2 replies; 4+ messages in thread
From: Guillaume LECERF @ 2010-12-08 16:00 UTC (permalink / raw)
  To: linux-mtd; +Cc: Matthias Buecher / Germany, David Woodhouse

These chips report CFI v0.0 [1], so extend cfi_fixup_major_minor()
to patch all Samsung chips with Major == 0 to 1.0.
Discussed and tested by the OpenWRT people [2].

[1] http://www.samsung.com/global/system/business/semiconductor/product/2007/6/11/NORFlash/64Mbit/K8D6316UTM/ds_K8D6x16UxM_rev16.pdf
[2] https://dev.openwrt.org/ticket/7348

Signed-off-by: Guillaume LECERF <glecerf@gmail.com>
---
 drivers/mtd/chips/cfi_cmdset_0002.c |   16 +++++++++++++---
 1 files changed, 13 insertions(+), 3 deletions(-)

diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c
index 9d68ab9..7966f07 100644
--- a/drivers/mtd/chips/cfi_cmdset_0002.c
+++ b/drivers/mtd/chips/cfi_cmdset_0002.c
@@ -392,9 +392,19 @@ static struct cfi_fixup fixup_table[] = {
 static void cfi_fixup_major_minor(struct cfi_private *cfi,
 				  struct cfi_pri_amdstd *extp)
 {
-	if (cfi->mfr == CFI_MFR_SAMSUNG && cfi->id == 0x257e &&
-	    extp->MajorVersion == '0')
-		extp->MajorVersion = '1';
+	if (cfi->mfr == CFI_MFR_SAMSUNG) {
+		if (extp->MajorVersion == '0') {
+			/*
+			 * Samsung K8P2815UQB and K8D6x16UxM chips report major=0 / minor=0
+			 */
+			printk(KERN_NOTICE "  Fixed Samsung's Amd/Fujitsu Extended Query version from 0.%c to 1.0\n",
+			       extp->MinorVersion);
+
+			extp->MajorVersion = '1';
+			extp->MinorVersion = '0';
+		}
+	}
+
 	/*
 	 * SST 38VF640x chips report major=0xFF / minor=0xFF.
 	 */

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC NOR chips
  2010-12-08 16:00 [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM NOR chips Guillaume LECERF
@ 2010-12-08 16:00 ` Guillaume LECERF
  2010-12-08 16:29   ` Wolfram Sang
  2010-12-08 16:32 ` [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM " Wolfram Sang
  1 sibling, 1 reply; 4+ messages in thread
From: Guillaume LECERF @ 2010-12-08 16:00 UTC (permalink / raw)
  To: linux-mtd; +Cc: Matthias Buecher / Germany, David Woodhouse

These chips report CFI v3.3 [1], so patch them on the fly to the more
correct v1.3.
Discussed and tested by the OpenWRT people [2].

[1] http://www.samsung.com/global/system/business/semiconductor/product/2007/6/11/NORFlash/32Mbit/K8D3216UBC/ds_K8D3x16UxC_rev17.pdf
[2] https://dev.openwrt.org/ticket/866

Signed-off-by: Guillaume LECERF <glecerf@gmail.com>
---
 drivers/mtd/chips/cfi_cmdset_0002.c |    8 ++++++++
 1 files changed, 8 insertions(+), 0 deletions(-)

diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c
index 7966f07..8ad6ee9 100644
--- a/drivers/mtd/chips/cfi_cmdset_0002.c
+++ b/drivers/mtd/chips/cfi_cmdset_0002.c
@@ -403,6 +403,14 @@ static void cfi_fixup_major_minor(struct cfi_private *cfi,
 			extp->MajorVersion = '1';
 			extp->MinorVersion = '0';
 		}
+		if (extp->MajorVersion == '3' && extp->MinorVersion == '3') {
+			/*
+			 * Samsung K8D3x16UxC chips report major=3 / minor=3
+			 */
+			printk(KERN_NOTICE "  Fixed Samsung's Amd/Fujitsu Extended Query version from 3.3 to 1.3\n");
+
+			extp->MajorVersion = '1';
+		}
 	}
 
 	/*

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC NOR chips
  2010-12-08 16:00 ` [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC " Guillaume LECERF
@ 2010-12-08 16:29   ` Wolfram Sang
  0 siblings, 0 replies; 4+ messages in thread
From: Wolfram Sang @ 2010-12-08 16:29 UTC (permalink / raw)
  To: Guillaume LECERF; +Cc: Matthias Buecher / Germany, linux-mtd, David Woodhouse

[-- Attachment #1: Type: text/plain, Size: 658 bytes --]

On Wed, Dec 08, 2010 at 05:00:23PM +0100, Guillaume LECERF wrote:
> These chips report CFI v3.3 [1], so patch them on the fly to the more
> correct v1.3.
> Discussed and tested by the OpenWRT people [2].
> 
> [1] http://www.samsung.com/global/system/business/semiconductor/product/2007/6/11/NORFlash/32Mbit/K8D3216UBC/ds_K8D3x16UxC_rev17.pdf
> [2] https://dev.openwrt.org/ticket/866
> 
> Signed-off-by: Guillaume LECERF <glecerf@gmail.com>

Acked-by: Wolfram Sang <w.sang@pengutronix.de>

-- 
Pengutronix e.K.                           | Wolfram Sang                |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM NOR chips
  2010-12-08 16:00 [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM NOR chips Guillaume LECERF
  2010-12-08 16:00 ` [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC " Guillaume LECERF
@ 2010-12-08 16:32 ` Wolfram Sang
  1 sibling, 0 replies; 4+ messages in thread
From: Wolfram Sang @ 2010-12-08 16:32 UTC (permalink / raw)
  To: Guillaume LECERF; +Cc: Matthias Buecher / Germany, linux-mtd, David Woodhouse

[-- Attachment #1: Type: text/plain, Size: 2170 bytes --]

On Wed, Dec 08, 2010 at 05:00:18PM +0100, Guillaume LECERF wrote:
> These chips report CFI v0.0 [1], so extend cfi_fixup_major_minor()
> to patch all Samsung chips with Major == 0 to 1.0.
> Discussed and tested by the OpenWRT people [2].
> 
> [1] http://www.samsung.com/global/system/business/semiconductor/product/2007/6/11/NORFlash/64Mbit/K8D6316UTM/ds_K8D6x16UxM_rev16.pdf
> [2] https://dev.openwrt.org/ticket/7348
> 
> Signed-off-by: Guillaume LECERF <glecerf@gmail.com>

One question left:

> ---
>  drivers/mtd/chips/cfi_cmdset_0002.c |   16 +++++++++++++---
>  1 files changed, 13 insertions(+), 3 deletions(-)
> 
> diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c
> index 9d68ab9..7966f07 100644
> --- a/drivers/mtd/chips/cfi_cmdset_0002.c
> +++ b/drivers/mtd/chips/cfi_cmdset_0002.c
> @@ -392,9 +392,19 @@ static struct cfi_fixup fixup_table[] = {
>  static void cfi_fixup_major_minor(struct cfi_private *cfi,
>  				  struct cfi_pri_amdstd *extp)
>  {
> -	if (cfi->mfr == CFI_MFR_SAMSUNG && cfi->id == 0x257e &&
> -	    extp->MajorVersion == '0')
> -		extp->MajorVersion = '1';
> +	if (cfi->mfr == CFI_MFR_SAMSUNG) {
> +		if (extp->MajorVersion == '0') {
> +			/*
> +			 * Samsung K8P2815UQB and K8D6x16UxM chips report major=0 / minor=0

The code below is prepared to show minor != 0, so is the comment above
apropriate? Given that it is okay to fixup major = 0 and minor != 0 to
1.0, you can add my

Acked-by: Wolfram Sang <w.sang@pengutronix.de>

> +			 */
> +			printk(KERN_NOTICE "  Fixed Samsung's Amd/Fujitsu Extended Query version from 0.%c to 1.0\n",
> +			       extp->MinorVersion);
> +
> +			extp->MajorVersion = '1';
> +			extp->MinorVersion = '0';
> +		}
> +	}
> +
>  	/*
>  	 * SST 38VF640x chips report major=0xFF / minor=0xFF.
>  	 */
> 
> 
> ______________________________________________________
> Linux MTD discussion mailing list
> http://lists.infradead.org/mailman/listinfo/linux-mtd/

-- 
Pengutronix e.K.                           | Wolfram Sang                |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2010-12-08 16:32 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-12-08 16:00 [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM NOR chips Guillaume LECERF
2010-12-08 16:00 ` [PATCH v3 2/2] mtd: cfi_cmdset_0002: add support for Samsung K8D3x16UxC " Guillaume LECERF
2010-12-08 16:29   ` Wolfram Sang
2010-12-08 16:32 ` [PATCH v3 1/2] mtd: cfi_cmdset_0002: add support for Samsung K8D6x16UxM " Wolfram Sang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).