一开始没写好就上传了,,,,,,,,这次来个全的

自己学MSP430是为了写一篇关于PID的文章,需要430在proteus上做仿真,一则认为在自动控制算法上PID真的很经典,PLC设备上大多是模块式的,拿来就是参考说明书设置,设置,,,而对于单片机而言就是程序!!!只有自己写出来PID算法,才能对PID有更深刻的理解,..二来感觉自己已经好久都没有写一篇让自己感到满意的文章了......

这些天,,,,今天终于解除了我的很大疑惑了,,,,,,,终于可以完成这篇普通普通定时器中断的文章了,,,,,,其实说普通也不普通,,MSP430的定时器确实设计的很强悍,,,,,,,,

其实对于普通定时器吧!不外乎,,,,定时,,,,产生中断,,,,细节问题就不说了,,,,看我下面的理论介绍部分,,其实写文章一部分是为了分享,最重要的是考验自己到底有没有真正的学会,真正的深入理解了自己所学的东西,自己学东西是一步一个脚印,这倒是高中的班主任的功劳,现在想想自己自学从高三就开始了,没想到当年的班主任的一段话对自己的影响竟然如此的大..如果文章有问题希望亲们给意见哈,,,

CCR0   和  TACCR0  是一个哈,,,,,,,,别在别处看到CCR0就蒙了哈,,,这是设置的计数比较值,,

430的定时器能选择时钟来源,,具体看下面,,,如果不选择那么就是用一个引脚(特定的)的输入PWM作为他的时钟了

先上菜----外部引脚来四个上升沿就进入下面的中断函数

实质----内部计数器TAR在计数到CCR0(TACCR0)时就进来了

__interrupt void Timer_A0 (void)     //定时器A0中断服务程序
{
P4OUT ^= BIT1; //P4_1引脚反转
}

然后再来一个上升沿,,就会进入---溢出中断-------可以取消,不让他有溢出中断

实质----内部计数器TAR在计数到CCR0后,,再来一个上升沿就变成 0 了,,,然后就就进来了

__interrupt void Timer_A1 (void) //A1,A2,溢出中断都会进
{
switch( TAIV )
{
case TAIV_TAIFG://溢出中断
P4OUT ^= BIT1; //P4_1反转
break;
}
}

下面是完整的程序

P1_0引脚,来四个上升沿TAR变为4,,P4_1反转,,,再来一个沿TAR变为0,再来四个,TAR变为4,,P4_1反转,再来一个沿TAR变为0,再来四个,TAR变为4,,P4_1反转,,,循环

所以发现第一次来四个P4_1反转,,,,后来的都是来5个再反转了,,所以如果你想来四个反转,,那么TACCR0应该为3

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1; TACTL |= TASSEL_0 + MC_1+ TAIE + TACLR;//时钟外部引脚输入,增计数模式,产生溢出中断(可以取消),清除一下溢出,,其实严谨一点嘛,先清除再说 TACCR0 = ;//计数值3
TACCTL0 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
P4OUT ^= BIT1;
} #pragma vector = TIMERA1_VECTOR
__interrupt void Timer_A1 (void) //A1,A2,溢出中断都会进
{
switch( TAIV )
{
case TAIV_TAIFG://溢出中断
P4OUT ^= BIT1;
break;
}
}

现在去掉溢出中断

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1; TACTL |= TASSEL_0 + MC_1+TACLR;//外部引脚模式,,增计数模式 TACCR0 = ;//计数值3,其实是4,,因为有一个溢出变为0
TACCTL0 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
P4OUT ^= BIT1;
}

下面是一些具体解释

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1+BIT2; TACTL |= TASSEL_0 + MC_2+TACLR;//外部引脚模式,,连续计数模式 TACCR0 = ;//计数值4
TACCTL0 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
P4OUT ^= BIT1;
}

可以这样

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1+BIT2; TACTL |= TASSEL_0 + MC_2+TACLR;//外部引脚模式,,连续计数模式 TACCR0 = ;//计数值4
TACCTL0 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
TACCR0 = TACCR0 + ;//******这里,这里***********//
P4OUT ^= BIT1;
}

因为是连续计数模式,所以可以用TACCR1了,,,,

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1+BIT2; TACTL |= TASSEL_0 + MC_2+TACLR;//外部引脚模式,,连续计数模式 TACCR0 = ;//计数值4,TAR==TACCR0进入它的中断函数
TACCTL0 = CCIE;//允许中断 TACCR1 = ;//计数值6,TAR==TACCR1进入它的中断函数
TACCTL1 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
TACCR0 = TACCR0 + ;//******这里,这里***********//
P4OUT ^= BIT1;
} #pragma vector = TIMERA1_VECTOR
__interrupt void Timer_A1 (void) //A1,A2,溢出中断都会进(共用)
{
switch( TAIV )
{
case TAIV_TACCR1://计数" TACCR1 "的中断
TACCR1 = TACCR1 + ;
P4OUT ^= BIT2;
break;
}
}

既然有溢出中断那么再加上溢出中断吧

#include "io430.h"

void main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;//关闭看门狗 P4DIR |= BIT1+BIT2+BIT3; TACTL |= TASSEL_0 + MC_2 + TAIE +TACLR;//外部引脚模式,,增计数模式 TACCR0 = ;//计数值4,TAR==TACCR0进入它的中断函数
TACCTL0 = CCIE;//允许中断 TACCR1 = ;//计数值6,TAR==TACCR1进入它的中断函数
TACCTL1 = CCIE;//允许中断 __enable_interrupt();//打开总中断
} #pragma vector = TIMERA0_VECTOR
__interrupt void Timer_A0 (void) //定时器A0中断服务程序
{
TACCR0 = TACCR0 + ;//******这里,这里***********//
P4OUT ^= BIT1;
} #pragma vector = TIMERA1_VECTOR
__interrupt void Timer_A1 (void) //A1,A2,溢出中断都会进(共用)
{
switch( TAIV )
{
case TAIV_TACCR1://计数" TACCR1 "的中断
TACCR1 = TACCR1 + ;
P4OUT ^= BIT2;
break;
case TAIV_TAIFG://溢出中断,,,,ffff变0时
P4OUT ^= BIT3;
break;
}
}

下面是理论知识的介绍,,,看了上面再看一下下面,,,,,

通俗来讲,430F249有三个振荡器,LFXT1,,XT2,,DCO,

内部的主时钟MCLK,,子系统时钟SMCLK和辅助时钟ACLK是由这三个振荡器来源提供的.

MCLK:主时钟

可以选择3个振荡器(LFXT1、XT2、DCO)之一,或它们1/2/4/8分频后作为其信号源;

SMCLK:子系统时钟

可以选择2个振荡器(XT2、DCO),或它们1/2/4/8分频后作为其信号源;

ACLK:辅助时钟

只能由LFXT1时钟信号或1/2/4/8分频后作为其信号源。

有三个呢!!!真多

自从博客可以复制粘贴图片,感觉真是太方便了

4-MSP430定时器_定时器中断的更多相关文章

  1. 定时器的应用---中断方式---让8个LED灯,左右各4个来回亮

    定时器的应用---中断方式---让8个LED灯,左右各4个来回亮 /*************************** 中断方式 是主程序专注于其他的事情, 待定时器中断时才执行中断子程序. ** ...

  2. 用定时器T0的中断控制8位LED闪烁

    #include<reg52.h> #define uchar unsigned char #define uint unsigned int uint i; void main() { ...

  3. STM32(5)——通用定时器基本定时器

    1.STM32的Timer简介 STM32中一共有11个定时器,其中2个高级控制定时器,4个普通定时器和2个基本定时器,以及2个看门狗定时器和1个系统嘀嗒定时器. 其中系统嘀嗒定时器是前文中所描述的S ...

  4. STM32 HAL库学习系列第4篇 定时器TIM----- 开始定时器与PWM输出配置

    基本流程: 1.配置定时器 2.开启定时器 3.动态改变pwm输出,改变值  HAL_TIM_PWM_Start(&htim4, TIM_CHANNEL_1); 函数总结: __HAL_TIM ...

  5. 019_linux驱动之_定时器的引入

    (一)定义一个timer_list定时器结构体,linux 内核定时器 timer_list详解 (二)初始化定时器,当超时时间expires到之后会调用buttons_timer_function函 ...

  6. 杨老师课堂之JavaScript定时器_农夫山泉限时秒杀案例

    预览效果图: 使用到的知识点: 定时器 setInterval(函数,毫秒):在指定的毫秒数后调用函数或执行一段代码 取消定时器 clearInterval:取消由setInterval设置的定时器 ...

  7. QT_8_Qt中的事件处理_定时器事件_定时器类_事件分发器_事件过滤器_绘图事件_高级绘图事件_绘图设备_QFile 文件读写_QFileInfo文件信息

    Qt中的事件处理 1.1. 捕获QLabel中是鼠标事件 1.2. enterevent 鼠标进入 1.3. leaveevent 鼠标离开 1.4. 鼠标按下MyLabel::mousePressE ...

  8. 定时器_在.net core3.0 webapi中添加自定义定时器功能

    前言:想在.net framework环境使用自定义定时器的话,参考我的另一篇文章:https://www.cnblogs.com/lxhbky/p/10242839.html 想在.net core ...

  9. go基础_定时器

    每间隔5s打印一句hello // time_ticker package main import ( "fmt" "time" ) func main() { ...

随机推荐

  1. 9.30notes

    memcached   缓存机制,减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度. array_slice(data['list'],0,10) ...

  2. nginx-nginx.conf脚本

    user www www; worker_processes ; error_log /usr/local/nginx/logs/error.log info ; pid /var/run/nginx ...

  3. js原生代码实现轮播图案例

    一.轮播图是现在网站网页上最常见的效果之一,对于轮播图的功能,要求不同,效果也不同! 我们见过很多通过不同的方式,实现这一效果,但是有很多比较麻烦,而且不容易理解,兼容性也不好. 在这里分享一下,用j ...

  4. jquery的each

    each()方法能使DOM循环结构简洁,不容易出错.each()函数封装了十分强大的循环功能,使用也很方便,它可以循环一维数组.多维数组.DOM, JSON 等等在javaScript开发过程中使用$ ...

  5. Logging with Debug And Trace (一)

    对于一个应用程序而言,Log 必不可少. 在.net 里面,最简单的方式就是用Console 来输出 信息了,例如下面的例子: public class Program { public static ...

  6. EasyPR--开发详解(3)高斯模糊、灰度化和Sobel算子

    在上篇文章中我们了解了PlateLocate的过程中的所有步骤.在本篇文章中我们对前3个步骤,分别是高斯模糊.灰度化和Sobel算子进行分析. 一.高斯模糊 1.目标 对图像去噪,为边缘检测算法做准备 ...

  7. 小型文件数据库 (a file database for small apps) SharpFileDB

    小型文件数据库 (a file database for small apps) SharpFileDB For english version of this article, please cli ...

  8. Self Host模式下的ASP. NET Web API是如何进行请求的监听与处理的?

    构成ASP.NET Web API核心框架的消息处理管道既不关心请求消息来源于何处,也不需要考虑响应消息归于何方.当我们采用Web Host模式将一个ASP.NET应用作为目标Web API的宿主时, ...

  9. ABP(现代ASP.NET样板开发框架)主题线下交流会(上海)开始报名了!

    点这里进入ABP系列文章总目录 ABP主题线下交流会(上海)开始报名了 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称.它是采用最佳实践和流行技术 ...

  10. Lua table之弱引用

    Lua采用了基于垃圾收集的内存管理机制,因此对于程序员来说,在很多时候内存问题都将不再困扰他们.然而任何垃圾收集器都不是万能的,在有些特殊情况下,垃圾收集器是无法准确的判断是否应该将当前对象清理.这样 ...