drv_dma.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  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-10 SummerGift first version
  9. */
  10. #ifndef __DRV_DMA_H_
  11. #define __DRV_DMA_H_
  12. #include <rtthread.h>
  13. #include <board.h>
  14. #ifdef __cplusplus
  15. extern "C" {
  16. #endif
  17. #if defined(SOC_SERIES_STM32F0) || defined(SOC_SERIES_STM32F1) || defined(SOC_SERIES_STM32L0) \
  18. || defined(SOC_SERIES_STM32L4) || defined(SOC_SERIES_STM32G0)
  19. #define DMA_INSTANCE_TYPE DMA_Channel_TypeDef
  20. #elif defined(SOC_SERIES_STM32F4) || defined(SOC_SERIES_STM32F7) || defined(SOC_SERIES_STM32H7)
  21. #define DMA_INSTANCE_TYPE DMA_Stream_TypeDef
  22. #endif /* defined(SOC_SERIES_STM32F1) || defined(SOC_SERIES_STM32L4) */
  23. struct dma_config {
  24. DMA_INSTANCE_TYPE *Instance;
  25. rt_uint32_t dma_rcc;
  26. IRQn_Type dma_irq;
  27. #if defined(SOC_SERIES_STM32F4) || defined(SOC_SERIES_STM32F7)
  28. rt_uint32_t channel;
  29. #endif
  30. #if defined(SOC_SERIES_STM32L4) || defined(SOC_SERIES_STM32G0)
  31. rt_uint32_t request;
  32. #endif
  33. };
  34. #ifdef __cplusplus
  35. }
  36. #endif
  37. #endif /*__DRV_DMA_H_ */