专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
TI
我想用msp430f5529做一个按键中断程序,就是通过按键P2.1取控制两个ledP1.0和P4.7轮流点亮,但运行进入不了中断
2019-07-15 15:38
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
TI MCU
5781
8
1222
/*
* dcomain.c
*
* Created on: 2015-7-25
* Author: feng
ti
anxu
*/
#include "MSP430f5529.h"
void P2_IODect();
void P21_Onclick();
void GPIO_Init();
void main(void)
{
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
8条回答
jkljkl5411490
2019-07-16 15:40
给你个例子参考下:
通过配置P1.1口按键为下降沿触发中断 ,进入中断后改变LED2的状态,然后进入Timer0中断,改变LED1的状态。
#include <msp430.h>
void delay(unsigned int i)
{
volatile unsigned int j;
for(;i>0;i--)
for(j=0;j<2000;j++); // 延时
}
int main(void)
{
volatile unsigned int i ;
WDTCTL = WDTPW+WDTHOLD; // 关闭看门狗
P1DIR |= BIT0; // P1.0 输出
P4DIR |= BIT7; // P4.7 输出
P1DIR &=~BIT1; //设置P1.1为输入
P1OUT |= BIT1; //上拉,有时候不上拉可以,有时候不可以,所以最好上拉
P1REN |= BIT1; //设为输入时必须加上此寄存器配置
P1IE |= BIT1; //打开P1.1口中断
P1IES &=~BIT1; //触发方式为下降沿
P1IFG &=~BIT1; //清中断标志位
__enable_interrupt();
while(1);
//__bis_SR_register(LPM0_bits+GIE); // 进入低功耗模式0,使能中断
}
#pragma vector=TIMER0_A0_VECTOR
__interrupt void TIMER0_A0_ISR(void)
{
P1OUT ^= BIT0; // 反转 P1.0状态
delay(20);
TA0CCTL0 = ~(CCIE);
}
#pragma vector = PORT1_VECTOR
__interrupt void Port1(void)
{
P4OUT ^= BIT7; //P4.7为输出取反
P1IFG &=~BIT1; //清中断标志位
delay(200);
TA0CCTL0 = CCIE; // CCR0中断使能
TA0CCR0 = 50000;
TA0CTL = TASSEL_2 + MC_1 +TACLR; // SMCLK,增计数模式,清除TAR
}
加载中...
查看其它8个回答
一周热门
更多
>
相关问题
CPLD的方波输出
4 个回答
11个版本Quartus II 软件下载,安装包网盘合集,附教程,47G!
20 个回答
请大家帮忙到21IC发展大家谈支持我申请新版面
20 个回答
【通知】21ic中国电子网服务条款 (所有人员必读)
1 个回答
满载而归乙亥年,大展鸿途庚子年---集签赢好礼
20 个回答
相关文章
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
TI
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
通过配置P1.1口按键为下降沿触发中断 ,进入中断后改变LED2的状态,然后进入Timer0中断,改变LED1的状态。
#include <msp430.h>
void delay(unsigned int i)
{
volatile unsigned int j;
for(;i>0;i--)
for(j=0;j<2000;j++); // 延时
}
int main(void)
{
volatile unsigned int i ;
WDTCTL = WDTPW+WDTHOLD; // 关闭看门狗
P1DIR |= BIT0; // P1.0 输出
P4DIR |= BIT7; // P4.7 输出
P1DIR &=~BIT1; //设置P1.1为输入
P1OUT |= BIT1; //上拉,有时候不上拉可以,有时候不可以,所以最好上拉
P1REN |= BIT1; //设为输入时必须加上此寄存器配置
P1IE |= BIT1; //打开P1.1口中断
P1IES &=~BIT1; //触发方式为下降沿
P1IFG &=~BIT1; //清中断标志位
__enable_interrupt();
while(1);
//__bis_SR_register(LPM0_bits+GIE); // 进入低功耗模式0,使能中断
}
#pragma vector=TIMER0_A0_VECTOR
__interrupt void TIMER0_A0_ISR(void)
{
P1OUT ^= BIT0; // 反转 P1.0状态
delay(20);
TA0CCTL0 = ~(CCIE);
}
#pragma vector = PORT1_VECTOR
__interrupt void Port1(void)
{
P4OUT ^= BIT7; //P4.7为输出取反
P1IFG &=~BIT1; //清中断标志位
delay(200);
TA0CCTL0 = CCIE; // CCR0中断使能
TA0CCR0 = 50000;
TA0CTL = TASSEL_2 + MC_1 +TACLR; // SMCLK,增计数模式,清除TAR
}
一周热门 更多>