打印

定时器A的基本例程

[复制链接]
918|3
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
上山砍老虎|  楼主 | 2016-2-29 22:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
//******************************************************************************
//  MSP-FET430P140 Demo - Timer_A, Toggle P1.0, CCR0 Cont. Mode ISR, DCO SMCLK
//
//  Description: Toggle P1.0 using software and TA_0 ISR. Toggles every
//  50000 SMCLK cycles. SMCLK provides clock source for TACLK.
//  During the TA_0 ISR, P1.0 is toggled and 50000 clock cycles are added to
//  CCR0. TA_0 ISR is triggered every 50000 cycles. CPU is normally off and
//  used only during TA_ISR.
//  ACLK = n/a, MCLK = SMCLK = TACLK = default DCO ~800kHz
//
//           MSP430F149
//         ---------------
//     /|\|            XIN|-
//      | |               |
//      --|RST        XOUT|-
//        |               |
//        |           P1.0|-->LED
//
//  M. Buccini
//  Texas Instruments Inc.
//  Feb 2005
//  Built with IAR Embedded Workbench Version: 3.21A
//******************************************************************************

#include  <msp430x14x.h>

void main(void)
{
  WDTCTL = WDTPW + WDTHOLD;                 // Stop WDT
  P1DIR |= 0x01;                            // P1.0 output
  CCTL0 = CCIE;                             // CCR0 interrupt enabled
  CCR0 = 50000;
  TACTL = TASSEL_2 + MC_2;                  // SMCLK, contmode

  _BIS_SR(LPM0_bits + GIE);                 // Enter LPM0 w/ interrupt
}

// Timer A0 interrupt service routine
#pragma vector=TIMERA0_VECTOR
__interrupt void Timer_A (void)
{
  P1OUT ^= 0x01;                            // Toggle P1.0
  CCR0 += 50000;                            // Add Offset to CCR0
}

相关帖子

沙发
上山砍老虎|  楼主 | 2016-2-29 22:54 | 只看该作者
最基础的东西,才能学到东西,我记得我以前学430的时候,用示波器把TA的每一个例程都看一遍

使用特权

评论回复
板凳
bboo| | 2016-2-29 22:56 | 只看该作者
确实是这样的,跑例程其实是一种很好的学习方法

使用特权

评论回复
地板
给力芯片| | 2016-2-29 23:01 | 只看该作者
定时器是一个芯片的灵魂啊

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

36

主题

332

帖子

3

粉丝