SPKT

Dependencies:   F746_GUI SD_PlayerSkeleton F746_SAI_IO

Committer:
phungductung
Date:
Tue Jun 04 21:37:21 2019 +0000
Revision:
0:8ede47d38d10
SPKT

Who changed what in which revision?

UserRevisionLine numberNew contents of line
phungductung 0:8ede47d38d10 1 /**
phungductung 0:8ede47d38d10 2 ******************************************************************************
phungductung 0:8ede47d38d10 3 * @file stm32f7xx_hal_dma2d.h
phungductung 0:8ede47d38d10 4 * @author MCD Application Team
phungductung 0:8ede47d38d10 5 * @version V1.0.4
phungductung 0:8ede47d38d10 6 * @date 09-December-2015
phungductung 0:8ede47d38d10 7 * @brief Header file of DMA2D HAL module.
phungductung 0:8ede47d38d10 8 ******************************************************************************
phungductung 0:8ede47d38d10 9 * @attention
phungductung 0:8ede47d38d10 10 *
phungductung 0:8ede47d38d10 11 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
phungductung 0:8ede47d38d10 12 *
phungductung 0:8ede47d38d10 13 * Redistribution and use in source and binary forms, with or without modification,
phungductung 0:8ede47d38d10 14 * are permitted provided that the following conditions are met:
phungductung 0:8ede47d38d10 15 * 1. Redistributions of source code must retain the above copyright notice,
phungductung 0:8ede47d38d10 16 * this list of conditions and the following disclaimer.
phungductung 0:8ede47d38d10 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
phungductung 0:8ede47d38d10 18 * this list of conditions and the following disclaimer in the documentation
phungductung 0:8ede47d38d10 19 * and/or other materials provided with the distribution.
phungductung 0:8ede47d38d10 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
phungductung 0:8ede47d38d10 21 * may be used to endorse or promote products derived from this software
phungductung 0:8ede47d38d10 22 * without specific prior written permission.
phungductung 0:8ede47d38d10 23 *
phungductung 0:8ede47d38d10 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
phungductung 0:8ede47d38d10 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
phungductung 0:8ede47d38d10 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
phungductung 0:8ede47d38d10 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
phungductung 0:8ede47d38d10 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
phungductung 0:8ede47d38d10 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
phungductung 0:8ede47d38d10 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
phungductung 0:8ede47d38d10 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
phungductung 0:8ede47d38d10 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
phungductung 0:8ede47d38d10 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
phungductung 0:8ede47d38d10 34 *
phungductung 0:8ede47d38d10 35 ******************************************************************************
phungductung 0:8ede47d38d10 36 */
phungductung 0:8ede47d38d10 37
phungductung 0:8ede47d38d10 38 /* Define to prevent recursive inclusion -------------------------------------*/
phungductung 0:8ede47d38d10 39 #ifndef __STM32F7xx_HAL_DMA2D_H
phungductung 0:8ede47d38d10 40 #define __STM32F7xx_HAL_DMA2D_H
phungductung 0:8ede47d38d10 41
phungductung 0:8ede47d38d10 42 #ifdef __cplusplus
phungductung 0:8ede47d38d10 43 extern "C" {
phungductung 0:8ede47d38d10 44 #endif
phungductung 0:8ede47d38d10 45
phungductung 0:8ede47d38d10 46 /* Includes ------------------------------------------------------------------*/
phungductung 0:8ede47d38d10 47 #include "stm32f7xx_hal_def.h"
phungductung 0:8ede47d38d10 48
phungductung 0:8ede47d38d10 49 /** @addtogroup STM32F7xx_HAL_Driver
phungductung 0:8ede47d38d10 50 * @{
phungductung 0:8ede47d38d10 51 */
phungductung 0:8ede47d38d10 52
phungductung 0:8ede47d38d10 53 /** @defgroup DMA2D DMA2D
phungductung 0:8ede47d38d10 54 * @brief DMA2D HAL module driver
phungductung 0:8ede47d38d10 55 * @{
phungductung 0:8ede47d38d10 56 */
phungductung 0:8ede47d38d10 57
phungductung 0:8ede47d38d10 58 /* Exported types ------------------------------------------------------------*/
phungductung 0:8ede47d38d10 59 /** @defgroup DMA2D_Exported_Types DMA2D Exported Types
phungductung 0:8ede47d38d10 60 * @{
phungductung 0:8ede47d38d10 61 */
phungductung 0:8ede47d38d10 62 #define MAX_DMA2D_LAYER 2
phungductung 0:8ede47d38d10 63
phungductung 0:8ede47d38d10 64 /**
phungductung 0:8ede47d38d10 65 * @brief DMA2D color Structure definition
phungductung 0:8ede47d38d10 66 */
phungductung 0:8ede47d38d10 67 typedef struct
phungductung 0:8ede47d38d10 68 {
phungductung 0:8ede47d38d10 69 uint32_t Blue; /*!< Configures the blue value.
phungductung 0:8ede47d38d10 70 This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF. */
phungductung 0:8ede47d38d10 71
phungductung 0:8ede47d38d10 72 uint32_t Green; /*!< Configures the green value.
phungductung 0:8ede47d38d10 73 This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF. */
phungductung 0:8ede47d38d10 74
phungductung 0:8ede47d38d10 75 uint32_t Red; /*!< Configures the red value.
phungductung 0:8ede47d38d10 76 This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF. */
phungductung 0:8ede47d38d10 77 } DMA2D_ColorTypeDef;
phungductung 0:8ede47d38d10 78
phungductung 0:8ede47d38d10 79 /**
phungductung 0:8ede47d38d10 80 * @brief DMA2D CLUT Structure definition
phungductung 0:8ede47d38d10 81 */
phungductung 0:8ede47d38d10 82 typedef struct
phungductung 0:8ede47d38d10 83 {
phungductung 0:8ede47d38d10 84 uint32_t *pCLUT; /*!< Configures the DMA2D CLUT memory address.*/
phungductung 0:8ede47d38d10 85
phungductung 0:8ede47d38d10 86 uint32_t CLUTColorMode; /*!< configures the DMA2D CLUT color mode.
phungductung 0:8ede47d38d10 87 This parameter can be one value of @ref DMA2D_CLUT_CM */
phungductung 0:8ede47d38d10 88
phungductung 0:8ede47d38d10 89 uint32_t Size; /*!< configures the DMA2D CLUT size.
phungductung 0:8ede47d38d10 90 This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF.*/
phungductung 0:8ede47d38d10 91 } DMA2D_CLUTCfgTypeDef;
phungductung 0:8ede47d38d10 92
phungductung 0:8ede47d38d10 93 /**
phungductung 0:8ede47d38d10 94 * @brief DMA2D Init structure definition
phungductung 0:8ede47d38d10 95 */
phungductung 0:8ede47d38d10 96 typedef struct
phungductung 0:8ede47d38d10 97 {
phungductung 0:8ede47d38d10 98 uint32_t Mode; /*!< configures the DMA2D transfer mode.
phungductung 0:8ede47d38d10 99 This parameter can be one value of @ref DMA2D_Mode */
phungductung 0:8ede47d38d10 100
phungductung 0:8ede47d38d10 101 uint32_t ColorMode; /*!< configures the color format of the output image.
phungductung 0:8ede47d38d10 102 This parameter can be one value of @ref DMA2D_Color_Mode */
phungductung 0:8ede47d38d10 103
phungductung 0:8ede47d38d10 104 uint32_t OutputOffset; /*!< Specifies the Offset value.
phungductung 0:8ede47d38d10 105 This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0x3FFF. */
phungductung 0:8ede47d38d10 106 } DMA2D_InitTypeDef;
phungductung 0:8ede47d38d10 107
phungductung 0:8ede47d38d10 108 /**
phungductung 0:8ede47d38d10 109 * @brief DMA2D Layer structure definition
phungductung 0:8ede47d38d10 110 */
phungductung 0:8ede47d38d10 111 typedef struct
phungductung 0:8ede47d38d10 112 {
phungductung 0:8ede47d38d10 113 uint32_t InputOffset; /*!< configures the DMA2D foreground offset.
phungductung 0:8ede47d38d10 114 This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0x3FFF. */
phungductung 0:8ede47d38d10 115
phungductung 0:8ede47d38d10 116 uint32_t InputColorMode; /*!< configures the DMA2D foreground color mode .
phungductung 0:8ede47d38d10 117 This parameter can be one value of @ref DMA2D_Input_Color_Mode */
phungductung 0:8ede47d38d10 118
phungductung 0:8ede47d38d10 119 uint32_t AlphaMode; /*!< configures the DMA2D foreground alpha mode.
phungductung 0:8ede47d38d10 120 This parameter can be one value of @ref DMA2D_ALPHA_MODE */
phungductung 0:8ede47d38d10 121
phungductung 0:8ede47d38d10 122 uint32_t InputAlpha; /*!< Specifies the DMA2D foreground alpha value and color value in case of A8 or A4 color mode.
phungductung 0:8ede47d38d10 123 This parameter must be a number between Min_Data = 0x00000000 and Max_Data = 0xFFFFFFFF
phungductung 0:8ede47d38d10 124 in case of A8 or A4 color mode (ARGB).
phungductung 0:8ede47d38d10 125 Otherwise, This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF.*/
phungductung 0:8ede47d38d10 126
phungductung 0:8ede47d38d10 127 } DMA2D_LayerCfgTypeDef;
phungductung 0:8ede47d38d10 128
phungductung 0:8ede47d38d10 129 /**
phungductung 0:8ede47d38d10 130 * @brief HAL DMA2D State structures definition
phungductung 0:8ede47d38d10 131 */
phungductung 0:8ede47d38d10 132 typedef enum
phungductung 0:8ede47d38d10 133 {
phungductung 0:8ede47d38d10 134 HAL_DMA2D_STATE_RESET = 0x00, /*!< DMA2D not yet initialized or disabled */
phungductung 0:8ede47d38d10 135 HAL_DMA2D_STATE_READY = 0x01, /*!< Peripheral Initialized and ready for use */
phungductung 0:8ede47d38d10 136 HAL_DMA2D_STATE_BUSY = 0x02, /*!< an internal process is ongoing */
phungductung 0:8ede47d38d10 137 HAL_DMA2D_STATE_TIMEOUT = 0x03, /*!< Timeout state */
phungductung 0:8ede47d38d10 138 HAL_DMA2D_STATE_ERROR = 0x04, /*!< DMA2D state error */
phungductung 0:8ede47d38d10 139 HAL_DMA2D_STATE_SUSPEND = 0x05 /*!< DMA2D process is suspended */
phungductung 0:8ede47d38d10 140 }HAL_DMA2D_StateTypeDef;
phungductung 0:8ede47d38d10 141
phungductung 0:8ede47d38d10 142 /**
phungductung 0:8ede47d38d10 143 * @brief DMA2D handle Structure definition
phungductung 0:8ede47d38d10 144 */
phungductung 0:8ede47d38d10 145 typedef struct __DMA2D_HandleTypeDef
phungductung 0:8ede47d38d10 146 {
phungductung 0:8ede47d38d10 147 DMA2D_TypeDef *Instance; /*!< DMA2D Register base address */
phungductung 0:8ede47d38d10 148
phungductung 0:8ede47d38d10 149 DMA2D_InitTypeDef Init; /*!< DMA2D communication parameters */
phungductung 0:8ede47d38d10 150
phungductung 0:8ede47d38d10 151 void (* XferCpltCallback)(struct __DMA2D_HandleTypeDef * hdma2d); /*!< DMA2D transfer complete callback */
phungductung 0:8ede47d38d10 152
phungductung 0:8ede47d38d10 153 void (* XferErrorCallback)(struct __DMA2D_HandleTypeDef * hdma2d); /*!< DMA2D transfer error callback */
phungductung 0:8ede47d38d10 154
phungductung 0:8ede47d38d10 155 DMA2D_LayerCfgTypeDef LayerCfg[MAX_DMA2D_LAYER]; /*!< DMA2D Layers parameters */
phungductung 0:8ede47d38d10 156
phungductung 0:8ede47d38d10 157 HAL_LockTypeDef Lock; /*!< DMA2D Lock */
phungductung 0:8ede47d38d10 158
phungductung 0:8ede47d38d10 159 __IO HAL_DMA2D_StateTypeDef State; /*!< DMA2D transfer state */
phungductung 0:8ede47d38d10 160
phungductung 0:8ede47d38d10 161 __IO uint32_t ErrorCode; /*!< DMA2D Error code */
phungductung 0:8ede47d38d10 162 } DMA2D_HandleTypeDef;
phungductung 0:8ede47d38d10 163 /**
phungductung 0:8ede47d38d10 164 * @}
phungductung 0:8ede47d38d10 165 */
phungductung 0:8ede47d38d10 166
phungductung 0:8ede47d38d10 167 /* Exported constants --------------------------------------------------------*/
phungductung 0:8ede47d38d10 168 /** @defgroup DMA2D_Exported_Constants DMA2D Exported Constants
phungductung 0:8ede47d38d10 169 * @{
phungductung 0:8ede47d38d10 170 */
phungductung 0:8ede47d38d10 171
phungductung 0:8ede47d38d10 172 /** @defgroup DMA2D_Error_Code DMA2D Error Code
phungductung 0:8ede47d38d10 173 * @{
phungductung 0:8ede47d38d10 174 */
phungductung 0:8ede47d38d10 175 #define HAL_DMA2D_ERROR_NONE ((uint32_t)0x00000000) /*!< No error */
phungductung 0:8ede47d38d10 176 #define HAL_DMA2D_ERROR_TE ((uint32_t)0x00000001) /*!< Transfer error */
phungductung 0:8ede47d38d10 177 #define HAL_DMA2D_ERROR_CE ((uint32_t)0x00000002) /*!< Configuration error */
phungductung 0:8ede47d38d10 178 #define HAL_DMA2D_ERROR_TIMEOUT ((uint32_t)0x00000020) /*!< Timeout error */
phungductung 0:8ede47d38d10 179 /**
phungductung 0:8ede47d38d10 180 * @}
phungductung 0:8ede47d38d10 181 */
phungductung 0:8ede47d38d10 182
phungductung 0:8ede47d38d10 183 /** @defgroup DMA2D_Mode DMA2D Mode
phungductung 0:8ede47d38d10 184 * @{
phungductung 0:8ede47d38d10 185 */
phungductung 0:8ede47d38d10 186 #define DMA2D_M2M ((uint32_t)0x00000000) /*!< DMA2D memory to memory transfer mode */
phungductung 0:8ede47d38d10 187 #define DMA2D_M2M_PFC ((uint32_t)0x00010000) /*!< DMA2D memory to memory with pixel format conversion transfer mode */
phungductung 0:8ede47d38d10 188 #define DMA2D_M2M_BLEND ((uint32_t)0x00020000) /*!< DMA2D memory to memory with blending transfer mode */
phungductung 0:8ede47d38d10 189 #define DMA2D_R2M ((uint32_t)0x00030000) /*!< DMA2D register to memory transfer mode */
phungductung 0:8ede47d38d10 190 /**
phungductung 0:8ede47d38d10 191 * @}
phungductung 0:8ede47d38d10 192 */
phungductung 0:8ede47d38d10 193
phungductung 0:8ede47d38d10 194 /** @defgroup DMA2D_Color_Mode DMA2D Color Mode
phungductung 0:8ede47d38d10 195 * @{
phungductung 0:8ede47d38d10 196 */
phungductung 0:8ede47d38d10 197 #define DMA2D_ARGB8888 ((uint32_t)0x00000000) /*!< ARGB8888 DMA2D color mode */
phungductung 0:8ede47d38d10 198 #define DMA2D_RGB888 ((uint32_t)0x00000001) /*!< RGB888 DMA2D color mode */
phungductung 0:8ede47d38d10 199 #define DMA2D_RGB565 ((uint32_t)0x00000002) /*!< RGB565 DMA2D color mode */
phungductung 0:8ede47d38d10 200 #define DMA2D_ARGB1555 ((uint32_t)0x00000003) /*!< ARGB1555 DMA2D color mode */
phungductung 0:8ede47d38d10 201 #define DMA2D_ARGB4444 ((uint32_t)0x00000004) /*!< ARGB4444 DMA2D color mode */
phungductung 0:8ede47d38d10 202 /**
phungductung 0:8ede47d38d10 203 * @}
phungductung 0:8ede47d38d10 204 */
phungductung 0:8ede47d38d10 205
phungductung 0:8ede47d38d10 206 /** @defgroup DMA2D_COLOR_VALUE DMA2D COLOR VALUE
phungductung 0:8ede47d38d10 207 * @{
phungductung 0:8ede47d38d10 208 */
phungductung 0:8ede47d38d10 209 #define COLOR_VALUE ((uint32_t)0x000000FF) /*!< color value mask */
phungductung 0:8ede47d38d10 210 /**
phungductung 0:8ede47d38d10 211 * @}
phungductung 0:8ede47d38d10 212 */
phungductung 0:8ede47d38d10 213
phungductung 0:8ede47d38d10 214 /** @defgroup DMA2D_SIZE DMA2D SIZE
phungductung 0:8ede47d38d10 215 * @{
phungductung 0:8ede47d38d10 216 */
phungductung 0:8ede47d38d10 217 #define DMA2D_PIXEL (DMA2D_NLR_PL >> 16) /*!< DMA2D pixel per line */
phungductung 0:8ede47d38d10 218 #define DMA2D_LINE DMA2D_NLR_NL /*!< DMA2D number of line */
phungductung 0:8ede47d38d10 219 /**
phungductung 0:8ede47d38d10 220 * @}
phungductung 0:8ede47d38d10 221 */
phungductung 0:8ede47d38d10 222
phungductung 0:8ede47d38d10 223 /** @defgroup DMA2D_Offset DMA2D Offset
phungductung 0:8ede47d38d10 224 * @{
phungductung 0:8ede47d38d10 225 */
phungductung 0:8ede47d38d10 226 #define DMA2D_OFFSET DMA2D_FGOR_LO /*!< Line Offset */
phungductung 0:8ede47d38d10 227 /**
phungductung 0:8ede47d38d10 228 * @}
phungductung 0:8ede47d38d10 229 */
phungductung 0:8ede47d38d10 230
phungductung 0:8ede47d38d10 231 /** @defgroup DMA2D_Input_Color_Mode DMA2D Input Color Mode
phungductung 0:8ede47d38d10 232 * @{
phungductung 0:8ede47d38d10 233 */
phungductung 0:8ede47d38d10 234 #define CM_ARGB8888 ((uint32_t)0x00000000) /*!< ARGB8888 color mode */
phungductung 0:8ede47d38d10 235 #define CM_RGB888 ((uint32_t)0x00000001) /*!< RGB888 color mode */
phungductung 0:8ede47d38d10 236 #define CM_RGB565 ((uint32_t)0x00000002) /*!< RGB565 color mode */
phungductung 0:8ede47d38d10 237 #define CM_ARGB1555 ((uint32_t)0x00000003) /*!< ARGB1555 color mode */
phungductung 0:8ede47d38d10 238 #define CM_ARGB4444 ((uint32_t)0x00000004) /*!< ARGB4444 color mode */
phungductung 0:8ede47d38d10 239 #define CM_L8 ((uint32_t)0x00000005) /*!< L8 color mode */
phungductung 0:8ede47d38d10 240 #define CM_AL44 ((uint32_t)0x00000006) /*!< AL44 color mode */
phungductung 0:8ede47d38d10 241 #define CM_AL88 ((uint32_t)0x00000007) /*!< AL88 color mode */
phungductung 0:8ede47d38d10 242 #define CM_L4 ((uint32_t)0x00000008) /*!< L4 color mode */
phungductung 0:8ede47d38d10 243 #define CM_A8 ((uint32_t)0x00000009) /*!< A8 color mode */
phungductung 0:8ede47d38d10 244 #define CM_A4 ((uint32_t)0x0000000A) /*!< A4 color mode */
phungductung 0:8ede47d38d10 245 /**
phungductung 0:8ede47d38d10 246 * @}
phungductung 0:8ede47d38d10 247 */
phungductung 0:8ede47d38d10 248
phungductung 0:8ede47d38d10 249 /** @defgroup DMA2D_ALPHA_MODE DMA2D ALPHA MODE
phungductung 0:8ede47d38d10 250 * @{
phungductung 0:8ede47d38d10 251 */
phungductung 0:8ede47d38d10 252 #define DMA2D_NO_MODIF_ALPHA ((uint32_t)0x00000000) /*!< No modification of the alpha channel value */
phungductung 0:8ede47d38d10 253 #define DMA2D_REPLACE_ALPHA ((uint32_t)0x00000001) /*!< Replace original alpha channel value by programmed alpha value */
phungductung 0:8ede47d38d10 254 #define DMA2D_COMBINE_ALPHA ((uint32_t)0x00000002) /*!< Replace original alpha channel value by programmed alpha value
phungductung 0:8ede47d38d10 255 with original alpha channel value */
phungductung 0:8ede47d38d10 256 /**
phungductung 0:8ede47d38d10 257 * @}
phungductung 0:8ede47d38d10 258 */
phungductung 0:8ede47d38d10 259
phungductung 0:8ede47d38d10 260 /** @defgroup DMA2D_CLUT_CM DMA2D CLUT CM
phungductung 0:8ede47d38d10 261 * @{
phungductung 0:8ede47d38d10 262 */
phungductung 0:8ede47d38d10 263 #define DMA2D_CCM_ARGB8888 ((uint32_t)0x00000000) /*!< ARGB8888 DMA2D C-LUT color mode */
phungductung 0:8ede47d38d10 264 #define DMA2D_CCM_RGB888 ((uint32_t)0x00000001) /*!< RGB888 DMA2D C-LUT color mode */
phungductung 0:8ede47d38d10 265 /**
phungductung 0:8ede47d38d10 266 * @}
phungductung 0:8ede47d38d10 267 */
phungductung 0:8ede47d38d10 268
phungductung 0:8ede47d38d10 269 /** @defgroup DMA2D_Size_Clut DMA2D Size Clut
phungductung 0:8ede47d38d10 270 * @{
phungductung 0:8ede47d38d10 271 */
phungductung 0:8ede47d38d10 272 #define DMA2D_CLUT_SIZE (DMA2D_FGPFCCR_CS >> 8) /*!< DMA2D C-LUT size */
phungductung 0:8ede47d38d10 273 /**
phungductung 0:8ede47d38d10 274 * @}
phungductung 0:8ede47d38d10 275 */
phungductung 0:8ede47d38d10 276
phungductung 0:8ede47d38d10 277 /** @defgroup DMA2D_DeadTime DMA2D DeadTime
phungductung 0:8ede47d38d10 278 * @{
phungductung 0:8ede47d38d10 279 */
phungductung 0:8ede47d38d10 280 #define LINE_WATERMARK DMA2D_LWR_LW
phungductung 0:8ede47d38d10 281 /**
phungductung 0:8ede47d38d10 282 * @}
phungductung 0:8ede47d38d10 283 */
phungductung 0:8ede47d38d10 284
phungductung 0:8ede47d38d10 285 /** @defgroup DMA2D_Interrupts DMA2D Interrupts
phungductung 0:8ede47d38d10 286 * @{
phungductung 0:8ede47d38d10 287 */
phungductung 0:8ede47d38d10 288 #define DMA2D_IT_CE DMA2D_CR_CEIE /*!< Configuration Error Interrupt */
phungductung 0:8ede47d38d10 289 #define DMA2D_IT_CTC DMA2D_CR_CTCIE /*!< C-LUT Transfer Complete Interrupt */
phungductung 0:8ede47d38d10 290 #define DMA2D_IT_CAE DMA2D_CR_CAEIE /*!< C-LUT Access Error Interrupt */
phungductung 0:8ede47d38d10 291 #define DMA2D_IT_TW DMA2D_CR_TWIE /*!< Transfer Watermark Interrupt */
phungductung 0:8ede47d38d10 292 #define DMA2D_IT_TC DMA2D_CR_TCIE /*!< Transfer Complete Interrupt */
phungductung 0:8ede47d38d10 293 #define DMA2D_IT_TE DMA2D_CR_TEIE /*!< Transfer Error Interrupt */
phungductung 0:8ede47d38d10 294 /**
phungductung 0:8ede47d38d10 295 * @}
phungductung 0:8ede47d38d10 296 */
phungductung 0:8ede47d38d10 297
phungductung 0:8ede47d38d10 298 /** @defgroup DMA2D_Flag DMA2D Flag
phungductung 0:8ede47d38d10 299 * @{
phungductung 0:8ede47d38d10 300 */
phungductung 0:8ede47d38d10 301 #define DMA2D_FLAG_CE DMA2D_ISR_CEIF /*!< Configuration Error Interrupt Flag */
phungductung 0:8ede47d38d10 302 #define DMA2D_FLAG_CTC DMA2D_ISR_CTCIF /*!< C-LUT Transfer Complete Interrupt Flag */
phungductung 0:8ede47d38d10 303 #define DMA2D_FLAG_CAE DMA2D_ISR_CAEIF /*!< C-LUT Access Error Interrupt Flag */
phungductung 0:8ede47d38d10 304 #define DMA2D_FLAG_TW DMA2D_ISR_TWIF /*!< Transfer Watermark Interrupt Flag */
phungductung 0:8ede47d38d10 305 #define DMA2D_FLAG_TC DMA2D_ISR_TCIF /*!< Transfer Complete Interrupt Flag */
phungductung 0:8ede47d38d10 306 #define DMA2D_FLAG_TE DMA2D_ISR_TEIF /*!< Transfer Error Interrupt Flag */
phungductung 0:8ede47d38d10 307 /**
phungductung 0:8ede47d38d10 308 * @}
phungductung 0:8ede47d38d10 309 */
phungductung 0:8ede47d38d10 310
phungductung 0:8ede47d38d10 311 /**
phungductung 0:8ede47d38d10 312 * @}
phungductung 0:8ede47d38d10 313 */
phungductung 0:8ede47d38d10 314 /* Exported macro ------------------------------------------------------------*/
phungductung 0:8ede47d38d10 315 /** @defgroup DMA2D_Exported_Macros DMA2D Exported Macros
phungductung 0:8ede47d38d10 316 * @{
phungductung 0:8ede47d38d10 317 */
phungductung 0:8ede47d38d10 318
phungductung 0:8ede47d38d10 319 /** @brief Reset DMA2D handle state
phungductung 0:8ede47d38d10 320 * @param __HANDLE__: specifies the DMA2D handle.
phungductung 0:8ede47d38d10 321 * @retval None
phungductung 0:8ede47d38d10 322 */
phungductung 0:8ede47d38d10 323 #define __HAL_DMA2D_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DMA2D_STATE_RESET)
phungductung 0:8ede47d38d10 324
phungductung 0:8ede47d38d10 325 /**
phungductung 0:8ede47d38d10 326 * @brief Enable the DMA2D.
phungductung 0:8ede47d38d10 327 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 328 * @retval None.
phungductung 0:8ede47d38d10 329 */
phungductung 0:8ede47d38d10 330 #define __HAL_DMA2D_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= DMA2D_CR_START)
phungductung 0:8ede47d38d10 331
phungductung 0:8ede47d38d10 332 /**
phungductung 0:8ede47d38d10 333 * @brief Disable the DMA2D.
phungductung 0:8ede47d38d10 334 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 335 * @retval None.
phungductung 0:8ede47d38d10 336 */
phungductung 0:8ede47d38d10 337 #define __HAL_DMA2D_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~DMA2D_CR_START)
phungductung 0:8ede47d38d10 338
phungductung 0:8ede47d38d10 339 /* Interrupt & Flag management */
phungductung 0:8ede47d38d10 340 /**
phungductung 0:8ede47d38d10 341 * @brief Get the DMA2D pending flags.
phungductung 0:8ede47d38d10 342 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 343 * @param __FLAG__: Get the specified flag.
phungductung 0:8ede47d38d10 344 * This parameter can be any combination of the following values:
phungductung 0:8ede47d38d10 345 * @arg DMA2D_FLAG_CE: Configuration error flag
phungductung 0:8ede47d38d10 346 * @arg DMA2D_FLAG_CTC: C-LUT transfer complete flag
phungductung 0:8ede47d38d10 347 * @arg DMA2D_FLAG_CAE: C-LUT access error flag
phungductung 0:8ede47d38d10 348 * @arg DMA2D_FLAG_TW: Transfer Watermark flag
phungductung 0:8ede47d38d10 349 * @arg DMA2D_FLAG_TC: Transfer complete flag
phungductung 0:8ede47d38d10 350 * @arg DMA2D_FLAG_TE: Transfer error flag
phungductung 0:8ede47d38d10 351 * @retval The state of FLAG.
phungductung 0:8ede47d38d10 352 */
phungductung 0:8ede47d38d10 353 #define __HAL_DMA2D_GET_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR & (__FLAG__))
phungductung 0:8ede47d38d10 354
phungductung 0:8ede47d38d10 355 /**
phungductung 0:8ede47d38d10 356 * @brief Clears the DMA2D pending flags.
phungductung 0:8ede47d38d10 357 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 358 * @param __FLAG__: specifies the flag to clear.
phungductung 0:8ede47d38d10 359 * This parameter can be any combination of the following values:
phungductung 0:8ede47d38d10 360 * @arg DMA2D_FLAG_CE: Configuration error flag
phungductung 0:8ede47d38d10 361 * @arg DMA2D_FLAG_CTC: C-LUT transfer complete flag
phungductung 0:8ede47d38d10 362 * @arg DMA2D_FLAG_CAE: C-LUT access error flag
phungductung 0:8ede47d38d10 363 * @arg DMA2D_FLAG_TW: Transfer Watermark flag
phungductung 0:8ede47d38d10 364 * @arg DMA2D_FLAG_TC: Transfer complete flag
phungductung 0:8ede47d38d10 365 * @arg DMA2D_FLAG_TE: Transfer error flag
phungductung 0:8ede47d38d10 366 * @retval None
phungductung 0:8ede47d38d10 367 */
phungductung 0:8ede47d38d10 368 #define __HAL_DMA2D_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->IFCR = (__FLAG__))
phungductung 0:8ede47d38d10 369
phungductung 0:8ede47d38d10 370 /**
phungductung 0:8ede47d38d10 371 * @brief Enables the specified DMA2D interrupts.
phungductung 0:8ede47d38d10 372 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 373 * @param __INTERRUPT__: specifies the DMA2D interrupt sources to be enabled.
phungductung 0:8ede47d38d10 374 * This parameter can be any combination of the following values:
phungductung 0:8ede47d38d10 375 * @arg DMA2D_IT_CE: Configuration error interrupt mask
phungductung 0:8ede47d38d10 376 * @arg DMA2D_IT_CTC: C-LUT transfer complete interrupt mask
phungductung 0:8ede47d38d10 377 * @arg DMA2D_IT_CAE: C-LUT access error interrupt mask
phungductung 0:8ede47d38d10 378 * @arg DMA2D_IT_TW: Transfer Watermark interrupt mask
phungductung 0:8ede47d38d10 379 * @arg DMA2D_IT_TC: Transfer complete interrupt mask
phungductung 0:8ede47d38d10 380 * @arg DMA2D_IT_TE: Transfer error interrupt mask
phungductung 0:8ede47d38d10 381 * @retval None
phungductung 0:8ede47d38d10 382 */
phungductung 0:8ede47d38d10 383 #define __HAL_DMA2D_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__))
phungductung 0:8ede47d38d10 384
phungductung 0:8ede47d38d10 385 /**
phungductung 0:8ede47d38d10 386 * @brief Disables the specified DMA2D interrupts.
phungductung 0:8ede47d38d10 387 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 388 * @param __INTERRUPT__: specifies the DMA2D interrupt sources to be disabled.
phungductung 0:8ede47d38d10 389 * This parameter can be any combination of the following values:
phungductung 0:8ede47d38d10 390 * @arg DMA2D_IT_CE: Configuration error interrupt mask
phungductung 0:8ede47d38d10 391 * @arg DMA2D_IT_CTC: C-LUT transfer complete interrupt mask
phungductung 0:8ede47d38d10 392 * @arg DMA2D_IT_CAE: C-LUT access error interrupt mask
phungductung 0:8ede47d38d10 393 * @arg DMA2D_IT_TW: Transfer Watermark interrupt mask
phungductung 0:8ede47d38d10 394 * @arg DMA2D_IT_TC: Transfer complete interrupt mask
phungductung 0:8ede47d38d10 395 * @arg DMA2D_IT_TE: Transfer error interrupt mask
phungductung 0:8ede47d38d10 396 * @retval None
phungductung 0:8ede47d38d10 397 */
phungductung 0:8ede47d38d10 398 #define __HAL_DMA2D_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__))
phungductung 0:8ede47d38d10 399
phungductung 0:8ede47d38d10 400 /**
phungductung 0:8ede47d38d10 401 * @brief Checks whether the specified DMA2D interrupt has occurred or not.
phungductung 0:8ede47d38d10 402 * @param __HANDLE__: DMA2D handle
phungductung 0:8ede47d38d10 403 * @param __INTERRUPT__: specifies the DMA2D interrupt source to check.
phungductung 0:8ede47d38d10 404 * This parameter can be one of the following values:
phungductung 0:8ede47d38d10 405 * @arg DMA2D_IT_CE: Configuration error interrupt mask
phungductung 0:8ede47d38d10 406 * @arg DMA2D_IT_CTC: C-LUT transfer complete interrupt mask
phungductung 0:8ede47d38d10 407 * @arg DMA2D_IT_CAE: C-LUT access error interrupt mask
phungductung 0:8ede47d38d10 408 * @arg DMA2D_IT_TW: Transfer Watermark interrupt mask
phungductung 0:8ede47d38d10 409 * @arg DMA2D_IT_TC: Transfer complete interrupt mask
phungductung 0:8ede47d38d10 410 * @arg DMA2D_IT_TE: Transfer error interrupt mask
phungductung 0:8ede47d38d10 411 * @retval The state of INTERRUPT.
phungductung 0:8ede47d38d10 412 */
phungductung 0:8ede47d38d10 413 #define __HAL_DMA2D_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR & (__INTERRUPT__))
phungductung 0:8ede47d38d10 414 /**
phungductung 0:8ede47d38d10 415 * @}
phungductung 0:8ede47d38d10 416 */
phungductung 0:8ede47d38d10 417
phungductung 0:8ede47d38d10 418 /* Exported functions --------------------------------------------------------*/
phungductung 0:8ede47d38d10 419 /** @defgroup DMA2D_Exported_Functions DMA2D Exported Functions
phungductung 0:8ede47d38d10 420 * @{
phungductung 0:8ede47d38d10 421 */
phungductung 0:8ede47d38d10 422 /* Initialization and de-initialization functions *******************************/
phungductung 0:8ede47d38d10 423 HAL_StatusTypeDef HAL_DMA2D_Init(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 424 HAL_StatusTypeDef HAL_DMA2D_DeInit (DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 425 void HAL_DMA2D_MspInit(DMA2D_HandleTypeDef* hdma2d);
phungductung 0:8ede47d38d10 426 void HAL_DMA2D_MspDeInit(DMA2D_HandleTypeDef* hdma2d);
phungductung 0:8ede47d38d10 427
phungductung 0:8ede47d38d10 428 /* IO operation functions *******************************************************/
phungductung 0:8ede47d38d10 429 HAL_StatusTypeDef HAL_DMA2D_Start(DMA2D_HandleTypeDef *hdma2d, uint32_t pdata, uint32_t DstAddress, uint32_t Width, uint32_t Height);
phungductung 0:8ede47d38d10 430 HAL_StatusTypeDef HAL_DMA2D_BlendingStart(DMA2D_HandleTypeDef *hdma2d, uint32_t SrcAddress1, uint32_t SrcAddress2, uint32_t DstAddress, uint32_t Width, uint32_t Height);
phungductung 0:8ede47d38d10 431 HAL_StatusTypeDef HAL_DMA2D_Start_IT(DMA2D_HandleTypeDef *hdma2d, uint32_t pdata, uint32_t DstAddress, uint32_t Width, uint32_t Height);
phungductung 0:8ede47d38d10 432 HAL_StatusTypeDef HAL_DMA2D_BlendingStart_IT(DMA2D_HandleTypeDef *hdma2d, uint32_t SrcAddress1, uint32_t SrcAddress2, uint32_t DstAddress, uint32_t Width, uint32_t Height);
phungductung 0:8ede47d38d10 433 HAL_StatusTypeDef HAL_DMA2D_Suspend(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 434 HAL_StatusTypeDef HAL_DMA2D_Resume(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 435 HAL_StatusTypeDef HAL_DMA2D_Abort(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 436 HAL_StatusTypeDef HAL_DMA2D_PollForTransfer(DMA2D_HandleTypeDef *hdma2d, uint32_t Timeout);
phungductung 0:8ede47d38d10 437 void HAL_DMA2D_IRQHandler(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 438
phungductung 0:8ede47d38d10 439 /* Peripheral Control functions *************************************************/
phungductung 0:8ede47d38d10 440 HAL_StatusTypeDef HAL_DMA2D_ConfigLayer(DMA2D_HandleTypeDef *hdma2d, uint32_t LayerIdx);
phungductung 0:8ede47d38d10 441 HAL_StatusTypeDef HAL_DMA2D_ConfigCLUT(DMA2D_HandleTypeDef *hdma2d, DMA2D_CLUTCfgTypeDef CLUTCfg, uint32_t LayerIdx);
phungductung 0:8ede47d38d10 442 HAL_StatusTypeDef HAL_DMA2D_EnableCLUT(DMA2D_HandleTypeDef *hdma2d, uint32_t LayerIdx);
phungductung 0:8ede47d38d10 443 HAL_StatusTypeDef HAL_DMA2D_DisableCLUT(DMA2D_HandleTypeDef *hdma2d, uint32_t LayerIdx);
phungductung 0:8ede47d38d10 444 HAL_StatusTypeDef HAL_DMA2D_ProgramLineEvent(DMA2D_HandleTypeDef *hdma2d, uint32_t Line);
phungductung 0:8ede47d38d10 445
phungductung 0:8ede47d38d10 446 /* Peripheral State functions ***************************************************/
phungductung 0:8ede47d38d10 447 HAL_DMA2D_StateTypeDef HAL_DMA2D_GetState(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 448 uint32_t HAL_DMA2D_GetError(DMA2D_HandleTypeDef *hdma2d);
phungductung 0:8ede47d38d10 449 /**
phungductung 0:8ede47d38d10 450 * @}
phungductung 0:8ede47d38d10 451 */
phungductung 0:8ede47d38d10 452
phungductung 0:8ede47d38d10 453 /* Private types -------------------------------------------------------------*/
phungductung 0:8ede47d38d10 454 /** @defgroup DMA2D_Private_Types DMA2D Private Types
phungductung 0:8ede47d38d10 455 * @{
phungductung 0:8ede47d38d10 456 */
phungductung 0:8ede47d38d10 457
phungductung 0:8ede47d38d10 458 /**
phungductung 0:8ede47d38d10 459 * @}
phungductung 0:8ede47d38d10 460 */
phungductung 0:8ede47d38d10 461
phungductung 0:8ede47d38d10 462 /* Private defines -------------------------------------------------------------*/
phungductung 0:8ede47d38d10 463 /** @defgroup DMA2D_Private_Defines DMA2D Private Defines
phungductung 0:8ede47d38d10 464 * @{
phungductung 0:8ede47d38d10 465 */
phungductung 0:8ede47d38d10 466
phungductung 0:8ede47d38d10 467 /**
phungductung 0:8ede47d38d10 468 * @}
phungductung 0:8ede47d38d10 469 */
phungductung 0:8ede47d38d10 470
phungductung 0:8ede47d38d10 471 /* Private variables ---------------------------------------------------------*/
phungductung 0:8ede47d38d10 472 /** @defgroup DMA2D_Private_Variables DMA2D Private Variables
phungductung 0:8ede47d38d10 473 * @{
phungductung 0:8ede47d38d10 474 */
phungductung 0:8ede47d38d10 475
phungductung 0:8ede47d38d10 476 /**
phungductung 0:8ede47d38d10 477 * @}
phungductung 0:8ede47d38d10 478 */
phungductung 0:8ede47d38d10 479
phungductung 0:8ede47d38d10 480 /* Private constants ---------------------------------------------------------*/
phungductung 0:8ede47d38d10 481 /** @defgroup DMA2D_Private_Constants DMA2D Private Constants
phungductung 0:8ede47d38d10 482 * @{
phungductung 0:8ede47d38d10 483 */
phungductung 0:8ede47d38d10 484
phungductung 0:8ede47d38d10 485 /**
phungductung 0:8ede47d38d10 486 * @}
phungductung 0:8ede47d38d10 487 */
phungductung 0:8ede47d38d10 488
phungductung 0:8ede47d38d10 489 /* Private macros ------------------------------------------------------------*/
phungductung 0:8ede47d38d10 490 /** @defgroup DMA2D_Private_Macros DMA2D Private Macros
phungductung 0:8ede47d38d10 491 * @{
phungductung 0:8ede47d38d10 492 */
phungductung 0:8ede47d38d10 493 #define IS_DMA2D_LAYER(LAYER) ((LAYER) <= MAX_DMA2D_LAYER)
phungductung 0:8ede47d38d10 494 #define IS_DMA2D_MODE(MODE) (((MODE) == DMA2D_M2M) || ((MODE) == DMA2D_M2M_PFC) || \
phungductung 0:8ede47d38d10 495 ((MODE) == DMA2D_M2M_BLEND) || ((MODE) == DMA2D_R2M))
phungductung 0:8ede47d38d10 496 #define IS_DMA2D_CMODE(MODE_ARGB) (((MODE_ARGB) == DMA2D_ARGB8888) || ((MODE_ARGB) == DMA2D_RGB888) || \
phungductung 0:8ede47d38d10 497 ((MODE_ARGB) == DMA2D_RGB565) || ((MODE_ARGB) == DMA2D_ARGB1555) || \
phungductung 0:8ede47d38d10 498 ((MODE_ARGB) == DMA2D_ARGB4444))
phungductung 0:8ede47d38d10 499 #define IS_DMA2D_COLOR(COLOR) ((COLOR) <= COLOR_VALUE)
phungductung 0:8ede47d38d10 500 #define IS_DMA2D_LINE(LINE) ((LINE) <= DMA2D_LINE)
phungductung 0:8ede47d38d10 501 #define IS_DMA2D_PIXEL(PIXEL) ((PIXEL) <= DMA2D_PIXEL)
phungductung 0:8ede47d38d10 502 #define IS_DMA2D_OFFSET(OOFFSET) ((OOFFSET) <= DMA2D_OFFSET)
phungductung 0:8ede47d38d10 503 #define IS_DMA2D_INPUT_COLOR_MODE(INPUT_CM) (((INPUT_CM) == CM_ARGB8888) || ((INPUT_CM) == CM_RGB888) || \
phungductung 0:8ede47d38d10 504 ((INPUT_CM) == CM_RGB565) || ((INPUT_CM) == CM_ARGB1555) || \
phungductung 0:8ede47d38d10 505 ((INPUT_CM) == CM_ARGB4444) || ((INPUT_CM) == CM_L8) || \
phungductung 0:8ede47d38d10 506 ((INPUT_CM) == CM_AL44) || ((INPUT_CM) == CM_AL88) || \
phungductung 0:8ede47d38d10 507 ((INPUT_CM) == CM_L4) || ((INPUT_CM) == CM_A8) || \
phungductung 0:8ede47d38d10 508 ((INPUT_CM) == CM_A4))
phungductung 0:8ede47d38d10 509 #define IS_DMA2D_ALPHA_MODE(AlphaMode) (((AlphaMode) == DMA2D_NO_MODIF_ALPHA) || \
phungductung 0:8ede47d38d10 510 ((AlphaMode) == DMA2D_REPLACE_ALPHA) || \
phungductung 0:8ede47d38d10 511 ((AlphaMode) == DMA2D_COMBINE_ALPHA))
phungductung 0:8ede47d38d10 512 #define IS_DMA2D_CLUT_CM(CLUT_CM) (((CLUT_CM) == DMA2D_CCM_ARGB8888) || ((CLUT_CM) == DMA2D_CCM_RGB888))
phungductung 0:8ede47d38d10 513 #define IS_DMA2D_CLUT_SIZE(CLUT_SIZE) ((CLUT_SIZE) <= DMA2D_CLUT_SIZE)
phungductung 0:8ede47d38d10 514 #define IS_DMA2D_LineWatermark(LineWatermark) ((LineWatermark) <= LINE_WATERMARK)
phungductung 0:8ede47d38d10 515 #define IS_DMA2D_IT(IT) (((IT) == DMA2D_IT_CTC) || ((IT) == DMA2D_IT_CAE) || \
phungductung 0:8ede47d38d10 516 ((IT) == DMA2D_IT_TW) || ((IT) == DMA2D_IT_TC) || \
phungductung 0:8ede47d38d10 517 ((IT) == DMA2D_IT_TE) || ((IT) == DMA2D_IT_CE))
phungductung 0:8ede47d38d10 518 #define IS_DMA2D_GET_FLAG(FLAG) (((FLAG) == DMA2D_FLAG_CTC) || ((FLAG) == DMA2D_FLAG_CAE) || \
phungductung 0:8ede47d38d10 519 ((FLAG) == DMA2D_FLAG_TW) || ((FLAG) == DMA2D_FLAG_TC) || \
phungductung 0:8ede47d38d10 520 ((FLAG) == DMA2D_FLAG_TE) || ((FLAG) == DMA2D_FLAG_CE))
phungductung 0:8ede47d38d10 521 /**
phungductung 0:8ede47d38d10 522 * @}
phungductung 0:8ede47d38d10 523 */
phungductung 0:8ede47d38d10 524
phungductung 0:8ede47d38d10 525 /* Private functions prototypes ---------------------------------------------------------*/
phungductung 0:8ede47d38d10 526 /** @defgroup DMA2D_Private_Functions_Prototypes DMA2D Private Functions Prototypes
phungductung 0:8ede47d38d10 527 * @{
phungductung 0:8ede47d38d10 528 */
phungductung 0:8ede47d38d10 529
phungductung 0:8ede47d38d10 530 /**
phungductung 0:8ede47d38d10 531 * @}
phungductung 0:8ede47d38d10 532 */
phungductung 0:8ede47d38d10 533
phungductung 0:8ede47d38d10 534 /* Private functions ---------------------------------------------------------*/
phungductung 0:8ede47d38d10 535 /** @defgroup DMA2D_Private_Functions DMA2D Private Functions
phungductung 0:8ede47d38d10 536 * @{
phungductung 0:8ede47d38d10 537 */
phungductung 0:8ede47d38d10 538
phungductung 0:8ede47d38d10 539 /**
phungductung 0:8ede47d38d10 540 * @}
phungductung 0:8ede47d38d10 541 */
phungductung 0:8ede47d38d10 542
phungductung 0:8ede47d38d10 543 /**
phungductung 0:8ede47d38d10 544 * @}
phungductung 0:8ede47d38d10 545 */
phungductung 0:8ede47d38d10 546
phungductung 0:8ede47d38d10 547 /**
phungductung 0:8ede47d38d10 548 * @}
phungductung 0:8ede47d38d10 549 */
phungductung 0:8ede47d38d10 550
phungductung 0:8ede47d38d10 551
phungductung 0:8ede47d38d10 552 #ifdef __cplusplus
phungductung 0:8ede47d38d10 553 }
phungductung 0:8ede47d38d10 554 #endif
phungductung 0:8ede47d38d10 555
phungductung 0:8ede47d38d10 556 #endif /* __STM32F7xx_HAL_DMA2D_H */
phungductung 0:8ede47d38d10 557
phungductung 0:8ede47d38d10 558
phungductung 0:8ede47d38d10 559 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/