打印

STM32F411CEU6的重大硬件bug

[复制链接]
529|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
博斯|  楼主 | 2018-7-10 09:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
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才有这个问题。

使用特权

评论回复

相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

412

主题

412

帖子

0

粉丝