STM32F4xx_HAL_Driver  1.8.3
stm32f4xx_hal_sai.h
Go to the documentation of this file.
1 
19 /* Define to prevent recursive inclusion -------------------------------------*/
20 #ifndef __STM32F4xx_HAL_SAI_H
21 #define __STM32F4xx_HAL_SAI_H
22 
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26 
27 /* Includes ------------------------------------------------------------------*/
28 #include "stm32f4xx_hal_def.h"
29 
33 #if defined(STM32F427xx) || defined(STM32F437xx) || defined(STM32F429xx) || defined(STM32F439xx) || \
34  defined(STM32F446xx) || defined(STM32F469xx) || defined(STM32F479xx) || defined(STM32F413xx) || \
35  defined(STM32F423xx)
36 
41 /* Exported types ------------------------------------------------------------*/
49 typedef enum
50 {
57  HAL_SAI_STATE_ERROR = 0x04U
59 
63 typedef void (*SAIcallback)(void);
64 
69 typedef struct
70 {
71  uint32_t AudioMode;
74  uint32_t Synchro;
77  uint32_t SynchroExt;
83  uint32_t OutputDrive;
88  uint32_t NoDivider;
97  uint32_t FIFOThreshold;
100  uint32_t ClockSource;
103  uint32_t AudioFrequency;
106  uint32_t Mckdiv;
111  uint32_t MonoStereoMode;
114  uint32_t CompandingMode;
117  uint32_t TriState;
120  /* This part of the structure is automatically filled if your are using the high level initialisation
121  function HAL_SAI_InitProtocol */
122 
123  uint32_t Protocol;
126  uint32_t DataSize;
129  uint32_t FirstBit;
132  uint32_t ClockStrobing;
144 typedef struct
145 {
146  uint32_t FrameLength;
152  uint32_t ActiveFrameLength;
157  uint32_t FSDefinition;
160  uint32_t FSPolarity;
163  uint32_t FSOffset;
176 typedef struct
177 {
178  uint32_t FirstBitOffset;
181  uint32_t SlotSize;
184  uint32_t SlotNumber;
187  uint32_t SlotActive;
198 typedef struct __SAI_HandleTypeDef
199 {
200  SAI_Block_TypeDef *Instance;
208  uint8_t *pBuffPtr;
210  uint16_t XferSize;
212  uint16_t XferCount;
220  void (*InterruptServiceRoutine)(struct __SAI_HandleTypeDef *hsai); /* function pointer for IRQ handler */
221 
226  __IO uint32_t ErrorCode;
228 #if (USE_HAL_SAI_REGISTER_CALLBACKS == 1)
229  void (*RxCpltCallback)(struct __SAI_HandleTypeDef *hsai);
230  void (*RxHalfCpltCallback)(struct __SAI_HandleTypeDef *hsai);
231  void (*TxCpltCallback)(struct __SAI_HandleTypeDef *hsai);
232  void (*TxHalfCpltCallback)(struct __SAI_HandleTypeDef *hsai);
233  void (*ErrorCallback)(struct __SAI_HandleTypeDef *hsai);
234  void (*MspInitCallback)(struct __SAI_HandleTypeDef *hsai);
235  void (*MspDeInitCallback)(struct __SAI_HandleTypeDef *hsai);
236 #endif /* USE_HAL_SAI_REGISTER_CALLBACKS */
242 #if (USE_HAL_SAI_REGISTER_CALLBACKS == 1)
246 typedef enum
247 {
254  HAL_SAI_MSPDEINIT_CB_ID = 0x06U
256 
261 #endif /* USE_HAL_SAI_REGISTER_CALLBACKS */
262 
267 /* Exported constants --------------------------------------------------------*/
275 #define HAL_SAI_ERROR_NONE 0x00000000U
276 #define HAL_SAI_ERROR_OVR 0x00000001U
277 #define HAL_SAI_ERROR_UDR 0x00000002U
278 #define HAL_SAI_ERROR_AFSDET 0x00000004U
279 #define HAL_SAI_ERROR_LFSDET 0x00000008U
280 #define HAL_SAI_ERROR_CNREADY 0x00000010U
281 #define HAL_SAI_ERROR_WCKCFG 0x00000020U
282 #define HAL_SAI_ERROR_TIMEOUT 0x00000040U
283 #define HAL_SAI_ERROR_DMA 0x00000080U
284 #if (USE_HAL_SAI_REGISTER_CALLBACKS == 1)
285 #define HAL_SAI_ERROR_INVALID_CALLBACK 0x00000100U
286 #endif /* USE_HAL_SAI_REGISTER_CALLBACKS */
294 #define SAI_SYNCEXT_DISABLE 0U
295 #define SAI_SYNCEXT_OUTBLOCKA_ENABLE 1U
296 #define SAI_SYNCEXT_OUTBLOCKB_ENABLE 2U
304 #define SAI_I2S_STANDARD 0U
305 #define SAI_I2S_MSBJUSTIFIED 1U
306 #define SAI_I2S_LSBJUSTIFIED 2U
307 #define SAI_PCM_LONG 3U
308 #define SAI_PCM_SHORT 4U
316 #define SAI_PROTOCOL_DATASIZE_16BIT 0U
317 #define SAI_PROTOCOL_DATASIZE_16BITEXTENDED 1U
318 #define SAI_PROTOCOL_DATASIZE_24BIT 2U
319 #define SAI_PROTOCOL_DATASIZE_32BIT 3U
327 #define SAI_AUDIO_FREQUENCY_192K 192000U
328 #define SAI_AUDIO_FREQUENCY_96K 96000U
329 #define SAI_AUDIO_FREQUENCY_48K 48000U
330 #define SAI_AUDIO_FREQUENCY_44K 44100U
331 #define SAI_AUDIO_FREQUENCY_32K 32000U
332 #define SAI_AUDIO_FREQUENCY_22K 22050U
333 #define SAI_AUDIO_FREQUENCY_16K 16000U
334 #define SAI_AUDIO_FREQUENCY_11K 11025U
335 #define SAI_AUDIO_FREQUENCY_8K 8000U
336 #define SAI_AUDIO_FREQUENCY_MCKDIV 0U
344 #define SAI_MODEMASTER_TX 0x00000000U
345 #define SAI_MODEMASTER_RX ((uint32_t)SAI_xCR1_MODE_0)
346 #define SAI_MODESLAVE_TX ((uint32_t)SAI_xCR1_MODE_1)
347 #define SAI_MODESLAVE_RX ((uint32_t)(SAI_xCR1_MODE_1 | SAI_xCR1_MODE_0))
355 #define SAI_FREE_PROTOCOL 0x00000000U
356 #define SAI_SPDIF_PROTOCOL ((uint32_t)SAI_xCR1_PRTCFG_0)
357 #define SAI_AC97_PROTOCOL ((uint32_t)SAI_xCR1_PRTCFG_1)
365 #define SAI_DATASIZE_8 ((uint32_t)SAI_xCR1_DS_1)
366 #define SAI_DATASIZE_10 ((uint32_t)(SAI_xCR1_DS_1 | SAI_xCR1_DS_0))
367 #define SAI_DATASIZE_16 ((uint32_t)SAI_xCR1_DS_2)
368 #define SAI_DATASIZE_20 ((uint32_t)(SAI_xCR1_DS_2 | SAI_xCR1_DS_0))
369 #define SAI_DATASIZE_24 ((uint32_t)(SAI_xCR1_DS_2 | SAI_xCR1_DS_1))
370 #define SAI_DATASIZE_32 ((uint32_t)(SAI_xCR1_DS_2 | SAI_xCR1_DS_1 | SAI_xCR1_DS_0))
378 #define SAI_FIRSTBIT_MSB 0x00000000U
379 #define SAI_FIRSTBIT_LSB ((uint32_t)SAI_xCR1_LSBFIRST)
387 #define SAI_CLOCKSTROBING_FALLINGEDGE 0U
388 #define SAI_CLOCKSTROBING_RISINGEDGE 1U
396 #define SAI_ASYNCHRONOUS 0U
397 #define SAI_SYNCHRONOUS 1U
398 #define SAI_SYNCHRONOUS_EXT_SAI1 2U
399 #define SAI_SYNCHRONOUS_EXT_SAI2 3U
407 #define SAI_OUTPUTDRIVE_DISABLE 0x00000000U
408 #define SAI_OUTPUTDRIVE_ENABLE ((uint32_t)SAI_xCR1_OUTDRIV)
416 #define SAI_MASTERDIVIDER_ENABLE 0x00000000U
417 #define SAI_MASTERDIVIDER_DISABLE ((uint32_t)SAI_xCR1_NODIV)
425 #define SAI_FS_STARTFRAME 0x00000000U
426 #define SAI_FS_CHANNEL_IDENTIFICATION ((uint32_t)SAI_xFRCR_FSDEF)
434 #define SAI_FS_ACTIVE_LOW 0x00000000U
435 #define SAI_FS_ACTIVE_HIGH ((uint32_t)SAI_xFRCR_FSPOL)
443 #define SAI_FS_FIRSTBIT 0x00000000U
444 #define SAI_FS_BEFOREFIRSTBIT ((uint32_t)SAI_xFRCR_FSOFF)
452 #define SAI_SLOTSIZE_DATASIZE 0x00000000U
453 #define SAI_SLOTSIZE_16B ((uint32_t)SAI_xSLOTR_SLOTSZ_0)
454 #define SAI_SLOTSIZE_32B ((uint32_t)SAI_xSLOTR_SLOTSZ_1)
462 #define SAI_SLOT_NOTACTIVE 0x00000000U
463 #define SAI_SLOTACTIVE_0 0x00000001U
464 #define SAI_SLOTACTIVE_1 0x00000002U
465 #define SAI_SLOTACTIVE_2 0x00000004U
466 #define SAI_SLOTACTIVE_3 0x00000008U
467 #define SAI_SLOTACTIVE_4 0x00000010U
468 #define SAI_SLOTACTIVE_5 0x00000020U
469 #define SAI_SLOTACTIVE_6 0x00000040U
470 #define SAI_SLOTACTIVE_7 0x00000080U
471 #define SAI_SLOTACTIVE_8 0x00000100U
472 #define SAI_SLOTACTIVE_9 0x00000200U
473 #define SAI_SLOTACTIVE_10 0x00000400U
474 #define SAI_SLOTACTIVE_11 0x00000800U
475 #define SAI_SLOTACTIVE_12 0x00001000U
476 #define SAI_SLOTACTIVE_13 0x00002000U
477 #define SAI_SLOTACTIVE_14 0x00004000U
478 #define SAI_SLOTACTIVE_15 0x00008000U
479 #define SAI_SLOTACTIVE_ALL 0x0000FFFFU
487 #define SAI_STEREOMODE 0x00000000U
488 #define SAI_MONOMODE ((uint32_t)SAI_xCR1_MONO)
496 #define SAI_OUTPUT_NOTRELEASED 0x00000000U
497 #define SAI_OUTPUT_RELEASED ((uint32_t)SAI_xCR2_TRIS)
505 #define SAI_FIFOTHRESHOLD_EMPTY 0x00000000U
506 #define SAI_FIFOTHRESHOLD_1QF ((uint32_t)(SAI_xCR2_FTH_0))
507 #define SAI_FIFOTHRESHOLD_HF ((uint32_t)(SAI_xCR2_FTH_1))
508 #define SAI_FIFOTHRESHOLD_3QF ((uint32_t)(SAI_xCR2_FTH_1 | SAI_xCR2_FTH_0))
509 #define SAI_FIFOTHRESHOLD_FULL ((uint32_t)(SAI_xCR2_FTH_2))
517 #define SAI_NOCOMPANDING 0x00000000U
518 #define SAI_ULAW_1CPL_COMPANDING ((uint32_t)(SAI_xCR2_COMP_1))
519 #define SAI_ALAW_1CPL_COMPANDING ((uint32_t)(SAI_xCR2_COMP_1 | SAI_xCR2_COMP_0))
520 #define SAI_ULAW_2CPL_COMPANDING ((uint32_t)(SAI_xCR2_COMP_1 | SAI_xCR2_CPL))
521 #define SAI_ALAW_2CPL_COMPANDING ((uint32_t)(SAI_xCR2_COMP_1 | SAI_xCR2_COMP_0 | SAI_xCR2_CPL))
529 #define SAI_ZERO_VALUE 0x00000000U
530 #define SAI_LAST_SENT_VALUE ((uint32_t)SAI_xCR2_MUTEVAL)
538 #define SAI_IT_OVRUDR ((uint32_t)SAI_xIMR_OVRUDRIE)
539 #define SAI_IT_MUTEDET ((uint32_t)SAI_xIMR_MUTEDETIE)
540 #define SAI_IT_WCKCFG ((uint32_t)SAI_xIMR_WCKCFGIE)
541 #define SAI_IT_FREQ ((uint32_t)SAI_xIMR_FREQIE)
542 #define SAI_IT_CNRDY ((uint32_t)SAI_xIMR_CNRDYIE)
543 #define SAI_IT_AFSDET ((uint32_t)SAI_xIMR_AFSDETIE)
544 #define SAI_IT_LFSDET ((uint32_t)SAI_xIMR_LFSDETIE)
552 #define SAI_FLAG_OVRUDR ((uint32_t)SAI_xSR_OVRUDR)
553 #define SAI_FLAG_MUTEDET ((uint32_t)SAI_xSR_MUTEDET)
554 #define SAI_FLAG_WCKCFG ((uint32_t)SAI_xSR_WCKCFG)
555 #define SAI_FLAG_FREQ ((uint32_t)SAI_xSR_FREQ)
556 #define SAI_FLAG_CNRDY ((uint32_t)SAI_xSR_CNRDY)
557 #define SAI_FLAG_AFSDET ((uint32_t)SAI_xSR_AFSDET)
558 #define SAI_FLAG_LFSDET ((uint32_t)SAI_xSR_LFSDET)
566 #define SAI_FIFOSTATUS_EMPTY 0x00000000U
567 #define SAI_FIFOSTATUS_LESS1QUARTERFULL 0x00010000U
568 #define SAI_FIFOSTATUS_1QUARTERFULL 0x00020000U
569 #define SAI_FIFOSTATUS_HALFFULL 0x00030000U
570 #define SAI_FIFOSTATUS_3QUARTERFULL 0x00040000U
571 #define SAI_FIFOSTATUS_FULL 0x00050000U
580 /* Exported macro ------------------------------------------------------------*/
590 #if (USE_HAL_SAI_REGISTER_CALLBACKS == 1)
591 #define __HAL_SAI_RESET_HANDLE_STATE(__HANDLE__) do{ \
592  (__HANDLE__)->State = HAL_SAI_STATE_RESET; \
593  (__HANDLE__)->MspInitCallback = NULL; \
594  (__HANDLE__)->MspDeInitCallback = NULL; \
595  } while(0U)
596 #else
597 #define __HAL_SAI_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SAI_STATE_RESET)
598 #endif /* USE_HAL_SAI_REGISTER_CALLBACKS */
599 
613 #define __HAL_SAI_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IMR |= (__INTERRUPT__))
614 #define __HAL_SAI_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IMR &= (~(__INTERRUPT__)))
615 
630 #define __HAL_SAI_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->IMR & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
631 
645 #define __HAL_SAI_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__))
646 
660 #define __HAL_SAI_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->CLRFR = (__FLAG__))
661 
666 #define __HAL_SAI_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= SAI_xCR1_SAIEN)
667 
672 #define __HAL_SAI_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~SAI_xCR1_SAIEN)
673 
678 /* Include HAL SAI Extension module */
679 #include "stm32f4xx_hal_sai_ex.h"
680 
681 /* Exported functions --------------------------------------------------------*/
686 /* Initialization/de-initialization functions **********************************/
690 HAL_StatusTypeDef HAL_SAI_InitProtocol(SAI_HandleTypeDef *hsai, uint32_t protocol, uint32_t datasize, uint32_t nbslot);
691 HAL_StatusTypeDef HAL_SAI_Init(SAI_HandleTypeDef *hsai);
692 HAL_StatusTypeDef HAL_SAI_DeInit(SAI_HandleTypeDef *hsai);
695 
696 #if (USE_HAL_SAI_REGISTER_CALLBACKS == 1)
697 /* SAI callbacks register/unregister functions ********************************/
698 HAL_StatusTypeDef HAL_SAI_RegisterCallback(SAI_HandleTypeDef *hsai,
699  HAL_SAI_CallbackIDTypeDef CallbackID,
700  pSAI_CallbackTypeDef pCallback);
701 HAL_StatusTypeDef HAL_SAI_UnRegisterCallback(SAI_HandleTypeDef *hsai,
702  HAL_SAI_CallbackIDTypeDef CallbackID);
703 #endif /* USE_HAL_SAI_REGISTER_CALLBACKS */
708 /* I/O operation functions *****************************************************/
712 /* Blocking mode: Polling */
713 HAL_StatusTypeDef HAL_SAI_Transmit(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size, uint32_t Timeout);
714 HAL_StatusTypeDef HAL_SAI_Receive(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size, uint32_t Timeout);
715 
716 /* Non-Blocking mode: Interrupt */
717 HAL_StatusTypeDef HAL_SAI_Transmit_IT(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size);
718 HAL_StatusTypeDef HAL_SAI_Receive_IT(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size);
719 
720 /* Non-Blocking mode: DMA */
721 HAL_StatusTypeDef HAL_SAI_Transmit_DMA(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size);
722 HAL_StatusTypeDef HAL_SAI_Receive_DMA(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size);
723 HAL_StatusTypeDef HAL_SAI_DMAPause(SAI_HandleTypeDef *hsai);
724 HAL_StatusTypeDef HAL_SAI_DMAResume(SAI_HandleTypeDef *hsai);
725 HAL_StatusTypeDef HAL_SAI_DMAStop(SAI_HandleTypeDef *hsai);
726 
727 /* Abort function */
728 HAL_StatusTypeDef HAL_SAI_Abort(SAI_HandleTypeDef *hsai);
729 
730 /* Mute management */
731 HAL_StatusTypeDef HAL_SAI_EnableTxMuteMode(SAI_HandleTypeDef *hsai, uint16_t val);
732 HAL_StatusTypeDef HAL_SAI_DisableTxMuteMode(SAI_HandleTypeDef *hsai);
733 HAL_StatusTypeDef HAL_SAI_EnableRxMuteMode(SAI_HandleTypeDef *hsai, SAIcallback callback, uint16_t counter);
734 HAL_StatusTypeDef HAL_SAI_DisableRxMuteMode(SAI_HandleTypeDef *hsai);
735 
736 /* SAI IRQHandler and Callbacks used in non blocking modes (Interrupt and DMA) */
750 /* Peripheral State functions ************************************************/
752 uint32_t HAL_SAI_GetError(const SAI_HandleTypeDef *hsai);
761 /* Private macros ------------------------------------------------------------*/
765 #define IS_SAI_BLOCK_SYNCEXT(STATE) (((STATE) == SAI_SYNCEXT_DISABLE) ||\
766  ((STATE) == SAI_SYNCEXT_OUTBLOCKA_ENABLE) ||\
767  ((STATE) == SAI_SYNCEXT_OUTBLOCKB_ENABLE))
768 
769 #define IS_SAI_SUPPORTED_PROTOCOL(PROTOCOL) (((PROTOCOL) == SAI_I2S_STANDARD) ||\
770  ((PROTOCOL) == SAI_I2S_MSBJUSTIFIED) ||\
771  ((PROTOCOL) == SAI_I2S_LSBJUSTIFIED) ||\
772  ((PROTOCOL) == SAI_PCM_LONG) ||\
773  ((PROTOCOL) == SAI_PCM_SHORT))
774 
775 #define IS_SAI_PROTOCOL_DATASIZE(DATASIZE) (((DATASIZE) == SAI_PROTOCOL_DATASIZE_16BIT) ||\
776  ((DATASIZE) == SAI_PROTOCOL_DATASIZE_16BITEXTENDED) ||\
777  ((DATASIZE) == SAI_PROTOCOL_DATASIZE_24BIT) ||\
778  ((DATASIZE) == SAI_PROTOCOL_DATASIZE_32BIT))
779 
780 #define IS_SAI_AUDIO_FREQUENCY(AUDIO) (((AUDIO) == SAI_AUDIO_FREQUENCY_192K) || ((AUDIO) == SAI_AUDIO_FREQUENCY_96K) || \
781  ((AUDIO) == SAI_AUDIO_FREQUENCY_48K) || ((AUDIO) == SAI_AUDIO_FREQUENCY_44K) || \
782  ((AUDIO) == SAI_AUDIO_FREQUENCY_32K) || ((AUDIO) == SAI_AUDIO_FREQUENCY_22K) || \
783  ((AUDIO) == SAI_AUDIO_FREQUENCY_16K) || ((AUDIO) == SAI_AUDIO_FREQUENCY_11K) || \
784  ((AUDIO) == SAI_AUDIO_FREQUENCY_8K) || ((AUDIO) == SAI_AUDIO_FREQUENCY_MCKDIV))
785 
786 #define IS_SAI_BLOCK_MODE(MODE) (((MODE) == SAI_MODEMASTER_TX) || \
787  ((MODE) == SAI_MODEMASTER_RX) || \
788  ((MODE) == SAI_MODESLAVE_TX) || \
789  ((MODE) == SAI_MODESLAVE_RX))
790 
791 #define IS_SAI_BLOCK_PROTOCOL(PROTOCOL) (((PROTOCOL) == SAI_FREE_PROTOCOL) || \
792  ((PROTOCOL) == SAI_AC97_PROTOCOL) || \
793  ((PROTOCOL) == SAI_SPDIF_PROTOCOL))
794 
795 #define IS_SAI_BLOCK_DATASIZE(DATASIZE) (((DATASIZE) == SAI_DATASIZE_8) || \
796  ((DATASIZE) == SAI_DATASIZE_10) || \
797  ((DATASIZE) == SAI_DATASIZE_16) || \
798  ((DATASIZE) == SAI_DATASIZE_20) || \
799  ((DATASIZE) == SAI_DATASIZE_24) || \
800  ((DATASIZE) == SAI_DATASIZE_32))
801 
802 #define IS_SAI_BLOCK_FIRST_BIT(BIT) (((BIT) == SAI_FIRSTBIT_MSB) || \
803  ((BIT) == SAI_FIRSTBIT_LSB))
804 
805 #define IS_SAI_BLOCK_CLOCK_STROBING(CLOCK) (((CLOCK) == SAI_CLOCKSTROBING_FALLINGEDGE) || \
806  ((CLOCK) == SAI_CLOCKSTROBING_RISINGEDGE))
807 
808 #define IS_SAI_BLOCK_SYNCHRO(SYNCHRO) (((SYNCHRO) == SAI_ASYNCHRONOUS) || \
809  ((SYNCHRO) == SAI_SYNCHRONOUS) || \
810  ((SYNCHRO) == SAI_SYNCHRONOUS_EXT_SAI1) ||\
811  ((SYNCHRO) == SAI_SYNCHRONOUS_EXT_SAI2))
812 
813 #define IS_SAI_BLOCK_OUTPUT_DRIVE(DRIVE) (((DRIVE) == SAI_OUTPUTDRIVE_DISABLE) || \
814  ((DRIVE) == SAI_OUTPUTDRIVE_ENABLE))
815 
816 #define IS_SAI_BLOCK_NODIVIDER(NODIVIDER) (((NODIVIDER) == SAI_MASTERDIVIDER_ENABLE) || \
817  ((NODIVIDER) == SAI_MASTERDIVIDER_DISABLE))
818 
819 #define IS_SAI_BLOCK_MUTE_COUNTER(COUNTER) ((COUNTER) <= 63U)
820 
821 #define IS_SAI_BLOCK_MUTE_VALUE(VALUE) (((VALUE) == SAI_ZERO_VALUE) || \
822  ((VALUE) == SAI_LAST_SENT_VALUE))
823 
824 #define IS_SAI_BLOCK_COMPANDING_MODE(MODE) (((MODE) == SAI_NOCOMPANDING) || \
825  ((MODE) == SAI_ULAW_1CPL_COMPANDING) || \
826  ((MODE) == SAI_ALAW_1CPL_COMPANDING) || \
827  ((MODE) == SAI_ULAW_2CPL_COMPANDING) || \
828  ((MODE) == SAI_ALAW_2CPL_COMPANDING))
829 
830 #define IS_SAI_BLOCK_FIFO_THRESHOLD(THRESHOLD) (((THRESHOLD) == SAI_FIFOTHRESHOLD_EMPTY) || \
831  ((THRESHOLD) == SAI_FIFOTHRESHOLD_1QF) || \
832  ((THRESHOLD) == SAI_FIFOTHRESHOLD_HF) || \
833  ((THRESHOLD) == SAI_FIFOTHRESHOLD_3QF) || \
834  ((THRESHOLD) == SAI_FIFOTHRESHOLD_FULL))
835 
836 #define IS_SAI_BLOCK_TRISTATE_MANAGEMENT(STATE) (((STATE) == SAI_OUTPUT_NOTRELEASED) ||\
837  ((STATE) == SAI_OUTPUT_RELEASED))
838 
839 #define IS_SAI_MONO_STEREO_MODE(MODE) (((MODE) == SAI_MONOMODE) ||\
840  ((MODE) == SAI_STEREOMODE))
841 
842 #define IS_SAI_SLOT_ACTIVE(ACTIVE) ((ACTIVE) <= SAI_SLOTACTIVE_ALL)
843 
844 #define IS_SAI_BLOCK_SLOT_NUMBER(NUMBER) ((1U <= (NUMBER)) && ((NUMBER) <= 16U))
845 
846 #define IS_SAI_BLOCK_SLOT_SIZE(SIZE) (((SIZE) == SAI_SLOTSIZE_DATASIZE) || \
847  ((SIZE) == SAI_SLOTSIZE_16B) || \
848  ((SIZE) == SAI_SLOTSIZE_32B))
849 
850 #define IS_SAI_BLOCK_FIRSTBIT_OFFSET(OFFSET) ((OFFSET) <= 24U)
851 
852 #define IS_SAI_BLOCK_FS_OFFSET(OFFSET) (((OFFSET) == SAI_FS_FIRSTBIT) || \
853  ((OFFSET) == SAI_FS_BEFOREFIRSTBIT))
854 
855 #define IS_SAI_BLOCK_FS_POLARITY(POLARITY) (((POLARITY) == SAI_FS_ACTIVE_LOW) || \
856  ((POLARITY) == SAI_FS_ACTIVE_HIGH))
857 
858 #define IS_SAI_BLOCK_FS_DEFINITION(DEFINITION) (((DEFINITION) == SAI_FS_STARTFRAME) || \
859  ((DEFINITION) == SAI_FS_CHANNEL_IDENTIFICATION))
860 
861 #define IS_SAI_BLOCK_MASTER_DIVIDER(DIVIDER) ((DIVIDER) <= 15U)
862 
863 #define IS_SAI_BLOCK_FRAME_LENGTH(LENGTH) ((8U <= (LENGTH)) && ((LENGTH) <= 256U))
864 
865 #define IS_SAI_BLOCK_ACTIVE_FRAME(LENGTH) ((1U <= (LENGTH)) && ((LENGTH) <= 128U))
866 
871 /* Private functions ---------------------------------------------------------*/
884 #endif /* STM32F427xx || STM32F437xx || STM32F429xx || STM32F439xx || STM32F446xx || STM32F469xx || STM32F479xx || STM32F413xx || STM32F423xx */
885 
890 #ifdef __cplusplus
891 }
892 #endif
893 
894 #endif /* __STM32F4xx_HAL_SAI_H */
895 
HAL_StatusTypeDef HAL_SAI_InitProtocol(SAI_HandleTypeDef *hsai, uint32_t protocol, uint32_t datasize, uint32_t nbslot)
Initialize the structure FrameInit, SlotInit and the low part of Init according to the specified para...
HAL_StatusTypeDef HAL_SAI_RegisterCallback(SAI_HandleTypeDef *hsai, HAL_SAI_CallbackIDTypeDef CallbackID, pSAI_CallbackTypeDef pCallback)
Register a user SAI callback to be used instead of the weak predefined callback.
void HAL_SAI_MspInit(SAI_HandleTypeDef *hsai)
Initialize the SAI MSP.
HAL_StatusTypeDef HAL_SAI_UnRegisterCallback(SAI_HandleTypeDef *hsai, HAL_SAI_CallbackIDTypeDef CallbackID)
Unregister a user SAI callback. SAI callback is redirected to the weak predefined callback.
void HAL_SAI_MspDeInit(SAI_HandleTypeDef *hsai)
DeInitialize the SAI MSP.
HAL_StatusTypeDef HAL_SAI_Init(SAI_HandleTypeDef *hsai)
Initialize the SAI according to the specified parameters. in the SAI_InitTypeDef structure and initia...
HAL_StatusTypeDef HAL_SAI_DeInit(SAI_HandleTypeDef *hsai)
DeInitialize the SAI peripheral.
HAL_StatusTypeDef HAL_SAI_Abort(SAI_HandleTypeDef *hsai)
Abort the current transfer and disable the SAI.
HAL_StatusTypeDef HAL_SAI_Receive_DMA(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size)
Receive an amount of data in non-blocking mode with DMA.
void HAL_SAI_TxCpltCallback(SAI_HandleTypeDef *hsai)
Tx Transfer completed callback.
HAL_StatusTypeDef HAL_SAI_Receive(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Receive an amount of data in blocking mode.
HAL_StatusTypeDef HAL_SAI_Transmit_IT(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size)
Transmit an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_SAI_DMAResume(SAI_HandleTypeDef *hsai)
Resume the audio stream playing from the Media.
HAL_StatusTypeDef HAL_SAI_Receive_IT(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size)
Receive an amount of data in non-blocking mode with Interrupt.
HAL_StatusTypeDef HAL_SAI_DisableRxMuteMode(SAI_HandleTypeDef *hsai)
Disable the Rx mute detection.
HAL_StatusTypeDef HAL_SAI_EnableRxMuteMode(SAI_HandleTypeDef *hsai, SAIcallback callback, uint16_t counter)
Enable the Rx mute detection.
HAL_StatusTypeDef HAL_SAI_DMAStop(SAI_HandleTypeDef *hsai)
Stop the audio stream playing from the Media.
void HAL_SAI_IRQHandler(SAI_HandleTypeDef *hsai)
Handle SAI interrupt request.
HAL_StatusTypeDef HAL_SAI_Transmit(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size, uint32_t Timeout)
Transmit an amount of data in blocking mode.
HAL_StatusTypeDef HAL_SAI_DMAPause(SAI_HandleTypeDef *hsai)
Pause the audio stream playing from the Media.
void HAL_SAI_ErrorCallback(SAI_HandleTypeDef *hsai)
SAI error callback.
void HAL_SAI_RxHalfCpltCallback(SAI_HandleTypeDef *hsai)
Rx Transfer half completed callback.
HAL_StatusTypeDef HAL_SAI_Transmit_DMA(SAI_HandleTypeDef *hsai, uint8_t *pData, uint16_t Size)
Transmit an amount of data in non-blocking mode with DMA.
void HAL_SAI_TxHalfCpltCallback(SAI_HandleTypeDef *hsai)
Tx Transfer Half completed callback.
HAL_StatusTypeDef HAL_SAI_DisableTxMuteMode(SAI_HandleTypeDef *hsai)
Disable the Tx mute mode.
HAL_StatusTypeDef HAL_SAI_EnableTxMuteMode(SAI_HandleTypeDef *hsai, uint16_t val)
Enable the Tx mute mode.
void HAL_SAI_RxCpltCallback(SAI_HandleTypeDef *hsai)
Rx Transfer completed callback.
uint32_t HAL_SAI_GetError(const SAI_HandleTypeDef *hsai)
Return the SAI error code.
HAL_SAI_StateTypeDef HAL_SAI_GetState(const SAI_HandleTypeDef *hsai)
Return the SAI handle state.
void(* pSAI_CallbackTypeDef)(SAI_HandleTypeDef *hsai)
SAI callback pointer definition.
void(* SAIcallback)(void)
SAI Callback prototype.
HAL_SAI_CallbackIDTypeDef
SAI callback ID enumeration definition.
HAL_SAI_StateTypeDef
HAL State structures definition.
@ HAL_SAI_MSPDEINIT_CB_ID
@ HAL_SAI_RX_HALFCOMPLETE_CB_ID
@ HAL_SAI_TX_HALFCOMPLETE_CB_ID
@ HAL_SAI_TX_COMPLETE_CB_ID
@ HAL_SAI_ERROR_CB_ID
@ HAL_SAI_MSPINIT_CB_ID
@ HAL_SAI_RX_COMPLETE_CB_ID
@ HAL_SAI_STATE_TIMEOUT
@ HAL_SAI_STATE_ERROR
@ HAL_SAI_STATE_RESET
@ HAL_SAI_STATE_BUSY_RX
@ HAL_SAI_STATE_READY
@ HAL_SAI_STATE_BUSY
@ HAL_SAI_STATE_BUSY_TX
HAL_LockTypeDef Lock
SAI_InitTypeDef Init
void(* TxHalfCpltCallback)(struct __SAI_HandleTypeDef *hsai)
DMA_HandleTypeDef * hdmatx
SAI_FrameInitTypeDef FrameInit
SAI_SlotInitTypeDef SlotInit
void(* RxCpltCallback)(struct __SAI_HandleTypeDef *hsai)
void(* RxHalfCpltCallback)(struct __SAI_HandleTypeDef *hsai)
void(* MspInitCallback)(struct __SAI_HandleTypeDef *hsai)
__IO HAL_SAI_StateTypeDef State
SAI_Block_TypeDef * Instance
void(* ErrorCallback)(struct __SAI_HandleTypeDef *hsai)
void(* TxCpltCallback)(struct __SAI_HandleTypeDef *hsai)
DMA_HandleTypeDef * hdmarx
void(* MspDeInitCallback)(struct __SAI_HandleTypeDef *hsai)
This file contains HAL common defines, enumeration, macros and structures definitions.
HAL_LockTypeDef
HAL Lock structures definition
Header file of SAI Extension HAL module.
DMA handle Structure definition.