nand.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. /*
  2. * (C) Copyright 2005
  3. * 2N Telekomunikace, a.s. <www.2n.cz>
  4. * Ladislav Michl <michl@2n.cz>
  5. *
  6. * See file CREDITS for list of people who contributed to this
  7. * project.
  8. *
  9. * This program is free software; you can redistribute it and/or
  10. * modify it under the terms of the GNU General Public License
  11. * version 2 as published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  21. * MA 02111-1307 USA
  22. */
  23. #ifndef _NAND_H_
  24. #define _NAND_H_
  25. #include <config.h>
  26. /*
  27. * All boards using a given driver must convert to self-init
  28. * at the same time, so do it here. When all drivers are
  29. * converted, this will go away.
  30. */
  31. #if defined(CONFIG_NAND_FSL_ELBC)
  32. #define CONFIG_SYS_NAND_SELF_INIT
  33. #endif
  34. extern void nand_init(void);
  35. #include <linux/compat.h>
  36. #include <linux/mtd/mtd.h>
  37. #include <linux/mtd/nand.h>
  38. #ifdef CONFIG_SYS_NAND_SELF_INIT
  39. void board_nand_init(void);
  40. int nand_register(int devnum);
  41. #else
  42. extern int board_nand_init(struct nand_chip *nand);
  43. #endif
  44. typedef struct mtd_info nand_info_t;
  45. extern int nand_curr_device;
  46. extern nand_info_t nand_info[];
  47. static inline int nand_read(nand_info_t *info, loff_t ofs, size_t *len, u_char *buf)
  48. {
  49. return info->read(info, ofs, *len, (size_t *)len, buf);
  50. }
  51. static inline int nand_write(nand_info_t *info, loff_t ofs, size_t *len, u_char *buf)
  52. {
  53. return info->write(info, ofs, *len, (size_t *)len, buf);
  54. }
  55. static inline int nand_block_isbad(nand_info_t *info, loff_t ofs)
  56. {
  57. return info->block_isbad(info, ofs);
  58. }
  59. static inline int nand_erase(nand_info_t *info, loff_t off, size_t size)
  60. {
  61. struct erase_info instr;
  62. instr.mtd = info;
  63. instr.addr = off;
  64. instr.len = size;
  65. instr.callback = 0;
  66. return info->erase(info, &instr);
  67. }
  68. /*****************************************************************************
  69. * declarations from nand_util.c
  70. ****************************************************************************/
  71. struct nand_write_options {
  72. u_char *buffer; /* memory block containing image to write */
  73. ulong length; /* number of bytes to write */
  74. ulong offset; /* start address in NAND */
  75. int quiet; /* don't display progress messages */
  76. int autoplace; /* if true use auto oob layout */
  77. int forcejffs2; /* force jffs2 oob layout */
  78. int forceyaffs; /* force yaffs oob layout */
  79. int noecc; /* write without ecc */
  80. int writeoob; /* image contains oob data */
  81. int pad; /* pad to page size */
  82. int blockalign; /* 1|2|4 set multiple of eraseblocks
  83. * to align to */
  84. };
  85. typedef struct nand_write_options nand_write_options_t;
  86. typedef struct mtd_oob_ops mtd_oob_ops_t;
  87. struct nand_read_options {
  88. u_char *buffer; /* memory block in which read image is written*/
  89. ulong length; /* number of bytes to read */
  90. ulong offset; /* start address in NAND */
  91. int quiet; /* don't display progress messages */
  92. int readoob; /* put oob data in image */
  93. };
  94. typedef struct nand_read_options nand_read_options_t;
  95. struct nand_erase_options {
  96. loff_t length; /* number of bytes to erase */
  97. loff_t offset; /* first address in NAND to erase */
  98. int quiet; /* don't display progress messages */
  99. int jffs2; /* if true: format for jffs2 usage
  100. * (write appropriate cleanmarker blocks) */
  101. int scrub; /* if true, really clean NAND by erasing
  102. * bad blocks (UNSAFE) */
  103. /* Don't include skipped bad blocks in size to be erased */
  104. int spread;
  105. };
  106. typedef struct nand_erase_options nand_erase_options_t;
  107. int nand_read_skip_bad(nand_info_t *nand, loff_t offset, size_t *length,
  108. u_char *buffer);
  109. #define WITH_YAFFS_OOB (1 << 0) /* whether write with yaffs format. This flag
  110. * is a 'mode' meaning it cannot be mixed with
  111. * other flags */
  112. #define WITH_DROP_FFS (1 << 1) /* drop trailing all-0xff pages */
  113. int nand_write_skip_bad(nand_info_t *nand, loff_t offset, size_t *length,
  114. u_char *buffer, int flags);
  115. int nand_erase_opts(nand_info_t *meminfo, const nand_erase_options_t *opts);
  116. #define NAND_LOCK_STATUS_TIGHT 0x01
  117. #define NAND_LOCK_STATUS_LOCK 0x02
  118. #define NAND_LOCK_STATUS_UNLOCK 0x04
  119. int nand_lock( nand_info_t *meminfo, int tight );
  120. int nand_unlock( nand_info_t *meminfo, ulong start, ulong length );
  121. int nand_get_lock_status(nand_info_t *meminfo, loff_t offset);
  122. int nand_spl_load_image(uint32_t offs, unsigned int size, void *dst);
  123. void nand_deselect(void);
  124. #ifdef CONFIG_SYS_NAND_SELECT_DEVICE
  125. void board_nand_select_device(struct nand_chip *nand, int chip);
  126. #endif
  127. __attribute__((noreturn)) void nand_boot(void);
  128. #endif
  129. #ifdef CONFIG_ENV_OFFSET_OOB
  130. #define ENV_OOB_MARKER 0x30425645 /*"EVB0" in little-endian -- offset is stored
  131. as block number*/
  132. #define ENV_OOB_MARKER_OLD 0x30564e45 /*"ENV0" in little-endian -- offset is
  133. stored as byte number */
  134. #define ENV_OFFSET_SIZE 8
  135. int get_nand_env_oob(nand_info_t *nand, unsigned long *result);
  136. #endif