历史上的今天
返回首页

历史上的今天

今天是:2025年04月02日(星期三)

正在发生

2020年04月02日 | msp430f5438定时器1s的程序

2020-04-02 来源:eefocus

void time_init_1s()

{

  TA1CCTL0 = CCIE;                          // CCR0 interrupt enabled

  TA1CCR0 = 16383;

  TA1CTL = TASSEL_1 + MC_1 + TACLR;         // ACLK, Up to CCR0 , clear TAR 

}

//中断服务程序

#pragma vector=TIMER1_A0_VECTOR

__interrupt void TIMER1_A0_ISR(void)

{

  P5OUT ^=BIT4; 

  TA1CCR0 += 16383;                         // Add Offset to CCR0

}


时钟设置:


void clk_init()

{

  //ACLK = REFO = 32kHz, MCLK = SMCLK = 25MHz

   WDTCTL = WDTPW + WDTHOLD;                 // Stop WDT

  UCSCTL3 |= SELREF_2;                      // Set DCO FLL reference = REFO

  UCSCTL4 |= SELA_2;                        // Set ACLK = REFO

 

  __bis_SR_register(SCG0);                  // Disable the FLL control loop

  UCSCTL0 = 0x0000;                         // Set lowest possible DCOx, MODx

  UCSCTL1 = DCORSEL_7;                      // Select DCO range 25MHz operation

  UCSCTL2 = FLLD_1 +762;                   // Set DCO Multiplier for 25MHz

                                            // (N + 1) * FLLRef = Fdco

                                            // (762 + 1) * 32768 = 25MHz

                                            // Set FLL Div = fDCOCLK/2

  __bic_SR_register(SCG0);                  // Enable the FLL control loop

 

  // Worst-case settling time for the DCO when the DCO range bits have been

  // changed is n x 32 x 32 x f_MCLK / f_FLL_reference. See UCS chapter in 5xx

  // UG for optimization.

  // 32 x 32 x 25 MHz / 32,768 Hz = 782000 = MCLK cycles for DCO to settle

  __delay_cycles(782000);

 

  // Loop until XT1,XT2 & DCO fault flag is cleared

  do

  {

    UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + XT1HFOFFG + DCOFFG);

                                            // Clear XT2,XT1,DCO fault flags

    SFRIFG1 &= ~OFIFG;                      // Clear fault flags

  }while (SFRIFG1&OFIFG);                   // Test oscillator fault flag              

}


msp430f有两个中断向量,还是一Ti的一个例程来说吧


//******************************************************************************

//  MSP430F5438 Demo - Timer_A3, Toggle P1.0;P2.1-3, Cont. Mode ISR, 32kHz ACLK

//

//  Description: Use Timer1_A CCRx units and overflow to generate four

//  independent timing intervals. For demonstration, CCR0, CCR1 and CCR2

//  output units are optionally selected with port pins P2.1, P2.2 and P2.3

//  in toggle mode. As such, these pins will toggle when respective CCRx

//  registers match the TAR counter. Interrupts are also enabled with all

//  CCRx units, software loads offset to next interval only - as long as

//  the interval offset is added to CCRx, toggle rate is generated in

//  hardware. Timer1_A overflow ISR is used to toggle P1.0 with software.

//  Proper use of the TAIV interrupt vector generator is demonstrated.

//  ACLK = TACLK = 32kHz, MCLK = SMCLK = default DCO ~1.045MHz

//

//  As coded and with TACLK = 32768Hz, toggle rates are:

//  P2.1= CCR0 = 32768/(2*4) = 4096Hz

//  P2.2= CCR1 = 32768/(2*16) = 1024Hz

//  P2.3= CCR2 = 32768/(2*100) = 163.84Hz

//  P1.0= overflow = 32768/(2*65536) = 0.25Hz

//

//               MSP430F5438

//            -------------------

//        /||                   |

//         | |                   |

//         --|RST                |

//           |                   |

//           |         P2.1/TA1.0|--> CCR0

//           |         P2.2/TA1.1|--> CCR1

//           |         P2.3/TA1.2|--> CCR2

//           |               P1.0|--> Overflow/software

//           |               P1.0|--> LED

//

//   M Smertneck / W. Goh

//   Texas Instruments Inc.

//   September 2008

//   Built with CCE Version: 3.2.2 and IAR Embedded Workbench Version: 4.11B

//******************************************************************************

 

#include "msp430x54x.h"

 

void main(void)

{

  WDTCTL = WDTPW + WDTHOLD;                 // Stop WDT

  P2SEL |= 0x0E;                            // P1.1 - P1.3 option select

  P2DIR |= 0x0E;                            // P2.1 - P2.3 outputs

  P1DIR |= 0x01;                            // P1.0 - Outputs

  TA1CCTL0 = OUTMOD_4 + CCIE;               // CCR0 toggle, interrupt enabled

  TA1CCTL1 = OUTMOD_4 + CCIE;               // CCR1 toggle, interrupt enabled

  TA1CCTL2 = OUTMOD_4 + CCIE;               // CCR2 toggle, interrupt enabled

  TA1CTL = TASSEL_1 + MC_2 + TACLR + TAIE;  // ACLK, contmode, clear TAR,

                                            // interrupt enabled

 

  __bis_SR_register(LPM3_bits + GIE);       // Enter LPM3, interrupts enabled

  __no_operation();                         // For debugger

}

 

// Timer1 A0 interrupt service routine

#pragma vector=TIMER1_A0_VECTOR

__interrupt void Timer_A0 (void)

{

  TA1CCR0 += 4;                             // Add Offset to CCR0

}

 

// Timer_A3 Interrupt Vector (TAIV) handler

#pragma vector=TIMER1_A1_VECTOR

__interrupt void TIMER1_A1_ISR(void)

{

  switch(__even_in_range(TA1IV,14))

  {

    case 0: break;                  

    case 2:  TA1CCR1 += 16;                 // Add Offset to CCR1

             break;

    case 4:  TA1CCR2 += 100;                // Add Offset to CCR2

             break;

    case 6:  break;                         // CCR3 not used

    case 8:  break;                         // CCR4 not used

    case 10: break;                         // CCR5 not used

    case 12: break;                         // Reserved not used

    case 14: P1OUT ^= 0x01;                 // overflow

             break;

    default: break;

 }

}

 


从datasheet可以看出模式4的波形。


看了两天时钟,定时器,想在写点体会,方法也难,最后还是建议大家多看datasheet,看英文的比较好,中文的太垃圾了

推荐阅读

史海拾趣

问答坊 | AI 解惑

PCB 元件器装备的三种工艺比较分析

本帖最后由 paulhyde 于 2014-9-15 08:56 编辑 PCB生产制作出来之后,还需要把元器件装配上去,才能进一步交付使用。目前最常见的装配方法,有波峰焊、回流焊及二者的混装技术。而PCB的质量问题对三种工艺的装配质量有着极大的影响,下面我们分别 ...…

查看全部问答>

关于FB,好奇怪的问题。。望高手解释。。。

硬件平台,TQ2440开发板。 操作系统:LINUX2.6.30.4. LCD:NEC NL8060BC31-17 屏幕设置为800*600 16bpp。看似一切正常。 跑MINIGUI的个应用程序。LCD就是不正常显示图形。后经多次检查。 发现一个很崩溃的问题:LCD的第2竖列不能写白数据,即 ...…

查看全部问答>

求助 关于MRC p15,0,R0,c0,c0,0的问题

MRC p15,0,R1,c0,c0,0这个指令是来读取ARM CPU的ID号到ARM寄存器R1里面的吗?如果是的话,我现在在EVC环境下嵌入了有下面汇编内容的.s文件:         AREA        |.text|, CODE &n ...…

查看全部问答>

嵌入式爱好者的学习笔记连载(一)

嵌入式爱好者的学习笔记连载(一)     本人从本科到研究生的专业都是电子工程,由于研究生阶段课题的需要,做了些控制方面的电路,但也只限于使用单片机。在介绍个人学习体会之前,先介绍一下我的学习背景,因为背景不同对某一方面的 ...…

查看全部问答>

LED背光模块的自动设计

LED背光模块的自动设计…

查看全部问答>

中断标志位放在中断程序中判断有什么用?

interrupt[PORT_vector]void PORT1(void) { if(P1IFG&BIT0) {Delay(); if(P1IFG&BIT0) {执行体; P1IFG&=~BIT0; } } } 这样能去抖动吗 ,我感觉在中断程序中判断中断 ...…

查看全部问答>

使用ATMEGA88芯片采集模拟信号不响应

问题如题 程序如下 #define  F_CPU 8000000UL#include<avr/io.h>#include<util/delay.h>#define INT8U unsigned char#define INT16U unsigned intconst INT8U SEG_CODE[]={0XC0,0Xf9,0XA4,0XB0,0X99,0X92,0X82,0XF8,0X80,0X90,0XFF} ...…

查看全部问答>

程序问题紧急求解

void main(void) {        long tom;                 lcd_init();         while(1)         {         tom=k ...…

查看全部问答>

如何进行电流检测?

本帖最后由 dontium 于 2015-1-23 12:40 编辑 请问各位大牛,如果要对4~20ma的电流进行检测怎么设计比较合适?我选的一款ad芯片内阻是兆欧级别的,所以一开始设计让要检测的电流通过一个小电阻接地后,在小电阻上取电压进行检测。后来找资料的时候 ...…

查看全部问答>