sfud_def.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. /*
  2. * This file is part of the Serial Flash Universal Driver Library.
  3. *
  4. * Copyright (c) 2016-2018, Armink, <armink.ztl@gmail.com>
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining
  7. * a copy of this software and associated documentation files (the
  8. * 'Software'), to deal in the Software without restriction, including
  9. * without limitation the rights to use, copy, modify, merge, publish,
  10. * distribute, sublicense, and/or sell copies of the Software, and to
  11. * permit persons to whom the Software is furnished to do so, subject to
  12. * the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be
  15. * included in all copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
  18. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  19. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  20. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  21. * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  22. * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  23. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  24. *
  25. * Function: It is the macro definition head file for this library.
  26. * Created on: 2016-04-23
  27. */
  28. #ifndef _SFUD_DEF_H_
  29. #define _SFUD_DEF_H_
  30. #include <stdio.h>
  31. #include <stdlib.h>
  32. #include <stdint.h>
  33. #include <stdbool.h>
  34. #include <sfud_cfg.h>
  35. #include "sfud_flash_def.h"
  36. #include "luat_base.h"
  37. #ifndef LUAT_LOG_TAG
  38. #define LUAT_LOG_TAG "sfud"
  39. #endif
  40. #include "luat_log.h"
  41. #ifdef __cplusplus
  42. extern "C" {
  43. #endif
  44. #define LUAT_TYPE_SPI 0
  45. #define LUAT_TYPE_SPI_DEVICE 1
  46. typedef struct luat_sfud_flash
  47. {
  48. int luat_spi; // bus
  49. void *user_data;// some user data
  50. void *sem;
  51. } luat_sfud_flash_t;
  52. /* debug print function. Must be implement by user. */
  53. #ifdef SFUD_DEBUG_MODE
  54. #ifndef SFUD_DEBUG
  55. #define SFUD_DEBUG(...) sfud_log_debug(__FILE__, __LINE__, __VA_ARGS__)
  56. #endif /* SFUD_DEBUG */
  57. #else
  58. #define SFUD_DEBUG(...)
  59. #endif /* SFUD_DEBUG_MODE */
  60. #ifndef SFUD_INFO
  61. #define SFUD_INFO(...) LLOGI(__VA_ARGS__)
  62. #endif
  63. /* assert for developer. */
  64. #ifdef SFUD_DEBUG_MODE
  65. #define SFUD_ASSERT(EXPR) \
  66. if (!(EXPR)) \
  67. { \
  68. SFUD_DEBUG("(%s) has assert failed at %s.", #EXPR, __FUNCTION__); \
  69. while (1); \
  70. }
  71. #else
  72. #define SFUD_ASSERT(EXPR)
  73. #endif
  74. /**
  75. * retry process
  76. *
  77. * @param delay delay function for every retry. NULL will not delay for every retry.
  78. * @param retry retry counts
  79. * @param result SFUD_ERR_TIMEOUT: retry timeout
  80. */
  81. #define SFUD_RETRY_PROCESS(delay, retry, result) \
  82. void (*__delay_temp)(void) = (void (*)(void))delay; \
  83. if (retry == 0) {result = SFUD_ERR_TIMEOUT;break;} \
  84. else {if (__delay_temp) {__delay_temp();} retry --;}
  85. /* software version number */
  86. #define SFUD_SW_VERSION "1.1.0"
  87. /*
  88. * all defined supported command
  89. */
  90. #ifndef SFUD_CMD_WRITE_ENABLE
  91. #define SFUD_CMD_WRITE_ENABLE 0x06
  92. #endif
  93. #ifndef SFUD_CMD_WRITE_DISABLE
  94. #define SFUD_CMD_WRITE_DISABLE 0x04
  95. #endif
  96. #ifndef SFUD_CMD_READ_STATUS_REGISTER
  97. #define SFUD_CMD_READ_STATUS_REGISTER 0x05
  98. #endif
  99. #ifndef SFUD_VOLATILE_SR_WRITE_ENABLE
  100. #define SFUD_VOLATILE_SR_WRITE_ENABLE 0x50
  101. #endif
  102. #ifndef SFUD_CMD_WRITE_STATUS_REGISTER
  103. #define SFUD_CMD_WRITE_STATUS_REGISTER 0x01
  104. #endif
  105. #ifndef SFUD_CMD_PAGE_PROGRAM
  106. #define SFUD_CMD_PAGE_PROGRAM 0x02
  107. #endif
  108. #ifndef SFUD_CMD_AAI_WORD_PROGRAM
  109. #define SFUD_CMD_AAI_WORD_PROGRAM 0xAD
  110. #endif
  111. #ifndef SFUD_CMD_ERASE_CHIP
  112. #define SFUD_CMD_ERASE_CHIP 0xC7
  113. #endif
  114. #ifndef SFUD_CMD_READ_DATA
  115. #define SFUD_CMD_READ_DATA 0x03
  116. #endif
  117. #ifndef SFUD_CMD_FAST_READ_DATA
  118. #define SFUD_CMD_FAST_READ_DATA 0x0B
  119. #endif
  120. #ifndef SFUD_CMD_DUAL_OUTPUT_READ_DATA
  121. #define SFUD_CMD_DUAL_OUTPUT_READ_DATA 0x3B
  122. #endif
  123. #ifndef SFUD_CMD_DUAL_IO_READ_DATA
  124. #define SFUD_CMD_DUAL_IO_READ_DATA 0xBB
  125. #endif
  126. #ifndef SFUD_CMD_QUAD_IO_READ_DATA
  127. #define SFUD_CMD_QUAD_IO_READ_DATA 0xEB
  128. #endif
  129. #ifndef SFUD_CMD_QUAD_OUTPUT_READ_DATA
  130. #define SFUD_CMD_QUAD_OUTPUT_READ_DATA 0x6B
  131. #endif
  132. #ifndef SFUD_CMD_MANUFACTURER_DEVICE_ID
  133. #define SFUD_CMD_MANUFACTURER_DEVICE_ID 0x90
  134. #endif
  135. #ifndef SFUD_CMD_JEDEC_ID
  136. #define SFUD_CMD_JEDEC_ID 0x9F
  137. #endif
  138. #ifndef SFUD_CMD_READ_UNIQUE_ID
  139. #define SFUD_CMD_READ_UNIQUE_ID 0x4B
  140. #endif
  141. #ifndef SFUD_CMD_READ_SFDP_REGISTER
  142. #define SFUD_CMD_READ_SFDP_REGISTER 0x5A
  143. #endif
  144. #ifndef SFUD_CMD_ENABLE_RESET
  145. #define SFUD_CMD_ENABLE_RESET 0x66
  146. #endif
  147. #ifndef SFUD_CMD_RESET
  148. #define SFUD_CMD_RESET 0x99
  149. #endif
  150. #ifndef SFUD_CMD_ENTER_4B_ADDRESS_MODE
  151. #define SFUD_CMD_ENTER_4B_ADDRESS_MODE 0xB7
  152. #endif
  153. #ifndef SFUD_CMD_EXIT_4B_ADDRESS_MODE
  154. #define SFUD_CMD_EXIT_4B_ADDRESS_MODE 0xE9
  155. #endif
  156. #ifndef SFUD_WRITE_MAX_PAGE_SIZE
  157. #define SFUD_WRITE_MAX_PAGE_SIZE 256
  158. #endif
  159. /* send dummy data for read data */
  160. #ifndef SFUD_DUMMY_DATA
  161. #define SFUD_DUMMY_DATA 0xFF
  162. #endif
  163. /* dummy data count for fast read data and etc */
  164. #ifndef SFUD_READ_DUMMY_BYTE_CNT
  165. #ifdef SFUD_USING_FAST_READ
  166. #define SFUD_READ_DUMMY_BYTE_CNT 1
  167. #else
  168. #define SFUD_READ_DUMMY_BYTE_CNT 0
  169. #endif
  170. #endif
  171. /* maximum number of erase type support on JESD216 (V1.0) */
  172. #define SFUD_SFDP_ERASE_TYPE_MAX_NUM 4
  173. /**
  174. * status register bits
  175. */
  176. enum {
  177. SFUD_STATUS_REGISTER_BUSY = (1 << 0), /**< busing */
  178. SFUD_STATUS_REGISTER_WEL = (1 << 1), /**< write enable latch */
  179. SFUD_STATUS_REGISTER_SRP = (1 << 7), /**< status register protect */
  180. };
  181. /**
  182. * error code
  183. */
  184. typedef enum {
  185. SFUD_SUCCESS = 0, /**< success */
  186. SFUD_ERR_NOT_FOUND = 1, /**< not found or not supported */
  187. SFUD_ERR_WRITE = 2, /**< write error */
  188. SFUD_ERR_READ = 3, /**< read error */
  189. SFUD_ERR_TIMEOUT = 4, /**< timeout error */
  190. SFUD_ERR_ADDR_OUT_OF_BOUND = 5, /**< address is out of flash bound */
  191. } sfud_err;
  192. #ifdef SFUD_USING_QSPI
  193. /**
  194. * QSPI flash read cmd format
  195. */
  196. typedef struct {
  197. uint8_t instruction;
  198. uint8_t instruction_lines;
  199. uint8_t address_size;
  200. uint8_t address_lines;
  201. uint8_t alternate_bytes_lines;
  202. uint8_t dummy_cycles;
  203. uint8_t data_lines;
  204. } sfud_qspi_read_cmd_format;
  205. #endif /* SFUD_USING_QSPI */
  206. /* SPI bus write read data function type */
  207. typedef sfud_err (*spi_write_read_func)(const uint8_t *write_buf, size_t write_size, uint8_t *read_buf, size_t read_size);
  208. #ifdef SFUD_USING_SFDP
  209. /**
  210. * the SFDP (Serial Flash Discoverable Parameters) parameter info which used on this library
  211. */
  212. typedef struct {
  213. bool available; /**< available when read SFDP OK */
  214. uint8_t major_rev; /**< SFDP Major Revision */
  215. uint8_t minor_rev; /**< SFDP Minor Revision */
  216. uint16_t write_gran; /**< write granularity (bytes) */
  217. uint8_t erase_4k; /**< 4 kilobyte erase is supported throughout the device */
  218. uint8_t erase_4k_cmd; /**< 4 Kilobyte erase command */
  219. bool sr_is_non_vola; /**< status register is supports non-volatile */
  220. uint8_t vola_sr_we_cmd; /**< volatile status register write enable command */
  221. bool addr_3_byte; /**< supports 3-Byte addressing */
  222. bool addr_4_byte; /**< supports 4-Byte addressing */
  223. uint32_t capacity; /**< flash capacity (bytes) */
  224. struct {
  225. uint32_t size; /**< erase sector size (bytes). 0x00: not available */
  226. uint8_t cmd; /**< erase command */
  227. } eraser[SFUD_SFDP_ERASE_TYPE_MAX_NUM]; /**< supported eraser types table */
  228. //TODO lots of fast read-related stuff (like modes supported and number of wait states/dummy cycles needed in each)
  229. } sfud_sfdp, *sfud_sfdp_t;
  230. #endif
  231. /**
  232. * SPI device
  233. */
  234. typedef struct __sfud_spi {
  235. /* SPI device name */
  236. char *name;
  237. /* SPI bus write read data function */
  238. sfud_err (*wr)(const struct __sfud_spi *spi, const uint8_t *write_buf, size_t write_size, uint8_t *read_buf,
  239. size_t read_size);
  240. #ifdef SFUD_USING_QSPI
  241. /* QSPI fast read function */
  242. sfud_err (*qspi_read)(const struct __sfud_spi *spi, uint32_t addr, sfud_qspi_read_cmd_format *qspi_read_cmd_format,
  243. uint8_t *read_buf, size_t read_size);
  244. #endif
  245. /* lock SPI bus */
  246. void (*lock)(const struct __sfud_spi *spi);
  247. /* unlock SPI bus */
  248. void (*unlock)(const struct __sfud_spi *spi);
  249. /* some user data */
  250. void *user_data;
  251. } sfud_spi, *sfud_spi_t;
  252. /**
  253. * serial flash device
  254. */
  255. typedef struct {
  256. char *name; /**< serial flash name */
  257. size_t index; /**< index of flash device information table @see flash_table */
  258. sfud_flash_chip chip; /**< flash chip information */
  259. sfud_spi spi; /**< SPI device */
  260. bool init_ok; /**< initialize OK flag */
  261. bool addr_in_4_byte; /**< flash is in 4-Byte addressing */
  262. struct {
  263. void (*delay)(void); /**< every retry's delay */
  264. void (*long_delay)(void); /**< every retry's delay */
  265. size_t times; /**< default times for error retry */
  266. } retry;
  267. luat_sfud_flash_t luat_sfud;
  268. void *user_data; /**< some user data */
  269. #ifdef SFUD_USING_QSPI
  270. sfud_qspi_read_cmd_format read_cmd_format; /**< fast read cmd format */
  271. #endif
  272. #ifdef SFUD_USING_SFDP
  273. sfud_sfdp sfdp; /**< serial flash discoverable parameters by JEDEC standard */
  274. #endif
  275. } sfud_flash, *sfud_flash_t;
  276. #ifdef __cplusplus
  277. }
  278. #endif
  279. #endif /* _SFUD_DEF_H_ */