0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

对STM32内部FLASH编程时遇到的ADC异常问题

茶话MCU 来源:ST MCU 信息交流 2020-05-14 09:18 次阅读

STM32用户使用STM32F407芯片开发产品。用到内部3个ADC,其中ADC1与ADC2工作在ADC双模式,ADC3独立工作。运行代码时给FLASH开锁编程后,发现ADC3不工作了(其DR数据寄存器似乎不更新了,倒是用来触发ADC的定时器TIM2依然正常),Flash编程前后ADC3配置寄存器CR1、CR2没有发生改变。如果重新配置ADC3后就能正常工作。

从问题现象来看,初步感觉跟flash编程有些关系。

经了解,客户的确做了flash编程,有一部分参数需要存放在FLASH内。他的ADC3是由TIM2触发的,ADC3的转换结果是通过DMA搬运。

鉴于此,我这边便提醒他,如果不是基于双BANK条件,在flash编程时CPU是堵塞的,此时若发生中断不会得到响应,让他注意这点及因此可能导致的问题。

客户进一步反馈确认:

1:通ADC结果过DMA读取,并非中断方式获取;

2:FLASH编程过程中禁止了所有中断;

3:奇怪的是ADC3改为由软件触发则没有异常现象。用来触发ADC的定时器一直计数正常,并且只要重新配置ADC3(无须对触发定时器重新配置)也能恢复它的正常工作。

先说下客户提到的在flash编程时将总中断关闭动作。其实,从效果来讲,这个关中断没啥用,反正在Flash编程过程中即使有中断发生CPU也不会给予响应。

结合其反馈,软件触发和定时器触发ADC有个明显差别,就在于定时器的触发对于我们用户来讲往往存在些未知性或不确定性,即不知它具体的触发时间点。客户一直强调TIM工作保持正常,对ADC不能被触发感到奇怪。

整体上,通过问题症状结合经验初步判断是ADC3发生溢出事件了,建议客户做进一步检查确认。

后来,他反馈的确是发生了ADC溢出事件。在FLASH编程前暂停TIM2触发就可以避免溢出发生,不再发生ADC功能异常。

按理说他现在ADC结果是DMA传输,TIM触发DMA时应该可以及时读取数据的,怎么还发生了溢出呢?那就有种可能,在某个时刻,当ADC被TIM触发完成转换后,这时的DMA还没有准备好,导致ADC的结果没有被及时取走。

那什么原因会导致ADC结果不能被及时取走呢?若DMA配置在非循环模式,当DMA传输完成一轮数据后,DMA将不再继续实施数据传输,这时CPU往往还会进入DMA中断服务程序做些必要处理或者为下轮传输做准备。若这个DMA传输完成中断发生在FLASH编程期间,这就可能导致问题。由于该期间它本身不能得到响应,下一轮的DMA传输就没法被开启。但此时的TIM还是依然如故地触发ADC,其结果若不能被及时取走,导致溢出就再自然不过了。

当ADC发生溢出后,如果没有对溢出位做清零,后续的ADC转换动作是不会触发DMA的。具体到本案例,严格地讲,后来客户觉得读不到ADC的更新数据,不是因为ADC不工作,其实它一直被定时器触发转换,只是因为发生了溢出,没法正常触发DMA传输,进而无法实现ADC结果的搬运。

所以,在上述应用情况下,在做flash编程前可以先行关闭定时器,之后再打开。或者在DMA传输完成的中断服务程序里,在重新开启DMA之前,先暂时关闭定时器,对并ADC的溢出及出错做检测处理,之后再开启定时器和DMA传输。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5327

    浏览量

    120061
  • STM32
    +关注

    关注

    2266

    文章

    10877

    浏览量

    354964
  • 定时器
    +关注

    关注

    23

    文章

    3242

    浏览量

    114528

原文标题:对STM32内部FLASH编程时遇到的ADC异常问题

文章出处:【微信号:stmcu832,微信公众号:茶话MCU】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32F334 ADC1和ADC2同步采样,有时会出现采ADC1和ADC2所有的通道采集数据都一样的情况为什么?

    STM32F334 ADC1和ADC2同步采样,有时会出现采ADC1和ADC2所有的通道采集数据都一样,给人直观的感觉像是
    发表于 05-15 08:15

    stm32ADC采样异常的原因?

    采用双ADC采样,其中的一个ADC的采样通道信号异常:具体来说就是在小范围内,信号随被采用信号线性跟随,超过一定值之后,采样值突然跳变为一固定值,此后再改变被采样电压也无济于事,非得重启方可。不知有没有人曾
    发表于 05-13 06:59

    STM32L475VE内部Flash编程出现ECCD错误的原因?

    使用的芯片型号 STM32L475VE,使用 HAL 库 `HAL_FLASH_Program` API 对 内部 Flash 进行编程,出
    发表于 04-26 07:21

    STM32是如何从flash读取指令并执行的?

    [td]因为STM32H750自带的FLASH太小,而工程文件超过这个flash的容量,所以需要外挂一块flash来存程序,但是此程序需要加密,然后就
    发表于 04-24 07:09

    STM32、ESP8266与MQTT连接阿里云物联网的串口通信异常解析

    阿里云物联网平台的过程中,串口通信异常成为了一个常见的挑战。本文将探讨这些异常现象及其可能的原因,并给出相应的解决方案。 首先,我们来谈谈STM32与ESP8266之间的串口通信问题。这两者的组合通常用于实现数据的采集与传输。然
    的头像 发表于 04-19 17:19 1383次阅读

    STM32F030F4 adc采集异常的原因?

    单片机型号:STM32F030F4P6 问题: 做ADC采集时,如果不调用LED_Init()函数,ADC的读数最大值就会变成1024,只有10位精度,而且如果把LED 的初始化函数放在ADC
    发表于 04-12 07:28

    STM32 ADC功能异常的原因?

    某人使用STM32芯片的ADC功能,发现ADC数据完全不对。反复核对供电、ADC硬件线路、来回验证ADC相关软件配置都没能解决问题,让人抓狂
    发表于 04-08 08:19

    stm32使用例程开启USB主机程序后,flash编程异常位是怎么回事?

    项目中使用到USB主机端,另外使用内部flsah存储数据;当USB接入设备后,从flash寄存器可看出有编程异常位,导致无法存储数据。如果开机后没有接入USB设备,
    发表于 03-28 09:28

    STM32G070 ADC如何禁用内部基准?

    STM32G070 :使用ADC时,不想使用MCU自带的VREF电压源,但只要使能ADC的ADEN位(CR寄存器),内部的电压源自动被使能(ADVREGEN=1),似乎是同步的。ADE
    发表于 03-27 06:50

    STM32上下电内部flash被改写的原因?

    基于STM32F405系列一个64pin MCU,在使用过程中,整机掉电更换另一个部件,再上电后发现这个产品不工作了。发回厂家发现STM32内部flash数据被改写了,前几行被改成了0
    发表于 03-25 08:24

    Stm32H7 spi会带来更大的adc噪声,导致小信号异常值的原因?

    [Stm32H7]spi会带来更大的adc噪声,导致小信号异常
    发表于 03-25 06:10

    stm32 flash写数据怎么存储的

    stm32 flash写数据怎么存储的  STM32是一款广泛应用于嵌入式系统开发的微控制器,它的Flash存储器是其中一个重要的组成部分。在本文中,我将详细介绍
    的头像 发表于 01-31 15:46 2283次阅读

    GD32 ADC内部通道采样异常原因

    熟悉GD32的小伙伴都知道,ADC除了可以采集IO口上的电压外,还有两个内部通道,分别为内部温度传感器通道(ADC0_CH16)和Vrefint通道(
    的头像 发表于 01-26 09:45 2717次阅读
    GD32 <b class='flag-5'>ADC</b><b class='flag-5'>内部</b>通道采样<b class='flag-5'>异常</b>原因

    stm32f103 flash模拟eeprom

    STM32F103的Flash存储器可以模拟EEPROM的功能,在本文中我们将详细介绍如何使用STM32F103的Flash存储器来实现EEPROM。 概述 EEPROM(Elect
    的头像 发表于 01-09 11:21 1924次阅读

    STM32F030芯片内部ADC结果挪位的问题分析及解决办法

    有人使用STM32F030芯片内部ADC的CH0、CH3、CH5共3个通道,单次扫描转换后通过DMA将结果放在一个数组。
    的头像 发表于 01-05 10:14 2835次阅读
    <b class='flag-5'>STM32</b>F030芯片<b class='flag-5'>内部</b><b class='flag-5'>ADC</b>结果挪位的问题分析及解决办法