diff options
Diffstat (limited to 'include/linux/mtd/nand.h')
| -rw-r--r-- | include/linux/mtd/nand.h | 53 | 
1 files changed, 53 insertions, 0 deletions
| diff --git a/include/linux/mtd/nand.h b/include/linux/mtd/nand.h index 2f0af2891f0f..3083c53e0270 100644 --- a/include/linux/mtd/nand.h +++ b/include/linux/mtd/nand.h @@ -810,6 +810,7 @@ extern struct nand_manufacturers nand_manuf_ids[];  extern int nand_scan_bbt(struct mtd_info *mtd, struct nand_bbt_descr *bd);  extern int nand_default_bbt(struct mtd_info *mtd);  extern int nand_markbad_bbt(struct mtd_info *mtd, loff_t offs); +extern int nand_isreserved_bbt(struct mtd_info *mtd, loff_t offs);  extern int nand_isbad_bbt(struct mtd_info *mtd, loff_t offs, int allowbbt);  extern int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr,  			   int allowbbt); @@ -947,4 +948,56 @@ static inline int jedec_feature(struct nand_chip *chip)  	return chip->jedec_version ? le16_to_cpu(chip->jedec_params.features)  		: 0;  } + +/** + * struct nand_sdr_timings - SDR NAND chip timings + * + * This struct defines the timing requirements of a SDR NAND chip. + * These informations can be found in every NAND datasheets and the timings + * meaning are described in the ONFI specifications: + * www.onfi.org/~/media/ONFI/specs/onfi_3_1_spec.pdf (chapter 4.15 Timing + * Parameters) + * + * All these timings are expressed in picoseconds. + */ + +struct nand_sdr_timings { +	u32 tALH_min; +	u32 tADL_min; +	u32 tALS_min; +	u32 tAR_min; +	u32 tCEA_max; +	u32 tCEH_min; +	u32 tCH_min; +	u32 tCHZ_max; +	u32 tCLH_min; +	u32 tCLR_min; +	u32 tCLS_min; +	u32 tCOH_min; +	u32 tCS_min; +	u32 tDH_min; +	u32 tDS_min; +	u32 tFEAT_max; +	u32 tIR_min; +	u32 tITC_max; +	u32 tRC_min; +	u32 tREA_max; +	u32 tREH_min; +	u32 tRHOH_min; +	u32 tRHW_min; +	u32 tRHZ_max; +	u32 tRLOH_min; +	u32 tRP_min; +	u32 tRR_min; +	u64 tRST_max; +	u32 tWB_max; +	u32 tWC_min; +	u32 tWH_min; +	u32 tWHR_min; +	u32 tWP_min; +	u32 tWW_min; +}; + +/* get timing characteristics from ONFI timing mode. */ +const struct nand_sdr_timings *onfi_async_timing_mode_to_sdr_timings(int mode);  #endif /* __LINUX_MTD_NAND_H */ | 
