public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [RFC 0/4] MXC: Add NAND support for i.MX31
@ 2009-11-08 10:55 Magnus Lilja
  2009-11-08 10:55 ` [U-Boot] [RFC 1/4] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
  0 siblings, 1 reply; 7+ messages in thread
From: Magnus Lilja @ 2009-11-08 10:55 UTC (permalink / raw)
  To: u-boot

Hi all,

This series adds NAND support for i.MX31 using the mxc_nand that was
added for i.MX27. The same NAND Flash Controller is used in i.MX31.

I've done some limited run-time testing on the Litekit using small
page NAND and it seems to work.

I have embedded a question in patch #2 and #4, this relates to where
the 16 bit SoC specific auto detection code shall be placed.


Once I've received input on the open question I will clean up the series
and do the necessary MAKEALL tests (not done at the moment), add 
signed-off-by and re-submit.



On a separate note, the Linux version of mxc_nand.c is undergoing updates
(don't think the patches have been accepted yet) and unfortunately it's
not just a matter of copying the new version since the uboot version was
converted to use readw(&host->regs->register) instead of 
readw(host->regs + REGISTER). 
But in any case, there may be things to import to u-boot.


Regards, Magnus

Magnus Lilja (4):
  MX31: Add struct definition for clock control module in i.MX31.
  mxc_nand: Update driver to work with i.MX31.
  MX31: Activate NAND support for i.MX31 Litekit board.
  MXC: Reorganize 16 bit nand detection.

 drivers/mtd/nand/mxc_nand.c           |    4 +--
 include/asm-arm/arch-mx27/imx-regs.h  |   13 ++++++++
 include/asm-arm/arch-mx31/mx31-regs.h |   54 +++++++++++++++++++++++++++++++++
 include/configs/imx31_litekit.h       |   11 +++++++
 4 files changed, 79 insertions(+), 3 deletions(-)

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

* [U-Boot] [RFC 1/4] MX31: Add struct definition for clock control module in i.MX31.
  2009-11-08 10:55 [U-Boot] [RFC 0/4] MXC: Add NAND support for i.MX31 Magnus Lilja
@ 2009-11-08 10:55 ` Magnus Lilja
  2009-11-08 10:55   ` [U-Boot] [RFC 2/4] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
  0 siblings, 1 reply; 7+ messages in thread
From: Magnus Lilja @ 2009-11-08 10:55 UTC (permalink / raw)
  To: u-boot

Comment:
The struct is called system_control_registers only because the mxc_nand.c
uses that name. For i.MX31 these registers are called "Clock Control
Registers" so the struct name should be clock_control_registers, while
for i.MX27 they are called "System Control Registers".
---
 include/asm-arm/arch-mx31/mx31-regs.h |   41 +++++++++++++++++++++++++++++++++
 1 files changed, 41 insertions(+), 0 deletions(-)

diff --git a/include/asm-arm/arch-mx31/mx31-regs.h b/include/asm-arm/arch-mx31/mx31-regs.h
index 51b02a2..86c9975 100644
--- a/include/asm-arm/arch-mx31/mx31-regs.h
+++ b/include/asm-arm/arch-mx31/mx31-regs.h
@@ -24,6 +24,47 @@
 #ifndef __ASM_ARCH_MX31_REGS_H
 #define __ASM_ARCH_MX31_REGS_H
 
+#if !(defined(__KERNEL_STRICT_NAMES) || defined(__ASSEMBLY__))
+#include <asm/types.h>
+
+/* Clock control module registers */
+struct system_control_regs {
+	u32 ccmr;
+	u32 pdr0;
+	u32 pdr1;
+	u32 rcsr;
+	u32 mpctl;
+	u32 upctl;
+	u32 spctl;
+	u32 cosr;
+	u32 cgr0;
+	u32 cgr1;
+	u32 cgr2;
+	u32 wimr0;
+	u32 ldc;
+	u32 dcvr0;
+	u32 dcvr1;
+	u32 dcvr2;
+	u32 dcvr3;
+	u32 ltr0;
+	u32 ltr1;
+	u32 ltr2;
+	u32 ltr3;
+	u32 ltbr0;
+	u32 ltbr1;
+	u32 pmcr0;
+	u32 pmcr1;
+	u32 pdr2;
+};
+
+#define IMX_SYSTEM_CTL_BASE (0x53F80000)
+
+/* Bit definitions for RCSR register in CCM */
+#define CCM_RCSR_NF16B	(1 << 31)
+#define CCM_RCSR_NFMS	(1 << 30)
+
+#endif
+
 #define __REG(x)     (*((volatile u32 *)(x)))
 #define __REG16(x)   (*((volatile u16 *)(x)))
 #define __REG8(x)    (*((volatile u8 *)(x)))
-- 
1.5.6

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

* [U-Boot] [RFC 2/4] mxc_nand: Update driver to work with i.MX31.
  2009-11-08 10:55 ` [U-Boot] [RFC 1/4] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
@ 2009-11-08 10:55   ` Magnus Lilja
  2009-11-08 10:55     ` [U-Boot] [RFC 3/4] MX31: Activate NAND support for i.MX31 Litekit board Magnus Lilja
  0 siblings, 1 reply; 7+ messages in thread
From: Magnus Lilja @ 2009-11-08 10:55 UTC (permalink / raw)
  To: u-boot

Comment:
Given how mxc_nand.c looks like (it was written with i.MX27 in mind),
this is the straight forward way of adding i.MX31 support. Personally
I don't like the #ifdef's and prefer the solution presented in a
later patch in this series.
---
 drivers/mtd/nand/mxc_nand.c |    8 +++++++-
 1 files changed, 7 insertions(+), 1 deletions(-)

diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
index eb0323f..3e4254a 100644
--- a/drivers/mtd/nand/mxc_nand.c
+++ b/drivers/mtd/nand/mxc_nand.c
@@ -871,9 +871,15 @@ int board_nand_init(struct nand_chip *this)
 	writew(0x4, &host->regs->nfc_wrprot);
 
 	/* NAND bus width determines access funtions used by upper layer */
+#ifdef CONFIG_MX27
 	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
 		this->options |= NAND_BUSWIDTH_16;
-
+#elif defined(CONFIG_MX31)
+	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
+		this->options |= NAND_BUSWIDTH_16;
+#else
+#warning "No autodetection of 8/16 bit NAND"
+#endif
 	host->pagesize_2k = 0;
 
 	return err;
-- 
1.5.6

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

* [U-Boot] [RFC 3/4] MX31: Activate NAND support for i.MX31 Litekit board.
  2009-11-08 10:55   ` [U-Boot] [RFC 2/4] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
@ 2009-11-08 10:55     ` Magnus Lilja
  2009-11-08 10:55       ` [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection Magnus Lilja
  0 siblings, 1 reply; 7+ messages in thread
From: Magnus Lilja @ 2009-11-08 10:55 UTC (permalink / raw)
  To: u-boot

---
 include/configs/imx31_litekit.h |   11 +++++++++++
 1 files changed, 11 insertions(+), 0 deletions(-)

diff --git a/include/configs/imx31_litekit.h b/include/configs/imx31_litekit.h
index 6131008..7e8ddbb 100644
--- a/include/configs/imx31_litekit.h
+++ b/include/configs/imx31_litekit.h
@@ -89,6 +89,7 @@
 #define CONFIG_CMD_PING
 #define CONFIG_CMD_SPI
 #define CONFIG_CMD_DATE
+#define CONFIG_CMD_NAND
 
 #define CONFIG_BOOTDELAY	3
 
@@ -174,4 +175,14 @@
 #undef CONFIG_CMD_MTDPARTS
 #define CONFIG_JFFS2_DEV	"nor0"
 
+/*
+ * NAND
+ */
+#define CONFIG_NAND_MXC
+#define CONFIG_MXC_NAND_REGS_BASE	NFC_BASE_ADDR
+#define CONFIG_SYS_MAX_NAND_DEVICE	1
+#define CONFIG_SYS_NAND_BASE		NFC_BASE_ADDR
+#define CONFIG_JFFS2_NAND
+#define CONFIG_MXC_NAND_HWECC
+
 #endif /* __CONFIG_H */
-- 
1.5.6

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

* [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection.
  2009-11-08 10:55     ` [U-Boot] [RFC 3/4] MX31: Activate NAND support for i.MX31 Litekit board Magnus Lilja
@ 2009-11-08 10:55       ` Magnus Lilja
  2009-11-09 20:12         ` Scott Wood
  0 siblings, 1 reply; 7+ messages in thread
From: Magnus Lilja @ 2009-11-08 10:55 UTC (permalink / raw)
  To: u-boot

Alternative solution for supporting 16 bit NAND detection for the
i.MX27 and i.MX31 SoCs. This moves the SoC specific code to the SoC header
file leaving mxc_nand.c free from #ifdef's (in this respect).

Question:
Is this approach acceptable/preferred over having #ifdef's for different
SoCs in mxc_nand.c?
---
 drivers/mtd/nand/mxc_nand.c           |   12 ++----------
 include/asm-arm/arch-mx27/imx-regs.h  |   13 +++++++++++++
 include/asm-arm/arch-mx31/mx31-regs.h |   13 +++++++++++++
 3 files changed, 28 insertions(+), 10 deletions(-)

diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
index 3e4254a..45d0024 100644
--- a/drivers/mtd/nand/mxc_nand.c
+++ b/drivers/mtd/nand/mxc_nand.c
@@ -808,8 +808,6 @@ static void mxc_nand_command(struct mtd_info *mtd, unsigned command,
 
 int board_nand_init(struct nand_chip *this)
 {
-	struct system_control_regs *sc_regs =
-		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
 	struct mtd_info *mtd;
 	uint16_t tmp;
 	int err = 0;
@@ -871,15 +869,9 @@ int board_nand_init(struct nand_chip *this)
 	writew(0x4, &host->regs->nfc_wrprot);
 
 	/* NAND bus width determines access funtions used by upper layer */
-#ifdef CONFIG_MX27
-	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
-		this->options |= NAND_BUSWIDTH_16;
-#elif defined(CONFIG_MX31)
-	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
+	if (mxc_nand_is_16bit())
 		this->options |= NAND_BUSWIDTH_16;
-#else
-#warning "No autodetection of 8/16 bit NAND"
-#endif
+
 	host->pagesize_2k = 0;
 
 	return err;
diff --git a/include/asm-arm/arch-mx27/imx-regs.h b/include/asm-arm/arch-mx27/imx-regs.h
index d36a6da..b88fe51 100644
--- a/include/asm-arm/arch-mx27/imx-regs.h
+++ b/include/asm-arm/arch-mx27/imx-regs.h
@@ -516,4 +516,17 @@ struct iim_regs {
 #define IIM0_SCC_KEY		11
 #define IIM1_SUID		1
 
+#ifndef __ASSEMBLY__
+static inline int mxc_nand_is_16bit(void)
+{
+	struct system_control_regs *sc_regs =
+		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
+
+	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
+		return 1;
+	else
+		return 0;
+}
+#endif
+
 #endif				/* _IMX_REGS_H */
diff --git a/include/asm-arm/arch-mx31/mx31-regs.h b/include/asm-arm/arch-mx31/mx31-regs.h
index 86c9975..613c632 100644
--- a/include/asm-arm/arch-mx31/mx31-regs.h
+++ b/include/asm-arm/arch-mx31/mx31-regs.h
@@ -63,6 +63,19 @@ struct system_control_regs {
 #define CCM_RCSR_NF16B	(1 << 31)
 #define CCM_RCSR_NFMS	(1 << 30)
 
+#include <asm/io.h>
+
+static inline int mxc_nand_is_16bit(void)
+{
+	struct system_control_regs *sc_regs =
+		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
+
+	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
+		return 1;
+	else
+		return 0;
+}
+
 #endif
 
 #define __REG(x)     (*((volatile u32 *)(x)))
-- 
1.5.6

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

* [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection.
  2009-11-08 10:55       ` [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection Magnus Lilja
@ 2009-11-09 20:12         ` Scott Wood
  2009-11-10 20:43           ` Magnus Lilja
  0 siblings, 1 reply; 7+ messages in thread
From: Scott Wood @ 2009-11-09 20:12 UTC (permalink / raw)
  To: u-boot

On Sun, Nov 08, 2009 at 11:55:39AM +0100, Magnus Lilja wrote:
> Alternative solution for supporting 16 bit NAND detection for the
> i.MX27 and i.MX31 SoCs. This moves the SoC specific code to the SoC header
> file leaving mxc_nand.c free from #ifdef's (in this respect).

OTOH, it moves more NAND stuff out of the NAND driver.

I guess it depends on how many more such alternatives you think will be
added in the future.

> diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
> index 3e4254a..45d0024 100644
> --- a/drivers/mtd/nand/mxc_nand.c
> +++ b/drivers/mtd/nand/mxc_nand.c
> @@ -808,8 +808,6 @@ static void mxc_nand_command(struct mtd_info *mtd, unsigned command,
>  
>  int board_nand_init(struct nand_chip *this)
>  {
> -	struct system_control_regs *sc_regs =
> -		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
>  	struct mtd_info *mtd;
>  	uint16_t tmp;
>  	int err = 0;
> @@ -871,15 +869,9 @@ int board_nand_init(struct nand_chip *this)
>  	writew(0x4, &host->regs->nfc_wrprot);
>  
>  	/* NAND bus width determines access funtions used by upper layer */
> -#ifdef CONFIG_MX27
> -	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
> -		this->options |= NAND_BUSWIDTH_16;
> -#elif defined(CONFIG_MX31)
> -	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
> +	if (mxc_nand_is_16bit())
>  		this->options |= NAND_BUSWIDTH_16;
> -#else
> -#warning "No autodetection of 8/16 bit NAND"
> -#endif
> +
>  	host->pagesize_2k = 0;
>  
>  	return err;
> diff --git a/include/asm-arm/arch-mx27/imx-regs.h b/include/asm-arm/arch-mx27/imx-regs.h
> index d36a6da..b88fe51 100644
> --- a/include/asm-arm/arch-mx27/imx-regs.h
> +++ b/include/asm-arm/arch-mx27/imx-regs.h
> @@ -516,4 +516,17 @@ struct iim_regs {
>  #define IIM0_SCC_KEY		11
>  #define IIM1_SUID		1
>  
> +#ifndef __ASSEMBLY__
> +static inline int mxc_nand_is_16bit(void)
> +{
> +	struct system_control_regs *sc_regs =
> +		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
> +
> +	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
> +		return 1;
> +	else
> +		return 0;
> +}
> +#endif
> +
>  #endif				/* _IMX_REGS_H */
> diff --git a/include/asm-arm/arch-mx31/mx31-regs.h b/include/asm-arm/arch-mx31/mx31-regs.h
> index 86c9975..613c632 100644
> --- a/include/asm-arm/arch-mx31/mx31-regs.h
> +++ b/include/asm-arm/arch-mx31/mx31-regs.h
> @@ -63,6 +63,19 @@ struct system_control_regs {
>  #define CCM_RCSR_NF16B	(1 << 31)
>  #define CCM_RCSR_NFMS	(1 << 30)
>  
> +#include <asm/io.h>
> +
> +static inline int mxc_nand_is_16bit(void)
> +{
> +	struct system_control_regs *sc_regs =
> +		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
> +
> +	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
> +		return 1;
> +	else
> +		return 0;
> +}
> +
>  #endif

It looks like you put the MX31 version in the MX27 file as well...

-Scott

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

* [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection.
  2009-11-09 20:12         ` Scott Wood
@ 2009-11-10 20:43           ` Magnus Lilja
  0 siblings, 0 replies; 7+ messages in thread
From: Magnus Lilja @ 2009-11-10 20:43 UTC (permalink / raw)
  To: u-boot

Scott Wood skrev:
> On Sun, Nov 08, 2009 at 11:55:39AM +0100, Magnus Lilja wrote:
>> Alternative solution for supporting 16 bit NAND detection for the
>> i.MX27 and i.MX31 SoCs. This moves the SoC specific code to the SoC header
>> file leaving mxc_nand.c free from #ifdef's (in this respect).
> 
> OTOH, it moves more NAND stuff out of the NAND driver.
> 
> I guess it depends on how many more such alternatives you think will be
> added in the future.

I'll figure something out that keeps the NAND stuff in mxc_nand.c and repost.

> 
>> diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
>> index 3e4254a..45d0024 100644
>> --- a/drivers/mtd/nand/mxc_nand.c
>> +++ b/drivers/mtd/nand/mxc_nand.c
>> @@ -808,8 +808,6 @@ static void mxc_nand_command(struct mtd_info *mtd, unsigned command,
>>  
>>  int board_nand_init(struct nand_chip *this)
>>  {
>> -	struct system_control_regs *sc_regs =
>> -		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
>>  	struct mtd_info *mtd;
>>  	uint16_t tmp;
>>  	int err = 0;
>> @@ -871,15 +869,9 @@ int board_nand_init(struct nand_chip *this)
>>  	writew(0x4, &host->regs->nfc_wrprot);
>>  
>>  	/* NAND bus width determines access funtions used by upper layer */
>> -#ifdef CONFIG_MX27
>> -	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
>> -		this->options |= NAND_BUSWIDTH_16;
>> -#elif defined(CONFIG_MX31)
>> -	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
>> +	if (mxc_nand_is_16bit())
>>  		this->options |= NAND_BUSWIDTH_16;
>> -#else
>> -#warning "No autodetection of 8/16 bit NAND"
>> -#endif
>> +
>>  	host->pagesize_2k = 0;
>>  
>>  	return err;
>> diff --git a/include/asm-arm/arch-mx27/imx-regs.h b/include/asm-arm/arch-mx27/imx-regs.h
>> index d36a6da..b88fe51 100644
>> --- a/include/asm-arm/arch-mx27/imx-regs.h
>> +++ b/include/asm-arm/arch-mx27/imx-regs.h
>> @@ -516,4 +516,17 @@ struct iim_regs {
>>  #define IIM0_SCC_KEY		11
>>  #define IIM1_SUID		1
>>  
>> +#ifndef __ASSEMBLY__
>> +static inline int mxc_nand_is_16bit(void)
>> +{
>> +	struct system_control_regs *sc_regs =
>> +		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
>> +
>> +	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
>> +		return 1;
>> +	else
>> +		return 0;
>> +}
>> +#endif
>> +
>>  #endif				/* _IMX_REGS_H */
>> diff --git a/include/asm-arm/arch-mx31/mx31-regs.h b/include/asm-arm/arch-mx31/mx31-regs.h
>> index 86c9975..613c632 100644
>> --- a/include/asm-arm/arch-mx31/mx31-regs.h
>> +++ b/include/asm-arm/arch-mx31/mx31-regs.h
>> @@ -63,6 +63,19 @@ struct system_control_regs {
>>  #define CCM_RCSR_NF16B	(1 << 31)
>>  #define CCM_RCSR_NFMS	(1 << 30)
>>  
>> +#include <asm/io.h>
>> +
>> +static inline int mxc_nand_is_16bit(void)
>> +{
>> +	struct system_control_regs *sc_regs =
>> +		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
>> +
>> +	if (readl(&sc_regs->rcsr) & CCM_RCSR_NF16B)
>> +		return 1;
>> +	else
>> +		return 0;
>> +}
>> +
>>  #endif
> 
> It looks like you put the MX31 version in the MX27 file as well...

Heh, thanks. Will take of that.


Thanks for the feedback

/Magnus

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

end of thread, other threads:[~2009-11-10 20:43 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-11-08 10:55 [U-Boot] [RFC 0/4] MXC: Add NAND support for i.MX31 Magnus Lilja
2009-11-08 10:55 ` [U-Boot] [RFC 1/4] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
2009-11-08 10:55   ` [U-Boot] [RFC 2/4] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
2009-11-08 10:55     ` [U-Boot] [RFC 3/4] MX31: Activate NAND support for i.MX31 Litekit board Magnus Lilja
2009-11-08 10:55       ` [U-Boot] [RFC 4/4] MXC: Reorganize 16 bit nand detection Magnus Lilja
2009-11-09 20:12         ` Scott Wood
2009-11-10 20:43           ` Magnus Lilja

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox