4034|6

9

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

430捕获模式求助 [复制链接]

#pragma vector=TIMERB0_VECTOR        
__interrupt void TimerB0(void)
{
    if(TBCCTL0&CM1)                        //捕获到下降沿
    {
        TBCTL|=TBCLR;
        TBCCTL0=(TBCCTL0&(~CM1))|CM0;    //改为上升沿捕获:CM1置零,CM0置一
    }
    else if(TBCCTL0&CM0)                    //捕获到上升沿
    {
        width[i++]=TBCCR0;                  //记录下结束时间
        TBCCTL0=(TBCCTL0&(~CM0))|CM1;   //改为下降沿捕获:CM0置零,CM1置一
        if(i==32)
        {
            AverageTB0 = 0;
            for(i = 0; i < 32; i++)
            AverageTB0 += width;
            AverageTB0 >>= 5;     //除以32求平均值,以免数据不停跳变
            i=0;
        }
    }
   
}
在改变上升沿捕获还是下降沿捕获的时候,为什么是设置CM1和CM0,而不是CM1和CM2呢

最新回复

对不起,是我没有领会到你的意思。#define CM_0                (0*0x4000u) /* Capture mode: 0 - disabled */#define CM_1                (1*0x4000u) /* Capture mode: 1 - pos. edge */#define CM_2                (2*0x4000u) /* Capture mode: 1 - neg. edge */#define CM_3                (3*0x4000u) /* Capture mode: 1 - both edges */这是IAR的一段定义,对CM0和CM1寄存器的赋值有四个,如上所示对应下面四种状态CMx Bit15-14Capture mode00 No capture01 Capture on rising edge10 Capture on falling edge11 Capture on both rising and falling edges这样解释你看能理解  详情 回复 发表于 2012-4-24 09:12
 
点赞 关注

回复
举报

5015

帖子

12

TA的资源

裸片初长成(初级)

沙发
 
在430中没有CM2这个寄存器位的定义,只有CM0和CM1的组合
 
 

回复

188

帖子

0

TA的资源

纯净的硅(中级)

板凳
 

回复 楼主 浅影月居 的帖子

在比较器模块里有一个寄存器是CMx,可以进行选择:
Capture mode
00 No capture
01 Capture on rising edge
10 Capture on falling edge
11 Capture on both rising and falling edges
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(中级)

4
 

回复 沙发 wstt 的帖子

就是说这里CM0和CM1是指两个寄存器,而不是指CM选择停止捕获和上升沿捕获嘛?

[ 本帖最后由 浅影月居 于 2012-4-23 20:33 编辑 ]
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(中级)

5
 

回复 板凳 peter_zheng 的帖子

如果是这样的话,CM0和CM1不就是指停止捕获和上升沿捕获了么?那怎么改变成下降沿捕获?
 
 
 

回复

5015

帖子

12

TA的资源

裸片初长成(初级)

6
 
原帖由 浅影月居 于 2012-4-23 20:32 发表 如果是这样的话,CM0和CM1不就是指停止捕获和上升沿捕获了么?那怎么改变成下降沿捕获?
对不起,是我没有领会到你的意思。
#define CM_0                (0*0x4000u) /* Capture mode: 0 - disabled */
#define CM_1                (1*0x4000u) /* Capture mode: 1 - pos. edge */
#define CM_2                (2*0x4000u) /* Capture mode: 1 - neg. edge */
#define CM_3                (3*0x4000u) /* Capture mode: 1 - both edges */
这是IAR的一段定义,对CM0和CM1寄存器的赋值有四个,如上所示
对应下面四种状态
CMx Bit
15-14
Capture mode
00 No capture
01 Capture on rising edge
10 Capture on falling edge
11 Capture on both rising and falling edges
这样解释你看能理解
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(中级)

7
 

回复 6楼 wstt 的帖子

了解,多谢
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表