2158|0

63

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

MSP430 F5529定时器A匹配中断如何准确设置 [复制链接]

在设置MSP430F5529定时器A时发现定时器的中断时间好像和预期的有点出入。情况如下:
1.在设置MCLK,SMCLK为2.097152M,实测2.097M,准确。
2.设置定时器输入时钟为SMCLK,分频系数为1,UP计数模式,定时器匹配值TA0CCR0=99。使能中断,中断每次取反P8.1引脚。
3.按照如上设置,理论信号应该为2.097152/(99+1)/2=10.48576K。P8.1产生的信号实测为10.49K。基本准确。
4.当我把定时器匹配值TA0CCR0=99改成TA0CCR0=9时,问题出来了。此时P8.1产生的信号实测为80.75K,和我理论计算的2.097152/(9+1)/2=104.8576K差了快20%,请问各位是哪里设置出问题了????
下面是程序:

#include "io430.h"
#include "Timer_A.h"
void InitCLK(void);
void InitTimerA(void);
int main( void )
{
  // Stop watchdog timer to prevent time out reset
  WDTCTL = WDTPW + WDTHOLD;
  
  P2SEL |= BIT2;//SMCLK  
  P2DIR |= BIT2;//SMCLK
  P8DIR |= BIT1;  
  P8OUT |= BIT1;
  P7SEL |= BIT7;//MCLK  
  P7DIR |= BIT7;//MCLK
  InitCLK();
  InitTimerA();
  __bis_SR_register(GIE);
  while(1)
  {
  }
  return 0;
}
#pragma vector=TIMER0_A0_VECTOR
__interrupt
void TIMER0_A0_IRQ(void)
{
  P8OUT ^= BIT1;
}
void InitCLK(void)
{

  UCSCTL4&=~(SELM_7);//DCOCLK连接到MCLK
  UCSCTL4|=(SELM_3);//DCOCLK连接到MCLK
  
  UCSCTL4&=~(SELS_7);//DCOCLK连接到SMCLK
  UCSCTL4|=(SELS_3);//DCOCLK连接到SMCLK
}
void InitTimerA(void)
{
  TA0CCTL0 |= CCIE;//0x0010;         //比较中断使能
  TA0CCR0 = 9;
  TA0CTL = TASSEL_2 + MC_1 + TACLR;         // SMCLK, upmode, clear TAR
}
 
点赞 关注

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条
【TI有奖直播报名中】
直播主题:MSPM0 系列 MCU 再添新成员:高性能与高性价比的优秀组合 MSPM0G351x / MSPM0L111x
直播时间:4月24日(周四)上午10:00
直播奖励:好礼等您拿!

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

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

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

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

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