MSP430单片机的框架程序

发布者:buzzedy最新更新时间:2015-02-03 来源: laogu关键字:MSP430  单片机  框架程序 手机看文章 扫描二维码
随时随地手机看文章

MSP430单片机的框架程序(转)下面给出MSP430的程序框架,我们可以在此基础上修改以及添加自己所需的程序。

/*****************************************************************************\
文件名:main.c
描述:MSP430框架程序。适用于MSP430F149,其他型号需要适当改变。
      不使用的中断函数保留或者删除都可以,但保留时应确保不要打开不需要的中断。
      保留中断函数,编译器将会为BSL密码填充所有的字节。
版本:1.0 2005-1-13
\*****************************************************************************/

//头文件
#include

//函数声明
void InitSys();


int main( void )
{

  WDTCTL = WDTPW + WDTHOLD;              //关闭看门狗

  InitSys();     //初始化

start:
  //以下填充用户代码


 LPM3;   //进入低功耗模式n,n:0~4。若不希望进入低功耗模式,屏蔽本句
 goto start;

}

/*****************************************************************************
系统初始化
******************************************************************************/
void InitSys()
{
   unsigned int iq0;

 //使用XT2振荡器
   BCSCTL1&=~XT2OFF;          //打开XT2振荡器
   do
   {
   IFG1 &= ~OFIFG;     // 清除振荡器失效标志
   for (iq0 = 0xFF; iq0 > 0; iq0--);  // 延时,等待XT2起振
  }
  while ((IFG1 & OFIFG) != 0);    // 判断XT2是否起振

  BCSCTL2 =SELM_2+SELS;     //选择MCLK、SMCLK为XT2

 //以下填充用户代码,对各种模块、中断、外围设备等进行初始化

   _EINT(); //打开全局中断控制,若不需要打开,可以屏蔽本句
}

/*****************************************************************************
端口2中断函数
******************************************************************************/
#pragma vector=PORT2_VECTOR
__interrupt void Port2()
{
 //以下为参考处理程序,不使用的端口应当删除其对于中断源的判断。
 if((P2IFG&BIT0) == BIT0)
 {
  //处理P2IN.0中断
  P2IFG &= ~BIT0; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT1) ==BIT1)
 {
  //处理P2IN.1中断
  P2IFG &= ~BIT1; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT2) ==BIT2)
 {
  //处理P2IN.2中断
  P2IFG &= ~BIT2; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT3) ==BIT3)
 {
  //处理P2IN.3中断
  P2IFG &= ~BIT3; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT4) ==BIT4)
 {
  //处理P2IN.4中断
  P2IFG &= ~BIT4; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT5) ==BIT5)
 {
  //处理P2IN.5中断
  P2IFG &= ~BIT5; //清除中断标志
  //以下填充用户代码

 }
 else if((P2IFG&BIT6) ==BIT6)
 {
  //处理P2IN.6中断
  P2IFG &= ~BIT6; //清除中断标志
  //以下填充用户代码

 }
 else
 {
  //处理P2IN.7中断
  P2IFG &= ~BIT7; //清除中断标志
  //以下填充用户代码

 }

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
USART1发送中断函数
******************************************************************************/
#pragma vector=USART1TX_VECTOR
__interrupt void Usart1Tx()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
USART1接收中断函数
******************************************************************************/
#pragma vector=USART1RX_VECTOR
__interrupt void Ustra1Rx()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
端口1中断函数
多中断中断源:P1IFG.0~P1IFG7
进入中断后应首先判断中断源,退出中断前应清除中断标志,否则将再次引发中断
******************************************************************************/
#pragma vector=PORT1_VECTOR
__interrupt void Port1()
{
 //以下为参考处理程序,不使用的端口应当删除其对于中断源的判断。
 if((P1IFG&BIT0) == BIT0)
 {
  //处理P1IN.0中断
  P1IFG &= ~BIT0; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT1) ==BIT1)
 {
  //处理P1IN.1中断
  P1IFG &= ~BIT1; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT2) ==BIT2)
 {
  //处理P1IN.2中断
  P1IFG &= ~BIT2; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT3) ==BIT3)
 {
  //处理P1IN.3中断
  P1IFG &= ~BIT3; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT4) ==BIT4)
 {
  //处理P1IN.4中断
  P1IFG &= ~BIT4; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT5) ==BIT5)
 {
  //处理P1IN.5中断
  P1IFG &= ~BIT5; //清除中断标志
  //以下填充用户代码

 }
 else if((P1IFG&BIT6) ==BIT6)
 {
  //处理P1IN.6中断
  P1IFG &= ~BIT6; //清除中断标志
  //以下填充用户代码

 }
 else
 {
  //处理P1IN.7中断
  P1IFG &= ~BIT7; //清除中断标志
  //以下填充用户代码

 }

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
定时器A中断函数
多中断中断源:CC1~2 TA
******************************************************************************/
#pragma vector=TIMERA1_VECTOR
__interrupt void TimerA1()
{
 //以下为参考处理程序,不使用的中断源应当删除
 switch (__even_in_range(TAIV, 10))
 {
  case 2:
   //捕获/比较1中断
   //以下填充用户代码

  break;
  case 4:
   //捕获/比较2中断
   //以下填充用户代码

  break;
  case 10:
   //TAIFG定时器溢出中断
   //以下填充用户代码

  break;
 }


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
定时器A中断函数
中断源:CC0
******************************************************************************/
#pragma vector=TIMERA0_VECTOR
__interrupt void TimerA0()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
AD转换器中断函数
多中断源:摸拟0~7、VeREF+、VREF-/VeREF-、(AVcc-AVss)/2
没有处理ADC12TOV和ADC12OV中断标志
******************************************************************************/
#pragma vector=ADC_VECTOR
__interrupt void Adc()
{
 //以下为参考处理程序,不使用的中断源应当删除
 if((ADC12IFG&BIT0)==BIT0)
 {
  //通道0
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT1)==BIT1)
 {
  //通道1
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT2)==BIT2)
 {
  //通道2
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT3)==BIT3)
 {
  //通道3
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT4)==BIT4)
 {
  //通道4
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT5)==BIT5)
 {
  //通道5
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT6)==BIT6)
 {
  //通道6
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT7)==BIT7)
 {
  //通道7
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT8)==BIT8)
 {
  //VeREF+
  //以下填充用户代码

 }
 else if((ADC12IFG&BIT9)==BIT9)
 {
  //VREF-/VeREF-
  //以下填充用户代码

 }
 else if((ADC12IFG&BITA)==BITA)
 {
  //温度
  //以下填充用户代码

 }
 else if((ADC12IFG&BITB)==BITB)
 {
  //(AVcc-AVss)/2
  //以下填充用户代码

 }

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
USART0发送中断函数
******************************************************************************/
#pragma vector=USART0TX_VECTOR
__interrupt void Usart0Tx()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
USART0接收中断函数
******************************************************************************/
#pragma vector=USART0RX_VECTOR
__interrupt void Usart0Rx()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
看门狗定时器中断函数
******************************************************************************/
#pragma vector=WDT_VECTOR
__interrupt void WatchDog()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
比较器A中断函数
******************************************************************************/
#pragma vector=COMPARATORA_VECTOR
__interrupt void ComparatorA()
{
 //以下填充用户代码


 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
定时器B中断函数
多中断源:CC1~6 TB
******************************************************************************/
#pragma vector=TIMERB1_VECTOR
__interrupt void TimerB1()
{
 //以下为参考处理程序,不使用的中断源应当删除
 switch (__even_in_range(TBIV, 14))
 {
  case 2:
   //捕获/比较1中断
   //以下填充用户代码

  break;
  case 4:
   //捕获/比较2中断
   //以下填充用户代码

  break;
  case 6:
   //捕获/比较3中断
   //以下填充用户代码

  break;
  case 8:
   //捕获/比较4中断
   //以下填充用户代码

  break;
  case 10:
   //捕获/比较5中断
   //以下填充用户代码

  break;
  case 12:
   //捕获/比较6中断
   //以下填充用户代码

  break;
  case 14:
   //TBIFG定时器溢出中断
   //以下填充用户代码

  break;
 }

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
定时器B中断函数
中断源:CC0
******************************************************************************/
#pragma vector=TIMERB0_VECTOR
__interrupt void TimerB0()
{
 //以下填充用户代码

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
不可屏蔽中断函数
******************************************************************************/
#pragma vector=NMI_VECTOR
__interrupt void Nmi()
{
 //以下为参考处理程序,不使用的中断源应当删除
 if((IFG1&OFIFG)==OFIFG)
 {
  //振荡器失效
  IFG1 &= ~OFIFG;
  //以下填充用户代码

 }
 else if((IFG1&NMIIFG)==NMIIFG)
 {
  //RST/NMI不可屏蔽中断
  IFG1 &= ~NMIIFG;
  //以下填充用户代码

 }
 else //if((FCTL3&ACCVIFG)==ACCVIFG)
 {
  //存储器非法访问
  FCTL3 &= ~ACCVIFG;
  //以下填充用户代码

 }

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

/*****************************************************************************
基本定时器中断函数
******************************************************************************/
#pragma vector=BASICTIMER_VECTOR
__interrupt void BasTimer()
{
 //以下填充用户代码

 LPM3_EXIT; //退出中断后退出低功耗模式。若退出中断后要保留低功耗模式,将本句屏蔽
}

关键字:MSP430  单片机  框架程序 引用地址:MSP430单片机的框架程序

上一篇:一种查表程序
下一篇:浮点度数转换成浮点弧度数

推荐阅读最新更新时间:2024-03-16 13:52

关于MSP430仿真器的选择
可以下载MSP430程序的有并口JTAG仿真器、USB接口JTAG仿真器、BSL下载器等。 1. 并口仿真器价格低廉,能够在线仿真调试程序,能够支持全系列MSP430芯片,只是需要您的电脑有一个并口。如果没有并口,台式机可以购买一个PCI转并口卡,笔记本可以根据自己本本的接口买一个相应的并口扩展卡(一般是EXPRESS转并口卡)。 2. USB仿真器价格高昂,能够在线仿真调试程序,不一定支持全系列MSP430芯片(根据仿制者水平的不同),接口简单,只需要一个USB口。 3 .BSL下载器价格低廉,不通过编译软件直接使用下载软件下载程序到单片机FLASH中,不能在线仿真调试程序,是后期对大批量产品下载已调试好的
[单片机]
如何学习单片机单片机c语言编程入门教程
我当初是自学单片机的,也用同样的方法带出过月入15K以上的徒弟。 我的方法不能说是最好的,但绝对是靠谱的,毕竟都是曾经自己趟过的路。 如果你还在纠结你的学历,纠结英语数学不好能不能学会的问题。 今天我就给你吃的定心丸,别的行业不敢说,单片机:稳! 学历,以及数学英语是决定你的天花板有多高,而不是门槛。 Ok,下面 干货开始 。 一、如何学习单片机? 看了很多帖子,单片机要学的东西很多,既要懂硬件又要会编程之类的话。 把很多人都吓尿在门外,其实这句话只对了一半。 单片机确实是要懂硬件和编程,但很多人忽略了 学习的深度的问题 。 我拿当初自学java来举例吧,光是java se就学了我1个多月,学完以后才发现只是入了门,接下
[单片机]
基于凌阳8位通用型工控单片机的CAN总线智能节点的设计
1 CAN总线概述 CAN, 全称为“Controller Area Network”,是国际上应用最广泛的现场总线之一。20世纪80年代初,德国Bosch公司为了解决现代汽车中众多的控制与测试仪表之间的数据交换问题,开发出 CAN总线。CAN总线能有效支持分布式控制或实时控制的串行通信网络,具有抗干扰性强和使用可靠等优点,最初主要应用汽车工业,现在广泛应用于汽车工业、航空工业和工业控制等自动化领域,如分布式环境监测系统、温室环境监控系统、变电站变监测系统等。 CAN总线是一种串行数据通信协议,其通信接口中集成了CAN协议的物理层和数据链路层功能,可完成对数据的成帧处理,用户可在其基础上开发适应系统实际需要的应用层
[单片机]
基于凌阳8位通用型工控<font color='red'>单片机</font>的CAN总线智能节点的设计
采用AT89C2051的数字可调稳压电源单片机程序
ORG 0000H ;定位 LJMP MAIN ;跳转到MAIN主程序 ; ORG 0003H ;定位 LJMP IT_0 ;转入INT0的中断服务程序 ; ORG 000BH ;定位 LJMP IT_1 ;转入INT0的中断服务程序 ; ORG 0100H ;定位 MAIN: MOV R6,#32H ;将50送R6 ANL P3,#4FH ;将P3.4、P3.5、P3.7置为0,使输出电压为0.0V MOV P1,#0FFH ;将0FFH送P1 SETB P3.0 ;将P3.0置1 CLR P3.1 ;将P3.1置0 MOV R2,#0CH ;将0CH送R2 LCALL DELAY ;调用DELAY延时子程序 SETB P3.1
[单片机]
使用单片机STM8S 驱动 CT1642
/*定义LED 数码管的位数,本驱动只实现3位和4位的操作,所以LED_BIT_COUNT的值只能是3或4*/ #define LED_BIT_COUNT 4 /****************************************************************************************************** ***************** * 按键值定义 *********************************************************
[单片机]
ARM内核应用不断增长 MCU架构多元化才利于产业发展
由于这几年ARM的Cortex M系列内核的成功推广,各主要MCU厂商都推出了ARM核心的MCU产品,甚至有厂商只推基于通用ARM内核的处理器。面对内核趋同,如何开发出独特的不会被替代的MCU变得越来越重要。有的厂商选择自家开发MCU内核增强竞争力与差异化,与ARM生态抗衡;有的则基于ARM授权,在此基础上完善外部接口电路、丰富资源。如何保持自家MCU产品亮点与特色,将是未来MCU厂商竞争的关键。 ARM内核应用不断增长 采用ARM公司处理器内核的MCU增势不减。飞思卡尔、TI、ST、英飞凌等半导体厂商纷纷致力于推出ARM内核MCU。根据ARM中国嵌入式市场经理耿立峰的介绍,ARM在全球已经累计卖出了大约160个Cor
[单片机]
单片机AT89C51制作一个8路流水灯
ORG 0000H START:MOV P1,#01111111B;最下面的LED点亮 LCALL DELAY ;延时1秒 MOV P1,#10111111B ;最下面第二个的LED点亮 LCALL DELAY ;延时1秒 MOV P1,#11011111B ;最下面第三个的LED点亮 (以下省略) LCALL DELAY MOV P1,#11101111B LCALL DELAY MOV P1,#11110111B LCALL DELAY MOV P1,#11111011B LCALL DELAY MOV P1,#11111101B LCALL DELAY MOV P1,#11111110B LCALL DELAY MOV
[单片机]
AD574与8031单片机及前置电路的一种实用接口电路
  AD574是美国核拟器件公司Analog Devices) 生产的12 位逐次逼近型快速A/D 转换器。其转换35us,转换误差为土0.05%,是前我国应用广泛,价格适中的A/D转换器。其内部含三态电路,可直接与各种微处理器连接,且无须附加逻辑接口电路,便能与CMOS 及TTL 电平兼容。内部配置的高精度参考电压源和时钟电路,使它不需要任何外部电路和时钟信号,就能实现A/D转换功能,应用非常方便。   许多文献有关于AD574与8031单片机接口技术的介绍, 但其控制功能引线基本局限于单一的AD574与8031的连接。由于8031无内部程序存贮器, 其内部数据存贮器也有限, 因而8031构成的测控系统, 往往都需外扩存贮器
[单片机]
AD574与8031<font color='red'>单片机</font>及前置电路的一种实用接口电路
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved