日常踩坑记录
51单片机使用printf为什么编译通过了,但是没有效果 ?
MCU型号:STC12C5A60S2
晶振 :11.0592MHZ
实验内容:利用单片机和PC机串口通信的
(晶振为11.0592MHZ)设置波特率为9600 第一个版本的代码如下**(不能正确输出的代码)**:
#include <REGX51.H>
#include "string.h"
#include "stdio.h"
#define Max_BUFF_Len 50
unsigned char Rec;
unsigned char Rx_Buff[Max_BUFF_Len];
unsigned int Rx_Count;
void Uart_init()
{
TMOD|=0X21;
TH1=0Xfd;
TL1=0Xfd;
TR1=1;
SM0=0;
SM1=1;
REN=1;
ES=1;
TH0=0xcd;
TL0=0xd4;
ET0=1;
TR0 = 1;
EA=1;
}
int main()
{
Uart_init();
while(1)
{
printf("Hello Word\r\n");
}
}
void Timer0() interrupt 1
{
TH0=0xcd;
TL0=0xd4;
if(Rx_Buff[Rx_Count-1] == 0x0a || Rx_Count == Max_BUFF_Len)
{
if((strstr((char*)Rx_Buff,"OK"))||(strstr((char *)Rx_Buff,">")))
{
Rx_Count=0;memset(Rx_Buff, 0, sizeof(Rx_Buff));
printf("Data Get OK\r\n");
P1=~P1;
}
else
{
Rx_Count=0;
}
}
}
void Usart0() interrupt 4
{
if(RI)
{
RI=0;
Rec=SBUF;
Rx_Buff[Rx_Count]=Rec;
Rx_Count++;
}
}
经过一番捣鼓,查看51单片机状态控制寄存器SCON寄存器才恍然大悟。 TI 为发送中断标志位,由硬件置位,软件清除。工作方式0中在发送第8位末尾由硬件置位;在其他工作方式时,在发送停止位开始时由硬件置位。TI=1时,申请中断。CPU响应中断后,发送下一帧数据。在任何工作方式中都必须由软件清除TI。:
分析代码后发现,程序运行到while(!TI)停止在该句,因为初始化后TI默认为0,而且还没有发送过数据,TI一直为0,因此程序不会继续向下执行。
解决方法:修改Uart_init()函数,添加TI = 1启动发送。
void Uart_init()
{
TMOD|=0X21;
TH1=0Xfd;
TL1=0Xfd;
TR1=1;
SM0=0;
SM1=1;
REN=1;
ES=1;
TH0=0xcd;
TL0=0xd4;
ET0=1;
TR0 = 1;
EA=1;
TI=1;
}
再重新下载到开发板进行调试,完美解决。
又是解决小bug的一天。。。
?
|