51单片机定时器0中断与串口使用相冲突以后怎么办

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;      //允许接收   
}

这样初始化就可以了,如果有不同的意见或者错误,欢迎大佬指出。

评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值