[研电赛技术支持] GD32 DAC+TIMER+DMA实现正弦波

[复制链接]
 楼主| 慢动作 发表于 2022-1-28 15:45 | 显示全部楼层 |阅读模式
一、目的

1.使用GD32的DAC、TIMER、DMA实现正弦波

二、原理

1.正弦波:周期一定,相同时间间隔时能够取得不同的数值(符合SIN函数)。

三、芯片功能组合实现SIN

1.DAC:能够输出不同的电压值(0-3.3v)

2.TIMER:能够提供均匀的时间

3.DMA:能够将数据从存储器传输到外设而不占用CPU资源

4.SIN数据:本工程中使用的是“野火”DAC正弦波工程中提供的正弦数据

 楼主| 慢动作 发表于 2022-1-28 15:46 | 显示全部楼层
四、GD32实现正弦波的步骤图

4317461f39f6eed920.png
 楼主| 慢动作 发表于 2022-1-28 15:51 | 显示全部楼层
1.步骤一:定时器按固定间隔触发DAC

2.步骤二:DAC被触发后,发送DMA请求

3.步骤三:DMA接收到DAC请求后,将一个数据发送到DAC的数据保持寄存器中

4.步骤四:DAC被外部触发后,会将DAC数据保持寄存器中的数据转移到数据输出寄存器中,输出数据对应的电压
 楼主| 慢动作 发表于 2022-1-28 15:54 | 显示全部楼层
五、实现环境

1.引脚:PA4

2.芯片:GD32F103X

3.开发板:GD32103C-START

4.显示环境:数字示波器
 楼主| 慢动作 发表于 2022-1-28 15:55 | 显示全部楼层
-详讲GD32中DAC+TIMER+DMA如何实现------------------------------

六、DAC(基础:可以将数据转换为模拟输出电压)

1.DAC结构图
3952161f3a17a8ac82.png
 楼主| 慢动作 发表于 2022-1-28 15:57 | 显示全部楼层
1)TIMER6_TRGO,为外部定时器触发;配置触发源时选择它,对应函数:timer_master_output_trigger_source_select()

2)DMA requestx,DMA请求;在有外部触发同时DAC中的DMA功能使能后,会发送DMA触发请求,对应函数:dac_dma_enable()
————————————————
 楼主| 慢动作 发表于 2022-1-28 15:59 | 显示全部楼层
 楼主| 慢动作 发表于 2022-1-28 15:59 | 显示全部楼层
3)DHx,DAC数据保持寄存器;用于保存将要转移到输出寄存器(DOx)的数据,及下一个输出的数据。在DMA传输时,这个寄存器就是DAC的接收地址。
 楼主| 慢动作 发表于 2022-1-28 16:00 | 显示全部楼层
2.DAC输出电压的计算

3033061f3a28ff30be.png
 楼主| 慢动作 发表于 2022-1-28 16:01 | 显示全部楼层
七、TIMER6(基本定时器)

1.结构图
36561f3a2c96364f.png

 楼主| 慢动作 发表于 2022-1-28 16:01 | 显示全部楼层
1)触发选择,这里说的是主输出的触发源要选择相应的参数,之后发送TIMERx_TRGO触发信号;对应函数:timer_master_output_trigger_source_select
 楼主| 慢动作 发表于 2022-1-28 16:02 | 显示全部楼层
2.相应参数如何选择(老实说这个比较坑,在文档的功能说明中没找到,是直接看寄存器才发现的,-_-||)

2883661f3a30fa5206.png
 楼主| 慢动作 发表于 2022-1-28 16:22 | 显示全部楼层
1)TIMERx_CTL1,就是进行同步时需要进行配置的寄存器
 楼主| 慢动作 发表于 2022-1-28 16:26 | 显示全部楼层
2)MMC,中选择更新(010)为定时器触发TIMERx_TRGO的时间。对应函数:timer_master_output_trigger_source_select
 楼主| 慢动作 发表于 2022-1-28 16:30 | 显示全部楼层
3.为什么要选择更新(010)为定时器触发???
 楼主| 慢动作 发表于 2022-1-28 16:31 | 显示全部楼层
 楼主| 慢动作 发表于 2022-1-28 16:47 | 显示全部楼层
1)阅读资料可知,定时器一旦超过阈值(自动重装载值),就会产生更新事件,同时更新所有寄存器。
 楼主| 慢动作 发表于 2022-1-28 16:48 | 显示全部楼层
2)结论是,更新事件发生时,时间已到设定的时间,反复实现更新事件就会产生定时触发TIMERx_TRGO。
 楼主| 慢动作 发表于 2022-1-28 16:49 | 显示全部楼层
3)防止额外因素,使能定时器更新事件;对应函数timer_update_event_enable
 楼主| 慢动作 发表于 2022-1-28 16:50 | 显示全部楼层
八、DMA

1.结构框图

834261f3ae128bff6.png
您需要登录后才可以回帖 登录 | 注册

本版积分规则

82

主题

914

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部

82

主题

914

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部