您的位置 首页 应用

avr单片机定时器0溢出中止程序

2014年2月17日22:26:32芯片名称:AVR(艾特梅尔公司)mega16A微控制器芯片;开发板:自主研发的YF-A1芯片开发板;(YF:是本

2014年2月17日22:26:32

芯片称号: AVR (艾特梅尔公司)mega16A微控制器芯片;
开发板: 自主研制的 YF-A1芯片开发板; (YF :是自己姓名缩写 )

第53次试验,用逻辑分析仪捕捉,输出于IO口的数字,脉冲信号,脉冲信号宽度:1.5~1.8奇妙,每9~11个脉宽1.5us的信号时序中,夹杂着一个脉宽位为3奇妙的高脉冲信号.
我用了好几个小时都核算不出定时器0内部的时钟频率……..哪里出错了呢?
外部用12兆晶体整荡器;
我的核算结论是:定时器0内部频率为32khz ,可是这显然有问题.
定时器时钟为内部8分频 TCCR0=0X02; TCNTO初始值250,即每6个时钟周期溢出一次,每溢出一次,PB口电平取反一次, 就这样反向核算 脉宽 1.5us ÷ 6 ==每一个被分频的时钟时刻 ÷ 8 =时钟频率;

/*
写这个程序我用了3个多小时,重复试验.苍天不负有心人额,,哎╮(╯▽╰)╭,,,,,

程序名: 定时器0溢出中止

概述: 定时器每一毫秒溢出一次,溢出500次,即0.5秒 ,LED灯跳变一次,我发现,假如
不将一切io口初始化,芯片将变得极端不稳定,无法正常作业,定时器0 溢出标志位
TOV0 一旦溢出,进入中止服务程序后,将主动清零,再无需软件清零,我好像理解了硬
件清零的意思;

finish time :2014年2月28日20:40:21;

*/

#include <avr/io.h>
#include interrupt.h>
#include

typedef unsigned char uint8;
typedef unsigned int uint16;

volatile uint16 a=0;

void io(void)
{
DDRA=0XFF;
PORTA=0X00;

DDRB=0XFF;
PORTB=0X00;

DDRC=0XFF;
PORTC=0X00;

DDRD=0XFF;
PORTD=0X00;

}

int main(void)
{

io();

TIMSK=0X01; // 溢出中止使能;

sei(); //大局中止使能;

TCNT0=69; //定时器初始值1毫秒溢出;

TCCR0=3; //64分频定时器开端运转!;

PORTB=4; //8位LED共阳极使能;

while(1); //死循环;

}

SIGNAL(SIG_OVERFLOW0) //中止服务程序;
{
static uint16 s=0; // 静态变量;

TCNT0=69; //重设定时器初始值;

s++;
if(s==502) //每500毫秒PA口电平跳变一次!
{ s=0;
PORTA^=0XFF;

}

// TIFR=0X01;//将定时器0溢出标志位和比较匹配标志方位一清零;

}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/317546.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部