完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
电子发烧友论坛|
430外部中断控制定时器的开启与关闭为什么不行?按完按键后要么常亮,要么长灭,再按不起作用
#include #include "Config.h" //开发板配置头文件,主要配置IO端口信息 uchar Flag=0; //标志位 uchar time=0; //时间计数变量 //*********************************************************************** // TIMERA初始化,设置为UP模式计数 //*********************************************************************** void TIMERA_Init(void) //连续计数模式,计数到0XFFFF产生中断 { TACTL |= TASSEL1 + TACLR + ID0 + ID1 + MC1 + TAIE; //SMCLK做时钟源,8分频,连续计数模式,计数到0XFFFF,开中断 } //*********************************************************************** // TIMERA中断服务程序,需要判断中断类型 //*********************************************************************** #pragma vector = TIMERA1_VECTOR __interrupt void Timer_A(void) { switch(TAIV) //需要判断中断的类型 { case 2:break; case 4:break; case 10:Flag=1;break; //设置标志位Flag } } //************************************************************************* // 初始化IO口子程序 //************************************************************************* void Port_init() { P1SEL = 0x00; //P1普通IO功能 P1DIR = 0xF0; //P10~P13输入模式,外部电路已接上拉电阻 P1IE = 0x0F; //开启P1低四位中断 P1IES = 0x0F; //下降沿触发中断 P1IFG = 0x00; //软件清零中断标志寄存器 LED8DIR = 0xFF; //P6口输出模式 LED8 = 0xFF; //先关闭所有LED } //********************************************************************** // P1口中断服务程序,需要判断 //********************************************************************** #pragma vector = PORT1_VECTOR __interrupt void P1_IRQ(void) { switch(P1IFG&0x0F) { case 0x01: TACTL |=MC0; P1IFG=0x00;break; // 引脚0对应S1中断,必须手动清标志位,点亮D1D2 case 0x02: TACTL |=MC0; P1IFG=0x00;break; // 引脚1对应S2中断,必须手动清标志位,点亮D3D4 case 0x04: TACTL |= TASSEL1 + TACLR + ID0 + ID1 + MC1 + TAIE; P1IFG=0x00;break; // 引脚2对应S3中断,必须手动清标志位,点亮D5D6 case 0x08: TACTL |= TASSEL1 + TACLR + ID0 + ID1 + MC1 + TAIE; P1IFG=0x00;break; // 引脚3对应S4中断,必须手动清标志位,点亮D7D8 } } //************************************************************************* // 主函数 //************************************************************************* void main(void) { WDT_Init(); //看门狗设置 Clock_Init(); //系统时钟设置 Port_init(); //端口初始化 TIMERA_Init(); //设置TIMERA _EINT(); while(1) { while(Flag) //判断Flag标志位循环 { Flag = 0; Time++; if(Time==1) //每中断一次对P61取反一次 { P6OUT = ~(P6OUT&BIT1); //P61取反闪烁 Time=0; } } } } |
|
相关推荐 |
|
只有小组成员才能发言,加入小组>>
549 浏览 0 评论
1613 浏览 0 评论
2047 浏览 0 评论
为啥BQ7693003DBTR芯片在和BQ769X0盒子通讯时收不到信号?
1513 浏览 0 评论
DSP 28027F 开发板 XDS100v2调试探针诊断日志显示了 Error -150 (SC_ERR_FTDI_FAIL)如何解决
1337 浏览 0 评论
AT32F407在USART2 DMA发送数据时,接包接到了要发送的数据,程序还是处于等待传输完成的标识判断中,为什么?
1757浏览 29评论
2781浏览 23评论
请问下tpa3220实际测试引脚功能和官方资料不符,哪位大佬可以帮忙解答下
1724浏览 20评论
请教下关于TAS5825PEVM评估模块原理图中不太明白的地方,寻求答疑
1634浏览 14评论
两个TMP117传感器一个可以正常读取温度值,一个读取的值一直是0,为什么?
1645浏览 13评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 06:54 , Processed in 0.586372 second(s), Total 72, Slave 54 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
4306