MSP430 定时器A的使用
msp430定时器a中文超级详解 (1)
文章转载自网络-----------------感谢原作者的辛勤奉献MSP430的定时器中有比较捕获比较模式:这是定时器的默认模式,当在比较模式下的时候,与捕获模式相关的硬件停止工作,如果这个时候开启定时器中断,然后设置定时器终值(将终值写入TACCRx),开启定时器,当TAR的值增到TACCRx的时候,中断标志位CCIFGx 置一,同时产生中断。
若中断允许未开启则只将中断标志位CCIFGx置一。
例子:比较模式就像51单片机一样,要能够软件设置定时间隔来产生中断处理一些事情,如键盘扫描,也可以结合信号输出产生时序脉冲发生器,PWM信号发生器。
如:不断装载TACCRx,启动定时器,TAR和TACCRx比较产生中断处理。
捕获模式:利用外部信号的上升沿、下降沿或上升下降沿触发来测量外部或内部事件,也可以由软件停止。
捕获源可以由CCISx选择CCIxA,CCIxB,GND,VCC。
完成捕获后相应的捕获标志位CCIFGx置一捕获模式的应用:利用捕获源的来触发捕获TAR的值,并将每次捕获的值都保存到TACCRx 中,可以随时读取TACCRx的值,TACCRx是个16位的寄存器,捕获模式用于事件的精确定位。
如测量时间、频率、速度等例子:利用两次捕获的值来测量脉冲的宽度。
或捕获选择任意沿,CCISx=”11“(输入选择VCC),这样即当VCC与GND发生切换时产生捕获条件结合利用:异步通讯同时应用比较模式和捕获模式来实现UART异步通信。
即利用定时器的比较模式来模拟通讯时序的波特率来发送数据,同时采用捕获模式来接收数据,并及时转换比较模式来选定调整通信的接受波特率,达到几首一个字节的目的----------------------------------------利用MSP430单片机定时器A和捕获/比较功能模块结合使用,实现脉冲宽度的测量。
本例程用到了定时器A的CCI1A端口(例如MSP430F14X的P1.2引脚)作捕获外部输入的脉冲电平跳变,同时结合简单的软件算法就能实现脉冲宽度的测量。
MSP430定时器A捕捉脉实例
MSP430定时器A捕捉脉实例[调试通过,很好用]微控论坛原创主贴作者:fangthMicrocontrol CODE/*****************************************************************//功能:利用定时器A的捕捉能测量脉冲信号的脉宽////// MSP430F449// -----------------// /|\| XIN|-// | | | 32kHz// --|RST XOUT|-// | |// | P1.5/ACLK|---+// | | |// | P2.0/TA2|<--+// | |// | |//说明:ACLK要进行8分频(4K),并将其作为外部的要捕获的脉冲;//MCLK=SMCLK=8M;*****************************************************************/#include <msp430x44x.h>int pwm_start,pwm_end,pwm_wide=0;void main(void){WDTCTL = WDTPW + WDTHOLD; // Stop WDTP1DIR = 0x20; // P1.5 输出P1SEL = 0x20; // P1.5输出ACLKP2SEL|=BIT0; //P2.0 CCI2ASCFI0 |= FN_4;SCFQCTL = 121; // (121+1) ×32768 *2= 7.99MhzFLL_CTL0=DCOPLUS+OSCCAP1; //MCLK=SMCLK=8MFLL_CTL1 |= FLL_DIV_8; //ACLK要进行8分频,ACLK=4KTACCTL2 =CAP+CM_3+CCIS_0+SCS+CCIE; //捕获模式,上升和下降都捕获,选择CCI2A,同步,捕获中断开//Capture input select: 0 - CCI2ATACTL = TASSEL_2 + MC_2 ; //SMCLK=8M,L连续计数模式_EINT(); //开总中断LPM0;_NOP();pwm_wide=pwm_end-pwm_start;while(1);}// Timer_A3 Interrupt Vector (TAIV) handler#pragma vector=TIMERA1_VECTOR__interrupt void Timer_A(void){switch(TAIV){case 2:break;case 4:if(TACCTL2 & CCI)pwm_start=CCR2;elsepwm_end=CCR2;//pwm_wide=pwm_end-pwm_start;break;case 10:break;}LPM0_EXIT;}检验方法:在调试环境下,在watch 窗口观察pwm_end和pwm_start,然后相减!我计算了一下。
Msp430定时器的介绍及其基本应用
Msp430定时器的介绍及其基本应用Msp430定时器的介绍及其基本应用Msp430单片机一共有5种类型的定时器。
看门狗定时器(WDT)、基本定时器(Basic Timer1)、8位定时器/计数器(8-bit Timer/Counter)、定时器A(Timer_A)和定时器B(Timer_B)。
但是这些模块不是所有msp430型号都具有的功能。
1、看门狗定时器(WDT)学过电子的人可能都知道,看门狗的主要功能就是当程序发生故障时能使受控系统重新启动。
msp430中它是一个16位的定时器,有看门狗和定时器两种模式。
2、基本定时器(Basic Timer1)基本定时器是msp430x3xx和msp430F4xx系列器件中的模块,通常向其他外围提供低频控制信号。
它可以只两个8位定时器,也可以是一个16位定时器。
3、8位定时器/计数器(8-bit Timer/Counter)如其名字所示,它是8位的定时器,主要应用在支持串行通信或数据交换,脉冲计数或累加以及定时器使用。
4、16位定时器A和B定时器A在所有msp430系列单片机中都有,而定时器B在msp430f13x/14x和msp430f43x/44x等器件中出现,基本的结构和定时器A是相同的,由于本人最先熟悉并应用的是定时器A所以在这里就主要谈一下自己对定时器A的了解和应用。
定时器A是16位定时器,有4种工作模式,时钟源可选,一般都会有3个可配置输入端的比较/捕获寄存器,并且有8种输出模式。
通过8种输出模式很容易实现PWM波。
定时器A的硬件电路大致可分为2类功能模块:一:计数器TAR计数器TAR是主体,它是一个开启和关闭的定时器,如果开启它就是一直在循环计数,只会有一个溢出中断,也就是当计数由0xffff到0时会产生一个中断TAIFG。
二:比较/捕获寄存器CCRX如何实现定时功能呢?这就要靠三个比较/捕获寄存器了(以后用CCRx表示)。
当计数器TAR的计数值等于CCRx时(这就是捕获/比较中的比较的意思:比较TAR是否等于CCRx),CCRx单元会产生一个中断。
【MSP430入门例程】:Timer A
MSP430F1系列定时器A结构图[1]TimerA模块结构组成在MSP430F1XX-TimerA的结构中,分别由TA基础模块、CCR0、CCR1、CCR2子模块。
TA基础模块:[1]TA基础子模块主要完成定时器时钟源的输入(时钟源的选择、分频)。
[2]TA定时器计数。
[3]定时器的工作模式设置。
CCR0、CCR1、CCR2子模块:CCRx全称为Capture Compare Register-捕获比较寄存器,这些子模块有着捕获和比较的功能。
捕获、比较信号的触发源可以从芯片的外部引脚、CPU的外围模块输入来。
同时CCRx子模块也有其输出信号OUT.x ,此OUT.x可以输出到芯片的外部引脚、或输入到CPU的外围模块中。
CCRx与TAR(Timer A Register - 简称:TAR )结合使可以实现特定的的功能。
常用TimerA可以实现功能:PWM信号输出功能:通过设置TA的工作模式,结合CCR0、CCR1或CCR2计数。
直从CCR0、CCR1或CCR2中子模块的OUT.x端输出。
Slope AD转换功能:利用定时器A与比较器A结合设计成斜边数模转换器。
实现软USART功能:利用CCR0子模块中的捕获输入功能,结合TAR实现通用串行异步通讯功能(USART)。
ADC12模块的采样信号:利用定时器的TAR或CCR0实现OUT.x输出得到ADC12模块所需要的采样触发信号。
其它应用...。
[2]TimerA 模块工作模式[TA工作模式]TA定时器的工作模式有4种,这4种模式由TACTL寄存器的MC1、MC0位控制:模式 MC1 MC0 功能说明停止0 0 TA为停止(上电状态)增计数0 1 TAR增计数至CCR0,然后回到0。
连续计数 1 0 TAR连续计数至FFFFH,然后回到0。
增/减计数 1 1 TAR增计数至CCR0,然后减计数至0。
[时钟输入]定时器A时钟源有4种选择,分别为外部时钟TACLK、辅助时钟ACLK、子系统时钟SMCLK及INCLK。
MSP430单片机定时器A结构及其应用范例
MSP430单片机定时器A结构及其应用范例MSP430单片机定时器A结构及其应用范例1-简介简介MSP430单片机定时器A结构及其应用范例。
2-定时器模块在MSP430系列单片机中带有功能强大的定时器资源,这定时器在单片机应用系统中起到重要的作用。
利用MSP430(以下称为430)单片机的定时器可以用来实现计时,延时,信号频率测量,信号触发检测,脉冲脉宽信号测量,PWM信号发生。
另外通过软件编写可以用作串口的波特率发生器。
后面我们将用定时器A作为一个波特率发生器,来编写一个串口例程给初学者参考。
以加强初学者对定时器A的理解和应用。
在430的大系列产品中,不同的子系列产品定时器资源有所不同;在F11X,F11X1中是不带定时器B资源的。
430的定时器主要分为3部分模块:看门狗定时器,定时器A,定时器B。
定时器A主要资源特点有16位定时计数器,其计数模式有4种。
多种计数时钟信号供选择。
3个可配置输入的捕获/比较功能寄存器和8种输出模式的3个可配置输出单片。
以上各块定时器资源可作多种组合使用,以实现强大的功能。
定时器资源功能说明(1)看门狗定时器(WDT):主要用于程序在生错误时用作单片机系统复位重起的。
另外,也可作为一个基本定时器使用。
(2)定时器A:作基本定时器使用,结合捕获/比较功能模块可实现时序控制,可编程波形信号发生输出。
可作串口波特率发生器使用。
(3)定时器B:作基本定时器使用,与定时器A基本相同,但是功能方面有某些功能会比A 增强些。
详情请看关于定时器B应用范例。
3-定时器A模块结构4-定时器A--基础应用例程(1)//例程描述:利用定时器定时功能,实现P1.0方波输出。
MSP430F149的定时器A操作
MSP430F149的定时器A定时操作1)定时器A的图解图1 定时器A图解2)定时器A的四种计数模式。
1.停止模式。
2.增计数模式。
(产生两个中断标志)也就是当计数到跟TACCR0一样的时候,就返回0,重新计数。
当计数到TACCR0的同时产生一个中断标志CCIFG,而当计数器溢出返回零的同时又同时产生一个中断标志TAIFG。
如图:图2 增计数模式的波形图3.连续计数模式。
(产生一个中断标志)也就是计数器将直接计数到计数器所能计数的最大值0FFFFH之后重新返回零,再次计数。
返回零的同时产生一个TAIFG中断标志。
如图:4.增减计数模式。
(产生两个中断标志)也就是当计数器计数到跟TACCR0一样的之后,然后从TACCR0开始又减少,直到为零,然后又开始增。
当计数跟TACCT0一样的时候产生一个中断标志CCIFG,当减到为零的时候又产生一个中断标志TAIFG。
如图:注意:当重新写入TACCR0数值的时候,当新的数据大于原来的数值的时候,计数器将计数到新的数值才重新返回零;当新的数据小于原来的数值的时候,计数器将直接返回零重新计数。
3)定时器A的寄存器。
1.TACTL●TASSELx:计时器A的时钟来源选择。
●IDx:计时器A时钟的分频选择。
●MCx:计时器A四种计数模式选择。
●TACLR:计数器A的TAR计数清零,同时也可以清楚时钟分频器和计数方向。
●TAIE:TAIFG中断标志使能。
在捕获模式下可以打开所有CCIFG的中断使能。
●TAIFG:中断标志位。
2.TAR计数器的计数寄存器。
3.TACCTLx●CMx:捕获模式选择。
00:关闭;01:上升沿捕获;10:下降沿捕获;11:上升下降沿捕获。
●CCISx:捕获引脚选择。
●SCS:选择捕获电平方式。
0异步时钟;1同步时钟。
●SCCI:锁存同步时钟输入端。
也就是锁存EQUx的值,以供CPU读取。
●CAP:捕获模式和比较模式选择。
0比较;1捕获。
●OUTMODx:输出模式选择。
msp430定时器AD模块以及其他笔记
定时器A用到CCR0定时器A的中断可由定时器溢出引起,也可由捕获/比较器模块产生。
每个捕获/比较模块可以独立编程,由捕获/比较外部信号产生中断。
定时器A使用两个中断向量,一个单独分配给捕获/比较寄存器CCR0;另一个作为共用中断向量用于定时器和其他的捕获/比较寄存器。
捕获/比较寄存器CCR0中断向量具有最高优先级,因为CCR0主要用来定义定时器的工作模式,而这是定时器A其他功能的基础,需要最快速的服务。
开启定时器应该在修改定时器工作频率之前。
CCR1,CCR2和定时器共用另一个中断向量,属于多源中断。
由向量中断寄存器TAIV决定由哪个中断标志来触发中断。
中断标志产生数据表:中断优先级中断源缩写 TAIV 的内容最高捕获/比较器1 CCIFG1 2捕获/比较器2 CCIFG2 4定时器溢出 TAIFG 10最低没有中断将挂起 0PxDIR输入/输出方向寄存器0:I/O引脚切换成输入模式 PxIN1:I/O引脚切换成输出模式 PxOUTPxIE中断使能寄存器0:禁止该中断 1:允许该中断PxIES中断触发沿选择寄存器如果允许Px口的某个引脚中断,还需要定义该引脚的中断触发沿。
0:上升沿使相应标志置位 1:下降沿使相应标志置位PxSEL功能选择寄存器0:选择引脚为I/O端口 1:选择引脚为外围模块功能上电复位信号:POR(power-on reset)上电清除复位信号:PUC(power-up clear)POR信号的产生总会产生PUC信号,但是PUC信号的发生不一定会产生POR信号。
脉冲宽度调制(PWM),是英文“Pulse Width Modulation”的缩写,简称脉宽调制,是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术,广泛应用在从测量、通信到功率控制与变换的许多领域中。
TACTL是最为主要的控制寄存器,它决定了TA的输入时钟信号、TA的工作模式、TA的开启与停止、中断的申请等工作。
MSP430 定时器A
上次Cloud和大家一起学习完了MSP430的时钟配置,这一篇,我们来学习MSP430单片机的TimerA (定时/计数器A)。
MSP430单片机的TimerA具有非常强大的功能,相关的寄存器配置也相当复杂,Cloud花了好久才逐步理清学习思路,尤其是学习数据手册的相关描述。
在这里Cloud提醒大家,虽然现在网上有中文汉化版的数据手册,但Cloud阅读英文原版后对比发现还是英文原版对器件特性描述得更加清楚,而中文汉化版的省略掉了一些内容。
好吧,扯远了。
下面进入正题:一、MSP430的Timer结构首先让我们通过官方描述来初步了解一下MSP430单片机的Timer资源:定时器A是一个16位的定时/计数器。
定时器A支持多重捕获/比较,PWM输出和内部定时。
定时器还有扩展中断功能,中断可以由定时器溢出产生或由捕获/比较寄存器产生。
定时器A的特性包括:??·四种运行模式的异步16位定时/计数器??·可选择配置的时钟源??·可配置的PWM输出??·异步输入和输出锁存??·对所有TA中断快速响应的中断向量寄存器MSP430G2553单片机共有两个TimerA,分别是Timer0A和Timer1A。
OK,零零总总说了这么多,大家一定带有很多的疑惑,比如什么叫“捕获/比较”等,这里Cloud 先不作解释,会用才是王道。
我们呢先找来定时器A的结构图给大家初步了解一下定时器A的结构:我们先从上面部分开始解释。
中间红色的是一个16位的TimerA,TAR,这其实就是MSP430单片机内部的一个定时计数器了,类似于51中的TH0和TL0的合体。
既然可以拿来计时,那么肯定可以有时钟信号输入,让我们最左边黄色的框,是一个选择器,由上面的TASSEL来选择TACLK、ACLK、SMCLK、INCLK的其中一种时钟。
上次我们已经学习过ACLK和SMCLK,也知道如何配置这两个时钟了(这也是为什么先学习时钟的原因),另外两个是外部时钟源,其中TACLK可以由P1.0输入。
MSP430 蜂鸣器例程 定时器A
//设置定时器A每10ms中断一次
CCTL0 = CCIE;
CCR0 = 10000;
TACTL |= TASSEL_2 + ID_3;
//设置控制蜂鸣器的IO方向为输出
Buzzer_DIR |= Buzzer;
//打开全局中断
_EINT();
//循环演奏歌曲
while(1)
{
Play_Song();
}
}
/*******************************************
函数名称:TimerA_ISR
功 能:定时器A的中断服务函数
返回值 :无
********************************************/
void Play_Song(void)
{
uchar Temp1,Temp2;
uchar addr = 0;
counter = 0; //中断计数器清0
{
for( j = 0;j < 3;j++ )
_NOP();
}
}
/*******************************************
函数名称:Play_Song
功 能:播放《祝你平安》的乐曲
参 数:无
#define uchar unsigned char
#define Buzzer BIT7
#define Buzzer_Port P2OUT //将P2.7作为beep输出
#define Buzzer_DIR P6DIR
uchar counter;
MSP430系列单片机定时器A
MSP430F5系列16位超低功耗单片机模块原理第12章Timer A 定时器A版本: 1.0日期: 2008.10.原文: TI slau208.pdf (5xxfamily User's Guide)翻译: 许俊超软件工程师郑州市编辑: DC 微控技术论坛版主注:以下文章是翻译TI slau208.pdf 文件中的部分内容。
由于我们翻译水平有限,有整理过程中难免有所不足或错误;所以以下内容只供参考.一切以原文为准。
文章更新详情请密切留意微控技术论坛。
第12章Timer A定时器A是一个复合了捕获/比较寄存器的十六位的定时/计数器。
本章介绍MSP430X5XX的定时器A。
章节12.1 定时器A介绍12.2 定时器A操作12.3 定时器A寄存器12.1 定时器A介绍定时器A是一个十六位的定时/计数器,其捕获/比较寄存器多达七个。
定时器A支持支持多重捕获/比较,PWM输出和内部定时。
定时器还有扩展中断功能,中断可以由定时器溢出产生或由捕获/比较寄存器产生。
定时器A的特性包括:○四种运行模式的异步16位定时/计数器○可选择配置的的时钟源○多达七个可配置的捕获/比较寄存器○可配置的PWM输出○异步输入和输出锁存○对所有TA中断快速响应的中断向量寄存器定时器A的结构图如图12-1图12-1 定时器A的结构图12.2TIMER_A 操作方法TIMERA模块由用户软件来配置,TIMERA的使用在下面的章节中讨论。
12.2.116位定时/计数器寄存器TAR,随着时钟信号的第个上升沿增/减(由模式所决定)。
TAR 可以由软件读写。
除此之外,定时器溢出时可以产生中断。
TAR可以通过设置TACLR位来清除。
在UP/DOWN模式下,设置TACLR也可以清除时钟分频器和计数方向。
注意:修改TIMERA寄存器建议在修改定时器运行模式前先停止定时器(中断使能、中断标志、TACLR例外),以避免产生求知的误操作。
当TACLK与CPU时钟不同步时,当定时器没有运行时TAR的读将产生,其结果也是不可预料的。
MSP430-定时器A的使用(含OUTMOD模式详解及运用)
MSP430-定时器A的使用(含OUTMOD模式详解及运用)第四讲第四讲第四讲第四讲定时器定时器定时器定时器A的使用的使用的使用的使用MSP430F413芯片中含有TimerA3模块,如图1-2所示。
其常用的外引线有三条:TACLK、TA1和TA2。
TACLK:定时器_A输入时钟(48脚),与P1.6和ACLK输出共用同一引脚。
TA1:定时器_A的第一通道输入、输出引脚(51脚)。
捕获方式:CCI1A 输入;比较方式:OUT1输出。
TA2:定时器_A的第二通道输入、输出引脚(45脚)。
捕获方式:CCI2A 输入;比较方式:OUT2输出。
1....定时器定时器定时器定时器A功能及结构功能及结构功能及结构功能及结构定时器A基本结构是一个十六位计数器,由时钟信号驱动工作,结构框图如图4-1所示。
图4-1定时器A结构图定时器A具有多种功能,其特性如下:(1)输入时钟可以有三种选择,可以是慢时钟(ACLK)、快时钟(SMCLK与单片机主时钟同频)和外部时钟。
(2)能产生的定时中断、定时脉冲和PWM(脉宽调制)信号,没有软件带来的误差。
(3)不仅能捕获外部事件发生的时间,还可选择触发脉冲沿(由上升沿或下降沿触发)。
定时器A功能模块主要包括:(1)计数器部分:输入的时钟源具有4种选择,所选定的时钟源又可以1、2、4或8分频作为计数频率,Timer_A可以通过选择4种工作模式灵活的完成定时/计数功能。
(2)捕获/比较器:用于捕获事件发生的时间或产生时间间隔,捕获比较功能的引入主要是为了提高I/O端口处理事务的能力和速度。
不同的MSP430单片机,Timer_A模块中所含有的捕获/比较器的数量不一样,每个捕获/比较器的结构完全相同,输入和输出都取决于各自所带控制寄存器的控制字,捕获/比较器相互之间完全独立工作。
(3)输出单元:具有可选的8种输出模式,用于产生用户需要的输出信号,支持PWM输出。
2....定时器工作模式定时器工作模式定时器工作模式定时器工作模式(1)停止模式:停止模式用于定时器暂停,并不发生复位,所有寄存器现行的内容在停止模式结束后都可用。
SDLu的MSP430入门学习笔记定时器TimerA比较输出PWM
S.D.Lu的MSP430入门学习笔记(8):定时器TimerA(3)比较输出PWM本篇笔记介绍如何使用TimerA的比较模式输出PWM信号。
PWM信号有两个参数,周期T和脉宽D。
为了实现PWM的控制,我们将通过TACCR0控制周期,通过TACCR1控制脉宽。
输出选择模式7(或模式6)。
在本例中,输出模式6和输出模式7只是第一个周期输出可能不同,从第二个周期开始输出是一样的。
CCR1单元的输出引脚是P1.2。
如下图,请参考MSP430G2x52、G2x12系列数据手册。
将P1.2的功能按下图配置,请参考MSP430G2x52、G2x12系列数据手册。
程序如下:程序运行结果是P1.2口输出占空比为20%的PWM信号。
在本例中,TIME用于控制PWM周期,DUTY指的是占空比,取值范围0~100。
需要特别注意的是,在14行中用到了乘法和除法运算,如果不注意,乘法非常容易产生溢出。
本例中将TIME定义为(1000ul),其中1000是TIME的数值,ul为后缀,它表示1000是一个unsigned long类型的数据,这是IAR编译环境定义的。
将TIME定义为unsigned long类型之后,14行右边的乘法运算结果将保存为32位长度,这样就避免了溢出。
如果将TIME定义改为#define TIME (1000),则当TIME * DUTY的值大于0xFFFF时,就会出现溢出,无法得到我们预想的结果。
本例中,9~17行的代码被执行一次之后,CPU就进入LPM0模式,不再执行任何语句。
PWM信号不是由CPU控制IO口产生的,而是由ACLK驱动TimerA产生的。
从图12-12可以看出,模式1、4、5不能用于输出PWM信号,模式2-模式6、模式3-模式7是两对反相的输出模式。
输出模式2,3,6,和7对于输出单元0无效,因为在这些模式下,EQUx=EQU0。
因此,CCR0单元需要以控制IO的方式才能输出PWM信号。
单片机MSP430 - Timer_A 定时器中断程序
单片机MSP430 - Timer_A 定时器中断程序一、利用定时器定时功能,实现定时器单个溢出中断,实现P3.0 方波输出#include “cc430x613x.h”void main(){WDTCTL = WDTPW + WDTHOLD; // 停止看门狗定时器P3DIR |= 0x04; // P3 口初始化,设置为输出模式TA0CCR0 = 32768; // 定义中断计数周期1s,时钟频率为32.768MHZ,32768 / 32768 = 1sTA0CCTL0 = CCIE; // TA0CCR0 捕获/比较中断寄存器中断使能TA0CTL = TASSEL_1 + MC_1 + TACLR; // TASSEL_1,ACLK 时钟源MC_1,增计数模式_BIS_SR(LPM3_bits + GIE); // 进入LPM3 低功耗模式,开启总中断}#pragma vector = TIMER0_A0_VECTOR__interrupt void Timer_A(void) // 定时器中断触发,P3 输出口异或,电平翻转{P3OUT – 0x04;二、利用定时器定时功能,实现定时器多个溢出,对应产生多个中断,实现P3.0 输出#include “cc430x613x.h”void main(){WDTCTL = WDTPW + WDTHOLD; // 停止看门狗定时器P3DIR |= 0x04; // P3 口初始化,设置为输出模式TA0CCR0 = 32768; // 定义中断计数周期1s,时钟频率为32.768MHZ,32768 / 32768 = 1sTA0CCTL0 = CCIE; // TA0CCR0 捕获/比较中断寄存器中断使能TA0CCR1 = 3276; // 定义中断溢出周期100msTA0CCTL1 = CCIE; // TA0CCR0 捕获/比较中断寄存器中断使能TA0CTL = TASSEL_1 + MC_1 + TACLR; // TASSEL_1,ACLK 时钟源MC_1,增计数模式_BIS_SR(LPM3_bits + GIE); // 进入LPM3 低功耗模式,开启总中断}#pragma vector = TIMER0_A0_VECTOR__interrupt void Timer_A(void) // 1s 溢出中断P3OUT = ~0x04;}#pragma vector = TIMER0_A1_VECTOR__interrupt void Timer_A1(void) // 100ms 溢出中断{switch(TA0IV){case 2:P3OUT = 0x04;break;case 4:break;case 10:break;}}tips:感谢大家的阅读,本文由我司收集整编。
msp430 Time-a中文手册
12.1Timer_A Introductiontimer_a是一个16位定时器/计数器三捕获/比较寄存器。
timer_a可以支持多个捕获/比较,脉宽调制输出,和间隔时间。
timer_a也拥有丰富的中断能力。
中断可能产生的计数器溢出条件,从每一个的捕获/比较寄存器timer_a功能包括:•异步的16位定时器/计数器具有四种操作模式•可选和可配置的时钟源•两或三个可配置捕获/比较寄存器•配置的输出PWM能力•异步输入和输出锁存•中断向量寄存器的快速解码所有的timer_a中断timer_a框图见图12-1。
注意:使用单词计数计数是在本章中使用。
这意味着计数器必须在计数的过程中采取行动。
如果一个特定的值是直接写入计数器,一个相关的行动将不会发生。
12.2Timer_A Operation该timer_a模块配置与用户软件。
安装和操作timer_a讨论以下部分。
12.2.116-Bit Timer Counter16位定时器/计数器寄存器,TAR,递增或递减(取决于操作模式)与每个时钟的上升沿信号。
TAR可以读或写软件。
此外,当它溢出时该定时器产生一个中断。
TAR可清除设置TACLR位。
设置TACLR清除时钟分频器和计数向上/下模式。
注:修改timer_a寄存器在修改其运作之前建议停止计时器(除了中断使能和中断标志),避免错误的操作情况。
当定时器时钟异步处理器的时钟时,任何读从TAR中有可能发生当计时器不工作或结果可能是不可预测的。
另外,该定时器可多次读取操作时,与多数表决采取软件确定正确的阅读。
任何写入TAR将立即生效。
12.2.1.1Clock Source Select and Divider12.2.1.1时钟源选择和分频器计时器时钟的来源可以从ACLK,SMCLK,或通过外部TACLK或INCLK。
时钟源选择与TASSELx 位。
选定的时钟源可直接传递给定时器或除以2,4,或8,使用IDx的位。
msp430单片机timer_a的应用
行。
伴随遥感等信息技术在矿产开发工作中的应用,地质勘探部门逐渐建立起了有关矿产开发的一系列信息平台,以帮助矿产资源开发工作更加精准、高效的完成。
5 结论伴随矿产资源在我国经济发展中的作用越来越高,矿产资源开发工作也就具有了更大的价值。
而与矿产开发工作密不可分的矿产资源信息勘测技术也就不断获得发展和完善,并在矿产资源开发中贡献出越来越重要的作用,如精确定位矿产资源、探明质量和储量等方面。
可以说,地质勘测信息技术在矿产资源开发工作中功不可没。
而伴随各类信息技术的逐渐完善,相信越来越多的高科技信息技术可以在矿产资源开发工作中得到应用,以不断推进矿产开发工作走向高效、完善的未来。
【参考文献】[1]张玮.地质找矿中地质勘探的应用与技术分析[J].世界有色金属,2019(15):279-280.[2]周志强,饶伟,刘志军.地质找矿中地质勘探技术的应用分析[J].世界有色金属,2019(13):56+58.作者简介 :吴健翔(1989年-),男,汉族,江西新余人,本科,地质工程师,研究方向:从事地质矿产勘查。
1 引言MSP430单片机是TI公司推出的一款超低功耗16位微控制器,该芯片除了16位RISC CPU以外,还集成了众多数字和模拟外设,减少了外围电路设计,方便用户使用。
超低的功耗是MSP430单片机最显著的特点[1]。
MSP430系列单片机的应用领域很广,在仪器仪表、自动控制,以及消费品领域都有应用。
其低功耗的设计更适合于用电池供电的场合,也可以用于需要较高运算性能的智能仪器设备。
2 MSP430单片机Timer_ATimer_A定时器是MSP430所有型号都具有的定时器,可以用来实现计时、延时、信号频率测量、信号触发检测、脉冲宽度测量、PWM(Pulse width modulation,脉冲宽度调制)信号发生等等功能。
Timer_A由定时计数器、时钟源的选择和分频、捕获/比较器、输出单元等部分组成。
利用MSP430的 定时器A(Timer_A)的比较捕获模式产生方波和PWM波
微机原理实验实验五定时器A(Timer_A)的比较/捕获模式一、实验目的1. 掌握 MSP430 系列片内集成定时器的比较/捕获模块的工作原理和应用方法;2. 掌握 MSP430 系列片内集成定时器的比较模式的原理和应用;3. 掌握利用定时器的比较模式产生方波的方法;4. 掌握利用定时器比较模式输出 PWM 波形的方法;5. 掌握定时器的捕获模式的原理和应用;6. 掌握利用定时器捕获模式测量方波信号频率的方法二、实验内容1.※●编程实现:采用定时器TA0控制LED1指示灯亮灭,中间间隔1s。
(1)源程序#include<msp430.h>void main(){WDTCTL=WDTPW+WDTHOLD; //关闭看门狗P1DIR |= BIT2;P1SEL |= BIT2; //P1.2定时器输出TA0CCR0=50000; //PWM周期定义TA0CCTL1=OUTMOD_3; //CCR1比较输出模式3TA0CCR1=32768; //CCR1 PWM占空比定义TA0CTL = TASSEL_1+MC_1+TACLR; //ACLK,增计数,清除TAR计数器__bis_SR_register(LPM3_bits); //进入LPM3}(2)运行结果上电后LED1闪烁,中间间隔1s. (以下为录制的运行视频截图)(3)输出信号波形图1s(4)对比分析采用定时器的比较模式和中断功能实现输出方波的各自优势是什么?采用中断功能产生方波是定时器计数到某个值使产生中断,利用此中断来翻转输出口的状态,从而产生方波,它的方波不是直接产生的,因此它有更强的可操作性。
比较模式是计数时与某两个值比较,然后置位复位或者反转输出口,这是直接产生方波,它容易控制方波的占空比。
2.※●编程实现:采用定时器TA0捕获/比较器CCR1的比较模式,设定输出方式,输出PWM波形,使LED1指示灯亮2s,灭1s,并绘制PWM波的波形和频率。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第四讲定时器A的使用MSP430F413芯片中含有TimerA3模块,如图1-2所示。
其常用的外引线有三条:TACLK、TA1和TA2。
TACLK:定时器_A输入时钟(48脚),与P1.6和ACLK输出共用同一引脚。
TA1:定时器_A的第一通道输入、输出引脚(51脚)。
捕获方式:CCI1A输入;比较方式:OUT1输出。
TA2:定时器_A的第二通道输入、输出引脚(45脚)。
捕获方式:CCI2A输入;比较方式:OUT2输出。
1.定时器A功能及结构定时器A基本结构是一个十六位计数器,由时钟信号驱动工作,结构框图如图4-1所示。
图4-1 定时器A结构图定时器A具有多种功能,其特性如下:(1)输入时钟可以有三种选择,可以是慢时钟(ACLK)、快时钟(SMCLK与单片机主时钟同频)和外部时钟。
(2)能产生的定时中断、定时脉冲和PWM(脉宽调制)信号,没有软件带来的误差。
(3)不仅能捕获外部事件发生的时间,还可选择触发脉冲沿(由上升沿或下降沿触发)。
定时器A功能模块主要包括:(1)计数器部分:输入的时钟源具有4种选择,所选定的时钟源又可以1、2、4或8分频作为计数频率,Timer_A可以通过选择4种工作模式灵活的完成定时/计数功能。
(2)捕获/比较器:用于捕获事件发生的时间或产生时间间隔,捕获比较功能的引入主要是为了提高I/O 端口处理事务的能力和速度。
不同的MSP430单片机,Timer_A模块中所含有的捕获/比较器的数量不一样,每个捕获/比较器的结构完全相同,输入和输出都取决于各自所带控制寄存器的控制字,捕获/比较器相互之间完全独立工作。
(3)输出单元:具有可选的8种输出模式,用于产生用户需要的输出信号,支持PWM输出。
2.定时器工作模式(1)停止模式:停止模式用于定时器暂停,并不发生复位,所有寄存器现行的内容在停止模式结束后都可用。
当定时器暂停后重新计数时,计数器将从暂停时的值开始以暂停前的计数方向计数。
例如,停止模式前,Timer_A工作于增/减计数模式并且处于下降计数方向,停止模式后,Timer_仍然工作于增/减计数模式,从暂停前的状态开始继续沿着下降方向开始计数。
如果不需这样,则可通过TACTL中的CLR控制位来清除定时器的方向记忆特性。
(2)增计数模式:捕获/比较寄存器CCR0用作Timer_A增计数模式的周期寄存器,因为CCR0为16位寄存器,所以该模式适用于定时周期小于65536的连续计数情况。
计数器TAR可以增计数到CCR0的值,当计数值与CCR0的值相等(或定时器值大于CCR0的值)时,定时器复位并从0开始重新计数。
增计数模式的计数过程如图4-2所示。
通过改变CCR0值,可重置计数周期。
图4-2增计数模式示意图(3)连续计数模式:在需要65536个时钟周期的定时应用场合常用连续计数模式。
定时器从当前值计数到单增到0FFFFH后,又从0开始重新计数如图4-3所示。
图4-3 连续计数模式(4)增/减计数模式需要对称波形的情况经常可以使用增/减计数模式,该模式下,定时器先增计数到CCR0的值,然后反向减计数到0。
计数周期仍由CCR0定义,它是CCR0计数器数值的2倍。
计数器的计数过程如图4-4所示。
图4-4增/减计数模式3.增计数模式应用举例增计数最大值存储器在CCR0,该值计算方法如下:选用辅助时钟时,ACLK 频率f=32768Hz ,周期T=1/32768,若选用250ms 中断,则CCR0值应为:81923276825.025.0=⨯==TN 转换成十六进制数后N=2000(H )MSP430F413单片机定时器A 构成的时钟小系统程序清单如下: /*************************************************** * 文件名称:MSP413C 语言定时程序* 文件说明:用MSP430F413定时器A 作为定时中断源。
***************************************************/ #include <msp430x41x.h>/***************************************************** * 文件说明:LCD 模块*****************************************************/ #define LCD_IN_USE 10/****************************************************** * 数据定义七段译码表 *****************************************************/ const unsigned char NUM_LCD[17]={ 0xd7, 0x06, 0xe3, 0xa7, 0x36, //'0'~ '4' 0xb5, 0xf5, 0x07, 0xf7, 0xb7, //'5' ~ '9'0x77, 0xf4, 0xd1, 0xe6, 0xf1, // 'A'~ 'E'0x71, 0x00}; // 'F','全熄'unsigned char lcd_Buf[LCD_IN_USE]; // 自定义显示缓冲区,用于要显示的数据 unsigned int cont,y0,y1,y2; //秒、时、分存储变量 /******************************************************** LCD模块初始化*******************************************************/ void init_LCD(void){char tmpv;BTCTL = BT_fLCD_DIV32; // set LCD 时钟P5SEL = 0xfc; // 置为外围模块LCDCTL = LCDON+LCD4MUX+LCDP1; // 4Mux 模式for (tmpv = 0;tmpv<10;tmpv++){LCDMEM[tmpv] = 0x00; //clear LCD }}/******************************************************** LCD清零模块*******************************************************/ void cl_LCD(void){char tmpv;for (tmpv = 0;tmpv<10;tmpv++){LCDMEM[tmpv] = 0x00; //clear LCD }}/***************************************************** 更新LCD缓冲区的内容,把数据显示到LCD****************************************************/void lcd_Display(void){char tmpv;lcd_Buf[0]=y2/10; lcd_Buf[1]=y2%10;lcd_Buf[2]=16;lcd_Buf[3]=y1/10; lcd_Buf[4]=y1%10;lcd_Buf[5]=16;lcd_Buf[6]=y0/10; lcd_Buf[7]=y0%10;lcd_Buf[8]=16; lcd_Buf[9]=16;for(tmpv=0;tmpv<LCD_IN_USE-1;tmpv++){LCDMEM[tmpv] = NUM_LCD[lcd_Buf[tmpv]]; //更新LCDMEM中的内容}}/************************************************************定时器A中断服务程序************************************************************/#pragma vector=TIMERA0_VECTOR__interrupt void Timer_A(void)//interrupt[TIMERA0_VECTOR] void Timer_A (void){cont=cont+1;if(cont==4){cont=0;y0=y0+1; //秒加1if(y0==60){y0=0; y1=y1+1; //60秒为1分,分加1if(y1==60){y1=0; y2=y2+1; //60分为1小时,小时加1if(y2==24){y2=0 ; //24小时再清零}}}cl_LCD();lcd_Display();_NOP();}}void init_TA(void) //初始化定时器A{TACCR0 = 0x2000;TACTL = TASSEL0 + TACLR; // ACLK, 清零TarTACCTL0 = CCIE; // 中断使能CCR0TACTL |= MC0; // 设置增模式启动定时器A }/************************************************************主程序************************************************************/void main(void){WDTCTL = WDTPW +WDTHOLD; // 关WDTSCFQCTL |= SCFQ_4M; // 设定主时钟为4MHzinit_LCD();init_TA() ;_EINT(); // 使能中断cont=0; y0=0; y1=0; y2=0;for (;;){_BIS_SR(CPUOFF); //关CPU_NOP(); // 调试程序使用}}4.输出单元定时器A的输出单元输出模式有8种,增计数模式下输出模式如图4-5所示。
图4-5输出模式示意图各模式说明如下:(1)输出模式0—输出模式:输出信号OUTx由每个捕获/比较模块的控制寄存器CCTLx 中的OUTx位定义,并在写入该寄存器后立即更新。
最终位OUTx直通。
(2)输出模式1—置位模式:输出信号在TAR等于CCRx时置位,并保持置位到定时器复位或选择另一种输出模式为止。
(3)输出模式2—PWM翻转/复位模式:输出在TAR的值等于CCRx时翻转,当TAR的值等于CCR0时复位。
(4)输出模式3—PWM置位/复位模式:输出在TAR的值等于CCRx时置位,当TAR的值等于CCR0时复位。