STM32H7 DAC2+BDMA

news/2024/10/18 2:30:26/

最近准备用H7做一个小东西需要用到DAC2生成波形,本以为很简单的事,只需把之前在F4上做的例子搬过来就好,但是发现实际上有个坑。

之前的想法是DAC + DMA + TIM6 Trig,但是发现DAC2始终无输出,HAL_DAC_SetValue()直接输出电压却又是可以的。
研究了半天排除了TIM等其他问题,觉得应该就是DMA的问题。

查看手册发现DAC2是挂在APB4上
在这里插入图片描述
再查DMA发现APB4的设备连接的是BDMA2,能访问的SRAM只能是SRD-SRAM(32k)或者Backup SRAM(4k)。
在这里插入图片描述
(1)所以需要把DMA Buffer 定义到SRD-SRAM (0x38000000)

ALIGN_32BYTES (uint16_t dac_raw_data[DAC_BUFFER_SIZE]) __attribute__((section(".ARM.__at_0x38000000")))

本以为这样就可行了,发现还是无输出。。。
(2)一顿GOOGLE才发现在开启D-Cache的情况下还要进行Clean D-Cache操作,不然SRAM中的数据不会传到Cache中。。。

网上的参考代码:

#define TX_LENGTH  (16)
uint8_t tx_buffer[TX_LENGTH];/* Write data */
tx_buffer[0] = 0x0;
tx_buffer[1] = 0x1;/* Clean D-cache */
/* Make sure the address is 32-byte aligned and add 32-bytes to length, in case it overlaps cacheline */
SCB_CleanDCache_by_Addr((uint32_t*)(((uint32_t)tx_buffer) & ~(uint32_t)0x1F), TX_LENGTH+32);/* Start DMA transfer */
HAL_UART_Transmit_DMA(&huart1, tx_buffer, TX_LENGTH);

自以为这样应该可以了吧,却发现DAC2还是没有输出。。。快崩溃了。
(3)后来百度看到参考【1】,其文中提到要将ADC,DAC的初始化放在DMA初始化之后。。。

终于有了输出,但是奇怪的是发现只有半个波,真是服了。。。
(4)再次研究,发现是SCB_CleanDCache_by_Addr()函数里面的长度是字节长度,u16的变量长度就要x2

经过一系列的骚操作终于出波形了。
在这里插入图片描述
(1)(2)(3)(4)四步一个不能少,写的不是很详细,点到即止,懂得自然就懂了。

参考文章:

  1. STM32H743 ADC1+DMA1 ADC3+BDMA CubeMX配置使用
  2. DMA is not working on STM32H7 devices

http://www.ppmy.cn/news/191386.html

相关文章

Cortex-M7 Cache 操作

目录 【Cortex-M7内核的L1 Cache】 二,Cache4种策略 三,Cache读操作和写操作 【cache配合MPU使用】 【什么是 cache 一致性问题】 一,第一种情况 二,第二种情况 【解决cache一致性问题,有两种可选方案】 一&am…

TXAA,MSAA,SMAA,FXAA

1 TXAA是英伟达开发的目前画质最高的抗锯齿模式,且TXAA x2可以达到MSAA x8的效百果,配置要求也没有MSAA x8那么高。目前只有600和700系列的英伟达显卡支持。 2 MSAA还原度很高,但是配置要求最高。 3 SMAA是性耗比最佳的模式,度用适…

Cortex-A7中断系统

一、中断向量表 中断向量表存放的是中断向量,中断服务程序的入口地址或存放中断服务程序的首地址成为中断向量,因此中断向量表是一系列中断服务程序入口地址组成的表。当某个中断被触发以后就会自动跳转到中断向量表中对应的中断服务程序(函数)入口地址…

STM32H7系列 双核系列:基于Arm® Cortex®-M7和Cortex®-M4的双核产品

基于ARM Cortex-M7的STM32H7 MCU系列采用了ST的非易失性存储器(NVM)技术。从片内闪存执行代码时,其处理器性能得分为1327 DMIPS/ 3224 CoreMark。 STM32H7产品线包括三个系列: 双核系列:基于Arm Cortex-M7和Cortex-M4…

给索尼A7 A7R A7RII选个挂机头?

https://www.zhihu.com/question/31510587 著作权归作者所有。 商业转载请联系作者获得授权,非商业转载请注明出处。 作者:Asa WANG 链接:https://www.zhihu.com/question/31510587/answer/77144848 来源:知乎 基本原则: 既然是挂…

20230426 cortex-A7 cortex-M4核综合实验

cortex-M4核综合实验 1.通过配置开发板LED1/LED2/LED3三盏灯 2.当KEY1/KEY2/KEY3/光电开关/火焰传感器/人体红外中断触发,需要完成以下内容 1)中断触发,在串口工具打印一句话 2)中断触发,对应LED灯状态取反 3.需求:实验中的内容&a…

redisson 随笔 0-入门

0. 虽说时运不佳,仍欲提桶跑路 分布式锁的常见实现方案 常用锁的用例 runoob Lua教程 对于分布式锁的实现方案,本文如标题所言,简单梳理了redisson的实现方案 redisson 也是基于redis的多个命令组合来实现的,为保证执行多个命…

福昕阅读器分屏

在阅读PDF文档的时候,经常会碰到阅读上面几页内容,和下面几页解释需要对照着一起看的情况,总是上下来回滚动鼠标很麻烦! 福昕阅读器的【分屏功能】完美解决这个问题。(备注:目前我所知,文电通阅…