123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
-
- #include "stm32l4xx_hal.h"
- #ifdef HAL_SAI_MODULE_ENABLED
- #if defined(STM32L4R5xx) || defined(STM32L4R7xx) || defined(STM32L4R9xx) || defined(STM32L4S5xx) || defined(STM32L4S7xx) || defined(STM32L4S9xx)
- #define SAI_PDM_DELAY_MASK 0x77U
- #define SAI_PDM_DELAY_OFFSET 8U
- #define SAI_PDM_RIGHT_DELAY_OFFSET 4U
- HAL_StatusTypeDef HAL_SAIEx_ConfigPdmMicDelay(SAI_HandleTypeDef *hsai, SAIEx_PdmMicDelayParamTypeDef *pdmMicDelay)
- {
- HAL_StatusTypeDef status = HAL_OK;
-
-
- if(hsai->Instance != SAI1_Block_A)
- {
- status = HAL_ERROR;
- }
- else
- {
-
- assert_param(IS_SAI_PDM_MIC_PAIRS_NUMBER(pdmMicDelay->MicPair));
- assert_param(IS_SAI_PDM_MIC_DELAY(pdmMicDelay->LeftDelay));
- assert_param(IS_SAI_PDM_MIC_DELAY(pdmMicDelay->RightDelay));
-
-
- if(hsai->State != HAL_SAI_STATE_RESET)
- {
-
- SAI1->PDMDLY &= ~(SAI_PDM_DELAY_MASK << (SAI_PDM_DELAY_OFFSET * (pdmMicDelay->MicPair - 1)));
-
-
- SAI1->PDMDLY |= (((pdmMicDelay->RightDelay << SAI_PDM_RIGHT_DELAY_OFFSET) | pdmMicDelay->LeftDelay) << \
- (SAI_PDM_DELAY_OFFSET * (pdmMicDelay->MicPair - 1)));
- }
- else
- {
- status = HAL_ERROR;
- }
- }
- return status;
- }
- #endif
- #endif
|