STM32F769IDiscovery  1.00
uDANTE Audio Networking with STM32F7 DISCO board
stm32f7xx_hal_nand.h
Go to the documentation of this file.
1 
38 /* Define to prevent recursive inclusion -------------------------------------*/
39 #ifndef __STM32F7xx_HAL_NAND_H
40 #define __STM32F7xx_HAL_NAND_H
41 
42 #ifdef __cplusplus
43  extern "C" {
44 #endif
45 
46 /* Includes ------------------------------------------------------------------*/
47 #include "stm32f7xx_ll_fmc.h"
48 
57 /* Exported typedef ----------------------------------------------------------*/
58 /* Exported types ------------------------------------------------------------*/
66 typedef enum
67 {
73 
77 typedef struct
78 {
79  /*<! NAND memory electronic signature maker and device IDs */
80 
81  uint8_t Maker_Id;
82 
83  uint8_t Device_Id;
84 
85  uint8_t Third_Id;
86 
87  uint8_t Fourth_Id;
89 
93 typedef struct
94 {
95  uint16_t Page;
97  uint16_t Zone;
99  uint16_t Block;
102 
106 typedef struct
107 {
108  uint32_t PageSize;
110  uint32_t SpareAreaSize;
112  uint32_t BlockSize;
114  uint32_t BlockNbr;
116  uint32_t ZoneSize;
118 
122 typedef struct
123 {
130  __IO HAL_NAND_StateTypeDef State;
138 /* Exported constants --------------------------------------------------------*/
139 /* Exported macro ------------------------------------------------------------*/
148 #define __HAL_NAND_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_NAND_STATE_RESET)
149 
154 /* Exported functions --------------------------------------------------------*/
163 /* Initialization/de-initialization functions ********************************/
170 
179 /* IO operation functions ****************************************************/
182 
183 HAL_StatusTypeDef HAL_NAND_Read_Page_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToRead);
184 HAL_StatusTypeDef HAL_NAND_Read_Page_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumPageToRead);
185 HAL_StatusTypeDef HAL_NAND_Write_Page_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToWrite);
186 HAL_StatusTypeDef HAL_NAND_Write_Page_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumPageToWrite);
187 HAL_StatusTypeDef HAL_NAND_Read_SpareArea_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaToRead);
188 HAL_StatusTypeDef HAL_NAND_Read_SpareArea_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumSpareAreaToRead);
189 HAL_StatusTypeDef HAL_NAND_Write_SpareArea_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaTowrite);
190 HAL_StatusTypeDef HAL_NAND_Write_SpareArea_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumSpareAreaTowrite);
194 
203 /* NAND Control functions ****************************************************/
206 HAL_StatusTypeDef HAL_NAND_GetECC(NAND_HandleTypeDef *hnand, uint32_t *ECCval, uint32_t Timeout);
207 
215 /* NAND State functions *******************************************************/
216 HAL_NAND_StateTypeDef HAL_NAND_GetState(NAND_HandleTypeDef *hnand);
225 /* Private types -------------------------------------------------------------*/
226 /* Private variables ---------------------------------------------------------*/
227 /* Private constants ---------------------------------------------------------*/
231 #define NAND_DEVICE ((uint32_t)0x80000000U)
232 #define NAND_WRITE_TIMEOUT ((uint32_t)0x01000000U)
233 
234 #define CMD_AREA ((uint32_t)(1<<16)) /* A16 = CLE high */
235 #define ADDR_AREA ((uint32_t)(1<<17)) /* A17 = ALE high */
236 
237 #define NAND_CMD_AREA_A ((uint8_t)0x00U)
238 #define NAND_CMD_AREA_B ((uint8_t)0x01U)
239 #define NAND_CMD_AREA_C ((uint8_t)0x50U)
240 #define NAND_CMD_AREA_TRUE1 ((uint8_t)0x30U)
241 
242 #define NAND_CMD_WRITE0 ((uint8_t)0x80U)
243 #define NAND_CMD_WRITE_TRUE1 ((uint8_t)0x10U)
244 #define NAND_CMD_ERASE0 ((uint8_t)0x60U)
245 #define NAND_CMD_ERASE1 ((uint8_t)0xD0U)
246 #define NAND_CMD_READID ((uint8_t)0x90U)
247 #define NAND_CMD_STATUS ((uint8_t)0x70U)
248 #define NAND_CMD_LOCK_STATUS ((uint8_t)0x7AU)
249 #define NAND_CMD_RESET ((uint8_t)0xFFU)
250 
251 /* NAND memory status */
252 #define NAND_VALID_ADDRESS ((uint32_t)0x00000100U)
253 #define NAND_INVALID_ADDRESS ((uint32_t)0x00000200U)
254 #define NAND_TIMEOUT_ERROR ((uint32_t)0x00000400U)
255 #define NAND_BUSY ((uint32_t)0x00000000U)
256 #define NAND_ERROR ((uint32_t)0x00000001U)
257 #define NAND_READY ((uint32_t)0x00000040U)
258 
262 /* Private macros ------------------------------------------------------------*/
273 #define ARRAY_ADDRESS(__ADDRESS__ , __HANDLE__) ((__ADDRESS__)->Page + \
274  (((__ADDRESS__)->Block + (((__ADDRESS__)->Zone) * ((__HANDLE__)->Info.ZoneSize)))* ((__HANDLE__)->Info.BlockSize)))
275 
281 #define ADDR_1ST_CYCLE(__ADDRESS__) (uint8_t)(__ADDRESS__) /* 1st addressing cycle */
282 #define ADDR_2ND_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 8) /* 2nd addressing cycle */
283 #define ADDR_3RD_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 16) /* 3rd addressing cycle */
284 #define ADDR_4TH_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 24) /* 4th addressing cycle */
285 
300 #ifdef __cplusplus
301 }
302 #endif
303 
304 #endif /* __STM32F7xx_HAL_NAND_H */
305 
306 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
FMC NAND Timing parameters structure definition.
FMC_NAND_TypeDef * Instance
#define FMC_NAND_TypeDef
void HAL_NAND_IRQHandler(NAND_HandleTypeDef *hnand)
void HAL_NAND_MspDeInit(NAND_HandleTypeDef *hnand)
HAL_LockTypeDef Lock
void HAL_NAND_MspInit(NAND_HandleTypeDef *hnand)
HAL_LockTypeDef
HAL Lock structures definition.
HAL_StatusTypeDef HAL_NAND_Read_SpareArea_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumSpareAreaToRead)
HAL_NAND_StateTypeDef HAL_NAND_GetState(NAND_HandleTypeDef *hnand)
HAL_NAND_StateTypeDef
HAL NAND State structures definition.
HAL_StatusTypeDef HAL_NAND_ECC_Disable(NAND_HandleTypeDef *hnand)
NAND Memory electronic signature Structure definition.
HAL_StatusTypeDef HAL_NAND_Read_Page_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToRead)
HAL_StatusTypeDef HAL_NAND_ECC_Enable(NAND_HandleTypeDef *hnand)
__IO HAL_NAND_StateTypeDef State
NAND_InfoTypeDef Info
HAL_StatusTypeDef HAL_NAND_Read_SpareArea_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaToRead)
void HAL_NAND_ITCallback(NAND_HandleTypeDef *hnand)
HAL_StatusTypeDef HAL_NAND_Write_Page_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToWrite)
NAND Memory info Structure definition.
#define __IO
Definition: core_cm0.h:213
HAL_StatusTypeDef HAL_NAND_Init(NAND_HandleTypeDef *hnand, FMC_NAND_PCC_TimingTypeDef *ComSpace_Timing, FMC_NAND_PCC_TimingTypeDef *AttSpace_Timing)
HAL_StatusTypeDef HAL_NAND_Read_Page_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumPageToRead)
uint32_t HAL_NAND_Read_Status(NAND_HandleTypeDef *hnand)
NAND Memory address Structure definition.
HAL_StatusTypeDef HAL_NAND_Write_SpareArea_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumSpareAreaTowrite)
uint32_t HAL_NAND_Address_Inc(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress)
NAND handle Structure definition.
FMC_NAND_InitTypeDef Init
Header file of FMC HAL module.
HAL_StatusTypeDef HAL_NAND_DeInit(NAND_HandleTypeDef *hnand)
HAL_StatusTypeDef HAL_NAND_Erase_Block(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress)
HAL_StatusTypeDef HAL_NAND_Read_ID(NAND_HandleTypeDef *hnand, NAND_IDTypeDef *pNAND_ID)
HAL_StatusTypeDef HAL_NAND_Write_Page_16b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint16_t *pBuffer, uint32_t NumPageToWrite)
HAL_StatusTypeDef HAL_NAND_Reset(NAND_HandleTypeDef *hnand)
HAL_StatusTypeDef
HAL Status structures definition.
HAL_StatusTypeDef HAL_NAND_Write_SpareArea_8b(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaTowrite)
FMC NAND Configuration Structure definition.
HAL_StatusTypeDef HAL_NAND_GetECC(NAND_HandleTypeDef *hnand, uint32_t *ECCval, uint32_t Timeout)