spi_flash_rom_patch.c 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671
  1. // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. // http://www.apache.org/licenses/LICENSE-2.0
  7. //
  8. // Unless required by applicable law or agreed to in writing, software
  9. // distributed under the License is distributed on an "AS IS" BASIS,
  10. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. // See the License for the specific language governing permissions and
  12. // limitations under the License.
  13. #include "rom/ets_sys.h"
  14. #include "rom/gpio.h"
  15. #include "rom/spi_flash.h"
  16. #include "sdkconfig.h"
  17. #define SPI_IDX 1
  18. #define OTH_IDX 0
  19. extern esp_rom_spiflash_chip_t g_rom_spiflash_chip;
  20. esp_rom_spiflash_result_t esp_rom_spiflash_wait_idle(esp_rom_spiflash_chip_t *spi)
  21. {
  22. uint32_t status;
  23. //wait for spi control ready
  24. while ((REG_READ(SPI_EXT2_REG(1)) & SPI_ST)) {
  25. }
  26. while ((REG_READ(SPI_EXT2_REG(0)) & SPI_ST)) {
  27. }
  28. //wait for flash status ready
  29. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_read_status(spi, &status)) {
  30. return ESP_ROM_SPIFLASH_RESULT_ERR;
  31. }
  32. return ESP_ROM_SPIFLASH_RESULT_OK;
  33. }
  34. /* Modified version of esp_rom_spiflash_unlock() that replaces version in ROM.
  35. This works around a bug where esp_rom_spiflash_unlock sometimes reads the wrong
  36. high status byte (RDSR2 result) and then copies it back to the
  37. flash status, which can cause the CMP bit or Status Register
  38. Protect bit to become set.
  39. Like other ROM SPI functions, this function is not designed to be
  40. called directly from an RTOS environment without taking precautions
  41. about interrupts, CPU coordination, flash mapping. However some of
  42. the functions in esp_spi_flash.c call it.
  43. */
  44. esp_rom_spiflash_result_t esp_rom_spiflash_unlock()
  45. {
  46. uint32_t status;
  47. esp_rom_spiflash_wait_idle(&g_rom_spiflash_chip);
  48. if (esp_rom_spiflash_read_statushigh(&g_rom_spiflash_chip, &status) != ESP_ROM_SPIFLASH_RESULT_OK) {
  49. return ESP_ROM_SPIFLASH_RESULT_ERR;
  50. }
  51. /* Clear all bits except QIE, if it is set.
  52. (This is different from ROM esp_rom_spiflash_unlock, which keeps all bits as-is.)
  53. */
  54. status &= ESP_ROM_SPIFLASH_QE;
  55. SET_PERI_REG_MASK(SPI_CTRL_REG(SPI_IDX), SPI_WRSR_2B);
  56. esp_rom_spiflash_wait_idle(&g_rom_spiflash_chip);
  57. REG_WRITE(SPI_CMD_REG(SPI_IDX), SPI_FLASH_WREN);
  58. while (REG_READ(SPI_CMD_REG(SPI_IDX)) != 0) {
  59. }
  60. esp_rom_spiflash_wait_idle(&g_rom_spiflash_chip);
  61. esp_rom_spiflash_result_t ret = esp_rom_spiflash_write_status(&g_rom_spiflash_chip, status);
  62. // WEL bit should be cleared after operations regardless of writing succeed or not.
  63. esp_rom_spiflash_wait_idle(&g_rom_spiflash_chip);
  64. REG_WRITE(SPI_CMD_REG(SPI_IDX), SPI_FLASH_WRDI);
  65. while (REG_READ(SPI_CMD_REG(SPI_IDX)) != 0) {
  66. }
  67. return ret;
  68. }
  69. #if CONFIG_SPI_FLASH_ROM_DRIVER_PATCH
  70. extern uint8_t g_rom_spiflash_dummy_len_plus[];
  71. static esp_rom_spiflash_result_t esp_rom_spiflash_enable_write(esp_rom_spiflash_chip_t *spi);
  72. //only support spi1
  73. static esp_rom_spiflash_result_t esp_rom_spiflash_erase_chip_internal(esp_rom_spiflash_chip_t *spi)
  74. {
  75. esp_rom_spiflash_wait_idle(spi);
  76. // Chip erase.
  77. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_CE);
  78. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  79. // check erase is finished.
  80. esp_rom_spiflash_wait_idle(spi);
  81. return ESP_ROM_SPIFLASH_RESULT_OK;
  82. }
  83. //only support spi1
  84. static esp_rom_spiflash_result_t esp_rom_spiflash_erase_sector_internal(esp_rom_spiflash_chip_t *spi, uint32_t addr)
  85. {
  86. //check if addr is 4k alignment
  87. if (0 != (addr & 0xfff)) {
  88. return ESP_ROM_SPIFLASH_RESULT_ERR;
  89. }
  90. esp_rom_spiflash_wait_idle(spi);
  91. // sector erase 4Kbytes erase is sector erase.
  92. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, addr & 0xffffff);
  93. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_SE);
  94. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  95. esp_rom_spiflash_wait_idle(spi);
  96. return ESP_ROM_SPIFLASH_RESULT_OK;
  97. }
  98. //only support spi1
  99. static esp_rom_spiflash_result_t esp_rom_spiflash_erase_block_internal(esp_rom_spiflash_chip_t *spi, uint32_t addr)
  100. {
  101. esp_rom_spiflash_wait_idle(spi);
  102. // sector erase 4Kbytes erase is sector erase.
  103. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, addr & 0xffffff);
  104. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_BE);
  105. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  106. esp_rom_spiflash_wait_idle(spi);
  107. return ESP_ROM_SPIFLASH_RESULT_OK;
  108. }
  109. //only support spi1
  110. static esp_rom_spiflash_result_t esp_rom_spiflash_program_page_internal(esp_rom_spiflash_chip_t *spi, uint32_t spi_addr,
  111. uint32_t *addr_source, int32_t byte_length)
  112. {
  113. uint32_t temp_addr;
  114. int32_t temp_bl;
  115. uint8_t i;
  116. uint8_t remain_word_num;
  117. //check 4byte alignment
  118. if (0 != (byte_length & 0x3)) {
  119. return ESP_ROM_SPIFLASH_RESULT_ERR;
  120. }
  121. //check if write in one page
  122. if ((spi->page_size) < ((spi_addr % (spi->page_size)) + byte_length)) {
  123. return ESP_ROM_SPIFLASH_RESULT_ERR;
  124. }
  125. esp_rom_spiflash_wait_idle(spi);
  126. temp_addr = spi_addr;
  127. temp_bl = byte_length;
  128. while (temp_bl > 0 ) {
  129. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_enable_write(spi)) {
  130. return ESP_ROM_SPIFLASH_RESULT_ERR;
  131. }
  132. if ( temp_bl >= ESP_ROM_SPIFLASH_BUFF_BYTE_WRITE_NUM ) {
  133. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, (temp_addr & 0xffffff) | ( ESP_ROM_SPIFLASH_BUFF_BYTE_WRITE_NUM << ESP_ROM_SPIFLASH_BYTES_LEN )); // 32 byte a block
  134. for (i = 0; i < (ESP_ROM_SPIFLASH_BUFF_BYTE_WRITE_NUM >> 2); i++) {
  135. WRITE_PERI_REG(PERIPHS_SPI_FLASH_C0 + i * 4, *addr_source++);
  136. }
  137. temp_bl = temp_bl - 32;
  138. temp_addr = temp_addr + 32;
  139. } else {
  140. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, (temp_addr & 0xffffff) | (temp_bl << ESP_ROM_SPIFLASH_BYTES_LEN ));
  141. remain_word_num = (0 == (temp_bl & 0x3)) ? (temp_bl >> 2) : (temp_bl >> 2) + 1;
  142. for (i = 0; i < remain_word_num; i++) {
  143. WRITE_PERI_REG(PERIPHS_SPI_FLASH_C0 + i * 4, *addr_source++);
  144. temp_bl = temp_bl - 4;
  145. }
  146. temp_bl = 0;
  147. }
  148. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_PP);
  149. while ( READ_PERI_REG(PERIPHS_SPI_FLASH_CMD ) != 0 );
  150. esp_rom_spiflash_wait_idle(spi);
  151. }
  152. return ESP_ROM_SPIFLASH_RESULT_OK;
  153. }
  154. //only support spi1
  155. static esp_rom_spiflash_result_t esp_rom_spiflash_read_data(esp_rom_spiflash_chip_t *spi, uint32_t flash_addr,
  156. uint32_t *addr_dest, int32_t byte_length)
  157. {
  158. uint32_t temp_addr;
  159. int32_t temp_length;
  160. uint8_t i;
  161. uint8_t remain_word_num;
  162. //address range check
  163. if ((flash_addr + byte_length) > (spi->chip_size)) {
  164. return ESP_ROM_SPIFLASH_RESULT_ERR;
  165. }
  166. temp_addr = flash_addr;
  167. temp_length = byte_length;
  168. esp_rom_spiflash_wait_idle(spi);
  169. while (temp_length > 0) {
  170. if (temp_length >= ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM) {
  171. //WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, temp_addr |(ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM << ESP_ROM_SPIFLASH_BYTES_LEN));
  172. REG_WRITE(SPI_MISO_DLEN_REG(1), ((ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM << 3) - 1) << SPI_USR_MISO_DBITLEN_S);
  173. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, temp_addr << 8);
  174. REG_WRITE(PERIPHS_SPI_FLASH_CMD, SPI_USR);
  175. while (REG_READ(PERIPHS_SPI_FLASH_CMD) != 0);
  176. for (i = 0; i < (ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM >> 2); i++) {
  177. *addr_dest++ = READ_PERI_REG(PERIPHS_SPI_FLASH_C0 + i * 4);
  178. }
  179. temp_length = temp_length - ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM;
  180. temp_addr = temp_addr + ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM;
  181. } else {
  182. //WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, temp_addr |(temp_length << ESP_ROM_SPIFLASH_BYTES_LEN ));
  183. WRITE_PERI_REG(PERIPHS_SPI_FLASH_ADDR, temp_addr << 8);
  184. REG_WRITE(SPI_MISO_DLEN_REG(1), ((ESP_ROM_SPIFLASH_BUFF_BYTE_READ_NUM << 3) - 1) << SPI_USR_MISO_DBITLEN_S);
  185. REG_WRITE(PERIPHS_SPI_FLASH_CMD, SPI_USR);
  186. while (REG_READ(PERIPHS_SPI_FLASH_CMD) != 0);
  187. remain_word_num = (0 == (temp_length & 0x3)) ? (temp_length >> 2) : (temp_length >> 2) + 1;
  188. for (i = 0; i < remain_word_num; i++) {
  189. *addr_dest++ = READ_PERI_REG(PERIPHS_SPI_FLASH_C0 + i * 4);
  190. }
  191. temp_length = 0;
  192. }
  193. }
  194. return ESP_ROM_SPIFLASH_RESULT_OK;
  195. }
  196. esp_rom_spiflash_result_t esp_rom_spiflash_read_status(esp_rom_spiflash_chip_t *spi, uint32_t *status)
  197. {
  198. uint32_t status_value = ESP_ROM_SPIFLASH_BUSY_FLAG;
  199. if (g_rom_spiflash_dummy_len_plus[1] == 0) {
  200. while (ESP_ROM_SPIFLASH_BUSY_FLAG == (status_value & ESP_ROM_SPIFLASH_BUSY_FLAG)) {
  201. WRITE_PERI_REG(PERIPHS_SPI_FLASH_STATUS, 0); // clear regisrter
  202. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_RDSR);
  203. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  204. status_value = READ_PERI_REG(PERIPHS_SPI_FLASH_STATUS) & (spi->status_mask);
  205. }
  206. } else {
  207. while (ESP_ROM_SPIFLASH_BUSY_FLAG == (status_value & ESP_ROM_SPIFLASH_BUSY_FLAG)) {
  208. esp_rom_spiflash_read_user_cmd(&status_value, 0x05);
  209. }
  210. }
  211. *status = status_value;
  212. return ESP_ROM_SPIFLASH_RESULT_OK;
  213. }
  214. esp_rom_spiflash_result_t esp_rom_spiflash_read_statushigh(esp_rom_spiflash_chip_t *spi, uint32_t *status)
  215. {
  216. esp_rom_spiflash_result_t ret;
  217. esp_rom_spiflash_wait_idle(&g_rom_spiflash_chip);
  218. ret = esp_rom_spiflash_read_user_cmd(status, 0x35);
  219. *status = *status << 8;
  220. return ret;
  221. }
  222. esp_rom_spiflash_result_t esp_rom_spiflash_write_status(esp_rom_spiflash_chip_t *spi, uint32_t status_value)
  223. {
  224. esp_rom_spiflash_wait_idle(spi);
  225. // update status value by status_value
  226. WRITE_PERI_REG(PERIPHS_SPI_FLASH_STATUS, status_value); // write status regisrter
  227. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_WRSR);
  228. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  229. esp_rom_spiflash_wait_idle(spi);
  230. return ESP_ROM_SPIFLASH_RESULT_OK;
  231. }
  232. static esp_rom_spiflash_result_t esp_rom_spiflash_enable_write(esp_rom_spiflash_chip_t *spi)
  233. {
  234. uint32_t flash_status = 0;
  235. esp_rom_spiflash_wait_idle(spi);
  236. //enable write
  237. WRITE_PERI_REG(PERIPHS_SPI_FLASH_CMD, SPI_FLASH_WREN); // enable write operation
  238. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  239. // make sure the flash is ready for writing
  240. while (ESP_ROM_SPIFLASH_WRENABLE_FLAG != (flash_status & ESP_ROM_SPIFLASH_WRENABLE_FLAG)) {
  241. esp_rom_spiflash_read_status(spi, &flash_status);
  242. }
  243. return ESP_ROM_SPIFLASH_RESULT_OK;
  244. }
  245. static void spi_cache_mode_switch(uint32_t modebit)
  246. {
  247. if ((modebit & SPI_FREAD_QIO) && (modebit & SPI_FASTRD_MODE)) {
  248. REG_CLR_BIT(SPI_USER_REG(0), SPI_USR_MOSI);
  249. REG_SET_BIT(SPI_USER_REG(0), SPI_USR_MISO | SPI_USR_DUMMY | SPI_USR_ADDR);
  250. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_ADDR_BITLEN, SPI0_R_QIO_ADDR_BITSLEN);
  251. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, SPI0_R_QIO_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[0]);
  252. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0xEB);
  253. } else if (modebit & SPI_FASTRD_MODE) {
  254. REG_CLR_BIT(SPI_USER_REG(0), SPI_USR_MOSI);
  255. REG_SET_BIT(SPI_USER_REG(0), SPI_USR_MISO | SPI_USR_DUMMY | SPI_USR_ADDR);
  256. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_ADDR_BITLEN, SPI0_R_FAST_ADDR_BITSLEN);
  257. if ((modebit & SPI_FREAD_QUAD)) {
  258. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0x6B);
  259. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, SPI0_R_FAST_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[0]);
  260. } else if ((modebit & SPI_FREAD_DIO)) {
  261. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_ADDR_BITLEN, SPI0_R_DIO_ADDR_BITSLEN);
  262. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, SPI0_R_DIO_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[0]);
  263. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0xBB);
  264. } else if ((modebit & SPI_FREAD_DUAL)) {
  265. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, SPI0_R_FAST_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[0]);
  266. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0x3B);
  267. } else {
  268. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, SPI0_R_FAST_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[0]);
  269. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0x0B);
  270. }
  271. } else {
  272. REG_CLR_BIT(SPI_USER_REG(0), SPI_USR_MOSI);
  273. if (g_rom_spiflash_dummy_len_plus[0] == 0) {
  274. REG_CLR_BIT(SPI_USER_REG(0), SPI_USR_DUMMY);
  275. } else {
  276. REG_SET_BIT(SPI_USER_REG(0), SPI_USR_DUMMY);
  277. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_DUMMY_CYCLELEN, g_rom_spiflash_dummy_len_plus[0] - 1);
  278. }
  279. REG_SET_BIT(SPI_USER_REG(0), SPI_USR_MISO | SPI_USR_ADDR);
  280. REG_SET_FIELD(SPI_USER1_REG(0), SPI_USR_ADDR_BITLEN, SPI0_R_SIO_ADDR_BITSLEN);
  281. REG_SET_FIELD(SPI_USER2_REG(0), SPI_USR_COMMAND_VALUE, 0x03);
  282. }
  283. }
  284. esp_rom_spiflash_result_t esp_rom_spiflash_lock()
  285. {
  286. uint32_t status;
  287. //read QE bit, not write if not QE
  288. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_read_statushigh(&g_rom_spiflash_chip, &status)) {
  289. return ESP_ROM_SPIFLASH_RESULT_ERR;
  290. }
  291. //enable 2 byte status writing
  292. SET_PERI_REG_MASK(PERIPHS_SPI_FLASH_CTRL, ESP_ROM_SPIFLASH_TWO_BYTE_STATUS_EN);
  293. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_enable_write(&g_rom_spiflash_chip)) {
  294. return ESP_ROM_SPIFLASH_RESULT_ERR;
  295. }
  296. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_write_status(&g_rom_spiflash_chip, status | ESP_ROM_SPIFLASH_WR_PROTECT)) {
  297. return ESP_ROM_SPIFLASH_RESULT_ERR;
  298. }
  299. return ESP_ROM_SPIFLASH_RESULT_OK;
  300. }
  301. esp_rom_spiflash_result_t esp_rom_spiflash_config_readmode(esp_rom_spiflash_read_mode_t mode)
  302. {
  303. uint32_t modebit;
  304. while ((REG_READ(SPI_EXT2_REG(1)) & SPI_ST)) {
  305. }
  306. while ((REG_READ(SPI_EXT2_REG(0)) & SPI_ST)) {
  307. }
  308. //clear old mode bit
  309. CLEAR_PERI_REG_MASK(PERIPHS_SPI_FLASH_CTRL, SPI_FREAD_QIO | SPI_FREAD_QUAD | SPI_FREAD_DIO | SPI_FREAD_DUAL | SPI_FASTRD_MODE);
  310. CLEAR_PERI_REG_MASK(SPI_CTRL_REG(0), SPI_FREAD_QIO | SPI_FREAD_QUAD | SPI_FREAD_DIO | SPI_FREAD_DUAL | SPI_FASTRD_MODE);
  311. //configure read mode
  312. switch (mode) {
  313. case ESP_ROM_SPIFLASH_QIO_MODE : modebit = SPI_FREAD_QIO | SPI_FASTRD_MODE; break;
  314. case ESP_ROM_SPIFLASH_QOUT_MODE : modebit = SPI_FREAD_QUAD | SPI_FASTRD_MODE; break;
  315. case ESP_ROM_SPIFLASH_DIO_MODE : modebit = SPI_FREAD_DIO | SPI_FASTRD_MODE; break;
  316. case ESP_ROM_SPIFLASH_DOUT_MODE : modebit = SPI_FREAD_DUAL | SPI_FASTRD_MODE; break;
  317. case ESP_ROM_SPIFLASH_FASTRD_MODE: modebit = SPI_FASTRD_MODE; break;
  318. case ESP_ROM_SPIFLASH_SLOWRD_MODE: modebit = 0; break;
  319. default : modebit = 0;
  320. }
  321. SET_PERI_REG_MASK(PERIPHS_SPI_FLASH_CTRL, modebit);
  322. SET_PERI_REG_MASK(SPI_CTRL_REG(0), modebit);
  323. spi_cache_mode_switch(modebit);
  324. return ESP_ROM_SPIFLASH_RESULT_OK;
  325. }
  326. esp_rom_spiflash_result_t esp_rom_spiflash_erase_chip()
  327. {
  328. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_enable_write(&g_rom_spiflash_chip)) {
  329. return ESP_ROM_SPIFLASH_RESULT_ERR;
  330. }
  331. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_chip_internal(&g_rom_spiflash_chip)) {
  332. return ESP_ROM_SPIFLASH_RESULT_ERR;
  333. }
  334. return ESP_ROM_SPIFLASH_RESULT_OK;
  335. }
  336. esp_rom_spiflash_result_t esp_rom_spiflash_erase_block(uint32_t block_num)
  337. {
  338. // flash write is always 1 line currently
  339. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  340. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, ESP_ROM_SPIFLASH_W_SIO_ADDR_BITSLEN);
  341. //check program size
  342. if (block_num >= ((g_rom_spiflash_chip.chip_size) / (g_rom_spiflash_chip.block_size))) {
  343. return ESP_ROM_SPIFLASH_RESULT_ERR;
  344. }
  345. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_enable_write(&g_rom_spiflash_chip)) {
  346. return ESP_ROM_SPIFLASH_RESULT_ERR;
  347. }
  348. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_block_internal(&g_rom_spiflash_chip, block_num * (g_rom_spiflash_chip.block_size))) {
  349. return ESP_ROM_SPIFLASH_RESULT_ERR;
  350. }
  351. return ESP_ROM_SPIFLASH_RESULT_OK;
  352. }
  353. esp_rom_spiflash_result_t esp_rom_spiflash_erase_sector(uint32_t sector_num)
  354. {
  355. // flash write is always 1 line currently
  356. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  357. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, ESP_ROM_SPIFLASH_W_SIO_ADDR_BITSLEN);
  358. //check program size
  359. if (sector_num >= ((g_rom_spiflash_chip.chip_size) / (g_rom_spiflash_chip.sector_size))) {
  360. return ESP_ROM_SPIFLASH_RESULT_ERR;
  361. }
  362. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_enable_write(&g_rom_spiflash_chip)) {
  363. return ESP_ROM_SPIFLASH_RESULT_ERR;
  364. }
  365. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_sector_internal(&g_rom_spiflash_chip, sector_num * (g_rom_spiflash_chip.sector_size))) {
  366. return ESP_ROM_SPIFLASH_RESULT_ERR;
  367. }
  368. return ESP_ROM_SPIFLASH_RESULT_OK;
  369. }
  370. esp_rom_spiflash_result_t esp_rom_spiflash_write(uint32_t target, const uint32_t *src_addr, int32_t len)
  371. {
  372. uint32_t page_size;
  373. uint32_t pgm_len, pgm_num;
  374. uint8_t i;
  375. // flash write is always 1 line currently
  376. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  377. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, ESP_ROM_SPIFLASH_W_SIO_ADDR_BITSLEN);
  378. //check program size
  379. if ( (target + len) > (g_rom_spiflash_chip.chip_size)) {
  380. return ESP_ROM_SPIFLASH_RESULT_ERR;
  381. }
  382. page_size = g_rom_spiflash_chip.page_size;
  383. pgm_len = page_size - (target % page_size);
  384. if (len < pgm_len) {
  385. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_program_page_internal(&g_rom_spiflash_chip,
  386. target, (uint32_t *)src_addr, len)) {
  387. return ESP_ROM_SPIFLASH_RESULT_ERR;
  388. }
  389. } else {
  390. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_program_page_internal(&g_rom_spiflash_chip,
  391. target, (uint32_t *)src_addr, pgm_len)) {
  392. return ESP_ROM_SPIFLASH_RESULT_ERR;
  393. }
  394. //whole page program
  395. pgm_num = (len - pgm_len) / page_size;
  396. for (i = 0; i < pgm_num; i++) {
  397. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_program_page_internal(&g_rom_spiflash_chip,
  398. target + pgm_len, (uint32_t *)src_addr + (pgm_len >> 2), page_size)) {
  399. return ESP_ROM_SPIFLASH_RESULT_ERR;
  400. }
  401. pgm_len += page_size;
  402. }
  403. //remain parts to program
  404. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_program_page_internal(&g_rom_spiflash_chip,
  405. target + pgm_len, (uint32_t *)src_addr + (pgm_len >> 2), len - pgm_len)) {
  406. return ESP_ROM_SPIFLASH_RESULT_ERR;
  407. }
  408. }
  409. return ESP_ROM_SPIFLASH_RESULT_OK;
  410. }
  411. esp_rom_spiflash_result_t esp_rom_spiflash_write_encrypted(uint32_t flash_addr, uint32_t *data, uint32_t len)
  412. {
  413. esp_rom_spiflash_result_t ret = ESP_ROM_SPIFLASH_RESULT_OK;
  414. uint32_t i;
  415. if ((flash_addr & 0x1f) || (len & 0x1f)) { //check 32 byte alignment
  416. return ESP_ROM_SPIFLASH_RESULT_ERR;
  417. }
  418. esp_rom_spiflash_write_encrypted_enable();
  419. for (i = 0; i < (len >> 5); i++) {
  420. if ((ret = esp_rom_spiflash_prepare_encrypted_data(flash_addr + (i << 5), data + (i << 3))) != ESP_ROM_SPIFLASH_RESULT_OK) {
  421. break;
  422. }
  423. if ((ret = esp_rom_spiflash_write(flash_addr + (i << 5), data, 32)) != ESP_ROM_SPIFLASH_RESULT_OK) {
  424. break;
  425. }
  426. }
  427. esp_rom_spiflash_write_encrypted_disable();
  428. return ret;
  429. }
  430. esp_rom_spiflash_result_t esp_rom_spiflash_read(uint32_t target, uint32_t *dest_addr, int32_t len)
  431. {
  432. // QIO or SIO, non-QIO regard as SIO
  433. uint32_t modebit;
  434. modebit = READ_PERI_REG(PERIPHS_SPI_FLASH_CTRL);
  435. if ((modebit & SPI_FREAD_QIO) && (modebit & SPI_FASTRD_MODE)) {
  436. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MOSI);
  437. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MISO | SPI_USR_DUMMY | SPI_USR_ADDR);
  438. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, SPI1_R_QIO_ADDR_BITSLEN);
  439. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_DUMMY_CYCLELEN, SPI1_R_QIO_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[1]);
  440. //REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0xEB);
  441. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0xEB);
  442. } else if (modebit & SPI_FASTRD_MODE) {
  443. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MOSI);
  444. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MISO | SPI_USR_ADDR);
  445. if (modebit & SPI_FREAD_DIO) {
  446. if (g_rom_spiflash_dummy_len_plus[1] == 0) {
  447. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  448. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, SPI1_R_DIO_ADDR_BITSLEN);
  449. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0xBB);
  450. } else {
  451. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  452. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, SPI1_R_DIO_ADDR_BITSLEN);
  453. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_DUMMY_CYCLELEN, g_rom_spiflash_dummy_len_plus[1] - 1);
  454. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0xBB);
  455. }
  456. } else {
  457. if ((modebit & SPI_FREAD_QUAD)) {
  458. //REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0x6B);
  459. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0x6B);
  460. } else if ((modebit & SPI_FREAD_DUAL)) {
  461. //REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0x3B);
  462. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0x3B);
  463. } else {
  464. //REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0x0B);
  465. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0x0B);
  466. }
  467. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  468. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, SPI1_R_FAST_ADDR_BITSLEN);
  469. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_DUMMY_CYCLELEN, SPI1_R_FAST_DUMMY_CYCLELEN + g_rom_spiflash_dummy_len_plus[1]);
  470. }
  471. } else {
  472. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MOSI);
  473. if (g_rom_spiflash_dummy_len_plus[1] == 0) {
  474. REG_CLR_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  475. } else {
  476. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_DUMMY);
  477. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_DUMMY_CYCLELEN, g_rom_spiflash_dummy_len_plus[1] - 1);
  478. }
  479. REG_SET_BIT(PERIPHS_SPI_FLASH_USRREG, SPI_USR_MISO | SPI_USR_ADDR);
  480. REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG1, SPI_USR_ADDR_BITLEN, SPI1_R_SIO_ADDR_BITSLEN);
  481. //REG_SET_FIELD(PERIPHS_SPI_FLASH_USRREG2, SPI_USR_COMMAND_VALUE, 0x03);
  482. REG_WRITE(PERIPHS_SPI_FLASH_USRREG2, (0x7 << SPI_USR_COMMAND_BITLEN_S) | 0x03);
  483. }
  484. if ( ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_read_data(&g_rom_spiflash_chip, target, dest_addr, len)) {
  485. return ESP_ROM_SPIFLASH_RESULT_ERR;
  486. }
  487. return ESP_ROM_SPIFLASH_RESULT_OK;
  488. }
  489. esp_rom_spiflash_result_t esp_rom_spiflash_erase_area(uint32_t start_addr, uint32_t area_len)
  490. {
  491. int32_t total_sector_num;
  492. int32_t head_sector_num;
  493. uint32_t sector_no;
  494. uint32_t sector_num_per_block;
  495. //set read mode to Fastmode ,not QDIO mode for erase
  496. //
  497. // TODO: this is probably a bug as it doesn't re-enable QIO mode, not serious as this
  498. // function is not used in IDF.
  499. esp_rom_spiflash_config_readmode(ESP_ROM_SPIFLASH_SLOWRD_MODE);
  500. //check if area is oversize of flash
  501. if ((start_addr + area_len) > g_rom_spiflash_chip.chip_size) {
  502. return ESP_ROM_SPIFLASH_RESULT_ERR;
  503. }
  504. //start_addr is aligned as sector boundary
  505. if (0 != (start_addr % g_rom_spiflash_chip.sector_size)) {
  506. return ESP_ROM_SPIFLASH_RESULT_ERR;
  507. }
  508. //Unlock flash to enable erase
  509. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_unlock(/*&g_rom_spiflash_chip*/)) {
  510. return ESP_ROM_SPIFLASH_RESULT_ERR;
  511. }
  512. sector_no = start_addr / g_rom_spiflash_chip.sector_size;
  513. sector_num_per_block = g_rom_spiflash_chip.block_size / g_rom_spiflash_chip.sector_size;
  514. total_sector_num = (0 == (area_len % g_rom_spiflash_chip.sector_size)) ? area_len / g_rom_spiflash_chip.sector_size :
  515. 1 + (area_len / g_rom_spiflash_chip.sector_size);
  516. //check if erase area reach over block boundary
  517. head_sector_num = sector_num_per_block - (sector_no % sector_num_per_block);
  518. head_sector_num = (head_sector_num >= total_sector_num) ? total_sector_num : head_sector_num;
  519. //JJJ, BUG of 6.0 erase
  520. //middle part of area is aligned by blocks
  521. total_sector_num -= head_sector_num;
  522. //head part of area is erased
  523. while (0 != head_sector_num) {
  524. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_sector(sector_no)) {
  525. return ESP_ROM_SPIFLASH_RESULT_ERR;
  526. }
  527. sector_no++;
  528. head_sector_num--;
  529. }
  530. while (total_sector_num > sector_num_per_block) {
  531. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_block(sector_no / sector_num_per_block)) {
  532. return ESP_ROM_SPIFLASH_RESULT_ERR;
  533. }
  534. sector_no += sector_num_per_block;
  535. total_sector_num -= sector_num_per_block;
  536. }
  537. //tail part of area burn
  538. while (0 < total_sector_num) {
  539. if (ESP_ROM_SPIFLASH_RESULT_OK != esp_rom_spiflash_erase_sector(sector_no)) {
  540. return ESP_ROM_SPIFLASH_RESULT_ERR;
  541. }
  542. sector_no++;
  543. total_sector_num--;
  544. }
  545. return ESP_ROM_SPIFLASH_RESULT_OK;
  546. }
  547. esp_rom_spiflash_result_t esp_rom_spiflash_write_disable(void)
  548. {
  549. REG_WRITE(SPI_CMD_REG(SPI_IDX), SPI_FLASH_WRDI);
  550. while (READ_PERI_REG(PERIPHS_SPI_FLASH_CMD) != 0);
  551. return ESP_ROM_SPIFLASH_RESULT_OK;
  552. }
  553. #endif