mbed library sources

Dependents:   Encrypted my_mbed lklk CyaSSL_DTLS_Cellular ... more

Superseded

This library was superseded by mbed-dev - https://os.mbed.com/users/mbed_official/code/mbed-dev/.

Development branch of the mbed library sources. This library is kept in synch with the latest changes from the mbed SDK and it is not guaranteed to work.

If you are looking for a stable and tested release, please import one of the official mbed library releases:

Import librarymbed

The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Committer:
mbed_official
Date:
Fri Aug 14 13:15:17 2015 +0100
Revision:
610:813dcc80987e
Parent:
573:ad23fe03a082
Synchronized with git revision 6d84db41c6833e0b9b024741eb0616a5f62d5599

Full URL: https://github.com/mbedmicro/mbed/commit/6d84db41c6833e0b9b024741eb0616a5f62d5599/

DISCO_F746NG - Improvements

Who changed what in which revision?

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