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