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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索

請教STC8G1K08A單片機串口程序發送正常,接收不正常

查看數: 8927 | 評論數: 16 | 收藏 1
關燈 | 提示:支持鍵盤翻頁<-左 右->
    組圖打開中,請稍候......
發布時間: 2022-1-11 16:16

正文摘要:

請大俠指點下: 串口為什么發送正常,接收卻不正常呢? 單片機源程序如下: #include "STC8G.h" #include "intrins.h"   void UartInit(void)          ...

回復

ID:725306 發表于 2022-1-15 10:02

用的查詢法,不需要EA=1;
ID:725306 發表于 2022-1-15 10:01
TEC 發表于 2022-1-14 11:00
你這個程序單片機沒法工作的,單片機不能接收,也不能發送,單片機和上位機無法通信。發送成功和單片機沒關 ...

原來上傳的程序串口初始化中,P31 = 0; //PWM關 這一句不能寫的。寫了串口就收發不了數據了。
ID:725306 發表于 2022-1-15 09:38
188610329 發表于 2022-1-11 21:06
你知道不知道  P31 是用來干什么的么?
你一邊要用  P31 發送串口, 一邊還要反轉  P31, 心不是一般的大阿 ...

大哥,就是這個問題 。。。。。 后來我調整了波特率為9600,可以正常收到數據了。因為用的事8腳的單片機,資源比較少,所以調試的時候想看看正常不。謝謝,貼吧是個好環境,大家都會幫助小白菜。
ID:625730 發表于 2022-1-14 11:00
你這個程序單片機沒法工作的,單片機不能接收,也不能發送,單片機和上位機無法通信。發送成功和單片機沒關系,是上位機給單片機發送了數據,但是單片機沒法接收到。
ID:213173 發表于 2022-1-13 08:39

串口助手發送用HEX模式,接收用文本模式
  1. #include "STC8G.h"
  2. #include "intrins.h"
  3. /*
  4. void UartInit(void)                //115200bps@35MHz
  5. {
  6.         SCON = 0x50;                //8位數據,可變波特率
  7.         AUXR |= 0x40;                //定時器時鐘1T模式
  8.         AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
  9.         TMOD &= 0x0F;                //設置定時器模式
  10.         TL1 = 0xB4;                //設置定時初始值
  11.         TH1 = 0xFF;                //設置定時初始值
  12.         ET1 = 0;                //禁止定時器%d中斷
  13.         TR1 = 1;                //定時器1開始計時
  14. }*/
  15. void UartInit(void)                //115200bps@33.1776MHz
  16. {
  17.         SCON = 0x50;                //8位數據,可變波特率
  18.         AUXR |= 0x40;                //定時器時鐘1T模式
  19.         AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
  20.         TMOD &= 0x0F;                //設置定時器模式
  21.         TL1 = 0xB8;                //設置定時初始值
  22.         TH1 = 0xFF;                //設置定時初始值
  23.         ET1 = 0;                //禁止定時器%d中斷
  24.         TR1 = 1;                //定時器1開始計時
  25. }

  26. void GPI_Init(void)
  27. {
  28.         P0M0 = 0x00;
  29.         P0M1 = 0x00;
  30.         P1M0 = 0x00;
  31.         P1M1 = 0x00;
  32.         P2M0 = 0x00;
  33.         P2M1 = 0x00;
  34.         P3M0 = 0x00;
  35.         P3M1 = 0x00;
  36.         P4M0 = 0x00;
  37.         P4M1 = 0x00;
  38.         P5M0 = 0x00;
  39.         P5M1 = 0x00;
  40. //        P31 = 0; //PWM關
  41. }

  42. /* 串口發送字節數據函數 參數是你要發送的字節 */
  43. void UartSend_Data(unsigned char dat)
  44. {
  45.         SBUF = dat;  // 把要發送的數據給了SBUF寄存器
  46.         while(!TI);  // 等待數據發送完成
  47.         TI = 0;      // 清除發送完成標志位
  48. }
  49. void main()
  50. {
  51.         /* 定義一個8位變量 用于接收串口接收的字節 */
  52.         unsigned char x =0;       
  53.         /* IO設置*/
  54.         GPI_Init();       
  55.         UartInit(); // 串口初始化       
  56.         while (1)
  57.         {
  58. /*                SBUF = 0x01;  // 把要發送的數據給了SBUF寄存器
  59.                 while(!TI);  // 等待數據發送完成
  60.                 TI = 0;         
  61.                 if (TI)
  62.                 {
  63.                 TI = 0;     //清中斷標志
  64.                 P31 = !P31; //測試PWM端口
  65.                 }*/
  66.                 if(RI)// 如果串口接收到數據
  67.                 {
  68.                         RI = 0;      //清中斷標志
  69.                         x =SBUF;
  70.                         if (x == 0x01)
  71.                         {
  72.                                 P32 = !P32;  //翻轉MOS管狀態
  73.                                 UartSend_Data('l');
  74.                         }               
  75.                         if (x == 0x02)
  76.                         {
  77.                                 P33 = !P33;  //翻轉led狀態
  78.                                 UartSend_Data('m');
  79. //                                SBUF = 'm';  // 把要發送的數據給了SBUF寄存器
  80. //                                while(!TI);  // 等待數據發送完成
  81. //                                TI = 0;      // 清除發送完成標志位
  82.                         }               
  83.                 }
  84.         }
  85. }
復制代碼
ID:25310 發表于 2022-1-12 15:46
EA=1 有嗎?
ID:624769 發表于 2022-1-11 21:06
你知道不知道  P31 是用來干什么的么?
你一邊要用  P31 發送串口, 一邊還要反轉  P31, 心不是一般的大阿……
ID:725306 發表于 2022-1-11 18:53
npn 發表于 2022-1-11 18:51
35Mhz/115200 不能被整除,你要用33.1776Mhz的晶振。

下面顯示已自動調節為35.004MHz了呀
ID:725306 發表于 2022-1-11 18:52
  1. #include "STC8G.h"
  2. #include "intrins.h"

  3. void UartInit(void)                //115200bps@35MHz
  4. {
  5.         SCON = 0x50;                //8位數據,可變波特率
  6.         AUXR |= 0x40;                //定時器時鐘1T模式
  7.         AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
  8.         TMOD &= 0x0F;                //設置定時器模式
  9.         TL1 = 0xB4;                //設置定時初始值
  10.         TH1 = 0xFF;                //設置定時初始值
  11.         ET1 = 0;                //禁止定時器%d中斷
  12.         TR1 = 1;                //定時器1開始計時
  13. }
  14. void GPI_Init(void)
  15. {
  16.         P3M0 = 0x00;
  17.         P3M1 = 0x00
  18.         P31 = 0; //PWM關
  19. }

  20. /* 串口發送字節數據函數 參數是你要發送的字節 */
  21. void UartSend_Data(unsigned char dat)
  22. {
  23.         SBUF = dat;  // 把要發送的數據給了SBUF寄存器
  24.         while(!TI);  // 等待數據發送完成
  25.         TI = 0;      // 清除發送完成標志位
  26. }
  27. void main()
  28. {
  29.         /* 定義一個8位變量 用于接收串口接收的字節 */
  30.         unsigned char x =0;
  31.        
  32.         /* IO設置*/
  33.         GPI_Init();
  34.                
  35.         UartInit(); // 串口初始化

  36.         while (1)
  37.         {
  38.                 SBUF = 0x01;  // 把要發送的數據給了SBUF寄存器
復制代碼


ID:57657 發表于 2022-1-11 18:51
35Mhz/115200 不能被整除,你要用33.1776Mhz的晶振。
ID:725306 發表于 2022-1-11 18:47
第一次用,不太熟悉帖子版面
ID:725306 發表于 2022-1-11 18:47
代碼格式顯示是亂的,  我重新補下
ID:725306 發表于 2022-1-11 18:46
  1. #include "STC8G.h"
  2. #include "intrins.h"

  3. void UartInit(void)                //115200bps@35MHz
  4. {
  5.         SCON = 0x50;                //8位數據,可變波特率
  6.         AUXR |= 0x40;                //定時器時鐘1T模式
  7.         AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
  8.         TMOD &= 0x0F;                //設置定時器模式
  9.         TL1 = 0xB4;                //設置定時初始值
  10.         TH1 = 0xFF;                //設置定時初始值
  11.         ET1 = 0;                //禁止定時器%d中斷
  12.         TR1 = 1;                //定時器1開始計時
  13. }

  14. void GPI_Init(void)
  15. {
  16.           P0M0 = 0x00;
  17.     P0M1 = 0x00;
  18.     P1M0 = 0x00;
  19.     P1M1 = 0x00;
  20.     P2M0 = 0x00;
  21.     P2M1 = 0x00;
  22.     P3M0 = 0x00;
  23.     P3M1 = 0x00;
  24.     P4M0 = 0x00;
  25.     P4M1 = 0x00;
  26.     P5M0 = 0x00;
  27.     P5M1 = 0x00;
  28.     P31 = 0; //PWM關
  29. }

  30. /* 串口發送字節數據函數 參數是你要發送的字節 */
  31. void UartSend_Data(unsigned char dat)
  32. {
  33.         SBUF = dat;  // 把要發送的數據給了SBUF寄存器
  34.         while(!TI);  // 等待數據發送完成
  35.         TI = 0;      // 清除發送完成標志位
  36. }
  37. void main()
  38. {
  39.                 /* 定義一個8位變量 用于接收串口接收的字節 */
  40.                 unsigned char x =0;
  41.        
  42.                 /* IO設置*/
  43.                 GPI_Init();
  44.                
  45.                 UartInit(); // 串口初始化

  46.     while (1)
  47.                 {
  48.                         SBUF = 0x01;  // 把要發送的數據給了SBUF寄存器
  49.                                                                 while(!TI);  // 等待數據發送完成
  50.                                                                 TI = 0;  
  51.                        
  52.                                 if (TI)
  53.                                 {
  54.                                                 TI = 0;     //清中斷標志
  55.                                                 P31 = !P31; //測試PWM端口
  56.                                 }
  57.                                 if (RI)// 如果串口接收到數據
  58.                                 {
  59.                                                 RI = 0;      //清中斷標志
  60.                                                 x =SBUF;
  61.                                                 if (x == 0x01)
  62.                                                 {
  63.                                                                 P31 = !P31;  //翻轉MOS管狀態
  64.                                                                 UartSend_Data('l');
  65.                                                 }               
  66.                                                 if (x == 0x02)
  67.                                                 {
  68.                                                                 P32 = !P32;  //翻轉led狀態
  69.                                                                 SBUF = 'm';  // 把要發送的數據給了SBUF寄存器
  70.                                                                 while(!TI);  // 等待數據發送完成
  71.                                                                 TI = 0;      // 清除發送完成標志位
  72.                                                 }               
  73.                                 }
  74.                 }
  75. }
復制代碼

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

Powered by 單片機教程網

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