STM32CubeMX(07)定时器+ DAC+DMA输出阶梯波实验。

在这里插入图片描述


前言

定时器6溢出信号作为触发信号,控制DAC1(PA4) 循环输出阶梯波形信号,DAC1需要的数据使用DMA方式提供。实现下面的波形周期输出。
在这里插入图片描述
实验目的
1.熟悉keil和STM32CubeMX的使用,及下载程序方法。
2.学习STM32F407的D/A、DMA、定时器的使用

一、DMA是什么?

DMA:Direct Memory Access 直接内存存取 作用:DMA可以不通过CPU将数据从一个地址空间复制到另外一个地址空间, CPU初始化这个传输动作,传输动作本身是由DMA控制器来实行完成。
在这里插入图片描述

1.1 DMA传输的要素和特点

DMA传输三大要素
ü 传输源:DMA控制器从传输源读出数据;
ü 传输目标: DMA控制器将数据传输的目标;
ü 触发信号:用于触发一次数据传输的动作,执行一个单位的传输 源至传输目标的数据传输;可以用来控制传输的时机。
STM32的DMA特点 ü 传输源和传输目标可以分别是存储器或片上外设
ü 一次数据传输的单位可以为:8位、16位或32位

说白了就是快速搬运数据的工具,不需要CPU来亲自搬运。就开始和结束需要CPU来干预之外。可以说是非常好用。

二、STM32CubeMX配置

定时器6溢出信号作为触发信号,控制DAC1(PA4) 循环输出阶梯波形信号,DAC1需要的数据使用DMA方式提供。实现下面的波形周期输出。

首先我们看要求,一共需要三个STM32资源,定时器6,DAC1,DMA,那就是定时器触发DAC转换,DMA搬运数据(从内存搬运到外设)
所以在cube中我们把这三个资源开起来。SYS,和RCC咱就不说了,都是固定选项
其中定时器6是挂在APB1总线上的,主频是84M,所以这也是我分频8400,10000的装载值的原因,这样算下来就是1秒了。

在这里插入图片描述

2.1 DAC配置

在这里插入图片描述

2.2 定时器配置

在这里插入图片描述
在这里插入图片描述

2.3 DMA配置

在DAC这一栏选择DMA,选择循环模式,这样DMA就会一直搬运我们的这个数据了。
在这里插入图片描述
在这里插入图片描述
到这里我们的配置已经结束,可见用cube来配置,非常的方便快捷

三、软件部分

软件需要编写的东西也很少,首先定义一个数组,分别是0,1241,2482,分别代表着0V,1V,2V。这个大家懂的都懂。
在这里插入图片描述
然后在我们的main函数里面初始化、一个是定时器开启,一个是DMA的启动函数,一共需要四个参数。
在这里插入图片描述
第一个是结构体变量,第二个是通道,第三个是数据,第四个是对其方式。
这四个一个都不能错。尤其是数据,必须是32位的,因为数据寄存器就是32位的。
在这里插入图片描述

  HAL_DAC_Start_DMA(&hdac,DAC_CHANNEL_1,(uint32_t*)dac_data,3,DAC_ALIGN_12B_R);

四、测试结果

编译,烧录。查看测试结果,我们选择level 0不优化代码
在这里插入图片描述
在这里插入图片描述
可以看到是符合实验要求的。

在这里插入图片描述

总结

今天的分享到此结束,希望能够帮助到大家,输出正弦波也是一样的,输出一个正弦波表就行。有机会再给大家讲。

  • 17
    点赞
  • 110
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要使用DAC DMA输出正弦,您需要按照以下步骤操作: 1. 打开STM32CubeMX软件,并创建一个新的工程。 2. 在“Pinout”选项卡中,选择您的MCU型号,然后选择DAC输出管脚。 3. 在“Clock Configuration”选项卡中,设置DAC时钟源和时钟分频器。 4. 在“DAC Configuration”选项卡中,启用DAC,并设置DAC输出参数,例如分辨率和数据对齐方式。 5. 在“DMA Configuration”选项卡中,启用DMA,并设置DMA通道参数,例如传输方向和数据宽度。 6. 在“Project Manager”选项卡中,生成代码,并在Keil或者其他编译器中编译和下载代码。 7. 在代码中编写一个生成正弦的函数,并使用DMA将正弦数据发送到DAC输出寄存器。 8. 在主函数中调用生成正弦函数,并启动DMA传输。 下面是一个简单的生成正弦函数的示例代码: ```c #include <math.h> #define PI 3.14159265358979323846 void generate_sine_wave(uint16_t *buffer, uint16_t buffer_size, uint16_t amplitude, uint16_t offset, uint16_t frequency) { for (uint16_t i = 0; i < buffer_size; i++) { float sine_value = sin(2 * PI * frequency * i / buffer_size); uint16_t dac_value = (uint16_t)((sine_value + 1) * amplitude / 2 + offset); buffer[i] = dac_value; } } ``` 在主函数中,您可以按照以下步骤启动DMA传输: ```c // 初始化DAC输出缓冲区 #define BUFFER_SIZE 100 uint16_t dac_buffer[BUFFER_SIZE]; generate_sine_wave(dac_buffer, BUFFER_SIZE, 2048, 2048, 10); // 启动DMA传输 HAL_StatusTypeDef status = HAL_DAC_Start_DMA(&hdac, DAC_CHANNEL_1, (uint32_t*)dac_buffer, BUFFER_SIZE, DAC_ALIGN_12B_R); if (status != HAL_OK) { // DMA传输启动失败 } ``` 这样,您就可以使用DAC DMA输出正弦了。您可以通过更改生成正弦函数中的参数来调整正弦的幅度、偏移和频率。您还可以通过更改DAC输出参数来调整DAC输出的分辨率和数据对齐方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学工科的皮皮志^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值