久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4443|回復: 15
收起左側

為什么單片機串口只能接受前兩個接受的數據啊?

  [復制鏈接]
ID:394056 發表于 2018-9-18 17:28 | 顯示全部樓層 |閱讀模式

想要通過串口發送一串16進制數來控制小燈的亮滅。這個十六進制數有15個,但是通過電腦發送之后指令后只能檢測到前兩個數據不知道是什么原因引起的啊?

#include "stc12c5a60s2.h"

#include "init.h"
#include "uart.h"
#include "delay.h"
uchar uart1_flag=0;
uint xdata rbuf[];
sbit jdq1=P0^0;
sbit jdq2=P0^1;         
void main()
{
jdq1=0;
jdq2=0;
uart1_flag=0;
InitUart();   //初始化Uart函數獨立波特率發生器            
EA=1;
ES=1;
while(1)
  {
  if(uart1_flag==1)
     {
   uart1_flag=0;
   jdq1=1;
   mDelay(100);
   jdq2=1;
   mDelay(800);   
   jdq1=0;
   mDelay(100);
   jdq2=0;
    }
  }
   
}

void uart_js() interrupt 4    //RI==1時執行串口中斷
{
static unsigned char count;
uchar xdata  receive1_xorg=0;

if(RI==1)
  {
  RI=0;
  rbuf[count]=SBUF; //保存數據
  SBUF=rbuf[count];
  if(uart1_flag!=0)
   {
   count=0;
   return;
   }
  count++;
  if((count==1)&&(rbuf[0]!=0x7E))//0  0xf1   
   {
   count=0;
   }            
  else if((count==2)&&(rbuf[1]!=0x80)) //1 0xb1
   {
    count=0;
    //uart1_flag=1;
   }
  else if((count==3)&&(rbuf[2]!=0x00)) //1 0xbf
   {
    count=0;
   }
  else if((count==4)&&(rbuf[3]!=0x01))    //rbuf[3]     
   {  
     count=0;
     //uart1_flag=1;
   }
  else if((count==5)&&(rbuf[4]!=0x00)) //7E 80 00 01 00 /0-4     
   {  
     count=0;
   }
            
  else if((count==6)&&(rbuf[5]!=0x00))     
    {
    count=0;
    }
    else if((count==7)&&(rbuf[6]!=0x80)) // 00 80 AA 00  / 5-8
    {
    count=0 ;
    }
  else if((count==8)&&(rbuf[7]!=0xAA))     
    {
  
    count=0 ;
    }
  else if((count==9)&&(rbuf[8]!=0x00))     
    {
    count=0 ;
    }
  else if((count==10)&&(rbuf[9]!=0x01))     
    {
    count=0 ;
    }
  else if((count==11)&&(rbuf[10]!=0x01))     
    {
    count=0 ;
    }
  else if((count==12)&&(rbuf[11]!=0x00))     // 01 01 00 DE 62 //7E   9-14
    {
    count=0 ;
   
    }
  else if((count==13)&&(rbuf[12]!=0xDE))     
    {
    count=0;
    }
  else if((count==14)&&(rbuf[13]!=0x62))     
    {
    count=0;
    }
  else if((count==15)&&(rbuf[14]!=0x7E))   
    {
    count=0;
   
    }
  else if (count>=16)
   {
   count=0;
   uart1_flag=1;
   }    //*/
}
}
回復

使用道具 舉報

ID:359145 發表于 2018-9-19 13:58 | 顯示全部樓層
jtag調試

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

ID:400118 發表于 2018-9-19 17:10 | 顯示全部樓層
在等待時拉長等待延時,或者加printf調試信息,在什么地方出現問題。

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

ID:400118 發表于 2018-9-19 17:12 | 顯示全部樓層
可以拉長等待發送完畢的延時,或者添加打印函數進行跟蹤問題

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

ID:400162 發表于 2018-9-19 18:13 | 顯示全部樓層
建議單步調試
回復

使用道具 舉報

ID:400182 發表于 2018-9-19 18:51 | 顯示全部樓層
精簡程序,可能是串口被占用,導致了沖突,你可以試著加大時間間隔

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

ID:400231 發表于 2018-9-19 20:29 | 顯示全部樓層
可能是串口被占用
回復

使用道具 舉報

ID:394056 發表于 2018-9-20 11:01 | 顯示全部樓層
perfect123 發表于 2018-9-19 15:09
精簡程序,可能是串口被占用,導致了沖突,你可以試著加大時間間隔

是將延時函數加大嗎
回復

使用道具 舉報

ID:394056 發表于 2018-9-20 11:02 | 顯示全部樓層
lw12 發表于 2018-9-19 17:10
在等待時拉長等待延時,或者加printf調試信息,在什么地方出現問題。

加Printf怎么加啊,不太明白。∵請指教
回復

使用道具 舉報

ID:394056 發表于 2018-9-20 11:06 | 顯示全部樓層
perfect123 發表于 2018-9-20 09:08
你這人復制別人的話來回復,這樣做不好吧?

嗯,是的。批評他
回復

使用道具 舉報

ID:387733 發表于 2018-9-20 12:06 | 顯示全部樓層
現在是沒收到一個字節都進行校驗,不符則清零,不太好判斷,如果先將校驗和清零去掉,看看到底收到的是什么,尋找規律,再查原因可能會更好一些
回復

使用道具 舉報

ID:213173 發表于 2018-9-20 17:05 | 顯示全部樓層
給你寫個示例程序,是在你的程序基礎上改的,你試試。

#include <STC12C5A60S2.H>
sbit jdq1=P0^0;
sbit jdq2=P0^1;
bit flag=0;
bit uart1_flag=0;
unsigned char rbuf[15];
unsigned char code rbuf1[]={0x7E,0x80,0x00,0x01,0x00,0x00,0x80,0xAA,0x00,0x01,0x01,0x00,0xDE,0x62,0x7E};
/*************初始化串口**************/         
void InitUart()                //9600bps@11.0592MHz
{
        PCON &= 0x7F;                //波特率不倍速
        SCON = 0x50;                //8位數據,可變波特率
        AUXR &= 0xBF;                //定時器1時鐘為Fosc/12,即12T
        AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
        TMOD &= 0x0F;                //清除定時器1模式位
        TMOD |= 0x20;                //設定定時器1為8位自動重裝方式
        TL1 = 0xFD;                        //設定定時初值
        TH1 = 0xFD;                        //設定定時器重裝值
        ET1 = 0;                        //禁止定時器1中斷
        TR1 = 1;                        //啟動定時器1
        EA=1;                                //開總中斷
        ES=1;                                //開串口中斷
}
/**********串口發送函數*************/
void SendOneByte(unsigned char c)
{
    SBUF = c;                //發送數據
    while(!TI);        //等待發送完成
    TI = 0;                        //發送中斷請求標志位清0
}
/*-------------------------------
  1ms延時子程序(11.0592MHz 1T)
-------------------------------*/
void mDelay(unsigned int k)
{
        unsigned int i,j;
        for(i=k;i>0;i--)
                for(j=1150;j>0;j--);
}

void main()
{
        unsigned char i;
        jdq1=0;
        jdq2=0;
        InitUart();   //初始化串口         
        while(1)
        {
                if(uart1_flag==1)
                {
                        uart1_flag=0;
                        ES=0;                        //關串口中斷
                        for(i=0;i<15;i++)
                        {
                                if(rbuf[i]==rbuf1[i])
                                {
                                        flag=1;
                                        SendOneByte(rbuf[i]);
                                }
                                else
                                {
                                        flag=0; break;
                                }
                        }
                        ES=1;                //開串口中斷
                        if(flag==1)
                        {
                                jdq1=1;
                                mDelay(100);
                                jdq2=1;
                                mDelay(800);   
                                jdq1=0;
                                mDelay(100);
                                jdq2=0;
                        }
                }
        }       
}

void uart_js() interrupt 4    //RI==1時執行串口中斷
{
        static unsigned char count=0;
        unsigned char i;
        RI=0;
        rbuf[count]=SBUF; //保存數據
        if(rbuf[0]==0x7E)        //驗證數據頭(起始位)
        {
                count++;
                if(count>=15)
                {
                        count=0;                        //計數變量清0
                        if(rbuf[14]==0x7E)//驗證數據尾
                                uart1_flag=1;        //接收完成標志置1
                        else
                        {
                                for(i=0;i<15;i++)
                                        rbuf[i]=0x00;//緩存全部清0
                        }
                }
        }       
}
// 7E 80 00 01 00 00 80 AA 00 01 01 00 DE 62 7E

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 中文字幕在线一区二区三区 | 国产精品一区2区 | 不卡在线视频 | 天堂av中文 | 午夜久久久久久久久久一区二区 | 亚洲日日夜夜 | 黄色中文字幕 | 91久久精品日日躁夜夜躁欧美 | 99久久久久 | 久久国产精品72免费观看 | 久久久久国产精品一区二区 | 日韩精品一区二区三区在线播放 | 成人久久久久 | 国产在线拍偷自揄拍视频 | 国产精品久久久久久久久免费软件 | 日本精品网站 | 免费观看羞羞视频网站 | 99热99| 久久国产区| 欧美国产亚洲一区二区 | 国产精品久久久久久亚洲调教 | 亚洲午夜在线 | 国产精品1区 | 日韩三级免费网站 | 日韩中文一区二区三区 | 九九热re | 涩涩视频在线看 | 黄视频免费在线 | 久久久国产一区 | 日韩高清中文字幕 | 久久最新 | 亚洲人成人一区二区在线观看 | 国产精品久久久久久久午夜 | 午夜久久久久久久久久一区二区 | 日韩高清在线观看 | 毛片一级片 | 国产一区三区视频 | 亚洲资源在线 | 国产欧美在线 | 国产精品久久久久久久久久久久久 | 天天曰夜夜 |