bulk 发表于 2012-8-28 23:12:14

请大家看看这个串口通讯程序

#include<at89x51.H>

unsigned char a,b,c,d;
unsigned int i,j,k;

void UART_init()
{                     //初始化串行口和波特率发生器
TMOD=0x20;                   //用定时器设置串口波特率                   9600
      TH1=0xfd;
      TL1=0xfd;
      SCON=0x50;
      TR1=1;
      REN=1;          //串口初始化
      SM0=0;
      SM1=1;
      EA=1;         //开启总中断
      ES=1;
}
void send()
{
   TI=0;                  //清零串口发送完成中断请求标志
   SBUF='1';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志


       SBUF='L';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志

       SBUF='O';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志

       SBUF='C';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志

       SBUF='K';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志

       SBUF='0';
   while(TI==1);        //等待发送完成
   TI=0;          //清零串口发送完成中断请求标志


}

void uart_isr() interrupt 4
{
    if(RI)
      {
       RI=0;
       a=SBUF;
       if((a=='1')&&(c==1))
             {
                     send();
             }
    }
   
}


void main()
{
                  c=1;
        UART_init();
    while(1)
       {
             ;
           }


}

用串口调试软件发“1” 给单片机,单片机收到后,返回“1LOCK0给PC端”,结过发现PC端 收到的数据不全,只能显示一个字符,比如 1 或者L或O或C,K,0。



beijinggood2008 发表于 2012-8-29 22:57:14

波特率的问题吧?

tcm123 发表于 2012-8-29 23:19:44

中断里先不调用SEND函数,主函数循环里调用看看情况就知道了

bg8wj 发表于 2012-8-30 11:19:27

中断里先不调用SEND函数,主函数循环里调用看看情况就知道了
这个问题是中断的问题,如果你间隔时间足够也许能够完整发送“1LOCK0”。因为send 函数每次按照1个字节发送字符。你的PC端发送字符产生RI中断太过于平凡导致RI一直响应,但是send函数每次发送一个字节就清除TI,当然无法完整的发送一个字符串。修改send函数,设置整个“1lock0”发送完才清除TI,这样的函数例子太多自己找了。要不就降低PC端发送1的频率,加长发送字符之间的间隔。
另外,如上述程序的send函数非常不可取,不仅增加代码长度,而且占用资源。
页: [1]
查看完整版本: 请大家看看这个串口通讯程序