public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31
@ 2009-11-12 18:39 Magnus Lilja
  2009-11-12 18:39 ` [U-Boot] [PATCH v2 1/3] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
  2010-01-04 20:01 ` [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja
  0 siblings, 2 replies; 5+ messages in thread
From: Magnus Lilja @ 2009-11-12 18:39 UTC (permalink / raw)
  To: u-boot

Hi all,

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

Tested on i.MX31 Litekit. MAKEALL ARM11&ARM9 performed.

Changes since v1: Changed variable name in mxc_nand.c.

Regards, Magnus



Magnus Lilja (3):
  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.

 drivers/mtd/nand/mxc_nand.c           |   34 ++++++++++++++++++++++++++--
 include/asm-arm/arch-mx31/mx31-regs.h |   39 +++++++++++++++++++++++++++++++++
 include/configs/imx31_litekit.h       |   10 ++++++++
 3 files changed, 80 insertions(+), 3 deletions(-)

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

* [U-Boot] [PATCH v2 1/3] MX31: Add struct definition for clock control module in i.MX31.
  2009-11-12 18:39 [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja
@ 2009-11-12 18:39 ` Magnus Lilja
  2009-11-12 18:39   ` [U-Boot] [PATCH v2 2/3] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
  2010-01-04 20:01 ` [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja
  1 sibling, 1 reply; 5+ messages in thread
From: Magnus Lilja @ 2009-11-12 18:39 UTC (permalink / raw)
  To: u-boot

Signed-off-by: Magnus Lilja <lilja.magnus@gmail.com>
---
 include/asm-arm/arch-mx31/mx31-regs.h |   39 +++++++++++++++++++++++++++++++++
 1 files changed, 39 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..6f6e9a4 100644
--- a/include/asm-arm/arch-mx31/mx31-regs.h
+++ b/include/asm-arm/arch-mx31/mx31-regs.h
@@ -24,6 +24,45 @@
 #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 clock_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;
+};
+
+/* 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] 5+ messages in thread

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

Tested on i.MX31 Litekit.

Signed-off-by: Magnus Lilja <lilja.magnus@gmail.com>
Acked-by: Scott Wood <scottwood@freescale.com>
---

Change since v1: Renamed sc_regs variable for i.MX31 to cc_regs.

 drivers/mtd/nand/mxc_nand.c |   34 +++++++++++++++++++++++++++++++---
 1 files changed, 31 insertions(+), 3 deletions(-)

diff --git a/drivers/mtd/nand/mxc_nand.c b/drivers/mtd/nand/mxc_nand.c
index eb0323f..3ce3adb 100644
--- a/drivers/mtd/nand/mxc_nand.c
+++ b/drivers/mtd/nand/mxc_nand.c
@@ -149,6 +149,36 @@ static struct nand_ecclayout nand_soft_eccoob = {
 };
 #endif
 
+#ifdef CONFIG_MX27
+static int is_16bit_nand(void)
+{
+	struct system_control_regs *sc_regs =
+		(struct system_control_regs *)IMX_SYSTEM_CTL_BASE;
+
+	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
+		return 1;
+	else
+		return 0;
+}
+#elif defined(CONFIG_MX31)
+static int is_16bit_nand(void)
+{
+	struct clock_control_regs *cc_regs =
+		(struct clock_control_regs *)CCM_BASE;
+
+	if (readl(&cc_regs->rcsr) & CCM_RCSR_NF16B)
+		return 1;
+	else
+		return 0;
+}
+#else
+#warning "8/16 bit NAND autodetection not supported"
+static int is_16bit_nand(void)
+{
+	return 0;
+}
+#endif
+
 static uint32_t *mxc_nand_memcpy32(uint32_t *dest, uint32_t *source, size_t size)
 {
 	uint32_t *d = dest;
@@ -808,8 +838,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,7 +899,7 @@ int board_nand_init(struct nand_chip *this)
 	writew(0x4, &host->regs->nfc_wrprot);
 
 	/* NAND bus width determines access funtions used by upper layer */
-	if (readl(&sc_regs->fmcr) & NF_16BIT_SEL)
+	if (is_16bit_nand())
 		this->options |= NAND_BUSWIDTH_16;
 
 	host->pagesize_2k = 0;
-- 
1.5.6

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

* [U-Boot] [PATCH v2 3/3] MX31: Activate NAND support for i.MX31 Litekit board.
  2009-11-12 18:39   ` [U-Boot] [PATCH v2 2/3] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
@ 2009-11-12 18:39     ` Magnus Lilja
  0 siblings, 0 replies; 5+ messages in thread
From: Magnus Lilja @ 2009-11-12 18:39 UTC (permalink / raw)
  To: u-boot

Signed-off-by: Magnus Lilja <lilja.magnus@gmail.com>
---
 include/configs/imx31_litekit.h |   10 ++++++++++
 1 files changed, 10 insertions(+), 0 deletions(-)

diff --git a/include/configs/imx31_litekit.h b/include/configs/imx31_litekit.h
index 6131008..f413994 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,13 @@
 #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_MXC_NAND_HWECC
+
 #endif /* __CONFIG_H */
-- 
1.5.6

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

* [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31
  2009-11-12 18:39 [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja
  2009-11-12 18:39 ` [U-Boot] [PATCH v2 1/3] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
@ 2010-01-04 20:01 ` Magnus Lilja
  1 sibling, 0 replies; 5+ messages in thread
From: Magnus Lilja @ 2010-01-04 20:01 UTC (permalink / raw)
  To: u-boot

Hi


I received no further comments on these patches after posting
v2 (the NAND part is ACK-ed by Scott Wood). Could someone
pull these? I applied them to the current u-boot tip without
any problems.

Regads, Magnus

Magnus Lilja skrev:
> Hi all,
> 
> This series adds NAND support for i.MX31 using the mxc_nand driver
> that was added for i.MX27. The same NAND flash controller is used
> in i.MX31.
> 
> Tested on i.MX31 Litekit. MAKEALL ARM11&ARM9 performed.
> 
> Changes since v1: Changed variable name in mxc_nand.c.
> 
> Regards, Magnus
> 
> 
> 
> Magnus Lilja (3):
>   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.
> 
>  drivers/mtd/nand/mxc_nand.c           |   34 ++++++++++++++++++++++++++--
>  include/asm-arm/arch-mx31/mx31-regs.h |   39 +++++++++++++++++++++++++++++++++
>  include/configs/imx31_litekit.h       |   10 ++++++++
>  3 files changed, 80 insertions(+), 3 deletions(-)
> 
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot

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

end of thread, other threads:[~2010-01-04 20:01 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-11-12 18:39 [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja
2009-11-12 18:39 ` [U-Boot] [PATCH v2 1/3] MX31: Add struct definition for clock control module in i.MX31 Magnus Lilja
2009-11-12 18:39   ` [U-Boot] [PATCH v2 2/3] mxc_nand: Update driver to work with i.MX31 Magnus Lilja
2009-11-12 18:39     ` [U-Boot] [PATCH v2 3/3] MX31: Activate NAND support for i.MX31 Litekit board Magnus Lilja
2010-01-04 20:01 ` [U-Boot] [PATCH v2 0/3] MXC: Add NAND support for i.MX31 Magnus Lilja

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