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

標題: 關于rs485多機通信系統單片機源程序仿真與通信協議等資料 [打印本頁]

作者: 靈現江湖    時間: 2018-1-2 20:27
標題: 關于rs485多機通信系統單片機源程序仿真與通信協議等資料
這是rs485通信協議等資料,本人在此共享出來,謝謝



一、RS485基本知識
RS-485接口芯片已廣泛應用于工業控制、儀器、儀表、多媒體網絡、機電一體化產品等諸多領域。可用于RS-485接口的芯片種類也越來越多。如何在種類繁多的接口芯片中找到最合適的芯片,是擺在每一個使用者面前的一個問題。RS-485接口在不同的使用場合,對芯片的要求和使用方法也有所不同。使用者在芯片的選型和電路的設計上應考慮哪些因素,由于某些芯片的固有特性,通信中有些故障甚至還需要在軟件上作相應調整,如此等等。希望本文對解決RS-485接口的某些常見問題有所幫助。
1 RS-485接口標準
傳輸方式:差分
傳輸介質:雙絞線
標準節點數:32
最遠通信距離:1200m 共模電壓最大、最小值:+12V;-7V
差分輸入范圍:-7V~+12V
接收器輸入靈敏度:±200mV
接收器輸入阻抗:≥12kΩ
2 節點數及半雙工和全雙工通信



rs485仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)

單片機源程序如下:
  1.   
  2. /****************************************/
  3. /* Copyright (c) 2017, 通信工程學院     */
  4. /* All rights reserved.                 */
  5. /****************************************/

  6. #include "RS485.h"

  7. //主函數
  8. void main(void)
  9. {
  10.         uchar type;

  11.         Init();//初始化
  12.         
  13.         while (1)
  14.         {
  15.                 if (RecvData(&type)==0)                        // 接收幀錯誤或者地址不符合,丟棄
  16.                         continue;
  17.                
  18.                 switch (type)
  19.                 {
  20.                         case ACTIVE:                                // 主機詢問從機是否在位
  21.                                 SendData(READY,0,StatusBuf);        // 發送READY指令
  22.                                 break;
  23.                         case GETDATA:                                // 主機讀設備請求
  24.                                 ClrStatusBuf();
  25.                                 GetStat();                                // 數據采集函數
  26.                                 SendData(SENDDATA,strlen(StatusBuf),StatusBuf);
  27.                                 break;
  28.                         default:
  29.                                 break;                                        // 指令類型錯誤,丟棄當前幀
  30.                 }
  31.         }
  32. }




  33. //初始化
  34. void Init(void)
  35. {
  36.         P1 = 0xFF;
  37.         DevNo = (P1&0x00111111);                        // 讀取本機設備號

  38.         TMOD = 0x20;//定時器T1,工作方式2,自動重裝
  39.         SCON = 0x50;//串口通信工作方式1,允許接收
  40.         TH1 = 0xFD;//波特率9600
  41.         TL1 = 0xFD;
  42.         TR1 = 1;
  43.         PCON = 0x00;// SMOD=0,波特率不加倍
  44.         EA = 0;
  45.                                                 
  46. }

  47. //接收數據幀函數,實際上接收的是主機的指令
  48. //*type指令類型
  49. bit RecvData(uchar *type)
  50. {
  51.         uchar tmp,rCount,i;
  52.         uchar r_buf[RECFRMMAXLEN];                        // 保存接收到的幀
  53.         uchar FlagRecvOver;                                // 一幀接收結束標志        
  54.         uchar FlagStartRec;                                // 一幀開始接收標志
  55.         uchar CheckSum;                                                // 校驗和
  56.         uchar DataLen;                                                // 數據字節長度變量
  57.                
  58.         //禁止發送,允許接收
  59.         DE = 0;
  60.         RE = 0;

  61.         //接收一幀數據
  62.         rCount = 0;
  63.         FlagStartRec = 0;
  64.   FlagRecvOver = 0;
  65.         
  66.         while (!FlagRecvOver)
  67.         {
  68.                 RI = 0;
  69.                 while (!RI);
  70.                 tmp = SBUF;
  71.                 RI=0;

  72. …………
  73. …………限于本文篇幅 余下代碼請從51黑下載附件…………
  74. ,其數值為0x24         
  75.                 if ((!FlagStartRec) && (tmp == 0x24))
  76.                 {
  77.                         FlagStartRec = 1;        
  78.                 }

  79.                 if (FlagStartRec)
  80.                 {
  81.                         r_buf[rCount] = tmp;
  82.                         rCount ++;               
  83.                         
  84.                         //判斷是否收到字符'*',其數值為0x2A,根據接收的指令設置相應標志位
  85.                         if (tmp == 0x2A)
  86.                                 FlagRecvOver = 1;
  87.                 }

  88.                 if (rCount == RECFRMMAXLEN)                // 幀超長錯誤,返回0
  89.                         return 0;
  90.         }
  91.         
  92.         //計算校驗和字節
  93.         CheckSum = 0;
  94.         DataLen = r_buf[3];
  95.         
  96.         for (i=0;i<3+DataLen;i++)
  97.         {
  98.                 CheckSum = CheckSum + r_buf[i+1];
  99.         }
  100.         
  101.         //判斷幀是否錯誤
  102.         if (rCount<6)                                                // 幀過短錯誤,返回0,最短的指令幀為6個字節                                                
  103.                 return 0;
  104.         
  105.         if (r_buf[1]!=DevNo)                                  // 地址不符合,錯誤,返回0
  106.                 return 0;
  107.         
  108.         if (r_buf[rCount-2]!=CheckSum)                // 校驗錯誤,返回0
  109.             return 0;

  110.         *type = r_buf[2];                                        // 獲取指令類型

  111.         return 1;                                                        // 成功,返回1
  112. }


  113. //發送數據幀函數
  114. //type數據類型,len數據長度,*buf數據
  115. void SendData(uchar type,uchar len,uchar *buf)
  116. {
  117.         uchar i,tmp;
  118.         uchar CheckSum = 0;
  119.         
  120.         //允許發送,禁止接收
  121.         DE = 1;
  122.         RE = 1;
  123.         
  124.         //發送幀起始字節
  125.         tmp = 0x24;
  126.         Send(tmp);
  127.         
  128.         Send(DevNo);// 發送地址字節,也即設備號
  129.         CheckSum = CheckSum + DevNo;

  130.         Send(type);                                                        // 發送類型字節
  131.         CheckSum = CheckSum + type;

  132.         Send(len);                                                        // 發送數據長度字節
  133.         CheckSum = CheckSum + len;

  134.         //發送數據
  135.         for (i=0;i<len;i++)                        
  136.         {
  137.                 Send(*buf);
  138.                 CheckSum = CheckSum + *buf;
  139.                 buf++;
  140.         }
  141.         
  142.         Send(CheckSum);// 發送校驗和字節

  143.         //發送幀結束字節
  144.         tmp = 0x2A;
  145.         Send(tmp);
  146. }

  147. //采集數據函數經過簡化處理,取固定的10個字節數據
  148. void GetStat(void)
  149. {
  150.         StatusBuf[0]=DATA0;
  151.         StatusBuf[1]=DATA1;
  152.         StatusBuf[2]=DATA2;
  153.         StatusBuf[3]=DATA3;
  154.         StatusBuf[4]=DATA4;
  155.         StatusBuf[5]=DATA5;
  156.         StatusBuf[6]=DATA6;
  157. ……………………

  158. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
RS485通信協議及程序.zip (1.41 MB, 下載次數: 307)





作者: huaishang    時間: 2018-1-5 21:15
感謝分享,謝謝!
作者: xml9527    時間: 2018-1-6 12:24
485通訊,工控通訊主流
作者: simon1777    時間: 2018-6-7 19:11
這個按鍵控制要顯示的字符嗎
作者: kidark    時間: 2018-6-26 10:57
兩個從機的程序都是一樣的嗎
作者: kidark    時間: 2018-6-26 18:05
還有那個通信協議有哪位大佬講解一下嗎。。

作者: kidark    時間: 2018-6-26 18:17
或者數據包格式啊。。

作者: xiubing65    時間: 2018-7-4 21:49
不錯,是RTU嗎
作者: chenxiaojun1234    時間: 2018-7-27 21:09
感謝分享,謝謝!
作者: 皂皂奧奧    時間: 2018-11-11 11:47
感謝分享,謝謝!
作者: gemxie    時間: 2018-11-12 15:18
謝謝分享了。。學習學習
作者: Host    時間: 2018-11-20 13:48
謝謝分享
作者: 如果能編程回憶    時間: 2018-11-27 11:11
正好在學習
作者: x363731807    時間: 2019-1-11 13:02
感謝分享
作者: 該賬號已注銷    時間: 2019-3-16 10:04
感謝分享

作者: nishuideyu45    時間: 2019-5-12 02:25
學習了
作者: red178    時間: 2019-5-12 11:23
努力學習中。
作者: 起個名字下附件    時間: 2019-5-16 13:47
謝謝分享
作者: 電氣滔滔    時間: 2019-6-7 09:21
謝謝樓主




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1