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溢出标志位和比较匹配标志方位一清零;
}