mbed library sources

Fork of mbed-src by mbed official

Committer:
mbed_official
Date:
Thu Aug 20 10:45:13 2015 +0100
Revision:
613:bc40b8d2aec4
Parent:
532:fe11edbda85c
Synchronized with git revision 92ca8c7b60a283b6bb60eb65b183dac1599f0ade

Full URL: https://github.com/mbedmicro/mbed/commit/92ca8c7b60a283b6bb60eb65b183dac1599f0ade/

Nordic: update application start address in GCC linker script

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 87:085cde657901 1 /**
mbed_official 87:085cde657901 2 ******************************************************************************
mbed_official 87:085cde657901 3 * @file stm32f4xx_hal_sdram.h
mbed_official 87:085cde657901 4 * @author MCD Application Team
mbed_official 613:bc40b8d2aec4 5 * @version V1.3.2
mbed_official 613:bc40b8d2aec4 6 * @date 26-June-2015
mbed_official 87:085cde657901 7 * @brief Header file of SDRAM HAL module.
mbed_official 87:085cde657901 8 ******************************************************************************
mbed_official 87:085cde657901 9 * @attention
mbed_official 87:085cde657901 10 *
mbed_official 532:fe11edbda85c 11 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
mbed_official 87:085cde657901 12 *
mbed_official 87:085cde657901 13 * Redistribution and use in source and binary forms, with or without modification,
mbed_official 87:085cde657901 14 * are permitted provided that the following conditions are met:
mbed_official 87:085cde657901 15 * 1. Redistributions of source code must retain the above copyright notice,
mbed_official 87:085cde657901 16 * this list of conditions and the following disclaimer.
mbed_official 87:085cde657901 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
mbed_official 87:085cde657901 18 * this list of conditions and the following disclaimer in the documentation
mbed_official 87:085cde657901 19 * and/or other materials provided with the distribution.
mbed_official 87:085cde657901 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
mbed_official 87:085cde657901 21 * may be used to endorse or promote products derived from this software
mbed_official 87:085cde657901 22 * without specific prior written permission.
mbed_official 87:085cde657901 23 *
mbed_official 87:085cde657901 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
mbed_official 87:085cde657901 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
mbed_official 87:085cde657901 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
mbed_official 87:085cde657901 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
mbed_official 87:085cde657901 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
mbed_official 87:085cde657901 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
mbed_official 87:085cde657901 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
mbed_official 87:085cde657901 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_official 87:085cde657901 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
mbed_official 87:085cde657901 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
mbed_official 87:085cde657901 34 *
mbed_official 87:085cde657901 35 ******************************************************************************
mbed_official 87:085cde657901 36 */
mbed_official 87:085cde657901 37
mbed_official 87:085cde657901 38 /* Define to prevent recursive inclusion -------------------------------------*/
mbed_official 87:085cde657901 39 #ifndef __STM32F4xx_HAL_SDRAM_H
mbed_official 87:085cde657901 40 #define __STM32F4xx_HAL_SDRAM_H
mbed_official 87:085cde657901 41
mbed_official 87:085cde657901 42 #ifdef __cplusplus
mbed_official 87:085cde657901 43 extern "C" {
mbed_official 87:085cde657901 44 #endif
mbed_official 87:085cde657901 45
mbed_official 532:fe11edbda85c 46 #if defined(STM32F427xx) || defined(STM32F437xx) || defined(STM32F429xx) || defined(STM32F439xx) || defined(STM32F446xx)
mbed_official 87:085cde657901 47
mbed_official 87:085cde657901 48 /* Includes ------------------------------------------------------------------*/
mbed_official 87:085cde657901 49 #include "stm32f4xx_ll_fmc.h"
mbed_official 87:085cde657901 50
mbed_official 87:085cde657901 51 /** @addtogroup STM32F4xx_HAL_Driver
mbed_official 87:085cde657901 52 * @{
mbed_official 87:085cde657901 53 */
mbed_official 87:085cde657901 54
mbed_official 87:085cde657901 55 /** @addtogroup SDRAM
mbed_official 87:085cde657901 56 * @{
mbed_official 87:085cde657901 57 */
mbed_official 87:085cde657901 58
mbed_official 87:085cde657901 59 /* Exported typedef ----------------------------------------------------------*/
mbed_official 532:fe11edbda85c 60 /** @defgroup SDRAM_Exported_Types SDRAM Exported Types
mbed_official 532:fe11edbda85c 61 * @{
mbed_official 532:fe11edbda85c 62 */
mbed_official 87:085cde657901 63
mbed_official 87:085cde657901 64 /**
mbed_official 87:085cde657901 65 * @brief HAL SDRAM State structure definition
mbed_official 87:085cde657901 66 */
mbed_official 87:085cde657901 67 typedef enum
mbed_official 87:085cde657901 68 {
mbed_official 87:085cde657901 69 HAL_SDRAM_STATE_RESET = 0x00, /*!< SDRAM not yet initialized or disabled */
mbed_official 87:085cde657901 70 HAL_SDRAM_STATE_READY = 0x01, /*!< SDRAM initialized and ready for use */
mbed_official 87:085cde657901 71 HAL_SDRAM_STATE_BUSY = 0x02, /*!< SDRAM internal process is ongoing */
mbed_official 87:085cde657901 72 HAL_SDRAM_STATE_ERROR = 0x03, /*!< SDRAM error state */
mbed_official 87:085cde657901 73 HAL_SDRAM_STATE_WRITE_PROTECTED = 0x04, /*!< SDRAM device write protected */
mbed_official 87:085cde657901 74 HAL_SDRAM_STATE_PRECHARGED = 0x05 /*!< SDRAM device precharged */
mbed_official 87:085cde657901 75
mbed_official 87:085cde657901 76 }HAL_SDRAM_StateTypeDef;
mbed_official 87:085cde657901 77
mbed_official 87:085cde657901 78 /**
mbed_official 87:085cde657901 79 * @brief SDRAM handle Structure definition
mbed_official 87:085cde657901 80 */
mbed_official 87:085cde657901 81 typedef struct
mbed_official 87:085cde657901 82 {
mbed_official 87:085cde657901 83 FMC_SDRAM_TypeDef *Instance; /*!< Register base address */
mbed_official 87:085cde657901 84
mbed_official 87:085cde657901 85 FMC_SDRAM_InitTypeDef Init; /*!< SDRAM device configuration parameters */
mbed_official 87:085cde657901 86
mbed_official 87:085cde657901 87 __IO HAL_SDRAM_StateTypeDef State; /*!< SDRAM access state */
mbed_official 87:085cde657901 88
mbed_official 87:085cde657901 89 HAL_LockTypeDef Lock; /*!< SDRAM locking object */
mbed_official 87:085cde657901 90
mbed_official 87:085cde657901 91 DMA_HandleTypeDef *hdma; /*!< Pointer DMA handler */
mbed_official 87:085cde657901 92
mbed_official 87:085cde657901 93 }SDRAM_HandleTypeDef;
mbed_official 532:fe11edbda85c 94 /**
mbed_official 532:fe11edbda85c 95 * @}
mbed_official 532:fe11edbda85c 96 */
mbed_official 532:fe11edbda85c 97
mbed_official 532:fe11edbda85c 98 /* Exported constants --------------------------------------------------------*/
mbed_official 87:085cde657901 99 /* Exported macro ------------------------------------------------------------*/
mbed_official 532:fe11edbda85c 100 /** @defgroup SDRAM_Exported_Macros SDRAM Exported Macros
mbed_official 532:fe11edbda85c 101 * @{
mbed_official 532:fe11edbda85c 102 */
mbed_official 226:b062af740e40 103
mbed_official 226:b062af740e40 104 /** @brief Reset SDRAM handle state
mbed_official 226:b062af740e40 105 * @param __HANDLE__: specifies the SDRAM handle.
mbed_official 226:b062af740e40 106 * @retval None
mbed_official 226:b062af740e40 107 */
mbed_official 226:b062af740e40 108 #define __HAL_SDRAM_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SDRAM_STATE_RESET)
mbed_official 532:fe11edbda85c 109 /**
mbed_official 532:fe11edbda85c 110 * @}
mbed_official 532:fe11edbda85c 111 */
mbed_official 226:b062af740e40 112
mbed_official 87:085cde657901 113 /* Exported functions --------------------------------------------------------*/
mbed_official 532:fe11edbda85c 114 /** @addtogroup SDRAM_Exported_Functions SDRAM Exported Functions
mbed_official 532:fe11edbda85c 115 * @{
mbed_official 532:fe11edbda85c 116 */
mbed_official 87:085cde657901 117
mbed_official 532:fe11edbda85c 118 /** @addtogroup SDRAM_Exported_Functions_Group1
mbed_official 532:fe11edbda85c 119 * @{
mbed_official 532:fe11edbda85c 120 */
mbed_official 532:fe11edbda85c 121
mbed_official 532:fe11edbda85c 122 /* Initialization/de-initialization functions *********************************/
mbed_official 87:085cde657901 123 HAL_StatusTypeDef HAL_SDRAM_Init(SDRAM_HandleTypeDef *hsdram, FMC_SDRAM_TimingTypeDef *Timing);
mbed_official 87:085cde657901 124 HAL_StatusTypeDef HAL_SDRAM_DeInit(SDRAM_HandleTypeDef *hsdram);
mbed_official 106:ced8cbb51063 125 void HAL_SDRAM_MspInit(SDRAM_HandleTypeDef *hsdram);
mbed_official 106:ced8cbb51063 126 void HAL_SDRAM_MspDeInit(SDRAM_HandleTypeDef *hsdram);
mbed_official 87:085cde657901 127
mbed_official 87:085cde657901 128 void HAL_SDRAM_IRQHandler(SDRAM_HandleTypeDef *hsdram);
mbed_official 106:ced8cbb51063 129 void HAL_SDRAM_RefreshErrorCallback(SDRAM_HandleTypeDef *hsdram);
mbed_official 106:ced8cbb51063 130 void HAL_SDRAM_DMA_XferCpltCallback(DMA_HandleTypeDef *hdma);
mbed_official 106:ced8cbb51063 131 void HAL_SDRAM_DMA_XferErrorCallback(DMA_HandleTypeDef *hdma);
mbed_official 532:fe11edbda85c 132 /**
mbed_official 532:fe11edbda85c 133 * @}
mbed_official 532:fe11edbda85c 134 */
mbed_official 87:085cde657901 135
mbed_official 532:fe11edbda85c 136 /** @addtogroup SDRAM_Exported_Functions_Group2
mbed_official 532:fe11edbda85c 137 * @{
mbed_official 532:fe11edbda85c 138 */
mbed_official 532:fe11edbda85c 139 /* I/O operation functions ****************************************************/
mbed_official 87:085cde657901 140 HAL_StatusTypeDef HAL_SDRAM_Read_8b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint8_t *pDstBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 141 HAL_StatusTypeDef HAL_SDRAM_Write_8b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint8_t *pSrcBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 142 HAL_StatusTypeDef HAL_SDRAM_Read_16b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint16_t *pDstBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 143 HAL_StatusTypeDef HAL_SDRAM_Write_16b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint16_t *pSrcBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 144 HAL_StatusTypeDef HAL_SDRAM_Read_32b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint32_t *pDstBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 145 HAL_StatusTypeDef HAL_SDRAM_Write_32b(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint32_t *pSrcBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 146
mbed_official 87:085cde657901 147 HAL_StatusTypeDef HAL_SDRAM_Read_DMA(SDRAM_HandleTypeDef *hsdram, uint32_t * pAddress, uint32_t *pDstBuffer, uint32_t BufferSize);
mbed_official 87:085cde657901 148 HAL_StatusTypeDef HAL_SDRAM_Write_DMA(SDRAM_HandleTypeDef *hsdram, uint32_t *pAddress, uint32_t *pSrcBuffer, uint32_t BufferSize);
mbed_official 532:fe11edbda85c 149 /**
mbed_official 532:fe11edbda85c 150 * @}
mbed_official 532:fe11edbda85c 151 */
mbed_official 532:fe11edbda85c 152
mbed_official 532:fe11edbda85c 153 /** @addtogroup SDRAM_Exported_Functions_Group3
mbed_official 532:fe11edbda85c 154 * @{
mbed_official 532:fe11edbda85c 155 */
mbed_official 87:085cde657901 156 /* SDRAM Control functions *****************************************************/
mbed_official 87:085cde657901 157 HAL_StatusTypeDef HAL_SDRAM_WriteProtection_Enable(SDRAM_HandleTypeDef *hsdram);
mbed_official 87:085cde657901 158 HAL_StatusTypeDef HAL_SDRAM_WriteProtection_Disable(SDRAM_HandleTypeDef *hsdram);
mbed_official 87:085cde657901 159 HAL_StatusTypeDef HAL_SDRAM_SendCommand(SDRAM_HandleTypeDef *hsdram, FMC_SDRAM_CommandTypeDef *Command, uint32_t Timeout);
mbed_official 87:085cde657901 160 HAL_StatusTypeDef HAL_SDRAM_ProgramRefreshRate(SDRAM_HandleTypeDef *hsdram, uint32_t RefreshRate);
mbed_official 87:085cde657901 161 HAL_StatusTypeDef HAL_SDRAM_SetAutoRefreshNumber(SDRAM_HandleTypeDef *hsdram, uint32_t AutoRefreshNumber);
mbed_official 87:085cde657901 162 uint32_t HAL_SDRAM_GetModeStatus(SDRAM_HandleTypeDef *hsdram);
mbed_official 532:fe11edbda85c 163 /**
mbed_official 532:fe11edbda85c 164 * @}
mbed_official 532:fe11edbda85c 165 */
mbed_official 87:085cde657901 166
mbed_official 532:fe11edbda85c 167 /** @addtogroup SDRAM_Exported_Functions_Group4
mbed_official 532:fe11edbda85c 168 * @{
mbed_official 532:fe11edbda85c 169 */
mbed_official 87:085cde657901 170 /* SDRAM State functions ********************************************************/
mbed_official 87:085cde657901 171 HAL_SDRAM_StateTypeDef HAL_SDRAM_GetState(SDRAM_HandleTypeDef *hsdram);
mbed_official 532:fe11edbda85c 172 /**
mbed_official 532:fe11edbda85c 173 * @}
mbed_official 532:fe11edbda85c 174 */
mbed_official 87:085cde657901 175
mbed_official 87:085cde657901 176 /**
mbed_official 87:085cde657901 177 * @}
mbed_official 532:fe11edbda85c 178 */
mbed_official 532:fe11edbda85c 179
mbed_official 532:fe11edbda85c 180 /**
mbed_official 532:fe11edbda85c 181 * @}
mbed_official 532:fe11edbda85c 182 */
mbed_official 532:fe11edbda85c 183
mbed_official 532:fe11edbda85c 184 #endif /* STM32F427xx || STM32F437xx || STM32F429xx || STM32F439xx || STM32F446xx */
mbed_official 87:085cde657901 185
mbed_official 87:085cde657901 186 /**
mbed_official 87:085cde657901 187 * @}
mbed_official 87:085cde657901 188 */
mbed_official 87:085cde657901 189
mbed_official 87:085cde657901 190 #ifdef __cplusplus
mbed_official 87:085cde657901 191 }
mbed_official 87:085cde657901 192 #endif
mbed_official 87:085cde657901 193
mbed_official 87:085cde657901 194 #endif /* __STM32F4xx_HAL_SDRAM_H */
mbed_official 87:085cde657901 195
mbed_official 87:085cde657901 196 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/