51单片机定时器0中断与串口使用相冲突
做小毕设的时候想实现一秒发送一个数据,被这个问题困扰了很久,后来在一位小伙伴的帮助下解决了问题,在这里还是谢谢热心解答问题的群友。
- 下面是最开始写的代码,冲突了
void ET0_init()//定时器0初始化
{
TMOD &= 0xf0; //定时器0
TMOD |= 0x01;
TH0 = (65536-2000)/256; //2ms溢出
TL0 = (65536-2000)%256;
}
void UartConfigurationInit()
{
TMOD=0x21; //设置定时器1工作方式为方式2
TH1=0xfd; //波特率9600
TL1=0xfd;
TR1=1; //启动定时器1
SM0=0;SM1=1; //串口方式1
REN=1; //允许接收
PCON=0x00; //关倍频
ES=1; //开串口中断
EA=1; //开总中断
}
void main()
{ ET0_init(); //定时器0初始化
ET0 = 1;
TR0 = 1;
ET1 = 1;
TR1 = 1;
UartConfigurationInit(); //初始化串口
CS = 0;
while(1)
}
}
//从定时器0初始化课串口初始化开始就相互冲突了,下在开发板上没有任何反应,即便是加上中断函数
void time() interrupt 1//定时器0事件子程序函数
{
TH0=(65536-50000)/256; //每次进来都赋值
TL0=(65536-50000)%256; //
i++;
if(i==10)
{ i=0;
P1=~P1;
}
}
小灯也是不会闪的(p1口 外围电路是小灯),后来和小伙伴一起测试了很久,发现是ET1的问题,不能将定时器1中断打开,因为在串口通信中,定时器1用的是八位自动重载模式产生波特率,所以和定时器0中断相冲突,下面给出可以进中断的代码,供大家参考。
void ET0_init()//定时器0初始化
{
EA=1; //打开总中断
TR0=1; //打开定时器0中断
ET0=1; //启动定时器0中断
TH0=(65536-50000)/256;//无脑赋值 相当于50毫秒进入一次中断函数,20次就是1秒
TL0=(65536-50000)%256; //无脑赋值
TMOD= 0x01;//设置定时器t0的工作方式
}
void UartInit() //串口定时器1初始化
{
EA=1; //打开总中断
ES=0;
TMOD|=0x20; //设置定时器1工作方式为方式2
TR1=1; //启动定时器1
TH1=0xfd; //波特率9600
TL1=0xfd;
SCON=0X50; //允许接收
}
这样初始化就可以了,如果有不同的意见或者错误,欢迎大佬指出。