📄 nand.h
字号:
/* * linux/include/linux/mtd/nand.h * * Copyright (c) 2000 David Woodhouse <dwmw2@mvhi.com> * Steven J. Hill <sjhill@realitydiluted.com> * Thomas Gleixner <tglx@linutronix.de> * * $Id: nand.h,v 1.73 2005/05/31 19:39:17 gleixner 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 * 08-07-2002 TG forced bad block location to byte 5 of OOB, even if * CONFIG_MTD_NAND_ECC_JFFS2 is not set * 08-10-2002 TG extensions to nand_chip structure to support HW-ECC * * 08-29-2002 tglx nand_chip structure: data_poi for selecting * internal / fs-driver buffer * support for 6byte/512byte hardware ECC * read_ecc, write_ecc extended for different oob-layout * oob layout selections: NAND_NONE_OOB, NAND_JFFS2_OOB, * NAND_YAFFS_OOB * 11-25-2002 tglx Added Manufacturer code FUJITSU, NATIONAL * Split manufacturer and device ID structures * * 02-08-2004 tglx added option field to nand structure for chip anomalities * 05-25-2004 tglx added bad block table support, ST-MICRO manufacturer id * update of nand_chip structure description * 01-17-2005 dmarlin added extended commands for AG-AND device and added option * for BBT_AUTO_REFRESH. * 01-20-2005 dmarlin added optional pointer to hardware specific callback for * extra error status checks. */#ifndef __LINUX_MTD_NAND_H#define __LINUX_MTD_NAND_H#include <linux/config.h>#include <linux/wait.h>#include <linux/spinlock.h>#include <linux/mtd/mtd.h>struct mtd_info;/* Scan and identify a NAND device */extern int nand_scan (struct mtd_info *mtd, int max_chips);/* Free resources held by the NAND device */extern void nand_release (struct mtd_info *mtd);/* Read raw data from the device without ECC */extern int nand_read_raw (struct mtd_info *mtd, uint8_t *buf, loff_t from, size_t len, size_t ooblen);/* The maximum number of NAND chips in an array */#define NAND_MAX_CHIPS 8/* This constant declares the max. oobsize / page, which * is supported now. If you add a chip with bigger oobsize/page * adjust this accordingly. */#define NAND_MAX_OOBSIZE 64/* * Constants for hardware specific CLE/ALE/NCE function*//* Select the chip by setting nCE to low */#define NAND_CTL_SETNCE 1/* Deselect the chip by setting nCE to high */#define NAND_CTL_CLRNCE 2/* Select the command latch by setting CLE to high */#define NAND_CTL_SETCLE 3/* Deselect the command latch by setting CLE to low */#define NAND_CTL_CLRCLE 4/* Select the address latch by setting ALE to high */#define NAND_CTL_SETALE 5/* Deselect the address latch by setting ALE to low */#define NAND_CTL_CLRALE 6/* Set write protection by setting WP to high. Not used! */#define NAND_CTL_SETWP 7/* Clear write protection by setting WP to low. Not used! */#define NAND_CTL_CLRWP 8/* * 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_STATUS_MULTI 0x71#define NAND_CMD_SEQIN 0x80#define NAND_CMD_READID 0x90#define NAND_CMD_ERASE2 0xd0#define NAND_CMD_RESET 0xff/* Extended commands for large page devices */#define NAND_CMD_READSTART 0x30#define NAND_CMD_CACHEDPROG 0x15/* Extended commands for AG-AND device *//* * Note: the command for NAND_CMD_DEPLETE1 is really 0x00 but * there is no way to distinguish that from NAND_CMD_READ0 * until the remaining sequence of commands has been completed * so add a high order bit and mask it off in the command. */#define NAND_CMD_DEPLETE1 0x100#define NAND_CMD_DEPLETE2 0x38#define NAND_CMD_STATUS_MULTI 0x71#define NAND_CMD_STATUS_ERROR 0x72/* multi-bank error status (banks 0-3) */#define NAND_CMD_STATUS_ERROR0 0x73#define NAND_CMD_STATUS_ERROR1 0x74#define NAND_CMD_STATUS_ERROR2 0x75#define NAND_CMD_STATUS_ERROR3 0x76#define NAND_CMD_STATUS_RESET 0x7f#define NAND_CMD_STATUS_CLEAR 0xff/* Status bits */#define NAND_STATUS_FAIL 0x01#define NAND_STATUS_FAIL_N1 0x02#define NAND_STATUS_TRUE_READY 0x20#define NAND_STATUS_READY 0x40#define NAND_STATUS_WP 0x80/* * Constants for ECC_MODES *//* No ECC. Usage is not recommended ! */#define NAND_ECC_NONE 0/* Software ECC 3 byte ECC per 256 Byte data */#define NAND_ECC_SOFT 1/* Hardware ECC 3 byte ECC per 256 Byte data */#define NAND_ECC_HW3_256 2/* Hardware ECC 3 byte ECC per 512 Byte data */#define NAND_ECC_HW3_512 3/* Hardware ECC 3 byte ECC per 512 Byte data */#define NAND_ECC_HW6_512 4/* Hardware ECC 8 byte ECC per 512 Byte data */#define NAND_ECC_HW8_512 6/* Hardware ECC 12 byte ECC per 2048 Byte data */#define NAND_ECC_HW12_2048 7/* * Constants for Hardware ECC *//* Reset Hardware ECC for read */#define NAND_ECC_READ 0/* Reset Hardware ECC for write */#define NAND_ECC_WRITE 1/* Enable Hardware ECC before syndrom is read back from flash */#define NAND_ECC_READSYN 2/* Bit mask for flags passed to do_nand_read_ecc */#define NAND_GET_DEVICE 0x80/* Option constants for bizarre disfunctionality and real* features*//* Chip can not auto increment pages */#define NAND_NO_AUTOINCR 0x00000001/* Buswitdh is 16 bit */#define NAND_BUSWIDTH_16 0x00000002/* Device supports partial programming without padding */#define NAND_NO_PADDING 0x00000004/* Chip has cache program function */#define NAND_CACHEPRG 0x00000008/* Chip has copy back function */#define NAND_COPYBACK 0x00000010/* AND Chip which has 4 banks and a confusing page / block * assignment. See Renesas datasheet for further information */#define NAND_IS_AND 0x00000020/* Chip has a array of 4 pages which can be read without * additional ready /busy waits */#define NAND_4PAGE_ARRAY 0x00000040 /* Chip requires that BBT is periodically rewritten to prevent * bits from adjacent blocks from 'leaking' in altering data. * This happens with the Renesas AG-AND chips, possibly others. */#define BBT_AUTO_REFRESH 0x00000080/* Options valid for Samsung large page devices */#define NAND_SAMSUNG_LP_OPTIONS \ (NAND_NO_PADDING | NAND_CACHEPRG | NAND_COPYBACK)/* Macros to identify the above */#define NAND_CANAUTOINCR(chip) (!(chip->options & NAND_NO_AUTOINCR))#define NAND_MUST_PAD(chip) (!(chip->options & NAND_NO_PADDING))#define NAND_HAS_CACHEPROG(chip) ((chip->options & NAND_CACHEPRG))#define NAND_HAS_COPYBACK(chip) ((chip->options & NAND_COPYBACK))/* Mask to zero out the chip options, which come from the id table */#define NAND_CHIPOPTIONS_MSK (0x0000ffff & ~NAND_NO_AUTOINCR)/* Non chip related options *//* Use a flash based bad block table. This option is passed to the * default bad block table function. */#define NAND_USE_FLASH_BBT 0x00010000/* The hw ecc generator provides a syndrome instead a ecc value on read * This can only work if we have the ecc bytes directly behind the * data bytes. Applies for DOC and AG-AND Renesas HW Reed Solomon generators */#define NAND_HWECC_SYNDROME 0x00020000/* This option skips the bbt scan during initialization. */#define NAND_SKIP_BBTSCAN 0x00040000/* Options set by nand scan *//* Nand scan has allocated oob_buf */#define NAND_OOBBUF_ALLOC 0x40000000/* Nand scan has allocated data_buf */#define NAND_DATABUF_ALLOC 0x80000000/* * nand_state_t - chip states * Enumeration for NAND flash chip state */typedef enum { FL_READY, FL_READING, FL_WRITING, FL_ERASING, FL_SYNCING, FL_CACHEDPRG,} nand_state_t;/* Keep gcc happy */struct nand_chip;/** * struct nand_hw_control - Control structure for hardware controller (e.g ECC generator) shared among independend devices * @lock: protection lock * @active: the mtd device which holds the controller currently * @wq: wait queue to sleep on if a NAND operation is in progress
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -