//======================================//
// T16定时
//案例为:
//利用T16计数器来计时,计时两秒后控制LED灯由亮变灭
//======================================//
#include "extern.h"
bit LED : PA.5 //定义LED灯的引脚
byte time_10ms;
word reload_T16;
void FPPA0 (void)
{
.ADJUST_IC SYSCLK=IHRC/16, IHRC=16MHz, VDD=5V;
$ LED out,high; //初始把灯点亮(高电平点灯)
$ T16M SYSCLK,/16,bit10; //T16的时钟源选择,内部的时钟分频器,中断源选择(当选择位由低到高或者由高到低时,发生中断事件);
//时钟源选择可以选择STOP, SYSCLK, PA4_F, IHRC, EOSC, ILRC, PA0_F;分频器可选择/1, /4, /16, /64
//中断源可选择BIT8, BIT9, BIT10, BIT11, BIT12, BIT13, BIT14, BIT15
reload_T16 = 1024 - 625; //每次进中断为10ms;
//计算公式为 [1/(时钟源/分频器)]*(中断源-reload_T16)=[1/(1M/16)]*(2^10-(1024-625))=0.01s
stt16 reload_T16; //设定计数器初始值reload_T16,当计数器累加超过设定中断源时产生中断;
$ INTEN T16; //中断允许寄存器,启用从T16的溢出中断;1:启用,0:停用。
$ INTRQ T16; //中断请求寄存器,此位是由硬件置位并由软件清零;1:请求,0:不请求。
//注:INTEN,INTRQ没有初始值,所以要使用中断前,一定要根据需要设定数据。即使INTEN为0,INTRQ还是会被中断发生源触发。
$ INTEGS BIT_R; //T16中断边缘选择,上升缘请求中断为BIT_R,下降缘请求中断为BIT_F;默认为上升缘请求。
// 设定INTEN、INTRQ的初始值
INTEN.T16 = 1; //开T16中断
// INTEN.T16 = 0; //关T16中断
INTRQ.T16 = 0; //清零INTRQ寄存器。
ENGINT; //打开全局中断
time_10ms = 0;
while (1)
{
nop;
}
}
void Interrupt (void)
{
pushaf;
if (Intrq.T16)
{ // T16 Trig
// User can add code
stt16 reload_T16; //设定计数器初始值reload_T16
time_10ms++;
if(time_10ms > 200) //定时两秒
{
time_10ms = 0;
//$ LED out,low; //关灯
}
$ LED toggle;
Intrq.T16 = 0;
}
popaf;
}
可以使用示波器结合看效果 计算定时时间的时候 特别注意分频和计数值
|