From 779ea88be79641ed35c6fe9cad3b5265e969dc35 Mon Sep 17 00:00:00 2001 From: barthess Date: Fri, 6 Jan 2017 11:06:40 +0300 Subject: [PATCH] NAND. Added reset function. --- os/hal/include/hal_nand.h | 1 + os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.c | 28 ++++++++++++++------ os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.h | 1 + os/hal/src/hal_nand.c | 1 + 4 files changed, 23 insertions(+), 8 deletions(-) diff --git a/os/hal/include/hal_nand.h b/os/hal/include/hal_nand.h index ace3e5dd..78971879 100644 --- a/os/hal/include/hal_nand.h +++ b/os/hal/include/hal_nand.h @@ -82,6 +82,7 @@ typedef enum { NAND_READ = 6, /**< Reading from NAND. */ NAND_DMA_TX = 7, /**< DMA transmitting. */ NAND_DMA_RX = 8, /**< DMA receiving. */ + NAND_RESET = 9, /**< Software reset in progress. */ } nandstate_t; /** diff --git a/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.c b/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.c index f39ff35d..5ba1b297 100644 --- a/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.c +++ b/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.c @@ -157,14 +157,9 @@ static void nand_isr_handler (NANDDriver *nandp) { /* thread will be waked up from DMA ISR */ break; - case NAND_ERASE: - /* NAND reports about erase finish */ - nandp->state = NAND_READY; - wakeup_isr(nandp); - break; - - case NAND_PROGRAM: - /* NAND reports about page programming finish */ + case NAND_ERASE: /* NAND reports about erase finish */ + case NAND_PROGRAM: /* NAND reports about page programming finish */ + case NAND_RESET: /* NAND reports about finished reset recover */ nandp->state = NAND_READY; wakeup_isr(nandp); break; @@ -410,6 +405,23 @@ uint8_t nand_lld_write_data(NANDDriver *nandp, const uint8_t *data, return nand_lld_read_status(nandp); } +/** + * @brief Soft reset NAND device. + * + * @param[in] nandp pointer to the @p NANDDriver object + * + * @notapi + */ +void nand_lld_reset(NANDDriver *nandp) { + + nandp->state = NAND_RESET; + + nand_lld_write_cmd (nandp, NAND_CMD_RESET); + osalSysLock(); + nand_lld_suspend_thread(nandp); + osalSysUnlock(); +} + /** * @brief Erase block. * diff --git a/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.h b/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.h index de7a0c4b..ead1a4e6 100644 --- a/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.h +++ b/os/hal/ports/STM32/LLD/FSMCv1/hal_nand_lld.h @@ -283,6 +283,7 @@ extern "C" { uint8_t nand_lld_write_data(NANDDriver *nandp, const uint8_t *data, size_t datalen, uint8_t *addr, size_t addrlen, uint32_t *ecc); uint8_t nand_lld_read_status(NANDDriver *nandp); + void nand_lld_reset(NANDDriver *nandp); #ifdef __cplusplus } #endif diff --git a/os/hal/src/hal_nand.c b/os/hal/src/hal_nand.c index e1b298a1..2e5c505e 100644 --- a/os/hal/src/hal_nand.c +++ b/os/hal/src/hal_nand.c @@ -229,6 +229,7 @@ void nandStart(NANDDriver *nandp, const NANDConfig *config, bitmap_t *bb_map) { pagesize_check(nandp->config->page_data_size); nand_lld_start(nandp); nandp->state = NAND_READY; + nand_lld_reset(nandp); if (NULL != bb_map) { nandp->bb_map = bb_map;