STM32F411CEU6的重大硬件bug

2019-07-20 01:08发布

STM32F411CEU6现在很便宜,才10块多,ROM/RAM也大,有512K/64K,看起来性价比不错,不过...

有没有人用DWT_CYCCNT做精确延时?听说ucOS就是。
然后你就中招了,STM32F411CEU6的DWT_CYCCNT很不稳定,基本不能使用。

是这样的,DWT_CYCCNT是一个3位的时钟计数寄存器,每一个时钟周期+1,溢出后归0,可以直接启动这个计数器,然后读取当前值,用来做延时。

问题来了:理论上到达是2^32后,计数器归0,但是STM32F411CEU6的DWT_CYCCNT,有些片无法达到32位,甚至31位都没有,而且每片都不一样。
这样说吧:如果100MHz,计数器+1就是10ns,32位的计数器,循环一次可以去到42秒多。

然后我有10片STM32F411CEU6做测试,结果是这样的:
1、只有1片可以达到32位,但是也不稳定,几分钟就出现了到31位就归0,或者说第31位不会变动,就是到了4294967295,理论上下一个就是0,但是这个片变成了2147483648,然后再增长。

2、有几片是直接31位,无法超越到32位;
3、按照时间来说,有些5秒直接归0,有些10秒,有些2秒,数字是随机的;

然后我在网上找了外国的一个文章:https://stackoverflow.com/questi ... yccnt-counter-width
看来是STM32F411CEU6的硬伤啊,所以STM32F411CEU6这么便宜是因为这个原因吗?

如果不使用DWT_CYCCNT,那就没有关系了。

后来我换了STM32F410C8U6,没有这个问题,看来只有STM32F411CEU6才有这个问题。


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。