stm8 输出比较多脉冲宽度不对

2019-12-12 18:20发布

本帖最后由 myxiaonia 于 2019-3-12 15:39 编辑

使用stm8s103的定时器2toggle模式生成脉冲值,时钟是16M,TIM2是2分频8M,现在我通过在中断里ccr值加600的方式,生成75us脉宽的脉冲

问题是脉冲宽度一直不准,比较神奇的是会很高频率出现43us,107us这两个值,尽管代码量不是仅仅自增600这么一句,但是我认为完全可以应付

我特意是16位访问的方式写入ccr值,保证是原子操作。

脉冲误差大量的情况都是+-32us,换算成ccr值是256,为什么会是这个值?

256这个值的特殊性我首先想到会不会是因为ccr出现非原子操作,外设寄存器是ccrl和ccrh,为了保证原子性我已经重新定义成16访问的ccr,实际最后的赋值语句是 ldw ccr X
而且600的16进制形式是0x258,即使ccrl和ccrh非原子操作的话ccrh增加的也是2,误差也应该是512

真是百思不得其解
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
8条回答
myxiaonia
2019-12-13 05:57
jyrpxj 发表于 2019-3-12 15:52
我记得STM8的芯片的定时器的载入不可以16位操作,只能8位操作,有先有后。具体看手册。 ...

不会吧,那这样操作的话怎么保证原子性,要知道外设内部肯定是拿16位的ccr和cnt比较

而且我确实是用16位操作这个寄存器的,你的意思是不支持吗? ldw ccr,X这句汇编其实会被翻译成2次写操作吗?

我看pm0044上说,flash区是32总线,ram区是8位总线,这个寄存器区到底算是flash区还是ram区呢

一周热门 更多>