* [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).