X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=include%2Fnand.h;h=dded4e27f059d6c6fb4e3987009a722433cf2ad6;hb=25b29921b2f5a9a133c6196afaf05fce1be9927b;hp=5dd1710eb281b26c70d8e8fffec675cf1cc693a3;hpb=578931b34d0a26974f14640fa4ec3aadeb2145cd;p=oweals%2Fu-boot.git diff --git a/include/nand.h b/include/nand.h index 5dd1710eb2..dded4e27f0 100644 --- a/include/nand.h +++ b/include/nand.h @@ -24,9 +24,20 @@ #ifndef _NAND_H_ #define _NAND_H_ +#include + +/* + * All boards using a given driver must convert to self-init + * at the same time, so do it here. When all drivers are + * converted, this will go away. + */ +#if defined(CONFIG_NAND_FSL_ELBC) || defined(CONFIG_NAND_ATMEL) +#define CONFIG_SYS_NAND_SELF_INIT +#endif + extern void nand_init(void); -#include +#include #include #include @@ -128,13 +139,14 @@ int nand_read_skip_bad(nand_info_t *nand, loff_t offset, size_t *length, int nand_write_skip_bad(nand_info_t *nand, loff_t offset, size_t *length, u_char *buffer, int flags); int nand_erase_opts(nand_info_t *meminfo, const nand_erase_options_t *opts); +int nand_torture(nand_info_t *nand, loff_t offset); #define NAND_LOCK_STATUS_TIGHT 0x01 -#define NAND_LOCK_STATUS_LOCK 0x02 #define NAND_LOCK_STATUS_UNLOCK 0x04 -int nand_lock( nand_info_t *meminfo, int tight ); -int nand_unlock( nand_info_t *meminfo, ulong start, ulong length ); +int nand_lock(nand_info_t *meminfo, int tight); +int nand_unlock(nand_info_t *meminfo, loff_t start, size_t length, + int allexcept); int nand_get_lock_status(nand_info_t *meminfo, loff_t offset); int nand_spl_load_image(uint32_t offs, unsigned int size, void *dst);