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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

STM8 RS485的modbus通迅(主機及從機)程序代碼

  [復制鏈接]
跳轉到指定樓層
樓主
ID:155774 發表于 2017-8-24 15:49 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
如題,兩份源碼程序,STVD打開
STM8主控的RS485的modbus通迅所有資料51hei提供下載(含主機和從機程序):
STM8RS485通迅(主機).rar (572.8 KB, 下載次數: 1152)
STM8RS485通迅(從機).rar (613.53 KB, 下載次數: 930)

stm8單片機源程序(從機)如下:
  1. /* Includes ------------------------------------------------------------------*/
  2. #include "stm8s_lib.h"
  3. #include "functions.h"
  4. //#include "STM8S103F.h"
  5. #include "stm8s_tim1.h"

  6. /* Private typedef -----------------------------------------------------------*/
  7. /* Private define ------------------------------------------------------------*/

  8. u16                                          re_CRC16;
  9. u8                                                 CRC_Len;
  10. u8                                                 Data_Len;
  11. u8                                                 OffsetAdr;
  12. u8                                                 SlaveAdr;
  13. u8                                                 ModbusFC;
  14. ModBusData                 ModbusRAM[ModBusRAM_LEN_MAX];

  15. void Respond_ModbusREQ(void);
  16. void Init_Clock(void);
  17. /*
  18. void Init_GPIO(void);
  19. void Init_GPIO(void)
  20. {
  21.     GPIO_Init(GPIOD, GPIO_PIN_6, GPIO_MODE_IN_FL_NO_IT);                                //UART1 RX
  22.           GPIO_Init(GPIOD, GPIO_PIN_5, GPIO_MODE_OUT_PP_HIGH_FAST);                //UART1 TX
  23. }
  24. */
  25. void Init_Clock(void)//
  26. {
  27.     /* Select fCPU = 16MHz*/
  28.                 CLK_DeInit();
  29.     CLK_HSICmd(ENABLE);
  30.     CLK_HSECmd(DISABLE);
  31.                 CLK_SYSCLKConfig(CLK_PRESCALER_HSIDIV1);//CLK_PRESCALER_CPUDIV1 16mhz
  32.                 nop();nop();nop();nop();nop();nop();
  33.     //CLK_CCOConfig(CLK_OUTPUT_CPU);                                /* For test purpose output Fcpu on MCO pin */
  34. }
  35. /******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/
  36. void Respond_ModbusREQ(void)
  37.         {               
  38.                 u8 tmpMODBUS[RX_LEN_MAX];
  39.                 u8 i;
  40.                
  41.                 ModbusFC = MODBUS[1];
  42.                 Data_Len = MODBUS[5];
  43.                
  44.                 switch(ModbusFC)
  45.                         {
  46.                                 case 0x03:
  47.                                         i = 8;
  48.                                         break;
  49.                                        
  50.                                 case 0x10:
  51.                                         i = (u8)(9 +  (Data_Len * 2));
  52.                                         break;
  53.                                 
  54.                                 default:
  55.                                         i = 0;
  56.                                         break;
  57.                         }
  58.                 if(i>0)
  59.                         {
  60.                                 CRC_Len = (u8)(i - 2);
  61.                                 
  62.                                 while(i>0)
  63.                                 {
  64.                                         tmpMODBUS[i-1] = MODBUS[i-1];
  65.                                         i--;
  66.                                 }
  67.                                 
  68.                                 re_CRC16 = tmpMODBUS[CRC_Len + 1];
  69.                                 re_CRC16 = (re_CRC16<<8)+tmpMODBUS[CRC_Len];                                //尋找接收的CRC碼
  70.                                 CRC16    = crc16(tmpMODBUS,CRC_Len);                                                                //計算接收數據的CRC
  71.                                 if((re_CRC16 == CRC16)&&(OffsetAdr<ModBusRAM_LEN_MAX))//如果校驗正確  判斷功能碼和數據起始地址
  72.                                         {
  73.                                                 OffsetAdr = (u8)((tmpMODBUS[3]) * 2);                                                //OffsetAdr = tmpMODBUS[2] * 256 + tmpMODBUS[3];
  74.                                                 Data_Len  = (u8)(tmpMODBUS[5] * 2);                                                        //讀寫寄存器數量
  75.                                                 switch(ModbusFC)
  76.                                                         {  
  77.                                                                 case 0x03:                                                                                                                                         //判斷功能碼響應指令 發送被召喚數據
  78.                                                                 {
  79.                                                                         //if(tmpMODBUS[3] == 0x01)
  80.                                                                         //        {                                       
  81.                                                                         tmpMODBUS[2] = Data_Len;                                                                        //字節數=寄存器數量*2
  82.                                                                         for(i=0;i<Data_Len;i++)
  83.                                                                         {
  84.                                                                                 if(i & 0x01)
  85.                                                                                         tmpMODBUS[3 + i] = (u8)(ModbusRAM[((OffsetAdr+i)>>1)].ModBus16Word % 0x100);
  86.                                                                                 else
  87.                                                                                         tmpMODBUS[3 + i] = (u8)(ModbusRAM[((OffsetAdr+i)>>1)].ModBus16Word / 0x100);
  88.                                                                         }
  89.                                                                         
  90.                                                                         CRC_Len = (u8)(3 + Data_Len);
  91.                                                                         CRC16   = crc16(tmpMODBUS,CRC_Len);                                //計算接收數據的CRC
  92.                                                                         tmpMODBUS[CRC_Len]=(u8)(CRC16);                                                //LSB
  93.                                                                         tmpMODBUS[CRC_Len+1]=(u8)(CRC16>>8);                        //MSB
  94.                                                                         SEND_ON
  95.                                                                         for(i=0;i<CRC_Len+2;i++)                                                                        //發送應答數據        多寄存器讀命令返回
  96.                                                                                 {
  97.                                                                                         UART1->DR=tmpMODBUS[i];
  98.                                                                                         while (UART1_GetFlagStatus(UART1_FLAG_TXE) == RESET);                        //
  99.                                                                                 }
  100.                                                                         while (UART1_GetFlagStatus(UART1_FLAG_TC) == RESET);
  101.                                                                         SEND_OFF
  102.                                                                                 //}                        
  103.                                                                 }
  104.                                                                 break;
  105.                                                         
  106.                                                                 case 0x10:                                                                                                                                         //如果檢測到是多字節寫入指令
  107.                                                                 {
  108.                                                                         /*
  109.                                                                         FLASH_SetProgrammingTime(FLASH_PROGRAMTIME_STANDARD);                        //寫EEPROM準備
  110.                                                                         FLASH_Unlock(FLASH_MEMTYPE_DATA);        
  111.                                                                         
  112.                                                                         for(i=0;i<Data_Len;i++)                                                                        //寫EEP        
  113.                                                                                 {
  114.                                                                                         FLASH_ProgramByte((EEPROM_Start_Adr + OffsetAdr + i), tmpMODBUS[i + 7]);
  115.                                                                                 }
  116.                                                                         */
  117.                                                                         CRC_Len = 3 + 4;                                                                                                //發送應答數據
  118.                                                                         CRC16   = crc16(tmpMODBUS,CRC_Len);                        //計算接收數據的CRC

  119.                                                                         tmpMODBUS[CRC_Len]=(u8)(CRC16);                                        //LSB
  120.                                                                         tmpMODBUS[CRC_Len+1]=(u8)(CRC16>>8);                //MSB
  121.                                                                         SEND_ON
  122.                                                                         for(i=0;i<CRC_Len+2;i++)                                                                //發送應答數據
  123.                                                                                 {
  124.                                                                                         UART1->DR = tmpMODBUS[i];
  125.                                                                                         while (UART1_GetFlagStatus(UART1_FLAG_TXE) == RESET);
  126.                                                                                 }
  127.                                                                         while (UART1_GetFlagStatus(UART1_FLAG_TC) == RESET);
  128.                                                                         SEND_OFF
  129.                                                                 }
  130.                                                                 break;
  131.                                                                
  132.                                                                 default:
  133.                                                                         break;
  134.                                                         }
  135.                                                 return;                                                                                                                                                                        //直接退出中斷函數,不執行CT=CT+1;語句
  136.                                         }
  137.                                  else                                                                                                                                                                                         //如果校驗出錯  發送自定義異常代碼 80||03||10,04讀寫指令ERROR
  138.                                         {        
  139.                                                                                                                                                                                                                                                 //發送異常代碼
  140.                                                 tmpMODBUS[1] |= 0x80;                                                                                                                //異常指令 OR
  141.                                                 tmpMODBUS[2]        =        0x04;                                                                                                                //異常代碼

  142.                                                 CRC16   = crc16(tmpMODBUS,3);                                                                                //計算接收數據的CRC
  143.                                                 tmpMODBUS[3]         =        (u8)(CRC16);                                                                                //LSB
  144.                                                 tmpMODBUS[4]        =        (u8)(CRC16>>8);                                                                        //MSB
  145.                                                 
  146.                                                 SEND_ON
  147.                                                 for(CRC16=0;CRC16<5;CRC16++)                                                                                //發送應答數據
  148.                                                         {
  149.                                                                 UART1->DR=tmpMODBUS[CRC16];
  150.                                                                 while (UART1_GetFlagStatus(UART1_FLAG_TXE) == RESET);
  151.                                                         }
  152.                                                 while (UART1_GetFlagStatus(UART1_FLAG_TC) == RESET);
  153.                                                 SEND_OFF
  154.                                                 return;
  155.                                         }
  156.                         }
  157.         }
復制代碼





評分

參與人數 1黑幣 +5 收起 理由
lxmxyw + 5 好東西,學習

查看全部評分

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

使用道具 舉報

沙發
ID:65961 發表于 2017-9-4 20:45 | 只看該作者
好東西,正在學習
回復

使用道具 舉報

板凳
ID:59768 發表于 2017-9-25 11:06 | 只看該作者
好東西,頂頂
回復

使用道具 舉報

地板
ID:146544 發表于 2017-9-27 17:18 | 只看該作者
這是用什么軟件寫的?
回復

使用道具 舉報

5#
ID:146544 發表于 2017-10-19 20:27 | 只看該作者
請問這是用什么軟件編寫的?
回復

使用道具 舉報

6#
ID:98767 發表于 2017-10-20 01:07 | 只看該作者
STVD寫的
回復

使用道具 舉報

7#
ID:67853 發表于 2017-10-21 11:03 | 只看該作者
好東西啊,謝謝啊
回復

使用道具 舉報

8#
ID:67853 發表于 2017-10-21 11:04 | 只看該作者

學習學習,非常感謝!!!!
回復

使用道具 舉報

9#
ID:137543 發表于 2017-10-22 18:49 | 只看該作者
大贊一個,雖然自己已經用了RS485通信好幾年了
回復

使用道具 舉報

10#
ID:45457 發表于 2017-10-23 09:06 | 只看該作者
好東西啊
回復

使用道具 舉報

11#
ID:45457 發表于 2017-10-23 20:25 | 只看該作者
STM8 RS485的modbus通迅(主機及從機)程序代碼
回復

使用道具 舉報

12#
ID:242552 發表于 2017-10-24 20:50 | 只看該作者
謝謝分享
回復

使用道具 舉報

13#
ID:237527 發表于 2017-10-25 00:39 | 只看該作者
不錯的程序哦
回復

使用道具 舉報

14#
ID:155774 發表于 2017-11-12 03:18 | 只看該作者
樓主宅心仁厚!謝謝,有沒相關圖紙?
回復

使用道具 舉報

15#
ID:257805 發表于 2017-12-5 18:24 | 只看該作者
非常感謝
回復

使用道具 舉報

16#
ID:261411 發表于 2017-12-14 09:57 | 只看該作者

好東西啊,謝謝啊
回復

使用道具 舉報

17#
ID:110369 發表于 2017-12-15 15:58 | 只看該作者
樓主雪中送炭!
回復

使用道具 舉報

18#
ID:258322 發表于 2018-1-3 15:35 | 只看該作者
非常感謝,學習1中
回復

使用道具 舉報

19#
ID:260390 發表于 2018-1-4 11:35 | 只看該作者
好東西,正在學習
回復

使用道具 舉報

20#
ID:155817 發表于 2018-1-5 14:42 | 只看該作者
好東西,謝謝分享
回復

使用道具 舉報

21#
ID:273285 發表于 2018-1-10 10:39 | 只看該作者
發現一個問題啊,用這個的從機代碼出現這樣一個情況。
如果之前發送的沒問題的話,那么從機反饋的數據也正常。
但是一旦發送過一次有問題的數據,使其返回錯誤代碼了的話,之后即便再發送正確的數據,也是返回錯誤代碼。
回復

使用道具 舉報

22#
ID:275068 發表于 2018-1-12 08:17 | 只看該作者
回復了是不是就可以下載
回復

使用道具 舉報

23#
ID:276106 發表于 2018-1-15 11:43 | 只看該作者
一直再尋找,非常感謝
回復

使用道具 舉報

24#
ID:277321 發表于 2018-1-18 13:25 | 只看該作者
STM8L的可以用嗎
回復

使用道具 舉報

25#
ID:65961 發表于 2018-1-27 22:31 | 只看該作者

好東西,頂頂
回復

使用道具 舉報

26#
ID:280092 發表于 2018-1-29 21:24 | 只看該作者
這沒用過stvd,特地下載了一個,但是要打開哪個文件啊
回復

使用道具 舉報

27#
ID:247622 發表于 2018-2-28 17:39 | 只看該作者
candura 發表于 2018-1-10 10:39
發現一個問題啊,用這個的從機代碼出現這樣一個情況。
如果之前發送的沒問題的話,那么從機反饋的數據也正 ...

怎么好像進不了中斷?還有,你們是用的什么串口工具啊
回復

使用道具 舉報

28#
ID:247622 發表于 2018-2-28 19:10 | 只看該作者
樓主有沒有相應的PC端工具
回復

使用道具 舉報

29#
ID:277321 發表于 2018-3-6 17:40 | 只看該作者
學習一下,有沒有IAR的
回復

使用道具 舉報

30#
ID:117531 發表于 2018-3-7 09:02 | 只看該作者
謝謝樓主,下來學習
回復

使用道具 舉報

31#
ID:291582 發表于 2018-3-14 00:21 | 只看該作者
謝謝了 很不錯 棒棒的
回復

使用道具 舉報

32#
ID:291582 發表于 2018-3-14 00:21 | 只看該作者
大贊一個,RS485通信很經典
回復

使用道具 舉報

33#
ID:298533 發表于 2018-3-28 20:08 | 只看該作者
好東西
回復

使用道具 舉報

34#
ID:302542 發表于 2018-4-5 21:06 | 只看該作者
謝謝分享
回復

使用道具 舉報

35#
ID:304353 發表于 2018-4-9 12:46 | 只看該作者

謝謝分享
回復

使用道具 舉報

36#
ID:311300 發表于 2018-5-15 19:34 | 只看該作者
主機模式怎么跟從機是一樣的呢?
回復

使用道具 舉報

37#
ID:331754 發表于 2018-5-16 23:33 | 只看該作者
向樓主多學習
回復

使用道具 舉報

38#
ID:337376 發表于 2018-5-24 16:12 | 只看該作者
謝謝分享
回復

使用道具 舉報

39#
ID:337808 發表于 2018-5-26 23:17 | 只看該作者
不錯,程序結構非常好。CRC16   = crc16(tmpMODBUS,3);  中的unsigned int CRC16(unsinge char *dat,unsigned char len)函數沒有看到呢?我其實是想找CRC算法來的。
回復

使用道具 舉報

40#
ID:264733 發表于 2018-6-9 16:20 | 只看該作者

一直再尋找,非常感謝
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 成人看片在线观看 | 老牛影视av一区二区在线观看 | 日韩精品一区二区三区中文在线 | 精品国产欧美 | 男女羞羞免费视频 | 免费同性女女aaa免费网站 | 国产一区二区三区久久久久久久久 | 欧美日在线 | 国产高清视频 | 精品久久久久久久久久久久久久 | 成人二区三区 | 日韩av在线中文字幕 | 97偷拍视频| 日本不卡一区 | 亚洲国产欧美一区二区三区久久 | 91资源在线 | 一区二区免费高清视频 | 精品www| 天天夜碰日日摸日日澡 | 91豆花视频| 国产视频一二三区 | 成人精品毛片国产亚洲av十九禁 | 国产成人免费视频网站高清观看视频 | 精品一区二区三区四区在线 | 欧美福利| 精品美女久久久久久免费 | 国产一区二区三区在线视频 | 国产成人精品网站 | 97色综合 | 一区二区三区日韩 | 日本一卡精品视频免费 | 久久色视频| 日韩一级免费电影 | 国产激情在线观看视频 | 久久国 | 四虎首页 | 日韩激情在线 | 欧美在线视频网 | 国产成人综合在线 | 国产午夜精品一区二区三区嫩草 | 蜜桃黄网 |