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

標題: 為啥單片機串口解析時好時壞希望有大佬能解決下 [打印本頁]

作者: yslsdas    時間: 2023-3-16 10:09
標題: 為啥單片機串口解析時好時壞希望有大佬能解決下
#include "..\comm\STC32G.h"

#include "stdio.h"
#include "intrins.h"
#include "string.h"

typedef         unsigned char        u8;
typedef         unsigned int        u16;
typedef         unsigned long        u32;

#define MAIN_Fosc        22118400L   //定義主時鐘(精確計算115200波特率)
#define Timer0_Reload   (MAIN_Fosc / 1000)      //Timer 0 中斷頻率, 1000次/秒
//==========================================================================


#define Baudrate1   (65536 - MAIN_Fosc / 115200 / 4)
#define Baudrate2   (65536 - MAIN_Fosc / 115200 / 4)

#define UART1_BUF_LENGTH    256
#define UART2_BUF_LENGTH    256



/*************  本地變量聲明    **************/

u16  TX1_Cnt;    //發送計數
u16  RX1_Cnt;    //接收計數
u16  TX2_Cnt;    //發送計數
u16  RX2_Cnt;    //接收計數

bit B_TX1_Busy;  //發送忙標志
bit B_TX2_Busy;  //發送忙標志


u8  RX1_Buffer[UART1_BUF_LENGTH]; //接收緩沖
u8  RX2_Buffer[UART2_BUF_LENGTH]; //接收緩沖

//短息處理變量

u8 Message_info[256];
//Messgae_Flag = 0;
u16 Cnt_len  = 0;
u16 Cnt_head = 0;
bit M_Flag = 0;
bit Uart_S = 0;



void main(void)
{
    WTST = 0;  //設置程序指令延時參數,賦值為0可將CPU執行指令的速度設置為最快

    P0M1 = 0x00;   P0M0 = 0x00;   //設置為準雙向口
    P1M1 = 0x00;   P1M0 = 0x00;   //設置為準雙向口
    P2M1 = 0x00;   P2M0 = 0x00;   //設置為準雙向口
    P3M1 = 0x00;   P3M0 = 0x00;   //設置為準雙向口
    P4M1 = 0x00;   P4M0 = 0x00;   //設置為準雙向口
    P5M1 = 0x00;   P5M0 = 0x00;   //設置為準雙向口
    P6M1 = 0x00;   P6M0 = 0x00;   //設置為準雙向口
    P7M1 = 0x00;   P7M0 = 0x00;   //設置為準雙向口

    UART1_config(1);    // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
    UART2_config(2);    // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 無效.

         

                while(1)              
                        {
                                  u16 i;
                                
                                if( Uart_S)
                                        {  
                                                
                                                for(i=0;i<=Cnt_len;i++)
                                                {UART1_TxByte(RX1_Buffer[Cnt_head+i]);}
                                                Uart_S   =0;
                                                RX1_Cnt         =0;
                                                Cnt_head =0;
                                        }
                        }               
}

void UART1_int (void) interrupt 4
{
                if(TI)
    {
        TI = 0;
        B_TX1_Busy = 0;
    }
               
                if(RI) // 中斷產生
                                {
                                        RI=0 ; //清楚中斷標志
                                        RX1_Buffer[RX1_Cnt] = SBUF;
                                        RX1_Cnt++;
                                       
                                        if((RX1_Buffer[RX1_Cnt-1]==0x2B)&&(RX1_Buffer[RX1_Cnt]==0x43))//頭
                                                                {        Cnt_head  = RX1_Cnt-1;}
                                        if((RX1_Buffer[Cnt_head]==0x2B)&&(RX1_Buffer[RX1_Cnt-1]==0x0A)) //檢測到頭的情況下檢測尾巴
                                                        {
                                                                        Cnt_len = RX1_Cnt-1 - Cnt_head;
                                                                        Uart_S = 1;
                                                        
                                                        }
                                }
               
                //數據溢出的情況
                if(RX1_Cnt >= UART1_BUF_LENGTH)   
                                {RX1_Cnt = 0;}


}

作者: yslsdas    時間: 2023-3-16 11:24
有大佬幫忙看看嗎?

作者: 暖西夏    時間: 2023-3-16 14:48
中斷盡量快,不要處理數據,把數據放到其他地方判斷
作者: 人中狼    時間: 2023-3-16 15:42
中斷里的接收判斷錯誤了
作者: yslsdas    時間: 2023-3-16 18:34
人中狼 發表于 2023-3-16 15:42
中斷里的接收判斷錯誤了

能略微指點一下嗎?
作者: lihuajie32    時間: 2023-3-16 20:56
不用大佬,小弟就可以,時好時壞,以硬件的角度看,沒插好、插頭慫了,軟件看那是玄學!
作者: 人中狼    時間: 2023-3-16 22:08
if((RX1_Buffer[RX1_Cnt-1]==0x2B)&&(RX1_Buffer[RX1_Cnt]==0x43))
這里邏輯問題

作者: yslsdas    時間: 2023-3-17 08:58
人中狼 發表于 2023-3-16 22:08
if((RX1_Buffer[RX1_Cnt-1]==0x2B)&&(RX1_Buffer[RX1_Cnt]==0x43))
這里邏輯問題

emm 抱歉實在是 邏輯理解不出來 RX1_Cnt-1 時為0x2B (+)RX1_Cnt 時 為 0x43 (C) 這里有什么邏輯問題,還望不吝賜教
作者: yslsdas    時間: 2023-3-17 08:59
lihuajie32 發表于 2023-3-16 20:56
不用大佬,小弟就可以,時好時壞,以硬件的角度看,沒插好、插頭慫了,軟件看那是玄學!

線什么的應該沒什么問題
作者: lkc8210    時間: 2023-3-17 10:14
yslsdas 發表于 2023-3-17 08:58
emm 抱歉實在是 邏輯理解不出來 RX1_Cnt-1 時為0x2B (+)RX1_Cnt 時 為 0x43 (C) 這里有什么邏輯問題,還 ...


由于12行的關系
13行的RX1_Buffer[RX1_Cnt-1]為接收值后面的RX1_Buffer[RX1_Cnt]永遠等于0


作者: yslsdas    時間: 2023-3-17 11:06
確實是這樣 RX1_Buffer[1] 的值確實沒有謝謝大佬指出

作者: yslsdas    時間: 2023-3-17 11:13
lkc8210 發表于 2023-3-17 10:14
由于12行的關系
13行的RX1_Buffer[RX1_Cnt-1]為接收值后面的RX1_Buffer[RX1_Cnt]永遠等于0

按照您這么說,這確實后面的那個RX1_Buffer[RX1_Cnt] 沒有值
作者: yslsdas    時間: 2023-3-19 16:37
  1. if( M_Flag)
  2.                                         {  
  3.                                        
  4.                                                 PrintString1(RX1_Buffer);
  5.                                                 PrintString1("\n");
  6.                                                 M_index[M_index_num]=RX1_Buffer[3] ;
  7.                                                 M_index_num++;
  8.                                                 memset(RX1_Buffer,0,RX1_Cnt);
  9.                                                  M_Flag   =0;
  10.                                                 RX1_Cnt         =0;
  11.                                                 PrintString1(M_index);
  12.                                                 PrintString1("\n");
  13.                                         }
  14. void UART1_int (void) interrupt 4
  15. {
  16.                

  17. //               
  18. //                if(RI) // 中斷產生
  19. //                                {
  20. //                                        RI=0 ; //清除中斷標志
  21. //                                        RX1_Buffer[RX1_Cnt] = SBUF;
  22. //                                        RX1_Cnt++;
  23. //                                        if(RX1_Cnt >= UART1_BUF_LENGTH)   
  24. //                                                        {RX1_Cnt = 0;}
  25. //                                        }
  26. //                if((RX1_Buffer[RX1_Cnt-1]==0x2B)&&(RX1_Buffer[RX1_Cnt]==0x43))//頭
  27. //                                                                {        Cnt_head  = RX1_Cnt-1;}
  28. //                if((RX1_Buffer[Cnt_head]==0x2B)&&(RX1_Buffer[Cnt_head+1]==0x43)&&(RX1_Buffer[RX1_Cnt-1]==0x0A)) //檢測到頭的情況下檢測尾巴
  29. //                                {
  30. //                                                Cnt_len = RX1_Cnt-1 - Cnt_head;
  31. //                                          
  32. //                                                Uart_S = 1;
  33. //                                          RX1_Cnt = 0;
  34. //                                                Cnt_head =0;
  35. ////                               
  36. //                                }

  37.                          if(RI)//如果產生中斷
  38.                                  {
  39.                                        
  40.                                         switch(state){
  41.                                                 case 1:
  42.                                                                                 if(SBUF == 0x4C){ //頭
  43.                                                                                         RX1_Cnt=0;
  44.                                                                                         state = 2;
  45.                                                                                         RX1_Buffer[RX1_Cnt++] = SBUF;
  46.                                                                                 }
  47.                                                                                 else
  48.                                                                                 {
  49.                                                                                         state=1;
  50.                                                                                         RX1_Cnt=0;
  51.                                                                                        
  52.                                                                                 }
  53.                                                                                 break;
  54.                                                                                
  55.                                                 case 2:
  56.                                                                                 if(SBUF == 0x3A){ //頭
  57.                                                                                         state = 3;
  58.                                                                                         RX1_Buffer[RX1_Cnt++] = SBUF;
  59.                                                                                 }
  60.                                                                                 else
  61.                                                                                 {
  62.                                                                                         state=1;
  63.                                                                                         RX1_Cnt=0;
  64.                                                                                        
  65.                                                                                 }
  66.                                                                                 break;
  67.                                        
  68.                                                  case 3:
  69.                                                                                         if(SBUF==0x2C){  //尾
  70.                                                                                                
  71.                                                                                                         RX1_Buffer[RX1_Cnt++] = SBUF;
  72.                                                                                                         M_Flag = 1;
  73.                                                                                                         state =1;
  74.                                                                                                        
  75.                                                                                         }
  76.                                                                                         else
  77.                                                                                         {
  78.                                                                                                        
  79.                                                                                                 RX1_Buffer[RX1_Cnt++] = SBUF;
  80.                                                                                                  state=3;
  81.                                                                                         }
  82.                                                                                         break;
  83.        
  84.                                                                                        
  85.                                                  default:
  86.                                                                                         state = 1;
  87.                                                                                  break;
  88.                                        
  89.                                         }
  90.                                          
  91.                                          RI = 0;
  92.                  }
  93.                        
  94.     if(TI)
  95.     {
  96.         TI = 0;
  97.         B_TX1_Busy = 0;
  98.     }
  99.                          
  100. }
復制代碼


這個應該是可以解決指定頭和位幀然后不定長數據解析了吧嘿嘿




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 精品一区二区三 | 欧美一级欧美三级在线观看 | 日屁网站 | 免费xxxx大片国产在线 | 精品福利在线视频 | 成人精品鲁一区一区二区 | 国产不卡视频 | 日韩1区2区 | 日韩一区二区三区视频 | 99一区二区| 97超碰在线免费 | 亚洲av毛片 | 一区二区三区免费网站 | 大陆一级毛片免费视频观看 | 国产午夜精品久久久久 | 久久国产精品久久 | 国产综合在线视频 | 一区中文| 欧美二三区 | 成人免费在线视频 | 成人亚洲在线 | 免费的av | 国产精品久久久久一区二区三区 | 日本一本视频 | 亚洲精品一区中文字幕乱码 | 国产美女在线观看 | 成人午夜视频在线观看 | 黄色免费网站在线看 | 黄色免费看 | 欧美成人精品激情在线观看 | 日日日日操 | 久久久无码精品亚洲日韩按摩 | 日韩精品一区二区三区在线播放 | 亚洲h色| 成人自拍av| 久久视频一区 | 国产伊人久久久 | 99热热99| 一级毛毛片| 久久69精品久久久久久久电影好 | 成人精品鲁一区一区二区 |