OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 1981|回复: 0

原子哥DAC 小bug的分析和我的浅见

[复制链接]

1

主题

6

帖子

0

精华

新手上路

积分
22
金钱
22
注册时间
2019-8-11
在线时间
4 小时
发表于 2019-12-13 18:13:08 | 显示全部楼层 |阅读模式
关于这个小bug,之前有几个帖子介绍了,我分享一下我的想法。

原子哥的DAC.c文件里面DA输出程序是:
void DAC1_Set_Vol(u16 vol)
{
        double temp=vol;
        temp/=1000;
        temp=temp*4096/3.3;
    HAL_DAC_SetValue(&DAC1_Handler,DAC_CHANNEL_1,DAC_ALIGN_12B_R,temp);//12位右对齐数据格式设置DAC值
}


这里有个潜在的风险:
如果vol=3300的话,temp就是4096,十六进制表示就是0x1000。由于选择的模式是DAC_ALIGN_12B_R,此时就会将b(0000 0000 0000)写到寄存器里面,从而导致输出值为零。


我将程序改为:
void DAC1_Set_Vol(u16 vol)
{
        double temp=vol;
        if(temp>3300)temp=3300;
        if(temp<0)temp=0;
        temp/=1000;
        temp=temp*4095/3.3;
    HAL_DAC_SetValue(&DAC1_Handler,DAC_CHANNEL_1,DAC_ALIGN_12B_R,temp);//12位右对齐数据格式设置DAC值
}


这样输出就正常了,而且增强了程序的健壮性。

当然了,在原子哥的例程里面,并不会产生错误的后果,因为vol不会等于3300.

欢迎交流,谢绝攻击。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-22 00:45

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表