drv_audio.h 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-11-14 ZeroFree first implementation
  9. */
  10. #ifndef __DRV_AUDIO_H__
  11. #define __DRV_AUDIO_H__
  12. #include <rtthread.h>
  13. #include <drivers/audio.h>
  14. #include <audio_pipe.h>
  15. /* SAIA DMA Stream TX definitions */
  16. #define SAIA_TX_DMAx_CLK_ENABLE() __HAL_RCC_DMA2_CLK_ENABLE()
  17. #define SAIA_TX_DMAx_CLK_DISABLE() __HAL_RCC_DMA2_CLK_DISABLE()
  18. #define SAIA_TX_DMAx_STREAM DMA2_Stream3
  19. #define SAIA_TX_DMAx_CHANNEL DMA_CHANNEL_0
  20. #define SAIA_TX_DMAx_IRQ DMA2_Stream3_IRQn
  21. #define SAIA_TX_DMAx_PERIPH_DATA_SIZE DMA_PDATAALIGN_HALFWORD
  22. #define SAIA_TX_DMAx_MEM_DATA_SIZE DMA_MDATAALIGN_HALFWORD
  23. #define SAIA_TX_DMAx_IRQHandler DMA2_Stream3_IRQHandler
  24. /* SAIB DMA Stream TX definitions */
  25. #define SAIA_RX_DMAx_CLK_ENABLE() __HAL_RCC_DMA2_CLK_ENABLE()
  26. #define SAIA_RX_DMAx_CLK_DISABLE() __HAL_RCC_DMA2_CLK_DISABLE()
  27. #define SAIA_RX_DMAx_STREAM DMA2_Stream5
  28. #define SAIA_RX_DMAx_CHANNEL DMA_CHANNEL_0
  29. #define SAIA_RX_DMAx_IRQ DMA2_Stream5_IRQn
  30. #define SAIA_RX_DMAx_PERIPH_DATA_SIZE DMA_PDATAALIGN_HALFWORD
  31. #define SAIA_RX_DMAx_MEM_DATA_SIZE DMA_MDATAALIGN_HALFWORD
  32. #define SAIA_RX_DMAx_IRQHandler DMA2_Stream5_IRQHandler
  33. int SAIA_SampleRate_Set(uint32_t samplerate);
  34. int rt_hw_audio_init(char *i2c_bus_name);
  35. #endif