//本平台 msp430f149
#include
void select_xt2(void){
unsigned char i;
/*------选择系统主时钟为8MHz-------*/
BCSCTL1 &= ~XT2OFF; //打开XT2高频晶体振荡噿
do{
IFG1 &= ~OFIFG; //清除晶振失败标志
for (i = 0xFF; i > 0; i--); //等待8MHz晶体起振
}while ((IFG1 & OFIFG)); //晶振失效标志仍然存在_
BCSCTL2 |= SELM_2 + SELS; //MCLK和SMCLK选择高频晶振
}
void main(){
WDTCTL = WDTPW + WDTHOLD;
select_xt2();
P2DIR = 0x80;
P2OUT = 0xff
CCTL1 = CCIE; // CCR1 中断使能
CCR1 = 10000;
TACTL = TASSEL_2 + MC_2 + ID_3; // SMCLK = 1MHz, 连续计数模式
_EINT(); //打开全局中断
while(1){
if(count == 50){
count = 0;
P2OUT ^= BIT7; //led灯每0.5s变化一次
}
}
}
#pragma vector=TIMERA1_VECTOR
__interrupt void Timer_A1(void)
{
CCR1 += 10000; //
count ++;
}
昨天写了一段这样的代码,本想用定时器a 每0.5s控制led灯状态,发现程序运行不符合预期效果,仔细检验发现根本就没有进中断,count 值不变。先贴上可用的代码,再仔细分析
修改后的中断处理函数:
#pragma vector=TIMERA1_VECTOR
__interrupt void Timer_A1(void)
{
switch(TAIV){
case 2:
CCR1 += 10000; //
count ++;
}
}
这两个中断处理函数区别在修改后的多用了switch语句,里面还有TAIV,也就是中断向量值
仔细阅读数据手册,发现TAIFG的中断入口地址是TIMERA1_VECTOR,同时也是TACCR1和//TACCTR2的CCIFG的入口地址。TACCRO单独使用TIMERA0_VECTOR。从官方给出的代码,使用TACCR1事中断函数里面也有switch语句,结合上面这个图,分析中断处理代码,执行
switch(TAIV)
不难发现,TAIV是与CCIFG所在的向量值匹配,也就是查询中断向量,提供一个入口地址,
执行后case语句的代码,现在可以理解未修改之前中断处理函数count值为改变的原因。
以上都是本人结合官方的源码和数据手册做出的分析,如有出入的地方,欢迎指正!
上一篇:msp430学习笔记之定时器A
下一篇:MSP430G2553时钟系统配置
推荐阅读最新更新时间:2024-03-16 16:08
设计资源 培训 开发板 精华推荐
- PC产业驶入创新超车道,英特尔蓉城撬动AI新引擎
- 与产业聚力共赢,英特尔举行新质生产力技术生态大会
- “新”享5G-A万兆网络前沿体验 高通携手产业伙伴亮相第二届链博会
- 英飞凌推出符合ASIL-D标准的新型汽车制动系统和电动助力转向系统三相栅极驱动器 IC
- 南芯科技推出80V升降压转换器,持续深耕工业储能市场
- 法雷奥与罗姆联合开发新一代功率电子领域
- 贸泽电子开售能为电动汽车牵引逆变器提供可扩展性能的 英飞凌HybridPACK Drive G2模块
- 德州仪器新型 MCU 可实现边缘 AI 和先进的实时控制, 提高系统效率、安全性和可持续性
- 瑞萨推出高性能四核应用处理器, 增强工业以太网与多轴电机控制解决方案阵容
- 研华全新模块化电脑SOM-6833助力5G路测设备升级