STM32H743I_EVAL BSP User Manual
|
This file provides the Audio driver for the STM32H743I-EVAL board. More...
#include "stm32h743i_eval_audio.h"
Go to the source code of this file.
Defines | |
#define | DFSDM_OVER_SAMPLING(__FREQUENCY__) |
#define | DFSDM_CLOCK_DIVIDER(__FREQUENCY__) |
#define | DFSDM_FILTER_ORDER(__FREQUENCY__) |
#define | DFSDM_MIC_BIT_SHIFT(__FREQUENCY__) |
#define | SaturaLH(N, L, H) (((N)<(L))?(L):(((N)>(H))?(H):(N))) |
Functions | |
static void | SAIx_Out_Init (uint32_t SaiOutMode, uint32_t SlotActive, uint32_t AudioFreq) |
Initializes the Audio Codec audio interface (SAI). | |
static void | SAIx_Out_DeInit (SAI_HandleTypeDef *hsai) |
Deinitializes the Audio Codec audio interface (SAI). | |
static void | SAIx_In_MspInit (SAI_HandleTypeDef *hsai, void *Params) |
Initializes SAI Audio IN MSP. | |
static void | SAIx_In_MspDeInit (SAI_HandleTypeDef *hsai, void *Params) |
De-Initializes SAI Audio IN MSP. | |
static void | SAIx_In_Init (uint32_t SaiInMode, uint32_t SlotActive, uint32_t AudioFreq) |
Initializes the Audio Codec audio interface (SAI). | |
static void | SAIx_In_DeInit (SAI_HandleTypeDef *hsai) |
Deinitializes the output Audio Codec audio interface (SAI). | |
static uint8_t | DFSDMx_DeInit (void) |
De-initializes the Digital Filter for Sigma-Delta Modulators interface (DFSDM). | |
static void | DFSDMx_ChannelMspInit (void) |
Initializes the DFSDM channel MSP. | |
static void | DFSDMx_ChannelMspDeInit (void) |
DeInitializes the DFSDM channel MSP. | |
static void | DFSDMx_FilterMspInit (void) |
Initializes the DFSDM filter MSP. | |
static void | DFSDMx_FilterMspDeInit (void) |
DeInitializes the DFSDM filter MSP. | |
uint8_t | BSP_AUDIO_OUT_Init (uint16_t OutputDevice, uint8_t Volume, uint32_t AudioFreq) |
Configures the audio Out peripheral. | |
uint8_t | BSP_AUDIO_OUT_Play (uint16_t *pBuffer, uint32_t Size) |
Starts playing audio stream from a data buffer for a determined size. | |
void | BSP_AUDIO_OUT_ChangeBuffer (uint16_t *pData, uint16_t Size) |
Sends n-Bytes on the SAI interface. | |
uint8_t | BSP_AUDIO_OUT_Pause (void) |
This function Pauses the audio file stream. | |
uint8_t | BSP_AUDIO_OUT_Resume (void) |
Resumes the audio file stream. | |
uint8_t | BSP_AUDIO_OUT_Stop (uint32_t Option) |
Stops audio playing and Power down the Audio Codec. | |
uint8_t | BSP_AUDIO_OUT_SetVolume (uint8_t Volume) |
Controls the current audio volume level. | |
uint8_t | BSP_AUDIO_OUT_SetMute (uint32_t Cmd) |
Enables or disables the MUTE mode by software. | |
uint8_t | BSP_AUDIO_OUT_SetOutputMode (uint8_t Output) |
Switch dynamically (while audio file is played) the output target (speaker or headphone). | |
void | BSP_AUDIO_OUT_SetFrequency (uint32_t AudioFreq) |
Updates the audio frequency. | |
void | BSP_AUDIO_OUT_SetAudioFrameSlot (uint32_t AudioFrameSlot) |
Updates the Audio frame slot configuration. | |
void | BSP_AUDIO_OUT_DeInit (void) |
De-initializes the audio out peripheral. | |
__weak void | BSP_AUDIO_OUT_TransferComplete_CallBack (void) |
Manages the DMA full Transfer complete event. | |
__weak void | BSP_AUDIO_OUT_HalfTransfer_CallBack (void) |
Manages the DMA Half Transfer complete event. | |
__weak void | BSP_AUDIO_OUT_Error_CallBack (void) |
Manages the DMA FIFO error event. | |
__weak void | BSP_AUDIO_OUT_MspInit (SAI_HandleTypeDef *hsai, void *Params) |
Initializes BSP_AUDIO_OUT MSP. | |
__weak void | BSP_AUDIO_OUT_MspDeInit (SAI_HandleTypeDef *hsai, void *Params) |
Deinitializes SAI MSP. | |
__weak void | BSP_AUDIO_OUT_ClockConfig (SAI_HandleTypeDef *hsai, uint32_t AudioFreq, void *Params) |
Clock Config. | |
void | HAL_SAI_TxCpltCallback (SAI_HandleTypeDef *hsai) |
Tx Transfer completed callbacks. | |
void | HAL_SAI_TxHalfCpltCallback (SAI_HandleTypeDef *hsai) |
Tx Half Transfer completed callbacks. | |
void | HAL_SAI_ErrorCallback (SAI_HandleTypeDef *hsai) |
SAI error callbacks. | |
uint8_t | BSP_AUDIO_IN_Init (uint32_t AudioFreq, uint32_t BitRes, uint32_t ChnlNbr) |
Initialize wave recording. | |
uint8_t | BSP_AUDIO_IN_InitEx (uint16_t InputDevice, uint32_t AudioFreq, uint32_t BitRes, uint32_t ChnlNbr) |
Initialize wave recording. | |
uint8_t | BSP_AUDIO_IN_ConfigMicDefault (uint32_t InputDevice) |
Initializes default configuration of the Digital Filter for Sigma-Delta Modulators interface (DFSDM). | |
__weak uint8_t | BSP_AUDIO_IN_ConfigDigitalMic (uint32_t InputDevice, void *Params) |
Initializes the Digital Filter for Sigma-Delta Modulators interface (DFSDM). | |
uint8_t | BSP_AUDIO_IN_OUT_Init (uint32_t InputDevice, uint32_t OutputDevice, uint32_t AudioFreq, uint32_t BitRes, uint32_t ChnlNbr) |
Initializes wave recording and playback in parallel. | |
void | BSP_AUDIO_IN_SelectInterface (uint32_t Interface) |
Link digital mic to specified source. | |
uint32_t | BSP_AUDIO_IN_GetInterface (void) |
Get digital mic interface. | |
uint8_t | BSP_AUDIO_IN_AllocScratch (int32_t *pScratch, uint32_t size) |
Allocate channel buffer scratch. | |
uint8_t | BSP_AUDIO_IN_GetChannelNumber (void) |
Return audio in channel number. | |
uint8_t | BSP_AUDIO_IN_Record (uint16_t *pBuf, uint32_t size) |
Start audio recording. | |
uint8_t | BSP_AUDIO_IN_Stop (void) |
Stop audio recording. | |
uint8_t | BSP_AUDIO_IN_StopEx (uint32_t InputDevice) |
Stops audio recording. | |
uint8_t | BSP_AUDIO_IN_Pause (void) |
Pause the audio file stream. | |
uint8_t | BSP_AUDIO_IN_PauseEx (uint32_t InputDevice) |
Pauses the audio file stream. | |
uint8_t | BSP_AUDIO_IN_Resume (void) |
Resume the audio file stream. | |
uint8_t | BSP_AUDIO_IN_ResumeEx (uint32_t *pBuf, uint32_t InputDevice) |
Resumes the audio file stream. | |
uint8_t | BSP_AUDIO_IN_SetVolume (uint8_t Volume) |
Controls the audio in volume level. | |
void | BSP_AUDIO_IN_DeInit (void) |
Deinit the audio IN peripherals. | |
uint8_t | BSP_AUDIO_IN_PDMToPCM_Init (uint32_t AudioFreq, uint32_t ChnlNbrIn, uint32_t ChnlNbrOut) |
Initialize the PDM library. | |
uint8_t | BSP_AUDIO_IN_PDMToPCM (uint16_t *PDMBuf, uint16_t *PCMBuf) |
Converts audio format from PDM to PCM. | |
__weak void | BSP_AUDIO_IN_TransferComplete_CallBack (void) |
User callback when record buffer is filled. | |
__weak void | BSP_AUDIO_IN_HalfTransfer_CallBack (void) |
Manages the DMA Half Transfer complete event. | |
__weak void | BSP_AUDIO_IN_TransferComplete_CallBackEx (uint32_t InputDevice) |
User callback when record buffer is filled. | |
__weak void | BSP_AUDIO_IN_HalfTransfer_CallBackEx (uint32_t InputDevice) |
User callback when record buffer is filled. | |
__weak void | BSP_AUDIO_IN_Error_CallBack (void) |
Audio IN Error callback function. | |
__weak void | BSP_AUDIO_IN_MspInit (void) |
Initialize BSP_AUDIO_IN MSP. | |
__weak void | BSP_AUDIO_IN_MspDeInit (void) |
DeInitialize BSP_AUDIO_IN MSP. | |
__weak void | BSP_AUDIO_IN_ClockConfig (uint32_t AudioFreq, void *Params) |
Clock Config. | |
void | HAL_DFSDM_FilterRegConvCpltCallback (DFSDM_Filter_HandleTypeDef *hdfsdm_filter) |
Regular conversion complete callback. | |
void | HAL_DFSDM_FilterRegConvHalfCpltCallback (DFSDM_Filter_HandleTypeDef *hdfsdm_filter) |
Half regular conversion complete callback. | |
void | HAL_SAI_RxHalfCpltCallback (SAI_HandleTypeDef *hsai) |
Half reception complete callback. | |
void | HAL_SAI_RxCpltCallback (SAI_HandleTypeDef *hsai) |
Reception complete callback. | |
Variables | |
AUDIO_DrvTypeDef * | audio_drv |
SAI_HandleTypeDef | haudio_out_sai |
SAI_HandleTypeDef | haudio_in_sai |
AUDIOIN_ContextTypeDef | hAudioIn |
DFSDM_Channel_HandleTypeDef | hAudioInDfsdmChannel [DFSDM_MIC_NUMBER] |
DFSDM_Filter_HandleTypeDef | hAudioInDfsdmFilter [DFSDM_MIC_NUMBER] |
DMA_HandleTypeDef | hDmaDfsdm [DFSDM_MIC_NUMBER] |
int32_t * | pScratchBuff [DEFAULT_AUDIO_IN_CHANNEL_NBR] |
int32_t | ScratchSize |
uint32_t | DmaRecHalfBuffCplt [DFSDM_MIC_NUMBER] = {0} |
uint32_t | DmaRecBuffCplt [DFSDM_MIC_NUMBER] = {0} |
__IO uint32_t | AppBuffTrigger = 0 |
__IO uint32_t | AppBuffHalf = 0 |
__IO uint32_t | MicBuff [DFSDM_MIC_NUMBER] = {0} |
__IO uint16_t | AudioInVolume = DEFAULT_AUDIO_IN_VOLUME |
PDM_Filter_Handler_t | PDM_FilterHandler [2] |
PDM_Filter_Config_t | PDM_FilterConfig [2] |
Detailed Description
This file provides the Audio driver for the STM32H743I-EVAL board.
- Attention:
© COPYRIGHT(c) 2017 STMicroelectronics
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. Neither the name of STMicroelectronics nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Definition in file stm32h743i_eval_audio.c.
Generated on Wed Aug 23 2017 17:45:14 for STM32H743I_EVAL BSP User Manual by 1.7.6.1