diff options
| author | Wolfgang Denk <wd@nyx.denx.de> | 2006-03-06 11:25:22 +0100 | 
|---|---|---|
| committer | Wolfgang Denk <wd@nyx.denx.de> | 2006-03-06 11:25:22 +0100 | 
| commit | 4e3ccd26925e5ada78dd89779838f052dffe3e67 (patch) | |
| tree | 2df070a78b8f9e69b03b0e0b8bfd01d0d639865e /board/esd/common/auto_update.c | |
| parent | f1ee982506d8e58262ff0e5d1fb208e703640e34 (diff) | |
| parent | addb2e1650fdf872334478393f482dfdce965a61 (diff) | |
| download | olio-uboot-2014.01-4e3ccd26925e5ada78dd89779838f052dffe3e67.tar.xz olio-uboot-2014.01-4e3ccd26925e5ada78dd89779838f052dffe3e67.zip | |
Merge the new NAND code (testing-NAND brach); see doc/README.nand
Rewrite of NAND code based on what is in 2.6.12 Linux kernel
Patch by Ladislav Michl, 29 Jun 2005
[Merge with /home/tur/nand/u-boot]
Diffstat (limited to 'board/esd/common/auto_update.c')
| -rw-r--r-- | board/esd/common/auto_update.c | 28 | 
1 files changed, 18 insertions, 10 deletions
| diff --git a/board/esd/common/auto_update.c b/board/esd/common/auto_update.c index 1decc0ec0..5a70176fa 100644 --- a/board/esd/common/auto_update.c +++ b/board/esd/common/auto_update.c @@ -23,10 +23,15 @@   */  #include <common.h> + +#ifndef CFG_NAND_LEGACY +#error CFG_NAND_LEGACY not defined in a file using the legacy NAND support! +#endif +  #include <command.h>  #include <image.h>  #include <asm/byteorder.h> -#include <linux/mtd/nand.h> +#include <linux/mtd/nand_legacy.h>  #include <fat.h>  #include "auto_update.h" @@ -37,6 +42,9 @@  #error "must define CFG_CMD_FAT"  #endif + + +  extern au_image_t au_image[];  extern int N_AU_IMAGES; @@ -76,9 +84,9 @@ extern block_dev_desc_t *get_dev (char*, int);  #define NANDRW_JFFS2	0x02  #define NANDRW_JFFS2_SKIP	0x04  extern struct nand_chip nand_dev_desc[]; -extern int nand_rw(struct nand_chip* nand, int cmd, size_t start, size_t len, +extern int nand_legacy_rw(struct nand_chip* nand, int cmd, size_t start, size_t len,  		   size_t * retlen, u_char * buf); -extern int nand_erase(struct nand_chip* nand, size_t ofs, size_t len, int clean); +extern int nand_legacy_erase(struct nand_chip* nand, size_t ofs, size_t len, int clean);  #endif /* (CONFIG_COMMANDS & CFG_CMD_NAND) */  extern block_dev_desc_t ide_dev_desc[CFG_IDE_MAXDEVICE]; @@ -259,9 +267,9 @@ int au_do_update(int i, long sz)  		} else {  #if (CONFIG_COMMANDS & CFG_CMD_NAND)  			printf("Updating NAND FLASH with image %s\n", au_image[i].name); -			debug ("nand_erase(%lx, %lx);\n", start, end); -			rc = nand_erase (nand_dev_desc, start, end - start + 1, 0); -			debug ("nand_erase returned %x\n", rc); +			debug ("nand_legacy_erase(%lx, %lx);\n", start, end); +			rc = nand_legacy_erase (nand_dev_desc, start, end - start + 1, 0); +			debug ("nand_legacy_erase returned %x\n", rc);  #endif  		} @@ -286,10 +294,10 @@ int au_do_update(int i, long sz)  			rc = flash_write((char *)addr, start, nbytes);  		} else {  #if (CONFIG_COMMANDS & CFG_CMD_NAND) -			debug ("nand_rw(%p, %lx %x)\n", addr, start, nbytes); -			rc = nand_rw(nand_dev_desc, NANDRW_WRITE | NANDRW_JFFS2, +			debug ("nand_legacy_rw(%p, %lx %x)\n", addr, start, nbytes); +			rc = nand_legacy_rw(nand_dev_desc, NANDRW_WRITE | NANDRW_JFFS2,  				     start, nbytes, (size_t *)&total, (uchar *)addr); -			debug ("nand_rw: ret=%x total=%d nbytes=%d\n", rc, total, nbytes); +			debug ("nand_legacy_rw: ret=%x total=%d nbytes=%d\n", rc, total, nbytes);  #endif  		}  		if (rc != 0) { @@ -304,7 +312,7 @@ int au_do_update(int i, long sz)  			rc = crc32 (0, (uchar *)(start + off), ntohl(hdr->ih_size));  		} else {  #if (CONFIG_COMMANDS & CFG_CMD_NAND) -			rc = nand_rw(nand_dev_desc, NANDRW_READ | NANDRW_JFFS2 | NANDRW_JFFS2_SKIP, +			rc = nand_legacy_rw(nand_dev_desc, NANDRW_READ | NANDRW_JFFS2 | NANDRW_JFFS2_SKIP,  				     start, nbytes, (size_t *)&total, (uchar *)addr);  			rc = crc32 (0, (uchar *)(addr + off), ntohl(hdr->ih_size));  #endif |