欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1120|回復: 5
收起左側

STC奇怪現象 串口發送簡單的HEX單個數據程序卡死了

[復制鏈接]
ID:140644 發表于 2025-8-29 08:04 | 顯示全部樓層 |閱讀模式
USB LINK 1D.png



STC  開天斧 三

先用圈圈的USB開發板測試
  8個按鍵分別發送8個不同的HEX數據
只能按一次發送正確
第二次就發不出去了
今天很早就起床
用開天斧三開發板 改了一下例程字符串收發程序
用P3.2 P3.3 P3.4 P3.5
分別發送4個不同的HEX數據
也是卡死在發送函數(猜的,等一下點亮一個LED試試)



/*************  功能說明    ************************/
              #include     "stc8h.h"       //包含此頭文件后,不需要再包含"reg51.h"頭文件
              #define      MAIN_Fosc       11059200L   //定義主時鐘(精確計算9600波特率)
              typedef      unsigned char   u8;
              typedef      unsigned int    u16;
              typedef      unsigned long   u32;
              #define      Baudrate1           9600L
              #define      UART1_BUF_LENGTH    64
              sbit         InttPut0=P3^2;
              sbit         InttPut1=P3^3;
              sbit         InttPut2=P3^4;
              sbit         InttPut3=P3^5;
              u8           TX1_Cnt;    //發送計數
              u8           RX1_Cnt;    //接收計數
              bit          B_TX1_Busy; //發送忙標志
              u8           kcounter,kstatus;     //按鍵計數標志 按鍵狀態標志
/****************按鍵計數器狀態寄存器歸零*************/
              void RstKey()
              {
              kcounter=0;                        //按鍵計數器歸零
              kstatus=0;                         //狀態寄存器歸零
              }
/*****************按鍵低電平檢測函數*****************/
              void   LowVoltKey(void)            //按鍵計數器狀態標志加一
              {
              kcounter++;                       
              kstatus++;     
              _nop_();                           //延時                  
              }
/*****************按鍵高電平檢測函數*****************/
              void    HighVoltKey(void)          //按鍵計數器加一 狀態標志歸零
              {
              kcounter++;                        //按鍵計數器加一
              kstatus=0;                         //按鍵狀態標志歸零
              _nop_();                           //延時
              }
//========================================================================
// 函數: void PrintHex(u8 puts)
// 描述: 串口1發送字符串函數。
// 參數: puts:  Hex.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
              void Send(u8 puts) //發送一個字符串
              {
              B_TX1_Busy = 1;
              SBUF = puts;
              while(B_TX1_Busy);
              }
//========================================================================
// 函數: SetTimer2Baudraye(u16 dat)
// 描述: 設置Timer2做波特率發生器。
// 參數: dat: Timer2的重裝值.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
              void SetTimer2Baudraye(u16 dat)  // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
              {
              AUXR &= ~(1<<4);    //Timer stop
              AUXR &= ~(1<<3);    //Timer2 set As Timer
              AUXR |=  (1<<2);    //Timer2 set as 1T mode
              T2H = dat / 256;
              T2L = dat % 256;
              IE2  &= ~(1<<2);    //禁止中斷
              AUXR |=  (1<<4);    //Timer run enable
              }
//========================================================================
// 函數: void UART1_config(u8 brt)
// 描述: UART1初始化函數。
// 參數: brt: 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
              void UART1_config(u8 brt)    // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
              {
    /*********** 波特率使用定時器2 *****************/
              if(brt == 2)
               {
               AUXR |= 0x01;       //S1 BRT Use Timer2;
               SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate1);
               }
/*********** 波特率使用定時器1 *****************/
               else
               {
               TR1 = 0;
               AUXR &= ~0x01;      //S1 BRT Use Timer1;
               AUXR |=  (1<<6);    //Timer1 set as 1T mode
               TMOD &= ~(1<<6);    //Timer1 set As Timer
               TMOD &= ~0x30;      //Timer1_16bitAutoReload;
               TH1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) / 256);
               TL1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) % 256);
               ET1 = 0;    //禁止中斷
               INTCLKO &= ~0x02;   //不輸出時鐘
               TR1  = 1;
               }
    /*************************************************/

              SCON=(SCON&0x3f)|0x40;//UART1模式,0x00:同步移位輸出,0x40:8位數據,可變波特率,0x80:9位數據,固定波特率,0xc0: 9位數據,可變波特率
//  PS  = 1;    //高優先級中斷
              ES  = 1;    //允許中斷
              REN = 1;    //允許接收
              P_SW1 &= 0x3f;
              P_SW1 |= 0x00;      //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7, 0xC0: P4.3 P4.4
//  PCON2 |=  (1<<4);   //內部短路RXD與TXD, 做中繼, ENABLE,DISABLE

              B_TX1_Busy = 0;
              TX1_Cnt = 0;
              RX1_Cnt = 0;
              }
//========================================================================
// 函數: void main(void)
// 描述: 主函數。
// 參數: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 備注:
//========================================================================
              void main(void)
              {
               P_SW2|=0x80;  //擴展寄存器(XFR)訪問使能
               P0M1 = 0x30;   P0M0 = 0x30;   //設置P0.4、P0.5為漏極開路(實驗箱加了上拉電阻到3.3V)
               P1M1 = 0x30;   P1M0 = 0x30;   //設置P1.4、P1.5為漏極開路(實驗箱加了上拉電阻到3.3V)
               P2M1 = 0x3c;   P2M0 = 0x3c;   //設置P2.2~P2.5為漏極開路(實驗箱加了上拉電阻到3.3V)
               P3M1 = 0x50;   P3M0 = 0x50;   //設置P3.4、P3.6為漏極開路(實驗箱加了上拉電阻到3.3V)
               P4M1 = 0x3c;   P4M0 = 0x3c;   //設置P4.2~P4.5為漏極開路(實驗箱加了上拉電阻到3.3V)
               P5M1 = 0x0c;   P5M0 = 0x0c;   //設置P5.2、P5.3為漏極開路(實驗箱加了上拉電阻到3.3V)
               P6M1 = 0xff;   P6M0 = 0xff;   //設置為漏極開路(實驗箱加了上拉電阻到3.3V)
               P7M1 = 0x00;   P7M0 = 0x00;   //設置為準雙向口
               UART1_config(1);    // 選擇波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
               EA = 1; //允許總中斷
               while (1)
               {
                RstKey();
                for(;kcounter<5;)                 //按鍵循環5次
                {
                 if(!InttPut0)                      //按鍵低電平
                 {
                 LowVoltKey();
                 }
                 else if(~!InttPut0)               //按鍵高電平
                 {
                 HighVoltKey();
                 }
                }
                if(kstatus>=4)                    /*按鍵狀態標志大于等于3為有效值*/
                {                                /*循環檢測 */
                Send(0X01);
                P2=0X01;
                }
//1
                RstKey();
                for(;kcounter<5;)                 //按鍵循環5次
                {
                 if(!InttPut1)                      //按鍵低電平
                 {
                 LowVoltKey();
                 }
                 else if(~!InttPut1)               //按鍵高電平
                 {
                 HighVoltKey();
                 }
                }
                if(kstatus>=4)                    /*按鍵狀態標志大于等于3為有效值*/
                {                                /*循環檢測 */
                Send(0X02);
                P2=0X02;
                }
//2
                RstKey();
                for(;kcounter<5;)                 //按鍵循環5次
                {
                 if(!InttPut2)                      //按鍵低電平
                 {
                 LowVoltKey();
                 }
                 else if(~!InttPut2)               //按鍵高電平
                 {
                 HighVoltKey();
                 }
                }
                if(kstatus>=4)                    /*按鍵狀態標志大于等于3為有效值*/
                {                                /*循環檢測 */
                Send(0X04);
                P2=0X04;
                }
//3
                RstKey();
                for(;kcounter<5;)                 //按鍵循環5次
                {
                 if(!InttPut3)                      //按鍵低電平
                 {
                 LowVoltKey();
                 }
                 else if(~!InttPut3)               //按鍵高電平
                 {
                 HighVoltKey();
                 }
                }
                if(kstatus>=4)                    /*按鍵狀態標志大于等于3為有效值*/
                {                                /*循環檢測 */
                Send(0X08);
                P2=0X08;
               }
//4                     
    }
}






回復

使用道具 舉報

ID:878061 發表于 2025-8-30 07:57 | 顯示全部樓層
你沒有開串口發送中斷, void Send(u8 puts) //發送一個字符串               {               B_TX1_Busy = 1;               SBUF = puts;               while(B_TX1_Busy);               } B_TX1_Busy永遠不會等于0,正確的方法是{ SBUF = puts;  while(!TI);   TI = 0;
回復

使用道具 舉報

ID:140644 發表于 2025-9-24 05:02 | 顯示全部樓層
要改成這個樣子才可以   



             void Send(u8 puts) //發送一個字符串
              {
              SBUF = puts;
              while(!TI);
              TI=0;
              }

范例程序 bit busy;是全局變量
不是寄存器位檢測標志
void UartSend(char dat)
{
    while (busy);
    busy = 1;
    SBUF = dat;
}
回復

使用道具 舉報

ID:1160817 發表于 2025-9-24 09:56 | 顯示全部樓層
你沒有開串口發送中斷, void Send(u8 puts) //發送一個字符串
回復

使用道具 舉報

ID:1160817 發表于 2025-9-24 09:56 | 顯示全部樓層
你沒有開中斷, void Send(u8 puts) //發送一個字符串
回復

使用道具 舉報

ID:57657 發表于 2025-9-24 11:53 | 顯示全部樓層
上位機向下位機發數據卡死:檢查驅動程序,與單片機的關系較小
下位機向上位機發數據卡死:單片機串口寄存器、中斷配置有問題
具體用示波器或邏輯分析儀捕捉信號數據才能知道什么問題。
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表