|
|
|
/*
|
|
|
|
* linux/include/linux/mtd/nand.h
|
|
|
|
*
|
|
|
|
* Copyright (c) 2000 David Woodhouse <dwmw2@mvhi.com>
|
|
|
|
* Steven J. Hill <sjhill@cotw.com>
|
|
|
|
* Thomas Gleixner <gleixner@autronix.de>
|
|
|
|
*
|
|
|
|
* $Id: nand.h,v 1.7 2003/07/24 23:30:46 a0384864 Exp $
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* Info:
|
|
|
|
* Contains standard defines and IDs for NAND flash devices
|
|
|
|
*
|
|
|
|
* Changelog:
|
|
|
|
* 01-31-2000 DMW Created
|
|
|
|
* 09-18-2000 SJH Moved structure out of the Disk-On-Chip drivers
|
|
|
|
* so it can be used by other NAND flash device
|
|
|
|
* drivers. I also changed the copyright since none
|
|
|
|
* of the original contents of this file are specific
|
|
|
|
* to DoC devices. David can whack me with a baseball
|
|
|
|
* bat later if I did something naughty.
|
|
|
|
* 10-11-2000 SJH Added private NAND flash structure for driver
|
|
|
|
* 10-24-2000 SJH Added prototype for 'nand_scan' function
|
|
|
|
* 10-29-2001 TG changed nand_chip structure to support
|
|
|
|
* hardwarespecific function for accessing control lines
|
|
|
|
* 02-21-2002 TG added support for different read/write adress and
|
|
|
|
* ready/busy line access function
|
|
|
|
* 02-26-2002 TG added chip_delay to nand_chip structure to optimize
|
|
|
|
* command delay times for different chips
|
|
|
|
* 04-28-2002 TG OOB config defines moved from nand.c to avoid duplicate
|
|
|
|
* defines in jffs2/wbuf.c
|
|
|
|
*/
|
|
|
|
#ifndef __LINUX_MTD_NAND_LEGACY_H
|
|
|
|
#define __LINUX_MTD_NAND_LEGACY_H
|
|
|
|
|
|
|
|
#ifndef CONFIG_NAND_LEGACY
|
|
|
|
#error This module is for the legacy NAND support
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* The maximum number of NAND chips in an array */
|
|
|
|
#ifndef CONFIG_SYS_NAND_MAX_CHIPS
|
|
|
|
#define CONFIG_SYS_NAND_MAX_CHIPS 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Standard NAND flash commands
|
|
|
|
*/
|
|
|
|
#define NAND_CMD_READ0 0
|
|
|
|
#define NAND_CMD_READ1 1
|
|
|
|
#define NAND_CMD_PAGEPROG 0x10
|
|
|
|
#define NAND_CMD_READOOB 0x50
|
|
|
|
#define NAND_CMD_ERASE1 0x60
|
|
|
|
#define NAND_CMD_STATUS 0x70
|
|
|
|
#define NAND_CMD_SEQIN 0x80
|
|
|
|
#define NAND_CMD_READID 0x90
|
|
|
|
#define NAND_CMD_ERASE2 0xd0
|
|
|
|
#define NAND_CMD_RESET 0xff
|
|
|
|
|
|
|
|
/*
|
|
|
|
* NAND Private Flash Chip Data
|
|
|
|
*
|
|
|
|
* Structure overview:
|
|
|
|
*
|
|
|
|
* IO_ADDR - address to access the 8 I/O lines of the flash device
|
|
|
|
*
|
|
|
|
* hwcontrol - hardwarespecific function for accesing control-lines
|
|
|
|
*
|
|
|
|
* dev_ready - hardwarespecific function for accesing device ready/busy line
|
|
|
|
*
|
|
|
|
* chip_lock - spinlock used to protect access to this structure
|
|
|
|
*
|
|
|
|
* wq - wait queue to sleep on if a NAND operation is in progress
|
|
|
|
*
|
|
|
|
* state - give the current state of the NAND device
|
|
|
|
*
|
|
|
|
* page_shift - number of address bits in a page (column address bits)
|
|
|
|
*
|
|
|
|
* data_buf - data buffer passed to/from MTD user modules
|
|
|
|
*
|
|
|
|
* data_cache - data cache for redundant page access and shadow for
|
|
|
|
* ECC failure
|
|
|
|
*
|
|
|
|
* ecc_code_buf - used only for holding calculated or read ECCs for
|
|
|
|
* a page read or written when ECC is in use
|
|
|
|
*
|
|
|
|
* reserved - padding to make structure fall on word boundary if
|
|
|
|
* when ECC is in use
|
|
|
|
*/
|
|
|
|
struct Nand {
|
|
|
|
char floor, chip;
|
|
|
|
unsigned long curadr;
|
|
|
|
unsigned char curmode;
|
|
|
|
/* Also some erase/write/pipeline info when we get that far */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct nand_chip {
|
|
|
|
int page_shift;
|
|
|
|
u_char *data_buf;
|
|
|
|
u_char *data_cache;
|
|
|
|
int cache_page;
|
|
|
|
u_char ecc_code_buf[6];
|
|
|
|
u_char reserved[2];
|
|
|
|
char ChipID; /* Type of DiskOnChip */
|
|
|
|
struct Nand *chips;
|
|
|
|
int chipshift;
|
|
|
|
char* chips_name;
|
|
|
|
unsigned long erasesize;
|
|
|
|
unsigned long mfr; /* Flash IDs - only one type of flash per device */
|
|
|
|
unsigned long id;
|
|
|
|
char* name;
|
|
|
|
int numchips;
|
|
|
|
char page256;
|
|
|
|
char pageadrlen;
|
|
|
|
unsigned long IO_ADDR; /* address to access the 8 I/O lines to the flash device */
|
|
|
|
unsigned long totlen;
|
|
|
|
uint oobblock; /* Size of OOB blocks (e.g. 512) */
|
|
|
|
uint oobsize; /* Amount of OOB data per block (e.g. 16) */
|
|
|
|
uint eccsize;
|
|
|
|
int bus16;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* NAND Flash Manufacturer ID Codes
|
|
|
|
*/
|
|
|
|
#define NAND_MFR_TOSHIBA 0x98
|
|
|
|
#define NAND_MFR_SAMSUNG 0xec
|
|
|
|
|
|
|
|
/*
|
|
|
|
* NAND Flash Device ID Structure
|
|
|
|
*
|
|
|
|
* Structure overview:
|
|
|
|
*
|
|
|
|
* name - Complete name of device
|
|
|
|
*
|
|
|
|
* manufacture_id - manufacturer ID code of device.
|
|
|
|
*
|
|
|
|
* model_id - model ID code of device.
|
|
|
|
*
|
|
|
|
* chipshift - total number of address bits for the device which
|
|
|
|
* is used to calculate address offsets and the total
|
|
|
|
* number of bytes the device is capable of.
|
|
|
|
*
|
|
|
|
* page256 - denotes if flash device has 256 byte pages or not.
|
|
|
|
*
|
|
|
|
* pageadrlen - number of bytes minus one needed to hold the
|
|
|
|
* complete address into the flash array. Keep in
|
|
|
|
* mind that when a read or write is done to a
|
|
|
|
* specific address, the address is input serially
|
|
|
|
* 8 bits at a time. This structure member is used
|
|
|
|
* by the read/write routines as a loop index for
|
|
|
|
* shifting the address out 8 bits at a time.
|
|
|
|
*
|
|
|
|
* erasesize - size of an erase block in the flash device.
|
|
|
|
*/
|
|
|
|
struct nand_flash_dev {
|
|
|
|
char * name;
|
|
|
|
int manufacture_id;
|
|
|
|
int model_id;
|
|
|
|
int chipshift;
|
|
|
|
char page256;
|
|
|
|
char pageadrlen;
|
|
|
|
unsigned long erasesize;
|
|
|
|
int bus16;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Constants for oob configuration
|
|
|
|
*/
|
|
|
|
#define NAND_NOOB_ECCPOS0 0
|
|
|
|
#define NAND_NOOB_ECCPOS1 1
|
|
|
|
#define NAND_NOOB_ECCPOS2 2
|
|
|
|
#define NAND_NOOB_ECCPOS3 3
|
|
|
|
#define NAND_NOOB_ECCPOS4 6
|
|
|
|
#define NAND_NOOB_ECCPOS5 7
|
|
|
|
#define NAND_NOOB_BADBPOS -1
|
|
|
|
#define NAND_NOOB_ECCVPOS -1
|
|
|
|
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS0 0
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS1 1
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS2 2
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS3 3
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS4 6
|
|
|
|
#define NAND_JFFS2_OOB_ECCPOS5 7
|
|
|
|
#define NAND_JFFS2_OOB_BADBPOS 5
|
|
|
|
#define NAND_JFFS2_OOB_ECCVPOS 4
|
|
|
|
|
|
|
|
#define NAND_JFFS2_OOB8_FSDAPOS 6
|
|
|
|
#define NAND_JFFS2_OOB16_FSDAPOS 8
|
|
|
|
#define NAND_JFFS2_OOB8_FSDALEN 2
|
|
|
|
#define NAND_JFFS2_OOB16_FSDALEN 8
|
|
|
|
|
|
|
|
unsigned long nand_probe(unsigned long physadr);
|
|
|
|
#endif /* __LINUX_MTD_NAND_LEGACY_H */
|