This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

MSP430F149捕获不到信号

Other Parts Discussed in Thread: MSP430F149, LM393

通过一个LM393比较器产生一个脉冲信号给MSP430F149的P1.2管脚,发现进入不了中断。

在P1.2管脚处能测到脉冲信号,且上升沿,下降沿都很好。

另外::我看原理图上晶振8M的管脚处接着两个30p的电容,我的电路上接的是两个33p的电容,不知道这个有没有影响?

又测试了单片机,在P1.2管脚处,通过软件置高电平,低电平都可以。说明单片机和P1.2管脚都是可行的。另外JTAG也是可以联通单片机的,可以烧写。

硬件应该没有问题。但是在中断程序中设置断点的时候,怎么也进不了中断。不知道为什么,非常着急,非常着急。谢谢解答!困惑!!!

程序应该是对的。如下:

#include <msp430x14x.h>

unsigned int start,end;
unsigned char overflow;

void main (void)
{
WDTCTL = WDTPW+WDTHOLD; //关闭看门狗定时器

P1SEL = BIT2; //设置P1.2端口为功能模块使用
TACTL = TASSEL0+TACLR+TAIE+MC1; //定时器A时钟信号选择ACLK,同时设置定时器A计数模式为连续增计模式
CCTL1 = MC0+SCS+CAP+CCIE; //输入上升沿捕获,CCI0A为捕获信号源

_EINT(); //中断允许
while(1); //LOOP
}

#pragma vector=TIMERA1_VECTOR //定时器A中断处理
__interrupt void timer_a(void)
{
switch(TAIV) //向量查询
{ case 2: //捕获中断
if(CCTL1&CM0) //上升沿
{
CCTL1=(CCTL1&(~CM0))|CM1; //更变设置为下降沿触发
start=CCR1; //记录初始时间
overflow=0; //溢出计数变量复位
}
else if (CCTL1&CM1) //下降沿
{
CCTL1=(CCTL1&(~CM1))|CM0; //更变设置为上升沿触发
end=CCR1; //用start,end,overflow计算脉冲宽度
}
break;
case 10: //定时器溢出中断
overflow++;
break; //溢出计数加1
default:break;
}
}

  • 首先,没有看到你的端口中断服务程序,只是看到你的定时器,初始化仅这一句够呛,一般端口要初始化功能,方向,初始值。再好好配置下中断设置。

    其次,电容大小一般是18p,你30p也没关系,430的一般是14p~33p都可以的

  • 谢谢解答!

    里面有中断程序啊,关键现在是进不了中断。我的另一个程序是这样如下,也不行:

    void main (void)
    {

    WDTCTL = WDTPW+WDTHOLD; //关闭看门狗定时器
    set_sysclk(); //开启MCLK:8M;SMCLK:1M;

    // P1DIR = 0XFF;P1OUT = 0XFF;// 不用的管脚设成输出高电平,减小漏电流
    P2DIR = 0XFF;P2OUT = 0XFF;
    P3DIR = 0XFF;P3OUT = 0XFF;
    P4DIR = 0XFF;P4OUT = 0XFF;
    P5DIR = 0XFF;P5OUT = 0XFF;
    P6DIR = 0XFF;P6OUT = 0XFF;
    P1DIR=0X00; //设置P1.2方向为输入
    P1SEL |= BIT2; //设置P4.2端口为功能模块使用
    // P1SEL |= BIT2; //设置P1.2端口为功能模块使用

    TACTL = TASSEL_2+TACLR+TAIE+MC1; //定时器A时钟信号选择SMCLK,同时设置定时器A计数模式为连续增计模式
    CCTL1 = CM1+SCS+CAP+CCIE; //输入下降沿捕获,CCI1A为捕获信号源
    _EINT(); //中断允许

    while(1); //LOOP
    }

    #pragma vector=TIMERA1_VECTOR //定时器A中断处理
    __interrupt void timer_a(void)
    {
    counter++;
    switch(TAIV) //向量查询
    {
    case 2: //捕获中断
    {
    if(CCTL1&CM0) //上升沿
    {
    CCTL1=(CCTL1&(~CM0))|CM1; //更变设置为下降沿触发
    end=CCR1;//记录初始时间
    }
    else if (CCTL1&CM1) //下降沿
    {
    CCTL1=(CCTL1&(~CM1))|CM0; //更变设置为上升沿触发
    start=CCR1; //用start,end计算脉冲宽度
    }
    }
    break;
    case 10: //定时器溢出中断
    break; //溢出计数加1
    default:break;
    }
    }

  • 你好!

    调试的时候有去读CCTL1的CCI位吗?

    看MCU是否检测到触发信号

  • 一样的程序,一样的电路,前天没有搞好,昨天搞好了。奇怪!

  • 哈哈哈哈,恭喜,也说明你前几天肯定是马虎了