Sylvain Letreguilly / Mbed 2 deprecated cpelcddemo

Dependencies:   mbed

Committer:
agemio
Date:
Thu Nov 05 12:53:31 2015 +0000
Revision:
0:14f16771fe40
first commit;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
agemio 0:14f16771fe40 1 /**
agemio 0:14f16771fe40 2 ******************************************************************************
agemio 0:14f16771fe40 3 * @file stm32746g_discovery_sdram.h
agemio 0:14f16771fe40 4 * @author MCD Application Team
agemio 0:14f16771fe40 5 * @version V1.0.0
agemio 0:14f16771fe40 6 * @date 25-June-2015
agemio 0:14f16771fe40 7 * @brief This file contains the common defines and functions prototypes for
agemio 0:14f16771fe40 8 * the stm32746g_discovery_sdram.c driver.
agemio 0:14f16771fe40 9 ******************************************************************************
agemio 0:14f16771fe40 10 * @attention
agemio 0:14f16771fe40 11 *
agemio 0:14f16771fe40 12 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
agemio 0:14f16771fe40 13 *
agemio 0:14f16771fe40 14 * Redistribution and use in source and binary forms, with or without modification,
agemio 0:14f16771fe40 15 * are permitted provided that the following conditions are met:
agemio 0:14f16771fe40 16 * 1. Redistributions of source code must retain the above copyright notice,
agemio 0:14f16771fe40 17 * this list of conditions and the following disclaimer.
agemio 0:14f16771fe40 18 * 2. Redistributions in binary form must reproduce the above copyright notice,
agemio 0:14f16771fe40 19 * this list of conditions and the following disclaimer in the documentation
agemio 0:14f16771fe40 20 * and/or other materials provided with the distribution.
agemio 0:14f16771fe40 21 * 3. Neither the name of STMicroelectronics nor the names of its contributors
agemio 0:14f16771fe40 22 * may be used to endorse or promote products derived from this software
agemio 0:14f16771fe40 23 * without specific prior written permission.
agemio 0:14f16771fe40 24 *
agemio 0:14f16771fe40 25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
agemio 0:14f16771fe40 26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
agemio 0:14f16771fe40 27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
agemio 0:14f16771fe40 28 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
agemio 0:14f16771fe40 29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
agemio 0:14f16771fe40 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
agemio 0:14f16771fe40 31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
agemio 0:14f16771fe40 32 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
agemio 0:14f16771fe40 33 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
agemio 0:14f16771fe40 34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
agemio 0:14f16771fe40 35 *
agemio 0:14f16771fe40 36 ******************************************************************************
agemio 0:14f16771fe40 37 */
agemio 0:14f16771fe40 38
agemio 0:14f16771fe40 39 /* Define to prevent recursive inclusion -------------------------------------*/
agemio 0:14f16771fe40 40 #ifndef __STM32746G_DISCOVERY_SDRAM_H
agemio 0:14f16771fe40 41 #define __STM32746G_DISCOVERY_SDRAM_H
agemio 0:14f16771fe40 42
agemio 0:14f16771fe40 43 #ifdef __cplusplus
agemio 0:14f16771fe40 44 extern "C" {
agemio 0:14f16771fe40 45 #endif
agemio 0:14f16771fe40 46
agemio 0:14f16771fe40 47 /* Includes ------------------------------------------------------------------*/
agemio 0:14f16771fe40 48 #include "stm32f7xx_hal.h"
agemio 0:14f16771fe40 49
agemio 0:14f16771fe40 50 /** @addtogroup BSP
agemio 0:14f16771fe40 51 * @{
agemio 0:14f16771fe40 52 */
agemio 0:14f16771fe40 53
agemio 0:14f16771fe40 54 /** @addtogroup STM32746G_DISCOVERY
agemio 0:14f16771fe40 55 * @{
agemio 0:14f16771fe40 56 */
agemio 0:14f16771fe40 57
agemio 0:14f16771fe40 58 /** @addtogroup STM32746G_DISCOVERY_SDRAM
agemio 0:14f16771fe40 59 * @{
agemio 0:14f16771fe40 60 */
agemio 0:14f16771fe40 61
agemio 0:14f16771fe40 62 /** @defgroup STM32746G_DISCOVERY_SDRAM_Exported_Types STM32746G_DISCOVERY_SDRAM Exported Types
agemio 0:14f16771fe40 63 * @{
agemio 0:14f16771fe40 64 */
agemio 0:14f16771fe40 65
agemio 0:14f16771fe40 66 /**
agemio 0:14f16771fe40 67 * @brief SDRAM status structure definition
agemio 0:14f16771fe40 68 */
agemio 0:14f16771fe40 69 #define SDRAM_OK ((uint8_t)0x00)
agemio 0:14f16771fe40 70 #define SDRAM_ERROR ((uint8_t)0x01)
agemio 0:14f16771fe40 71
agemio 0:14f16771fe40 72 /** @defgroup STM32746G_DISCOVERY_SDRAM_Exported_Constants STM32746G_DISCOVERY_SDRAM Exported Constants
agemio 0:14f16771fe40 73 * @{
agemio 0:14f16771fe40 74 */
agemio 0:14f16771fe40 75 #define SDRAM_DEVICE_ADDR ((uint32_t)0xC0000000)
agemio 0:14f16771fe40 76 #define SDRAM_DEVICE_SIZE ((uint32_t)0x800000) /* SDRAM device size in MBytes */
agemio 0:14f16771fe40 77
agemio 0:14f16771fe40 78 /* #define SDRAM_MEMORY_WIDTH FMC_SDRAM_MEM_BUS_WIDTH_8 */
agemio 0:14f16771fe40 79 #define SDRAM_MEMORY_WIDTH FMC_SDRAM_MEM_BUS_WIDTH_16
agemio 0:14f16771fe40 80
agemio 0:14f16771fe40 81 #define SDCLOCK_PERIOD FMC_SDRAM_CLOCK_PERIOD_2
agemio 0:14f16771fe40 82 /* #define SDCLOCK_PERIOD FMC_SDRAM_CLOCK_PERIOD_3 */
agemio 0:14f16771fe40 83
agemio 0:14f16771fe40 84 #define REFRESH_COUNT ((uint32_t)0x0603) /* SDRAM refresh counter (100Mhz SD clock) */
agemio 0:14f16771fe40 85
agemio 0:14f16771fe40 86 #define SDRAM_TIMEOUT ((uint32_t)0xFFFF)
agemio 0:14f16771fe40 87
agemio 0:14f16771fe40 88 /* DMA definitions for SDRAM DMA transfer */
agemio 0:14f16771fe40 89 #define __DMAx_CLK_ENABLE __HAL_RCC_DMA2_CLK_ENABLE
agemio 0:14f16771fe40 90 #define __DMAx_CLK_DISABLE __HAL_RCC_DMA2_CLK_DISABLE
agemio 0:14f16771fe40 91 #define SDRAM_DMAx_CHANNEL DMA_CHANNEL_0
agemio 0:14f16771fe40 92 #define SDRAM_DMAx_STREAM DMA2_Stream0
agemio 0:14f16771fe40 93 #define SDRAM_DMAx_IRQn DMA2_Stream0_IRQn
agemio 0:14f16771fe40 94 #define SDRAM_DMAx_IRQHandler DMA2_Stream0_IRQHandler
agemio 0:14f16771fe40 95 /**
agemio 0:14f16771fe40 96 * @}
agemio 0:14f16771fe40 97 */
agemio 0:14f16771fe40 98
agemio 0:14f16771fe40 99 /**
agemio 0:14f16771fe40 100 * @brief FMC SDRAM Mode definition register defines
agemio 0:14f16771fe40 101 */
agemio 0:14f16771fe40 102 #define SDRAM_MODEREG_BURST_LENGTH_1 ((uint16_t)0x0000)
agemio 0:14f16771fe40 103 #define SDRAM_MODEREG_BURST_LENGTH_2 ((uint16_t)0x0001)
agemio 0:14f16771fe40 104 #define SDRAM_MODEREG_BURST_LENGTH_4 ((uint16_t)0x0002)
agemio 0:14f16771fe40 105 #define SDRAM_MODEREG_BURST_LENGTH_8 ((uint16_t)0x0004)
agemio 0:14f16771fe40 106 #define SDRAM_MODEREG_BURST_TYPE_SEQUENTIAL ((uint16_t)0x0000)
agemio 0:14f16771fe40 107 #define SDRAM_MODEREG_BURST_TYPE_INTERLEAVED ((uint16_t)0x0008)
agemio 0:14f16771fe40 108 #define SDRAM_MODEREG_CAS_LATENCY_2 ((uint16_t)0x0020)
agemio 0:14f16771fe40 109 #define SDRAM_MODEREG_CAS_LATENCY_3 ((uint16_t)0x0030)
agemio 0:14f16771fe40 110 #define SDRAM_MODEREG_OPERATING_MODE_STANDARD ((uint16_t)0x0000)
agemio 0:14f16771fe40 111 #define SDRAM_MODEREG_WRITEBURST_MODE_PROGRAMMED ((uint16_t)0x0000)
agemio 0:14f16771fe40 112 #define SDRAM_MODEREG_WRITEBURST_MODE_SINGLE ((uint16_t)0x0200)
agemio 0:14f16771fe40 113 /**
agemio 0:14f16771fe40 114 * @}
agemio 0:14f16771fe40 115 */
agemio 0:14f16771fe40 116
agemio 0:14f16771fe40 117 /** @defgroup STM32746G_DISCOVERY_SDRAM_Exported_Macro STM32746G_DISCOVERY_SDRAM Exported Macro
agemio 0:14f16771fe40 118 * @{
agemio 0:14f16771fe40 119 */
agemio 0:14f16771fe40 120 /**
agemio 0:14f16771fe40 121 * @}
agemio 0:14f16771fe40 122 */
agemio 0:14f16771fe40 123
agemio 0:14f16771fe40 124 /** @addtogroup STM32746G_DISCOVERY_SDRAM_Exported_Functions
agemio 0:14f16771fe40 125 * @{
agemio 0:14f16771fe40 126 */
agemio 0:14f16771fe40 127 uint8_t BSP_SDRAM_Init(void);
agemio 0:14f16771fe40 128 uint8_t BSP_SDRAM_DeInit(void);
agemio 0:14f16771fe40 129 void BSP_SDRAM_Initialization_sequence(uint32_t RefreshCount);
agemio 0:14f16771fe40 130 uint8_t BSP_SDRAM_ReadData(uint32_t uwStartAddress, uint32_t *pData, uint32_t uwDataSize);
agemio 0:14f16771fe40 131 uint8_t BSP_SDRAM_ReadData_DMA(uint32_t uwStartAddress, uint32_t *pData, uint32_t uwDataSize);
agemio 0:14f16771fe40 132 uint8_t BSP_SDRAM_WriteData(uint32_t uwStartAddress, uint32_t *pData, uint32_t uwDataSize);
agemio 0:14f16771fe40 133 uint8_t BSP_SDRAM_WriteData_DMA(uint32_t uwStartAddress, uint32_t *pData, uint32_t uwDataSize);
agemio 0:14f16771fe40 134 uint8_t BSP_SDRAM_Sendcmd(FMC_SDRAM_CommandTypeDef *SdramCmd);
agemio 0:14f16771fe40 135 void BSP_SDRAM_DMA_IRQHandler(void);
agemio 0:14f16771fe40 136
agemio 0:14f16771fe40 137 /* These functions can be modified in case the current settings (e.g. DMA stream)
agemio 0:14f16771fe40 138 need to be changed for specific application needs */
agemio 0:14f16771fe40 139 void BSP_SDRAM_MspInit(SDRAM_HandleTypeDef *hsdram, void *Params);
agemio 0:14f16771fe40 140 void BSP_SDRAM_MspDeInit(SDRAM_HandleTypeDef *hsdram, void *Params);
agemio 0:14f16771fe40 141
agemio 0:14f16771fe40 142
agemio 0:14f16771fe40 143 /**
agemio 0:14f16771fe40 144 * @}
agemio 0:14f16771fe40 145 */
agemio 0:14f16771fe40 146
agemio 0:14f16771fe40 147 /**
agemio 0:14f16771fe40 148 * @}
agemio 0:14f16771fe40 149 */
agemio 0:14f16771fe40 150
agemio 0:14f16771fe40 151 /**
agemio 0:14f16771fe40 152 * @}
agemio 0:14f16771fe40 153 */
agemio 0:14f16771fe40 154
agemio 0:14f16771fe40 155 /**
agemio 0:14f16771fe40 156 * @}
agemio 0:14f16771fe40 157 */
agemio 0:14f16771fe40 158
agemio 0:14f16771fe40 159 #ifdef __cplusplus
agemio 0:14f16771fe40 160 }
agemio 0:14f16771fe40 161 #endif
agemio 0:14f16771fe40 162
agemio 0:14f16771fe40 163 #endif /* __STM32746G_DISCOVERY_SDRAM_H */
agemio 0:14f16771fe40 164
agemio 0:14f16771fe40 165 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/