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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 7351|回復: 16
打印 上一主題 下一主題
收起左側

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

[復制鏈接]
跳轉到指定樓層
#
請大俠指點下:
串口為什么發送正常,接收卻不正常呢?



單片機源程序如下:

  1. #include "STC8G.h" #include "intrins.h"  

  2. void UartInit(void)                //115200bps@35MHz
  3. {         SCON = 0x50;                //8位數據,可變波特率         AUXR |= 0x40;                //定時器時鐘1T模式         AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器         TMOD &= 0x0F;                //設置定時器模式         TL1 = 0xB4;                //設置定時初始值         TH1 = 0xFF;                //設置定時初始值         ET1 = 0;                //禁止定時器%d中斷         TR1 = 1;                //定時器1開始計時 }  void GPI_Init(void) {           P0M0 = 0x00;     P0M1 = 0x00;     P1M0 = 0x00;     P1M1 = 0x00;     P2M0 = 0x00;     P2M1 = 0x00;     P3M0 = 0x00;     P3M1 = 0x00;     P4M0 = 0x00;     P4M1 = 0x00;     P5M0 = 0x00;     P5M1 = 0x00;     P31 = 0; //PWM關 }  /* 串口發送字節數據函數 參數是你要發送的字節 */ void UartSend_Data(unsigned char dat) {         SBUF = dat;  // 把要發送的數據給了SBUF寄存器         while(!TI);  // 等待數據發送完成         TI = 0;      // 清除發送完成標志位 }

  4. void main() {               
  5. /* 定義一個8位變量 用于接收串口接收的字節 */                 
  6. unsigned char x =0;                          /* IO設置*/                 GPI_Init();                                  UartInit(); // 串口初始化      

  7. while (1)                 
  8. {                                
  9. if (TI)                                 {                                                
  10. TI = 0;     //清中斷標志                                                
  11. P31 = !P31; //測試PWM端口                                 }                                
  12. if (RI)// 如果串口接收到數據                                 {                                                
  13. RI = 0;      //清中斷標志                                                
  14. x =SBUF;                                                
  15. if (x == 0x01)                                                 {                                                                 
  16. P31 = !P31;  //翻轉MOS管狀態                                                                 
  17. UartSend_Data('l');                                                 }                                                               
  18. if (x == 0x02)                                                
  19. {                                                               
  20. P32 = !P32;  //翻轉led狀態                                                                 
  21. SBUF = 'm';  // 把要發送的數據給了SBUF寄存器                                                                 
  22. while(!TI);  // 等待數據發送完成                                                                 
  23. TI = 0;      // 清除發送完成標志位                                                 }                                                 }                 } }
復制代碼



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

16#
ID:725306 發表于 2022-1-15 10:02 | 只看該作者

用的查詢法,不需要EA=1;
回復

使用道具 舉報

15#
ID:725306 發表于 2022-1-15 10:01 | 只看該作者
TEC 發表于 2022-1-14 11:00
你這個程序單片機沒法工作的,單片機不能接收,也不能發送,單片機和上位機無法通信。發送成功和單片機沒關 ...

原來上傳的程序串口初始化中,P31 = 0; //PWM關 這一句不能寫的。寫了串口就收發不了數據了。
回復

使用道具 舉報

14#
ID:725306 發表于 2022-1-15 09:51 | 只看該作者
TEC 發表于 2022-1-14 11:00
你這個程序單片機沒法工作的,單片機不能接收,也不能發送,單片機和上位機無法通信。發送成功和單片機沒關 ...

單片機可以接收,LED是有動作的。只是上位機接收不到串口發送的。原因為P32是串口。不能操作的同時收發數據。

51hei圖片_20220115094952.png (37.01 KB, 下載次數: 109)

調整波特率為9600以后的效果

調整波特率為9600以后的效果
回復

使用道具 舉報

13#
ID:725306 發表于 2022-1-15 09:38 | 只看該作者
188610329 發表于 2022-1-11 21:06
你知道不知道  P31 是用來干什么的么?
你一邊要用  P31 發送串口, 一邊還要反轉  P31, 心不是一般的大阿 ...

大哥,就是這個問題 。。。。。 后來我調整了波特率為9600,可以正常收到數據了。因為用的事8腳的單片機,資源比較少,所以調試的時候想看看正常不。謝謝,貼吧是個好環境,大家都會幫助小白菜。
回復

使用道具 舉報

12#
ID:625730 發表于 2022-1-14 11:00 | 只看該作者
你這個程序單片機沒法工作的,單片機不能接收,也不能發送,單片機和上位機無法通信。發送成功和單片機沒關系,是上位機給單片機發送了數據,但是單片機沒法接收到。
回復

使用道具 舉報

11#
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. }
復制代碼
回復

使用道具 舉報

10#
ID:25310 發表于 2022-1-12 15:46 | 只看該作者
EA=1 有嗎?
回復

使用道具 舉報

9#
ID:624769 發表于 2022-1-11 21:06 | 只看該作者
你知道不知道  P31 是用來干什么的么?
你一邊要用  P31 發送串口, 一邊還要反轉  P31, 心不是一般的大阿……
回復

使用道具 舉報

8#
ID:725306 發表于 2022-1-11 19:18 | 只看該作者
npn 發表于 2022-1-11 18:51
35Mhz/115200 不能被整除,你要用33.1776Mhz的晶振。

按照你的方法 還是不行。void UartInit(void)                //115200bps@33.1776MHz
{
        SCON = 0x50;                //8位數據,可變波特率
        AUXR |= 0x40;                //定時器時鐘1T模式
        AUXR &= 0xFE;                //串口1選擇定時器1為波特率發生器
        TMOD &= 0x0F;                //設置定時器模式
        TL1 = 0xB8;                //設置定時初始值
        TH1 = 0xFF;                //設置定時初始值
        ET1 = 0;                //禁止定時器%d中斷
        TR1 = 1;                //定時器1開始計時
}


回復

使用道具 舉報

7#
ID:725306 發表于 2022-1-11 19:10 | 只看該作者
npn 發表于 2022-1-11 18:51
35Mhz/115200 不能被整除,你要用33.1776Mhz的晶振。

按照你說的調節了, 還是不行
回復

使用道具 舉報

6#
ID:725306 發表于 2022-1-11 18:53 | 只看該作者
npn 發表于 2022-1-11 18:51
35Mhz/115200 不能被整除,你要用33.1776Mhz的晶振。

下面顯示已自動調節為35.004MHz了呀
回復

使用道具 舉報

5#
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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲人成人一区二区在线观看 | 九色视频网站 | 九九久久国产 | 久久久久久久一区 | 在线视频 亚洲 | 日韩欧美日韩在线 | 夜夜爽99久久国产综合精品女不卡 | 国产精品久久久久一区二区三区 | 欧美一级网站 | 欧美日韩在线免费观看 | 99视频在线免费观看 | 在线观看免费av网站 | 激情自拍偷拍 | 一区二区三区亚洲视频 | 草草视频在线免费观看 | 国产福利91精品一区二区三区 | www久久99| 99久久精品免费看国产高清 | 国产午夜精品久久久 | 91精品国产一区二区三区动漫 | 日日草天天干 | 人人人人人爽 | 一级毛片免费完整视频 | 狠狠艹 | 国产成人精品久久二区二区91 | 欧美福利视频一区 | 少妇精品久久久久久久久久 | 黑人精品欧美一区二区蜜桃 | 欧美日韩一区不卡 | 久久久免费观看视频 | 巨大黑人极品videos精品 | 亚洲一区中文字幕在线观看 | 成人在线观看免费 | 黄a网站 | 日韩av免费在线电影 | 黄色一级免费看 | 日韩欧美在线不卡 | 特黄视频| 国产一级淫片a直接免费看 免费a网站 | 久久精品一 | 欧美久久久久久 |