mbed library sources

Dependents:   Encrypted my_mbed lklk CyaSSL_DTLS_Cellular ... more

Superseded

This library was superseded by mbed-dev - https://os.mbed.com/users/mbed_official/code/mbed-dev/.

Development branch of the mbed library sources. This library is kept in synch with the latest changes from the mbed SDK and it is not guaranteed to work.

If you are looking for a stable and tested release, please import one of the official mbed library releases:

Import librarymbed

The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Committer:
mbed_official
Date:
Fri Aug 14 13:15:17 2015 +0100
Revision:
610:813dcc80987e
Parent:
573:ad23fe03a082
Synchronized with git revision 6d84db41c6833e0b9b024741eb0616a5f62d5599

Full URL: https://github.com/mbedmicro/mbed/commit/6d84db41c6833e0b9b024741eb0616a5f62d5599/

DISCO_F746NG - Improvements

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 573:ad23fe03a082 1 /**
mbed_official 573:ad23fe03a082 2 ******************************************************************************
mbed_official 573:ad23fe03a082 3 * @file stm32f7xx_hal_nand.h
mbed_official 573:ad23fe03a082 4 * @author MCD Application Team
mbed_official 610:813dcc80987e 5 * @version V1.0.1
mbed_official 610:813dcc80987e 6 * @date 25-June-2015
mbed_official 573:ad23fe03a082 7 * @brief Header file of NAND HAL module.
mbed_official 573:ad23fe03a082 8 ******************************************************************************
mbed_official 573:ad23fe03a082 9 * @attention
mbed_official 573:ad23fe03a082 10 *
mbed_official 573:ad23fe03a082 11 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
mbed_official 573:ad23fe03a082 12 *
mbed_official 573:ad23fe03a082 13 * Redistribution and use in source and binary forms, with or without modification,
mbed_official 573:ad23fe03a082 14 * are permitted provided that the following conditions are met:
mbed_official 573:ad23fe03a082 15 * 1. Redistributions of source code must retain the above copyright notice,
mbed_official 573:ad23fe03a082 16 * this list of conditions and the following disclaimer.
mbed_official 573:ad23fe03a082 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
mbed_official 573:ad23fe03a082 18 * this list of conditions and the following disclaimer in the documentation
mbed_official 573:ad23fe03a082 19 * and/or other materials provided with the distribution.
mbed_official 573:ad23fe03a082 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
mbed_official 573:ad23fe03a082 21 * may be used to endorse or promote products derived from this software
mbed_official 573:ad23fe03a082 22 * without specific prior written permission.
mbed_official 573:ad23fe03a082 23 *
mbed_official 573:ad23fe03a082 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
mbed_official 573:ad23fe03a082 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
mbed_official 573:ad23fe03a082 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
mbed_official 573:ad23fe03a082 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
mbed_official 573:ad23fe03a082 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
mbed_official 573:ad23fe03a082 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
mbed_official 573:ad23fe03a082 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
mbed_official 573:ad23fe03a082 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_official 573:ad23fe03a082 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
mbed_official 573:ad23fe03a082 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
mbed_official 573:ad23fe03a082 34 *
mbed_official 573:ad23fe03a082 35 ******************************************************************************
mbed_official 573:ad23fe03a082 36 */
mbed_official 573:ad23fe03a082 37
mbed_official 573:ad23fe03a082 38 /* Define to prevent recursive inclusion -------------------------------------*/
mbed_official 573:ad23fe03a082 39 #ifndef __STM32F7xx_HAL_NAND_H
mbed_official 573:ad23fe03a082 40 #define __STM32F7xx_HAL_NAND_H
mbed_official 573:ad23fe03a082 41
mbed_official 573:ad23fe03a082 42 #ifdef __cplusplus
mbed_official 573:ad23fe03a082 43 extern "C" {
mbed_official 573:ad23fe03a082 44 #endif
mbed_official 573:ad23fe03a082 45
mbed_official 573:ad23fe03a082 46 /* Includes ------------------------------------------------------------------*/
mbed_official 573:ad23fe03a082 47 #include "stm32f7xx_ll_fmc.h"
mbed_official 573:ad23fe03a082 48
mbed_official 573:ad23fe03a082 49 /** @addtogroup STM32F7xx_HAL_Driver
mbed_official 573:ad23fe03a082 50 * @{
mbed_official 573:ad23fe03a082 51 */
mbed_official 573:ad23fe03a082 52
mbed_official 573:ad23fe03a082 53 /** @addtogroup NAND
mbed_official 573:ad23fe03a082 54 * @{
mbed_official 573:ad23fe03a082 55 */
mbed_official 573:ad23fe03a082 56
mbed_official 573:ad23fe03a082 57 /* Exported typedef ----------------------------------------------------------*/
mbed_official 573:ad23fe03a082 58 /* Exported types ------------------------------------------------------------*/
mbed_official 573:ad23fe03a082 59 /** @defgroup NAND_Exported_Types NAND Exported Types
mbed_official 573:ad23fe03a082 60 * @{
mbed_official 573:ad23fe03a082 61 */
mbed_official 573:ad23fe03a082 62
mbed_official 573:ad23fe03a082 63 /**
mbed_official 573:ad23fe03a082 64 * @brief HAL NAND State structures definition
mbed_official 573:ad23fe03a082 65 */
mbed_official 573:ad23fe03a082 66 typedef enum
mbed_official 573:ad23fe03a082 67 {
mbed_official 573:ad23fe03a082 68 HAL_NAND_STATE_RESET = 0x00, /*!< NAND not yet initialized or disabled */
mbed_official 573:ad23fe03a082 69 HAL_NAND_STATE_READY = 0x01, /*!< NAND initialized and ready for use */
mbed_official 573:ad23fe03a082 70 HAL_NAND_STATE_BUSY = 0x02, /*!< NAND internal process is ongoing */
mbed_official 573:ad23fe03a082 71 HAL_NAND_STATE_ERROR = 0x03 /*!< NAND error state */
mbed_official 573:ad23fe03a082 72 }HAL_NAND_StateTypeDef;
mbed_official 573:ad23fe03a082 73
mbed_official 573:ad23fe03a082 74 /**
mbed_official 573:ad23fe03a082 75 * @brief NAND Memory electronic signature Structure definition
mbed_official 573:ad23fe03a082 76 */
mbed_official 573:ad23fe03a082 77 typedef struct
mbed_official 573:ad23fe03a082 78 {
mbed_official 573:ad23fe03a082 79 /*<! NAND memory electronic signature maker and device IDs */
mbed_official 573:ad23fe03a082 80
mbed_official 573:ad23fe03a082 81 uint8_t Maker_Id;
mbed_official 573:ad23fe03a082 82
mbed_official 573:ad23fe03a082 83 uint8_t Device_Id;
mbed_official 573:ad23fe03a082 84
mbed_official 573:ad23fe03a082 85 uint8_t Third_Id;
mbed_official 573:ad23fe03a082 86
mbed_official 573:ad23fe03a082 87 uint8_t Fourth_Id;
mbed_official 573:ad23fe03a082 88 }NAND_IDTypeDef;
mbed_official 573:ad23fe03a082 89
mbed_official 573:ad23fe03a082 90 /**
mbed_official 573:ad23fe03a082 91 * @brief NAND Memory address Structure definition
mbed_official 573:ad23fe03a082 92 */
mbed_official 573:ad23fe03a082 93 typedef struct
mbed_official 573:ad23fe03a082 94 {
mbed_official 573:ad23fe03a082 95 uint16_t Page; /*!< NAND memory Page address */
mbed_official 573:ad23fe03a082 96
mbed_official 573:ad23fe03a082 97 uint16_t Zone; /*!< NAND memory Zone address */
mbed_official 573:ad23fe03a082 98
mbed_official 573:ad23fe03a082 99 uint16_t Block; /*!< NAND memory Block address */
mbed_official 573:ad23fe03a082 100
mbed_official 573:ad23fe03a082 101 }NAND_AddressTypeDef;
mbed_official 573:ad23fe03a082 102
mbed_official 573:ad23fe03a082 103 /**
mbed_official 573:ad23fe03a082 104 * @brief NAND Memory info Structure definition
mbed_official 573:ad23fe03a082 105 */
mbed_official 573:ad23fe03a082 106 typedef struct
mbed_official 573:ad23fe03a082 107 {
mbed_official 573:ad23fe03a082 108 uint32_t PageSize; /*!< NAND memory page (without spare area) size measured in K. bytes */
mbed_official 573:ad23fe03a082 109
mbed_official 573:ad23fe03a082 110 uint32_t SpareAreaSize; /*!< NAND memory spare area size measured in K. bytes */
mbed_official 573:ad23fe03a082 111
mbed_official 573:ad23fe03a082 112 uint32_t BlockSize; /*!< NAND memory block size number of pages */
mbed_official 573:ad23fe03a082 113
mbed_official 573:ad23fe03a082 114 uint32_t BlockNbr; /*!< NAND memory number of blocks */
mbed_official 573:ad23fe03a082 115
mbed_official 573:ad23fe03a082 116 uint32_t ZoneSize; /*!< NAND memory zone size measured in number of blocks */
mbed_official 573:ad23fe03a082 117 }NAND_InfoTypeDef;
mbed_official 573:ad23fe03a082 118
mbed_official 573:ad23fe03a082 119 /**
mbed_official 573:ad23fe03a082 120 * @brief NAND handle Structure definition
mbed_official 573:ad23fe03a082 121 */
mbed_official 573:ad23fe03a082 122 typedef struct
mbed_official 573:ad23fe03a082 123 {
mbed_official 573:ad23fe03a082 124 FMC_NAND_TypeDef *Instance; /*!< Register base address */
mbed_official 573:ad23fe03a082 125
mbed_official 573:ad23fe03a082 126 FMC_NAND_InitTypeDef Init; /*!< NAND device control configuration parameters */
mbed_official 573:ad23fe03a082 127
mbed_official 573:ad23fe03a082 128 HAL_LockTypeDef Lock; /*!< NAND locking object */
mbed_official 573:ad23fe03a082 129
mbed_official 573:ad23fe03a082 130 __IO HAL_NAND_StateTypeDef State; /*!< NAND device access state */
mbed_official 573:ad23fe03a082 131
mbed_official 573:ad23fe03a082 132 NAND_InfoTypeDef Info; /*!< NAND characteristic information structure */
mbed_official 573:ad23fe03a082 133 }NAND_HandleTypeDef;
mbed_official 573:ad23fe03a082 134 /**
mbed_official 573:ad23fe03a082 135 * @}
mbed_official 573:ad23fe03a082 136 */
mbed_official 573:ad23fe03a082 137
mbed_official 573:ad23fe03a082 138 /* Exported constants --------------------------------------------------------*/
mbed_official 573:ad23fe03a082 139 /* Exported macro ------------------------------------------------------------*/
mbed_official 573:ad23fe03a082 140 /** @defgroup NAND_Exported_Macros NAND Exported Macros
mbed_official 573:ad23fe03a082 141 * @{
mbed_official 573:ad23fe03a082 142 */
mbed_official 573:ad23fe03a082 143
mbed_official 573:ad23fe03a082 144 /** @brief Reset NAND handle state
mbed_official 573:ad23fe03a082 145 * @param __HANDLE__: specifies the NAND handle.
mbed_official 573:ad23fe03a082 146 * @retval None
mbed_official 573:ad23fe03a082 147 */
mbed_official 573:ad23fe03a082 148 #define __HAL_NAND_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_NAND_STATE_RESET)
mbed_official 573:ad23fe03a082 149
mbed_official 573:ad23fe03a082 150 /**
mbed_official 573:ad23fe03a082 151 * @}
mbed_official 573:ad23fe03a082 152 */
mbed_official 573:ad23fe03a082 153
mbed_official 573:ad23fe03a082 154 /* Exported functions --------------------------------------------------------*/
mbed_official 573:ad23fe03a082 155 /** @addtogroup NAND_Exported_Functions NAND Exported Functions
mbed_official 573:ad23fe03a082 156 * @{
mbed_official 573:ad23fe03a082 157 */
mbed_official 573:ad23fe03a082 158
mbed_official 573:ad23fe03a082 159 /** @addtogroup NAND_Exported_Functions_Group1 Initialization and de-initialization functions
mbed_official 573:ad23fe03a082 160 * @{
mbed_official 573:ad23fe03a082 161 */
mbed_official 573:ad23fe03a082 162
mbed_official 573:ad23fe03a082 163 /* Initialization/de-initialization functions ********************************/
mbed_official 573:ad23fe03a082 164 HAL_StatusTypeDef HAL_NAND_Init(NAND_HandleTypeDef *hnand, FMC_NAND_PCC_TimingTypeDef *ComSpace_Timing, FMC_NAND_PCC_TimingTypeDef *AttSpace_Timing);
mbed_official 573:ad23fe03a082 165 HAL_StatusTypeDef HAL_NAND_DeInit(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 166 void HAL_NAND_MspInit(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 167 void HAL_NAND_MspDeInit(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 168 void HAL_NAND_IRQHandler(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 169 void HAL_NAND_ITCallback(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 170
mbed_official 573:ad23fe03a082 171 /**
mbed_official 573:ad23fe03a082 172 * @}
mbed_official 573:ad23fe03a082 173 */
mbed_official 573:ad23fe03a082 174
mbed_official 573:ad23fe03a082 175 /** @addtogroup NAND_Exported_Functions_Group2 Input and Output functions
mbed_official 573:ad23fe03a082 176 * @{
mbed_official 573:ad23fe03a082 177 */
mbed_official 573:ad23fe03a082 178
mbed_official 573:ad23fe03a082 179 /* IO operation functions ****************************************************/
mbed_official 573:ad23fe03a082 180 HAL_StatusTypeDef HAL_NAND_Read_ID(NAND_HandleTypeDef *hnand, NAND_IDTypeDef *pNAND_ID);
mbed_official 573:ad23fe03a082 181 HAL_StatusTypeDef HAL_NAND_Reset(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 182 HAL_StatusTypeDef HAL_NAND_Read_Page(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToRead);
mbed_official 573:ad23fe03a082 183 HAL_StatusTypeDef HAL_NAND_Write_Page(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumPageToWrite);
mbed_official 573:ad23fe03a082 184 HAL_StatusTypeDef HAL_NAND_Read_SpareArea(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaToRead);
mbed_official 573:ad23fe03a082 185 HAL_StatusTypeDef HAL_NAND_Write_SpareArea(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress, uint8_t *pBuffer, uint32_t NumSpareAreaTowrite);
mbed_official 573:ad23fe03a082 186 HAL_StatusTypeDef HAL_NAND_Erase_Block(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress);
mbed_official 573:ad23fe03a082 187 uint32_t HAL_NAND_Read_Status(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 188 uint32_t HAL_NAND_Address_Inc(NAND_HandleTypeDef *hnand, NAND_AddressTypeDef *pAddress);
mbed_official 573:ad23fe03a082 189
mbed_official 573:ad23fe03a082 190 /**
mbed_official 573:ad23fe03a082 191 * @}
mbed_official 573:ad23fe03a082 192 */
mbed_official 573:ad23fe03a082 193
mbed_official 573:ad23fe03a082 194 /** @addtogroup NAND_Exported_Functions_Group3 Peripheral Control functions
mbed_official 573:ad23fe03a082 195 * @{
mbed_official 573:ad23fe03a082 196 */
mbed_official 573:ad23fe03a082 197
mbed_official 573:ad23fe03a082 198 /* NAND Control functions ****************************************************/
mbed_official 573:ad23fe03a082 199 HAL_StatusTypeDef HAL_NAND_ECC_Enable(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 200 HAL_StatusTypeDef HAL_NAND_ECC_Disable(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 201 HAL_StatusTypeDef HAL_NAND_GetECC(NAND_HandleTypeDef *hnand, uint32_t *ECCval, uint32_t Timeout);
mbed_official 573:ad23fe03a082 202
mbed_official 573:ad23fe03a082 203 /**
mbed_official 573:ad23fe03a082 204 * @}
mbed_official 573:ad23fe03a082 205 */
mbed_official 573:ad23fe03a082 206
mbed_official 573:ad23fe03a082 207 /** @addtogroup NAND_Exported_Functions_Group4 Peripheral State functions
mbed_official 573:ad23fe03a082 208 * @{
mbed_official 573:ad23fe03a082 209 */
mbed_official 573:ad23fe03a082 210 /* NAND State functions *******************************************************/
mbed_official 573:ad23fe03a082 211 HAL_NAND_StateTypeDef HAL_NAND_GetState(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 212 uint32_t HAL_NAND_Read_Status(NAND_HandleTypeDef *hnand);
mbed_official 573:ad23fe03a082 213 /**
mbed_official 573:ad23fe03a082 214 * @}
mbed_official 573:ad23fe03a082 215 */
mbed_official 573:ad23fe03a082 216
mbed_official 573:ad23fe03a082 217 /**
mbed_official 573:ad23fe03a082 218 * @}
mbed_official 573:ad23fe03a082 219 */
mbed_official 573:ad23fe03a082 220 /* Private types -------------------------------------------------------------*/
mbed_official 573:ad23fe03a082 221 /* Private variables ---------------------------------------------------------*/
mbed_official 573:ad23fe03a082 222 /* Private constants ---------------------------------------------------------*/
mbed_official 573:ad23fe03a082 223 /** @defgroup NAND_Private_Constants NAND Private Constants
mbed_official 573:ad23fe03a082 224 * @{
mbed_official 573:ad23fe03a082 225 */
mbed_official 573:ad23fe03a082 226 #define NAND_DEVICE ((uint32_t)0x80000000)
mbed_official 573:ad23fe03a082 227 #define NAND_WRITE_TIMEOUT ((uint32_t)0x01000000)
mbed_official 573:ad23fe03a082 228
mbed_official 573:ad23fe03a082 229 #define CMD_AREA ((uint32_t)(1<<16)) /* A16 = CLE high */
mbed_official 573:ad23fe03a082 230 #define ADDR_AREA ((uint32_t)(1<<17)) /* A17 = ALE high */
mbed_official 573:ad23fe03a082 231
mbed_official 573:ad23fe03a082 232 #define NAND_CMD_AREA_A ((uint8_t)0x00)
mbed_official 573:ad23fe03a082 233 #define NAND_CMD_AREA_B ((uint8_t)0x01)
mbed_official 573:ad23fe03a082 234 #define NAND_CMD_AREA_C ((uint8_t)0x50)
mbed_official 573:ad23fe03a082 235 #define NAND_CMD_AREA_TRUE1 ((uint8_t)0x30)
mbed_official 573:ad23fe03a082 236
mbed_official 573:ad23fe03a082 237 #define NAND_CMD_WRITE0 ((uint8_t)0x80)
mbed_official 573:ad23fe03a082 238 #define NAND_CMD_WRITE_TRUE1 ((uint8_t)0x10)
mbed_official 573:ad23fe03a082 239 #define NAND_CMD_ERASE0 ((uint8_t)0x60)
mbed_official 573:ad23fe03a082 240 #define NAND_CMD_ERASE1 ((uint8_t)0xD0)
mbed_official 573:ad23fe03a082 241 #define NAND_CMD_READID ((uint8_t)0x90)
mbed_official 573:ad23fe03a082 242 #define NAND_CMD_STATUS ((uint8_t)0x70)
mbed_official 573:ad23fe03a082 243 #define NAND_CMD_LOCK_STATUS ((uint8_t)0x7A)
mbed_official 573:ad23fe03a082 244 #define NAND_CMD_RESET ((uint8_t)0xFF)
mbed_official 573:ad23fe03a082 245
mbed_official 573:ad23fe03a082 246 /* NAND memory status */
mbed_official 573:ad23fe03a082 247 #define NAND_VALID_ADDRESS ((uint32_t)0x00000100)
mbed_official 573:ad23fe03a082 248 #define NAND_INVALID_ADDRESS ((uint32_t)0x00000200)
mbed_official 573:ad23fe03a082 249 #define NAND_TIMEOUT_ERROR ((uint32_t)0x00000400)
mbed_official 573:ad23fe03a082 250 #define NAND_BUSY ((uint32_t)0x00000000)
mbed_official 573:ad23fe03a082 251 #define NAND_ERROR ((uint32_t)0x00000001)
mbed_official 573:ad23fe03a082 252 #define NAND_READY ((uint32_t)0x00000040)
mbed_official 573:ad23fe03a082 253 /**
mbed_official 573:ad23fe03a082 254 * @}
mbed_official 573:ad23fe03a082 255 */
mbed_official 573:ad23fe03a082 256
mbed_official 573:ad23fe03a082 257 /* Private macros ------------------------------------------------------------*/
mbed_official 573:ad23fe03a082 258 /** @defgroup NAND_Private_Macros NAND Private Macros
mbed_official 573:ad23fe03a082 259 * @{
mbed_official 573:ad23fe03a082 260 */
mbed_official 573:ad23fe03a082 261
mbed_official 573:ad23fe03a082 262 /**
mbed_official 573:ad23fe03a082 263 * @brief NAND memory address computation.
mbed_official 573:ad23fe03a082 264 * @param __ADDRESS__: NAND memory address.
mbed_official 573:ad23fe03a082 265 * @param __HANDLE__ : NAND handle.
mbed_official 573:ad23fe03a082 266 * @retval NAND Raw address value
mbed_official 573:ad23fe03a082 267 */
mbed_official 573:ad23fe03a082 268 #define ARRAY_ADDRESS(__ADDRESS__ , __HANDLE__) ((__ADDRESS__)->Page + \
mbed_official 573:ad23fe03a082 269 (((__ADDRESS__)->Block + (((__ADDRESS__)->Zone) * ((__HANDLE__)->Info.ZoneSize)))* ((__HANDLE__)->Info.BlockSize)))
mbed_official 573:ad23fe03a082 270
mbed_official 573:ad23fe03a082 271 /**
mbed_official 573:ad23fe03a082 272 * @brief NAND memory address cycling.
mbed_official 573:ad23fe03a082 273 * @param __ADDRESS__: NAND memory address.
mbed_official 573:ad23fe03a082 274 * @retval NAND address cycling value.
mbed_official 573:ad23fe03a082 275 */
mbed_official 573:ad23fe03a082 276 #define ADDR_1ST_CYCLE(__ADDRESS__) (uint8_t)(__ADDRESS__) /* 1st addressing cycle */
mbed_official 573:ad23fe03a082 277 #define ADDR_2ND_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 8) /* 2nd addressing cycle */
mbed_official 573:ad23fe03a082 278 #define ADDR_3RD_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 16) /* 3rd addressing cycle */
mbed_official 573:ad23fe03a082 279 #define ADDR_4TH_CYCLE(__ADDRESS__) (uint8_t)((__ADDRESS__) >> 24) /* 4th addressing cycle */
mbed_official 573:ad23fe03a082 280 /**
mbed_official 573:ad23fe03a082 281 * @}
mbed_official 573:ad23fe03a082 282 */
mbed_official 573:ad23fe03a082 283
mbed_official 573:ad23fe03a082 284 /**
mbed_official 573:ad23fe03a082 285 * @}
mbed_official 573:ad23fe03a082 286 */
mbed_official 573:ad23fe03a082 287 /**
mbed_official 573:ad23fe03a082 288 * @}
mbed_official 573:ad23fe03a082 289 */
mbed_official 573:ad23fe03a082 290
mbed_official 573:ad23fe03a082 291 /**
mbed_official 573:ad23fe03a082 292 * @}
mbed_official 573:ad23fe03a082 293 */
mbed_official 573:ad23fe03a082 294
mbed_official 573:ad23fe03a082 295 #ifdef __cplusplus
mbed_official 573:ad23fe03a082 296 }
mbed_official 573:ad23fe03a082 297 #endif
mbed_official 573:ad23fe03a082 298
mbed_official 573:ad23fe03a082 299 #endif /* __STM32F7xx_HAL_NAND_H */
mbed_official 573:ad23fe03a082 300
mbed_official 573:ad23fe03a082 301 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/