Fork of the official mbed C/C SDK provides the software platform and libraries to build your applications for RenBED.

Dependents:   1-RenBuggyTimed RenBED_RGB RenBED_RGB_PWM RenBED_RGB

Fork of mbed by mbed official

Committer:
elijahorr
Date:
Thu Apr 14 07:28:54 2016 +0000
Revision:
121:672067c3ada4
Parent:
100:cbbeb26dbd92
.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 100:cbbeb26dbd92 1 /**
Kojto 100:cbbeb26dbd92 2 ******************************************************************************
Kojto 100:cbbeb26dbd92 3 * @file stm32f3xx_hal_sram.h
Kojto 100:cbbeb26dbd92 4 * @author MCD Application Team
Kojto 100:cbbeb26dbd92 5 * @version V1.1.0
Kojto 100:cbbeb26dbd92 6 * @date 12-Sept-2014
Kojto 100:cbbeb26dbd92 7 * @brief Header file of SRAM HAL module.
Kojto 100:cbbeb26dbd92 8 ******************************************************************************
Kojto 100:cbbeb26dbd92 9 * @attention
Kojto 100:cbbeb26dbd92 10 *
Kojto 100:cbbeb26dbd92 11 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
Kojto 100:cbbeb26dbd92 12 *
Kojto 100:cbbeb26dbd92 13 * Redistribution and use in source and binary forms, with or without modification,
Kojto 100:cbbeb26dbd92 14 * are permitted provided that the following conditions are met:
Kojto 100:cbbeb26dbd92 15 * 1. Redistributions of source code must retain the above copyright notice,
Kojto 100:cbbeb26dbd92 16 * this list of conditions and the following disclaimer.
Kojto 100:cbbeb26dbd92 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
Kojto 100:cbbeb26dbd92 18 * this list of conditions and the following disclaimer in the documentation
Kojto 100:cbbeb26dbd92 19 * and/or other materials provided with the distribution.
Kojto 100:cbbeb26dbd92 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Kojto 100:cbbeb26dbd92 21 * may be used to endorse or promote products derived from this software
Kojto 100:cbbeb26dbd92 22 * without specific prior written permission.
Kojto 100:cbbeb26dbd92 23 *
Kojto 100:cbbeb26dbd92 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Kojto 100:cbbeb26dbd92 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Kojto 100:cbbeb26dbd92 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Kojto 100:cbbeb26dbd92 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Kojto 100:cbbeb26dbd92 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Kojto 100:cbbeb26dbd92 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Kojto 100:cbbeb26dbd92 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Kojto 100:cbbeb26dbd92 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Kojto 100:cbbeb26dbd92 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Kojto 100:cbbeb26dbd92 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Kojto 100:cbbeb26dbd92 34 *
Kojto 100:cbbeb26dbd92 35 ******************************************************************************
Kojto 100:cbbeb26dbd92 36 */
Kojto 100:cbbeb26dbd92 37
Kojto 100:cbbeb26dbd92 38 /* Define to prevent recursive inclusion -------------------------------------*/
Kojto 100:cbbeb26dbd92 39 #ifndef __STM32F3xx_HAL_SRAM_H
Kojto 100:cbbeb26dbd92 40 #define __STM32F3xx_HAL_SRAM_H
Kojto 100:cbbeb26dbd92 41
Kojto 100:cbbeb26dbd92 42 #ifdef __cplusplus
Kojto 100:cbbeb26dbd92 43 extern "C" {
Kojto 100:cbbeb26dbd92 44 #endif
Kojto 100:cbbeb26dbd92 45
Kojto 100:cbbeb26dbd92 46 /* Includes ------------------------------------------------------------------*/
Kojto 100:cbbeb26dbd92 47 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 100:cbbeb26dbd92 48 #include "stm32f3xx_ll_fmc.h"
Kojto 100:cbbeb26dbd92 49 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 100:cbbeb26dbd92 50
Kojto 100:cbbeb26dbd92 51
Kojto 100:cbbeb26dbd92 52 /** @addtogroup STM32F3xx_HAL_Driver
Kojto 100:cbbeb26dbd92 53 * @{
Kojto 100:cbbeb26dbd92 54 */
Kojto 100:cbbeb26dbd92 55
Kojto 100:cbbeb26dbd92 56 /** @addtogroup SRAM
Kojto 100:cbbeb26dbd92 57 * @{
Kojto 100:cbbeb26dbd92 58 */
Kojto 100:cbbeb26dbd92 59
Kojto 100:cbbeb26dbd92 60 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 100:cbbeb26dbd92 61
Kojto 100:cbbeb26dbd92 62 /* Exported typedef ----------------------------------------------------------*/
Kojto 100:cbbeb26dbd92 63
Kojto 100:cbbeb26dbd92 64 /** @defgroup SRAM_Exported_Types SRAM Exported Types
Kojto 100:cbbeb26dbd92 65 * @{
Kojto 100:cbbeb26dbd92 66 */
Kojto 100:cbbeb26dbd92 67 /**
Kojto 100:cbbeb26dbd92 68 * @brief HAL SRAM State structures definition
Kojto 100:cbbeb26dbd92 69 */
Kojto 100:cbbeb26dbd92 70 typedef enum
Kojto 100:cbbeb26dbd92 71 {
Kojto 100:cbbeb26dbd92 72 HAL_SRAM_STATE_RESET = 0x00, /*!< SRAM not yet initialized or disabled */
Kojto 100:cbbeb26dbd92 73 HAL_SRAM_STATE_READY = 0x01, /*!< SRAM initialized and ready for use */
Kojto 100:cbbeb26dbd92 74 HAL_SRAM_STATE_BUSY = 0x02, /*!< SRAM internal process is ongoing */
Kojto 100:cbbeb26dbd92 75 HAL_SRAM_STATE_ERROR = 0x03, /*!< SRAM error state */
Kojto 100:cbbeb26dbd92 76 HAL_SRAM_STATE_PROTECTED = 0x04 /*!< SRAM peripheral NORSRAM device write protected */
Kojto 100:cbbeb26dbd92 77
Kojto 100:cbbeb26dbd92 78 }HAL_SRAM_StateTypeDef;
Kojto 100:cbbeb26dbd92 79
Kojto 100:cbbeb26dbd92 80 /**
Kojto 100:cbbeb26dbd92 81 * @brief SRAM handle Structure definition
Kojto 100:cbbeb26dbd92 82 */
Kojto 100:cbbeb26dbd92 83 typedef struct
Kojto 100:cbbeb26dbd92 84 {
Kojto 100:cbbeb26dbd92 85 FMC_NORSRAM_TypeDef *Instance; /*!< Register base address */
Kojto 100:cbbeb26dbd92 86
Kojto 100:cbbeb26dbd92 87 FMC_NORSRAM_EXTENDED_TypeDef *Extended; /*!< Extended mode register base address */
Kojto 100:cbbeb26dbd92 88
Kojto 100:cbbeb26dbd92 89 FMC_NORSRAM_InitTypeDef Init; /*!< SRAM device control configuration parameters */
Kojto 100:cbbeb26dbd92 90
Kojto 100:cbbeb26dbd92 91 HAL_LockTypeDef Lock; /*!< SRAM locking object */
Kojto 100:cbbeb26dbd92 92
Kojto 100:cbbeb26dbd92 93 __IO HAL_SRAM_StateTypeDef State; /*!< SRAM device access state */
Kojto 100:cbbeb26dbd92 94
Kojto 100:cbbeb26dbd92 95 DMA_HandleTypeDef *hdma; /*!< Pointer DMA handler */
Kojto 100:cbbeb26dbd92 96
Kojto 100:cbbeb26dbd92 97 }SRAM_HandleTypeDef;
Kojto 100:cbbeb26dbd92 98
Kojto 100:cbbeb26dbd92 99 /**
Kojto 100:cbbeb26dbd92 100 * @}
Kojto 100:cbbeb26dbd92 101 */
Kojto 100:cbbeb26dbd92 102
Kojto 100:cbbeb26dbd92 103 /* Exported constants --------------------------------------------------------*/
Kojto 100:cbbeb26dbd92 104 /* Exported macro ------------------------------------------------------------*/
Kojto 100:cbbeb26dbd92 105
Kojto 100:cbbeb26dbd92 106 /** @defgroup SRAM_Exported_Macros SRAM Exported Macros
Kojto 100:cbbeb26dbd92 107 * @{
Kojto 100:cbbeb26dbd92 108 */
Kojto 100:cbbeb26dbd92 109
Kojto 100:cbbeb26dbd92 110 /** @brief Reset SRAM handle state
Kojto 100:cbbeb26dbd92 111 * @param __HANDLE__: SRAM handle
Kojto 100:cbbeb26dbd92 112 * @retval None
Kojto 100:cbbeb26dbd92 113 */
Kojto 100:cbbeb26dbd92 114 #define __HAL_SRAM_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SRAM_STATE_RESET)
Kojto 100:cbbeb26dbd92 115
Kojto 100:cbbeb26dbd92 116 /**
Kojto 100:cbbeb26dbd92 117 * @}
Kojto 100:cbbeb26dbd92 118 */
Kojto 100:cbbeb26dbd92 119
Kojto 100:cbbeb26dbd92 120 /* Exported functions --------------------------------------------------------*/
Kojto 100:cbbeb26dbd92 121 /** @addtogroup SRAM_Exported_Functions SRAM Exported Functions
Kojto 100:cbbeb26dbd92 122 * @{
Kojto 100:cbbeb26dbd92 123 */
Kojto 100:cbbeb26dbd92 124
Kojto 100:cbbeb26dbd92 125 /** @addtogroup SRAM_Exported_Functions_Group1 Initialization and de-initialization functions
Kojto 100:cbbeb26dbd92 126 * @{
Kojto 100:cbbeb26dbd92 127 */
Kojto 100:cbbeb26dbd92 128
Kojto 100:cbbeb26dbd92 129 /* Initialization/de-initialization functions ********************************/
Kojto 100:cbbeb26dbd92 130 HAL_StatusTypeDef HAL_SRAM_Init(SRAM_HandleTypeDef *hsram, FMC_NORSRAM_TimingTypeDef *Timing, FMC_NORSRAM_TimingTypeDef *ExtTiming);
Kojto 100:cbbeb26dbd92 131 HAL_StatusTypeDef HAL_SRAM_DeInit(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 132 void HAL_SRAM_MspInit(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 133 void HAL_SRAM_MspDeInit(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 134
Kojto 100:cbbeb26dbd92 135 void HAL_SRAM_DMA_XferCpltCallback(DMA_HandleTypeDef *hdma);
Kojto 100:cbbeb26dbd92 136 void HAL_SRAM_DMA_XferErrorCallback(DMA_HandleTypeDef *hdma);
Kojto 100:cbbeb26dbd92 137
Kojto 100:cbbeb26dbd92 138 /**
Kojto 100:cbbeb26dbd92 139 * @}
Kojto 100:cbbeb26dbd92 140 */
Kojto 100:cbbeb26dbd92 141
Kojto 100:cbbeb26dbd92 142 /** @addtogroup SRAM_Exported_Functions_Group2 Input Output and memory control functions
Kojto 100:cbbeb26dbd92 143 * @{
Kojto 100:cbbeb26dbd92 144 */
Kojto 100:cbbeb26dbd92 145
Kojto 100:cbbeb26dbd92 146 /* I/O operation functions ***************************************************/
Kojto 100:cbbeb26dbd92 147 HAL_StatusTypeDef HAL_SRAM_Read_8b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint8_t *pDstBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 148 HAL_StatusTypeDef HAL_SRAM_Write_8b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint8_t *pSrcBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 149 HAL_StatusTypeDef HAL_SRAM_Read_16b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint16_t *pDstBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 150 HAL_StatusTypeDef HAL_SRAM_Write_16b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint16_t *pSrcBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 151 HAL_StatusTypeDef HAL_SRAM_Read_32b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pDstBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 152 HAL_StatusTypeDef HAL_SRAM_Write_32b(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pSrcBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 153 HAL_StatusTypeDef HAL_SRAM_Read_DMA(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pDstBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 154 HAL_StatusTypeDef HAL_SRAM_Write_DMA(SRAM_HandleTypeDef *hsram, uint32_t *pAddress, uint32_t *pSrcBuffer, uint32_t BufferSize);
Kojto 100:cbbeb26dbd92 155
Kojto 100:cbbeb26dbd92 156 /**
Kojto 100:cbbeb26dbd92 157 * @}
Kojto 100:cbbeb26dbd92 158 */
Kojto 100:cbbeb26dbd92 159
Kojto 100:cbbeb26dbd92 160 /** @addtogroup SRAM_Exported_Functions_Group3 Control functions
Kojto 100:cbbeb26dbd92 161 * @{
Kojto 100:cbbeb26dbd92 162 */
Kojto 100:cbbeb26dbd92 163
Kojto 100:cbbeb26dbd92 164 /* SRAM Control functions ****************************************************/
Kojto 100:cbbeb26dbd92 165 HAL_StatusTypeDef HAL_SRAM_WriteOperation_Enable(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 166 HAL_StatusTypeDef HAL_SRAM_WriteOperation_Disable(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 167
Kojto 100:cbbeb26dbd92 168 /**
Kojto 100:cbbeb26dbd92 169 * @}
Kojto 100:cbbeb26dbd92 170 */
Kojto 100:cbbeb26dbd92 171
Kojto 100:cbbeb26dbd92 172 /** @addtogroup SRAM_Exported_Functions_Group4 Peripheral State functions
Kojto 100:cbbeb26dbd92 173 * @{
Kojto 100:cbbeb26dbd92 174 */
Kojto 100:cbbeb26dbd92 175
Kojto 100:cbbeb26dbd92 176 /* SRAM Peripheral State functions ********************************************/
Kojto 100:cbbeb26dbd92 177 HAL_SRAM_StateTypeDef HAL_SRAM_GetState(SRAM_HandleTypeDef *hsram);
Kojto 100:cbbeb26dbd92 178
Kojto 100:cbbeb26dbd92 179 /**
Kojto 100:cbbeb26dbd92 180 * @}
Kojto 100:cbbeb26dbd92 181 */
Kojto 100:cbbeb26dbd92 182
Kojto 100:cbbeb26dbd92 183 /**
Kojto 100:cbbeb26dbd92 184 * @}
Kojto 100:cbbeb26dbd92 185 */
Kojto 100:cbbeb26dbd92 186
Kojto 100:cbbeb26dbd92 187 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 100:cbbeb26dbd92 188 /**
Kojto 100:cbbeb26dbd92 189 * @}
Kojto 100:cbbeb26dbd92 190 */
Kojto 100:cbbeb26dbd92 191
Kojto 100:cbbeb26dbd92 192 /**
Kojto 100:cbbeb26dbd92 193 * @}
Kojto 100:cbbeb26dbd92 194 */
Kojto 100:cbbeb26dbd92 195
Kojto 100:cbbeb26dbd92 196 #ifdef __cplusplus
Kojto 100:cbbeb26dbd92 197 }
Kojto 100:cbbeb26dbd92 198 #endif
Kojto 100:cbbeb26dbd92 199
Kojto 100:cbbeb26dbd92 200 #endif /* __STM32F3xx_HAL_SRAM_H */
Kojto 100:cbbeb26dbd92 201
Kojto 100:cbbeb26dbd92 202 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/