STM32F479xx HAL User Manual
|
00001 /** 00002 ****************************************************************************** 00003 * @file stm32f4xx_hal_sram.h 00004 * @author MCD Application Team 00005 * @brief Header file of SRAM HAL module. 00006 ****************************************************************************** 00007 * @attention 00008 * 00009 * <h2><center>© Copyright (c) 2017 STMicroelectronics. 00010 * All rights reserved.</center></h2> 00011 * 00012 * This software component is licensed by ST under BSD 3-Clause license, 00013 * the "License"; You may not use this file except in compliance with the 00014 * License. You may obtain a copy of the License at: 00015 * opensource.org/licenses/BSD-3-Clause 00016 * 00017 ****************************************************************************** 00018 */ 00019 00020 /* Define to prevent recursive inclusion -------------------------------------*/ 00021 #ifndef STM32F4xx_HAL_SRAM_H 00022 #define STM32F4xx_HAL_SRAM_H 00023 00024 #ifdef __cplusplus 00025 extern "C" { 00026 #endif 00027 00028 #if defined(FMC_Bank1) || defined(FSMC_Bank1) 00029 00030 /* Includes ------------------------------------------------------------------*/ 00031 #if defined(FSMC_Bank1) 00032 #include "stm32f4xx_ll_fsmc.h" 00033 #else 00034 #include "stm32f4xx_ll_fmc.h" 00035 #endif /* FSMC_Bank1 */ 00036 00037 /** @addtogroup STM32F4xx_HAL_Driver 00038 * @{ 00039 */ 00040 /** @addtogroup SRAM 00041 * @{ 00042 */ 00043 00044 /* Exported typedef ----------------------------------------------------------*/ 00045 00046 /** @defgroup SRAM_Exported_Types SRAM Exported Types 00047 * @{ 00048 */ 00049 /** 00050 * @brief HAL SRAM State structures definition 00051 */ 00052 typedef enum 00053 { 00054 HAL_SRAM_STATE_RESET = 0x00U, /*!< SRAM not yet initialized or disabled */ 00055 HAL_SRAM_STATE_READY = 0x01U, /*!< SRAM initialized and ready for use */ 00056 HAL_SRAM_STATE_BUSY = 0x02U, /*!< SRAM internal process is ongoing */ 00057 HAL_SRAM_STATE_ERROR = 0x03U, /*!< SRAM error state */ 00058 HAL_SRAM_STATE_PROTECTED = 0x04U /*!< SRAM peripheral NORSRAM device write protected */ 00059 00060 } HAL_SRAM_StateTypeDef; 00061 00062 /** 00063 * @brief SRAM handle Structure definition 00064 */ 00065 #if (USE_HAL_SRAM_REGISTER_CALLBACKS == 1) 00066 typedef struct __SRAM_HandleTypeDef 00067 #else 00068 typedef struct 00069 #endif /* USE_HAL_SRAM_REGISTER_CALLBACKS */ 00070 { 00071 FMC_NORSRAM_TypeDef *Instance; /*!< Register base address */ 00072 00073 FMC_NORSRAM_EXTENDED_TypeDef *Extended; /*!< Extended mode register base address */ 00074 00075 FMC_NORSRAM_InitTypeDef Init; /*!< SRAM device control configuration parameters */ 00076 00077 HAL_LockTypeDef Lock; /*!< SRAM locking object */ 00078 00079 __IO HAL_SRAM_StateTypeDef State; /*!< SRAM device access state */ 00080 00081 DMA_HandleTypeDef *hdma; /*!< Pointer DMA handler */ 00082 00083 #if (USE_HAL_SRAM_REGISTER_CALLBACKS == 1) 00084 void (* MspInitCallback)(struct __SRAM_HandleTypeDef *hsram); /*!< SRAM Msp Init callback */ 00085 void (* MspDeInitCallback)(struct __SRAM_HandleTypeDef *hsram); /*!< SRAM Msp DeInit callback */ 00086 void (* DmaXferCpltCallback)(DMA_HandleTypeDef *hdma); /*!< SRAM DMA Xfer Complete callback */ 00087 void (* DmaXferErrorCallback)(DMA_HandleTypeDef *hdma); /*!< SRAM DMA Xfer Error callback */ 00088 #endif /* USE_HAL_SRAM_REGISTER_CALLBACKS */ 00089 } SRAM_HandleTypeDef; 00090 00091 #if (USE_HAL_SRAM_REGISTER_CALLBACKS == 1) 00092 /** 00093 * @brief HAL SRAM Callback ID enumeration definition 00094 */ 00095 typedef enum 00096 { 00097 HAL_SRAM_MSP_INIT_CB_ID = 0x00U, /*!< SRAM MspInit Callback ID */ 00098 HAL_SRAM_MSP_DEINIT_CB_ID = 0x01U, /*!< SRAM MspDeInit Callback ID */ 00099 HAL_SRAM_DMA_XFER_CPLT_CB_ID = 0x02U, /*!< SRAM DMA Xfer Complete Callback ID */ 00100 HAL_SRAM_DMA_XFER_ERR_CB_ID = 0x03U /*!< SRAM DMA Xfer Complete Callback ID */ 00101 } HAL_SRAM_CallbackIDTypeDef; 00102 00103 /** 00104 * @brief HAL SRAM Callback pointer definition 00105 */ 00106 typedef void (*pSRAM_CallbackTypeDef)(SRAM_HandleTypeDef *hsram); 00107 typedef void (*pSRAM_DmaCallbackTypeDef)(DMA_HandleTypeDef *hdma); 00108 #endif /* USE_HAL_SRAM_REGISTER_CALLBACKS */ 00109 /** 00110 * @} 00111 */ 00112 00113 /* Exported constants --------------------------------------------------------*/ 00114 /* Exported macro ------------------------------------------------------------*/ 00115 00116 /** @defgroup SRAM_Exported_Macros SRAM Exported Macros 00117 * @{ 00118 */ 00119 00120 /** @brief Reset SRAM handle state 00121 * @param __HANDLE__ SRAM handle 00122 * @retval None 00123 */ 00124 #if (USE_HAL_SRAM_REGISTER_CALLBACKS == 1) 00125 #define __HAL_SRAM_RESET_HANDLE_STATE(__HANDLE__) do { \ 00126 (__HANDLE__)->State = HAL_SRAM_STATE_RESET; \ 00127 (__HANDLE__)->MspInitCallback = NULL; \ 00128 (__HANDLE__)->MspDeInitCallback = NULL; \ 00129 } while(0) 00130 #else 00131 #define __HAL_SRAM_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SRAM_STATE_RESET) 00132 #endif /* USE_HAL_SRAM_REGISTER_CALLBACKS */ 00133 00134 /** 00135 * @} 00136 */ 00137 00138 /* Exported functions --------------------------------------------------------*/ 00139 /** @addtogroup SRAM_Exported_Functions SRAM Exported Functions 00140 * @{ 00141 */ 00142 00143 /** @addtogroup SRAM_Exported_Functions_Group1 Initialization and de-initialization functions 00144 * @{ 00145 */ 00146 00147 /* Initialization/de-initialization functions ********************************/ 00148 HAL_StatusTypeDef HAL_SRAM_Init(SRAM_HandleTypeDef *hsram, FMC_NORSRAM_TimingTypeDef *Timing, 00149 FMC_NORSRAM_TimingTypeDef *ExtTiming); 00150 HAL_StatusTypeDef HAL_SRAM_DeInit(SRAM_HandleTypeDef *hsram); 00151 void HAL_SRAM_MspInit(SRAM_HandleTypeDef *hsram); 00152 void HAL_SRAM_MspDeInit(SRAM_HandleTypeDef *hsram); 00153 00154 /** 00155 * @} 00156 */ 00157 00158 /** @addtogroup SRAM_Exported_Functions_Group2 Input Output and memory control functions 00159 * @{ 00160 */ 00161 00162 /* I/O operation functions ***************************************************/ 00163 HAL_StatusTypeDef HAL_SRAM_Read_8b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint8_t *pDstBuffer, 00164 uint32_t BufferSize); 00165 HAL_StatusTypeDef HAL_SRAM_Write_8b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint8_t *pSrcBuffer, 00166 uint32_t BufferSize); 00167 HAL_StatusTypeDef HAL_SRAM_Read_16b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint16_t *pDstBuffer, 00168 uint32_t BufferSize); 00169 HAL_StatusTypeDef HAL_SRAM_Write_16b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint16_t *pSrcBuffer, 00170 uint32_t BufferSize); 00171 HAL_StatusTypeDef HAL_SRAM_Read_32b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pDstBuffer, 00172 uint32_t BufferSize); 00173 HAL_StatusTypeDef HAL_SRAM_Write_32b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pSrcBuffer, 00174 uint32_t BufferSize); 00175 HAL_StatusTypeDef HAL_SRAM_Read_DMA(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pDstBuffer, 00176 uint32_t BufferSize); 00177 HAL_StatusTypeDef HAL_SRAM_Write_DMA(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pSrcBuffer, 00178 uint32_t BufferSize); 00179 00180 void HAL_SRAM_DMA_XferCpltCallback(DMA_HandleTypeDef *hdma); 00181 void HAL_SRAM_DMA_XferErrorCallback(DMA_HandleTypeDef *hdma); 00182 00183 #if (USE_HAL_SRAM_REGISTER_CALLBACKS == 1) 00184 /* SRAM callback registering/unregistering */ 00185 HAL_StatusTypeDef HAL_SRAM_RegisterCallback(SRAM_HandleTypeDef *hsram, HAL_SRAM_CallbackIDTypeDef CallbackId, 00186 pSRAM_CallbackTypeDef pCallback); 00187 HAL_StatusTypeDef HAL_SRAM_UnRegisterCallback(SRAM_HandleTypeDef *hsram, HAL_SRAM_CallbackIDTypeDef CallbackId); 00188 HAL_StatusTypeDef HAL_SRAM_RegisterDmaCallback(SRAM_HandleTypeDef *hsram, HAL_SRAM_CallbackIDTypeDef CallbackId, 00189 pSRAM_DmaCallbackTypeDef pCallback); 00190 #endif /* USE_HAL_SRAM_REGISTER_CALLBACKS */ 00191 00192 /** 00193 * @} 00194 */ 00195 00196 /** @addtogroup SRAM_Exported_Functions_Group3 Control functions 00197 * @{ 00198 */ 00199 00200 /* SRAM Control functions ****************************************************/ 00201 HAL_StatusTypeDef HAL_SRAM_WriteOperation_Enable(SRAM_HandleTypeDef *hsram); 00202 HAL_StatusTypeDef HAL_SRAM_WriteOperation_Disable(SRAM_HandleTypeDef *hsram); 00203 00204 /** 00205 * @} 00206 */ 00207 00208 /** @addtogroup SRAM_Exported_Functions_Group4 Peripheral State functions 00209 * @{ 00210 */ 00211 00212 /* SRAM State functions ******************************************************/ 00213 HAL_SRAM_StateTypeDef HAL_SRAM_GetState(SRAM_HandleTypeDef *hsram); 00214 00215 /** 00216 * @} 00217 */ 00218 00219 /** 00220 * @} 00221 */ 00222 00223 /** 00224 * @} 00225 */ 00226 00227 /** 00228 * @} 00229 */ 00230 00231 #endif /* FMC_Bank1) || defined(FSMC_Bank1 */ 00232 00233 #ifdef __cplusplus 00234 } 00235 #endif 00236 00237 #endif /* STM32F4xx_HAL_SRAM_H */ 00238 00239 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/