to make u-boot work for fat32 filesystem
[jz_uboot.git] / cpu / mips / jz4730_nand.c
blobfe713609b5513d65a15eee50dc0b43e79ad9b2e2
1 /*
2 * Platform independend driver for JZ4730.
4 * Copyright (c) 2007 Ingenic Semiconductor Inc.
5 * Author: <jlwei@ingenic.cn>
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License as
9 * published by the Free Software Foundation; either version 2 of
10 * the License, or (at your option) any later version.
12 #include <common.h>
14 #if (CONFIG_COMMANDS & CFG_CMD_NAND) && defined(CONFIG_JZ4730)
16 #include <nand.h>
18 #include <asm/jz4730.h>
20 static void jz_hwcontrol(struct mtd_info *mtd, int cmd)
22 struct nand_chip *this = (struct nand_chip *)(mtd->priv);
23 switch (cmd) {
24 case NAND_CTL_SETNCE:
25 REG_EMC_NFCSR |= EMC_NFCSR_FCE;
26 break;
28 case NAND_CTL_CLRNCE:
29 REG_EMC_NFCSR &= ~EMC_NFCSR_FCE;
30 break;
32 case NAND_CTL_SETCLE:
33 this->IO_ADDR_W = (void __iomem *)((unsigned long)(this->IO_ADDR_W) | 0x00040000);
34 break;
36 case NAND_CTL_CLRCLE:
37 this->IO_ADDR_W = (void __iomem *)((unsigned long)(this->IO_ADDR_W) & ~0x00040000);
38 break;
40 case NAND_CTL_SETALE:
41 this->IO_ADDR_W = (void __iomem *)((unsigned long)(this->IO_ADDR_W) | 0x00080000);
42 break;
44 case NAND_CTL_CLRALE:
45 this->IO_ADDR_W = (void __iomem *)((unsigned long)(this->IO_ADDR_W) & ~0x00080000);
46 break;
50 static int jz_device_ready(struct mtd_info *mtd)
52 int ready;
53 ready = (REG_EMC_NFCSR & EMC_NFCSR_RB) ? 1 : 0;
54 return ready;
58 * EMC setup
60 static void jz_device_setup(void)
62 /* Set NFE bit */
63 REG_EMC_NFCSR |= EMC_NFCSR_NFE;
64 REG_EMC_SMCR3 = 0x04444400;
67 void board_nand_select_device(struct nand_chip *nand, int chip)
70 * Don't use "chip" to address the NAND device,
71 * generate the cs from the address where it is encoded.
76 * Main initialization routine
78 void board_nand_init(struct nand_chip *nand)
80 jz_device_setup();
82 nand->eccmode = NAND_ECC_NONE; /* FIXME: should use NAND_ECC_SOFT */
83 nand->hwcontrol = jz_hwcontrol;
84 nand->dev_ready = jz_device_ready;
86 /* Set address of NAND IO lines */
87 nand->IO_ADDR_R = (void __iomem *) CFG_NAND_BASE;
88 nand->IO_ADDR_W = (void __iomem *) CFG_NAND_BASE;
90 /* 20 us command delay time */
91 nand->chip_delay = 20;
94 #endif /* (CONFIG_COMMANDS & CFG_CMD_NAND) */