20#ifndef STM32F4xx_HAL_I2S_EX_H
21#define STM32F4xx_HAL_I2S_EX_H
33#if defined(SPI_I2S_FULLDUPLEX_SUPPORT)
45#define I2SxEXT(__INSTANCE__) ((__INSTANCE__) == (SPI2)? (SPI_TypeDef *)(I2S2ext_BASE): (SPI_TypeDef *)(I2S3ext_BASE))
51#define __HAL_I2SEXT_ENABLE(__HANDLE__) (I2SxEXT((__HANDLE__)->Instance)->I2SCFGR |= SPI_I2SCFGR_I2SE)
52#define __HAL_I2SEXT_DISABLE(__HANDLE__) (I2SxEXT((__HANDLE__)->Instance)->I2SCFGR &= ~SPI_I2SCFGR_I2SE)
63#define __HAL_I2SEXT_ENABLE_IT(__HANDLE__, __INTERRUPT__) (I2SxEXT((__HANDLE__)->Instance)->CR2 |= (__INTERRUPT__))
64#define __HAL_I2SEXT_DISABLE_IT(__HANDLE__, __INTERRUPT__) (I2SxEXT((__HANDLE__)->Instance)->CR2 &= ~(__INTERRUPT__))
76#define __HAL_I2SEXT_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((I2SxEXT((__HANDLE__)->Instance)->CR2\
77 & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
92#define __HAL_I2SEXT_GET_FLAG(__HANDLE__, __FLAG__) (((I2SxEXT((__HANDLE__)->Instance)->SR) & (__FLAG__)) == (__FLAG__))
98#define __HAL_I2SEXT_CLEAR_OVRFLAG(__HANDLE__) do{ \
99 __IO uint32_t tmpreg_ovr = 0x00U; \
100 tmpreg_ovr = I2SxEXT((__HANDLE__)->Instance)->DR;\
101 tmpreg_ovr = I2SxEXT((__HANDLE__)->Instance)->SR;\
102 UNUSED(tmpreg_ovr); \
108#define __HAL_I2SEXT_CLEAR_UDRFLAG(__HANDLE__) do{ \
109 __IO uint32_t tmpreg_udr = 0x00U; \
110 tmpreg_udr = I2SxEXT((__HANDLE__)->Instance)->SR;\
111 UNUSED(tmpreg_udr); \
117#define __HAL_I2SEXT_FLUSH_RX_DR(__HANDLE__) do{ \
118 __IO uint32_t tmpreg_dr = 0x00U; \
119 tmpreg_dr = I2SxEXT((__HANDLE__)->Instance)->DR; \
120 tmpreg_dr = ((__HANDLE__)->Instance->DR); \
139 uint16_t Size, uint32_t Timeout);
This file contains HAL common defines, enumeration, macros and structures definitions.
HAL_StatusTypeDef
HAL Status structures definition
I2S handle Structure definition.