OpenEdv-开源电子网

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

高级定时器TIM1的OSSI标志位的问题

[复制链接]

3

主题

7

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2014-11-30
在线时间
0 小时
发表于 2015-2-3 21:12:02 | 显示全部楼层 |阅读模式
5金钱
问题描述:
        1、在计数器正常运行的情况下,若MOE(主输出使能)=AOE=0,CC1E = CC1NE=0,OIS1和OIS1N(Idle state选择)不同时为0,此时不管OSSI位是什么,都会在OC1和OC1N上面出现一个PWM波形,且占空比由CCxR和ARR决定。即关闭了主输出使能和通道使能,结果出现了波形。如图
 
        2、在ReferenceManual中,对OSSI位作出如下描述:
                 
                这里的inactive指的是MOE=0的状态吗?但是根据我实际测试,当MOE=0的时候,如果CCxE/CCxNE置位,OC/OCN的输出状态并不会根据CR2寄存器中OISx位设置的Idle state来输出。反而出现如下情况:
                若OSSI=1(根据RM,此时OC/OCN强制输出为idle level),且CR2寄存器中定义了OIS1=OIS1N=1(OC1=1,when MOE=0),结果OC1和OC1N都输出了低电平而不是预想的高电平。令人费解。
麻烦各位不吝赐教,感谢!

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11558
金钱
11558
注册时间
2014-4-1
在线时间
1318 小时
发表于 2015-2-3 22:10:01 | 显示全部楼层
印象里,active 是指溢出、匹配这些“事件”发生了, inactive 是没有发生,和最终电平的高低无关。

另外有控制位,决定 active 时输出高或低;inactive 的时候也可以单独设置。

最下面的图,貌似就是说这个情况。

ST 的这种设计,其实很妙的。


回复

使用道具 举报

3

主题

7

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2014-11-30
在线时间
0 小时
 楼主| 发表于 2015-2-3 22:25:29 | 显示全部楼层
回复【2楼】xuande:
---------------------------------
我懂得,ST用ACTIVE和INACTIVE代替了高低电平的分法。但是在他的RM0008这个文档里面,ACTIVE的用法前后有些不统一(之前有去过TI实习,这些manual一般都是分给不同的人写的),导致读起来比较费力。也用过MSP430带死区的TIMERA,那个要清楚得多。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-26 02:15

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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