Commit d776fbaa authored by David Brownell's avatar David Brownell Committed by Kevin Hilman

davinci_nand: clean up the A1CR hacks

The A1CR hacks aren't really needed on the DM355 EVM; NAND timings
set by UBL (or whatever) are a bit slower than needed, but that's
not too bad.  Remove, but add a comment in board setup.

For the DM6446 EVM, the problem is how to cope with re-jumpering
in the default boot-from-NOR case.  Boards modified to boot from
NAND should already have A1CR timings set up.  Comment this; for
the moment it's a bit nasty to move this code to board setup.
(And remove pointless AWRCC setting.  The "Extended Wait" mode
doesn't work with NAND chips.)

Related -- make board-dm6446-evm.c warn about trying to make NAND
and NOR coexist, and only set up one of them.
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
parent 07a05972
...@@ -234,6 +234,11 @@ static __init void dm355_evm_init(void) ...@@ -234,6 +234,11 @@ static __init void dm355_evm_init(void)
evm_init_i2c(); evm_init_i2c();
davinci_serial_init(&uart_config); davinci_serial_init(&uart_config);
/* NOTE: NAND flash timings set by the UBL are slower than
* needed by MT29F16G08FAA chips ... EMIF.A1CR is 0x40400204
* but could be 0x0400008c.
*/
gpio_request(2, "usb_id_toggle"); gpio_request(2, "usb_id_toggle");
gpio_direction_output(2, USB_ID_VALUE); gpio_direction_output(2, USB_ID_VALUE);
/* irlml6401 switches over 1A in under 8 msec */ /* irlml6401 switches over 1A in under 8 msec */
......
...@@ -646,8 +646,10 @@ static __init void davinci_evm_init(void) ...@@ -646,8 +646,10 @@ static __init void davinci_evm_init(void)
if (HAS_NAND) { if (HAS_NAND) {
platform_device_register(&davinci_evm_nandflash_device); platform_device_register(&davinci_evm_nandflash_device);
evm_leds[7].default_trigger = "nand-disk"; evm_leds[7].default_trigger = "nand-disk";
}
if (HAS_NOR) if (HAS_NOR)
pr_warning("WARNING: both NAND and NOR flash "
"are enabled; disable one of them.\n");
} else if (HAS_NOR)
platform_device_register(&davinci_evm_norflash_device); platform_device_register(&davinci_evm_norflash_device);
} }
......
...@@ -283,70 +283,18 @@ static int nand_davinci_dev_ready(struct mtd_info *mtd) ...@@ -283,70 +283,18 @@ static int nand_davinci_dev_ready(struct mtd_info *mtd)
return davinci_nand_readl(info, NANDFSR_OFFSET) & BIT(0); return davinci_nand_readl(info, NANDFSR_OFFSET) & BIT(0);
} }
static void __init nand_dm355evm_flash_init(struct davinci_nand_info *info)
{
u32 val, tmp;
/*
* For AEMIFCLK at 108.0 MHz (9.26 nsec/tick) these timings:
* - have small (a few nsec) margins for pcb+socket delays
* - assume standard mode operations (not cache mode)
* - are WAY OFF for turnaround not gated by ARM instructions
*
* Write setup (tCS, tDS) min 15 nsec
* Write strobes (tWP) could be subsumed in setup
*
* Read setup (tCEA - tREA) min 5 nsec
* Read strobes (tRP) min 12 nsec
*
* Hold times (tALH, tCLH, tCH, tDH) min 5 nsec
* Read and write cycle times (tRC, tWC) min 25 nsec
* Turnaround (tWHR, tRHW) min 100 nsec
*/
val = 0
| (0 << 31) /* selectStrobe normal mode */
| (0 << 30) /* extWait mbz for NAND */
/* WRITE: */
| (1 << 26) /* Setup 2 ticks (18 ns) */
| (0 << 20) /* Strobe 1 tick (9 ns) */
| (0 << 17) /* Hold 1 tick (9 ns) */
/* READ: */
| (0 << 13) /* Setup 1 tick (9 ns) */
| (1 << 7) /* Strobe 2 ticks (18 ns) */
| (0 << 4) /* Hold 1 tick (9 ns) */
| (3 << 2) /* turnAround 3 ticks (TOO LOW) */
| (0 << 0) /* asyncSize eight-bit bus */
;
tmp = davinci_nand_readl(info, A1CR_OFFSET);
if (tmp != val) {
dev_dbg(info->dev, "NAND config: Set A1CR "
"to 0x%08x, was 0x%08x\n", val, tmp);
davinci_nand_writel(info, A1CR_OFFSET, val);
}
}
static void __init nand_dm6446evm_flash_init(struct davinci_nand_info *info) static void __init nand_dm6446evm_flash_init(struct davinci_nand_info *info)
{ {
u32 regval, tmp; u32 regval, tmp;
regval = davinci_nand_readl(info, AWCCR_OFFSET); /*
regval |= 0x10000000; * NAND FLASH timings @ PLL1 == 459 MHz
davinci_nand_writel(info, AWCCR_OFFSET, regval); * - AEMIF.CLK freq = PLL1/6 = 459/6 = 76.5 MHz
* - AEMIF.CLK period = 1/76.5 MHz = 13.1 ns
/*------------------------------------------------------------------* */
* NAND FLASH CHIP TIMEOUT @ 459 MHz *
* *
* AEMIF.CLK freq = PLL1/6 = 459/6 = 76.5 MHz *
* AEMIF.CLK period = 1/76.5 MHz = 13.1 ns *
* *
*------------------------------------------------------------------*/
regval = 0 regval = 0
| (0 << 31) /* selectStrobe */ | (0 << 31) /* selectStrobe */
| (0 << 30) /* extWait */ | (0 << 30) /* extWait (never with NAND) */
| (1 << 26) /* writeSetup 10 ns */ | (1 << 26) /* writeSetup 10 ns */
| (3 << 20) /* writeStrobe 40 ns */ | (3 << 20) /* writeStrobe 40 ns */
| (1 << 17) /* writeHold 10 ns */ | (1 << 17) /* writeHold 10 ns */
...@@ -503,9 +451,13 @@ static int __init nand_davinci_probe(struct platform_device *pdev) ...@@ -503,9 +451,13 @@ static int __init nand_davinci_probe(struct platform_device *pdev)
goto err_clk_enable; goto err_clk_enable;
} }
/* FIXME these don't belong here ... */ /* EMIF timings should normally be set by the boot loader,
if (machine_is_davinci_dm355_evm()) * especially after boot-from-NAND. The *only* reason to
nand_dm355evm_flash_init(info); * have this special casing for the DM6446 EVM is to work
* with boot-from-NOR ... with CS0 manually re-jumpered
* (after startup) so it addresses the NAND flash, not NOR.
* Even for dev boards, that's unusually rude...
*/
if (machine_is_davinci_evm()) if (machine_is_davinci_evm())
nand_dm6446evm_flash_init(info); nand_dm6446evm_flash_init(info);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment