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

標題: STM32 RS485 modbus通訊源程序,親測有效 [打印本頁]

作者: 簡鐺鐺鐺鐺    時間: 2018-10-16 08:56
標題: STM32 RS485 modbus通訊源程序,親測有效
Modbus 一個工業上常用的通訊協議、一種通訊約定。Modbus協議包括RTU、ASCII、TCP。其中MODBUS-RTU最常用,比較簡單,在單片機上很容易實現。modbus協議簡單解析如下:
1、主機對從機寫數據操作
如果單片機接收到一個報文那么就對報文進行解析執行相應的處理,如上面報文:
    01             06            00 01           00 17          98 04
  從機地址        功能號          數據地址          數據         CRC校驗

假如本機地址是 1 ,那么單片機接收到這串數據根據數據計算CRC校驗判斷數據是否正確,如果判斷數據無誤,則結果是:
            HoldDataReg[1]  =  0x0017;
MODBUS主機就完成了一次對從機數據的寫操作,實現了通訊。

2、主機對從機讀數據操作
主機進行讀HoldDataReg[1] 操作,則報文是:
    01             03            00 01           00 01          D5 CA
從機地址        功能號          數據地址      讀取數據個數       CRC校驗
那么單片機接收到這串數據根據數據計算CRC校驗判斷數據是否正確,如果判斷數據無誤,則結果是:返回信息給主機,返回的信息也是有格式的:
返回內容:  
    01         03            02             0017          F8 4A
  從機地址   功能號     數據字節個數    兩個字節數據    CRC校驗
MODBUS主機就完成了一次對從機數據的讀操作,實現了通訊。


上傳的程序是根據手把手教你51單片機的例程修改而來,能實現讀/寫操作(03,06碼),成功通過modbus調試精靈測試,讀寫通訊正常!
由于剛接觸modbus通訊協議,之前一直出現通訊超時的問題,找了網上很多資料,都不得其解,所以把程序拿出來和大家分享。希望和大家相互學習、共同進步!


單片機源程序如下:
  1. #include "rs485.h"
  2. #include "SysTick.h"
  3. #include "crc16.h"
  4. #include "led.h"

  5. /*******************************************************************************
  6. * 函 數 名         : RS485_Init
  7. * 函數功能                   : USART2初始化函數
  8. * 輸    入         : bound:波特率
  9. * 輸    出         : 無
  10. *******************************************************************************/  
  11. u8 USART2_RX_BUF[64];                   //接收緩沖,最大64字節
  12. u8 USART2_RX_CNT=0;                       //接收字節計數器
  13. u8 flagFrame=0;                         //幀接收完成標志,即接收到一幀新數據
  14. unsigned char regGroup[5];  //Modbus寄存器組,地址為0x00~0x04

  15. void RS485_Init(u32 bound)
  16. {
  17.         GPIO_InitTypeDef GPIO_InitStructure;
  18.         USART_InitTypeDef USART_InitStructure;
  19.         NVIC_InitTypeDef NVIC_InitStructure;
  20.        
  21.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOG|RCC_APB2Periph_GPIOA,ENABLE); //使能GPIOA\G時鐘
  22.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2時鐘
  23.        
  24.         /*  配置GPIO的模式和IO口 */
  25.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2;        //TX-485        //串口輸出PA2
  26.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP;                  //復用推挽輸出
  27.         GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;       
  28.         GPIO_Init(GPIOA,&GPIO_InitStructure);                /* 初始化串口輸入IO */
  29.        
  30.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_3;        //RX-485           //串口輸入PA3
  31.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;            //模擬輸入
  32.         GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
  33.         GPIO_Init(GPIOA,&GPIO_InitStructure);
  34.        
  35.         GPIO_InitStructure.GPIO_Pin=GPIO_Pin_3;        //CS-485
  36.         GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;           //推挽輸出
  37.         GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
  38.         GPIO_Init(GPIOG,&GPIO_InitStructure);
  39.        
  40.         //USART2 初始化設置
  41.         USART_InitStructure.USART_BaudRate = bound;//波特率設置
  42.         USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字長為8位數據格式
  43.         USART_InitStructure.USART_StopBits = USART_StopBits_1;//一個停止位
  44.         USART_InitStructure.USART_Parity = USART_Parity_No;//無奇偶校驗位
  45.         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//無硬件數據流控制
  46.         USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;        //收發模式
  47.         USART_Init(USART2, &USART_InitStructure); //初始化串口2
  48.        
  49.         USART_Cmd(USART2, ENABLE);  //使能串口 2
  50.        
  51.         USART_ClearFlag(USART2, USART_FLAG_TC);
  52.                
  53.         USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//開啟接受中斷

  54.         //Usart2 NVIC 配置
  55.         NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
  56.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=2;//搶占優先級3
  57.         NVIC_InitStructure.NVIC_IRQChannelSubPriority =2;                //子優先級2
  58.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQ通道使能
  59.         NVIC_Init(&NVIC_InitStructure);        //根據指定的參數初始化VIC寄存器、
  60.        
  61.         RS485_TX_EN=0;                                //默認為接收模式       
  62. }

  63.        

  64. //1ms定時

  65. void TIM2_Init()
  66. {
  67.         TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
  68.         NVIC_InitTypeDef NVIC_InitStructure;
  69.        
  70.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);//使能TIM4時鐘
  71.        
  72.         TIM_TimeBaseInitStructure.TIM_Period=1000;   //自動裝載值
  73.         TIM_TimeBaseInitStructure.TIM_Prescaler=72-1; //分頻系數
  74.         TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1;
  75.         TIM_TimeBaseInitStructure.TIM_CounterMode=TIM_CounterMode_Up; //設置向上計數模式
  76.         TIM_TimeBaseInit(TIM2,&TIM_TimeBaseInitStructure);
  77.        
  78.         TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE); //開啟定時器中斷
  79.         TIM_ClearITPendingBit(TIM2,TIM_IT_Update);
  80.        
  81.         NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;//定時器中斷通道
  82.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=2;//搶占優先級
  83.         NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;                //子優先級
  84.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQ通道使能
  85.         NVIC_Init(&NVIC_InitStructure);       
  86.        
  87.         TIM_Cmd(TIM2,ENABLE); //使能定時器       
  88. }


  89. //計算發送的數據長度,并且將數據放到*buf數組中                     
  90. u8 UartRead(u8 *buf, u8 len)  
  91. {
  92.          u8 i;
  93.         if(len>USART2_RX_CNT)  //指定讀取長度大于實際接收到的數據長度時
  94.         {
  95.                 len=USART2_RX_CNT; //讀取長度設置為實際接收到的數據長度
  96.         }
  97.         for(i=0;i<len;i++)  //拷貝接收到的數據到接收指針中
  98.         {
  99.                 *buf=USART2_RX_BUF[i];  //將數據復制到buf中
  100.                 buf++;
  101.         }
  102.         USART2_RX_CNT=0;              //接收計數器清零
  103.         return len;                   //返回實際讀取長度
  104. }


  105. u8 rs485_UartWrite(u8 *buf ,u8 len)                                                                                 //發送
  106. {
  107.         u8 i=0;
  108.    GPIO_SetBits(GPIOG,GPIO_Pin_3);                                            //發送模式
  109.    delay_ms(3);                                                               //3MS延時
  110.     for(i=0;i<=len;i++)
  111.     {
  112.         USART_SendData(USART2,buf[i]);                                              //通過USARTx外設發送單個數據
  113.         while(USART_GetFlagStatus(USART2,USART_FLAG_TXE)==RESET);             //檢查指定的USART標志位設置與否,發送數據空位標志
  114.     }
  115.     GPIO_ResetBits(GPIOG,GPIO_Pin_3);                                         //設置為接收模式

  116. }





  117. //串口驅動函數,檢測數據幀的接收,調度功能函數,需在主循環中調用
  118. void UartDriver()
  119. {
  120.         unsigned char i=0,cnt;
  121.         unsigned int crc;
  122.         unsigned char crch,crcl;
  123.         static u8 len;
  124.         static u8 buf[60];
  125.         if(flagFrame)            //幀接收完成標志,即接收到一幀新數據
  126.         {
  127.                 flagFrame=0;           //幀接收完成標志清零
  128.                 len = UartRead(buf,sizeof(buf));   //將接收到的命令讀到緩沖區中
  129.                 if(buf[0]==0x01)                   //判斷地址是不是0x01
  130.                 {
  131.                         crc=GetCRC16(buf,len-2);       //計算CRC校驗值,出去CRC校驗值
  132.                         crch=crc>>8;                                    //crc高位
  133.                         crcl=crc&0xFF;                                        //crc低位
  134.                         if((buf[len-2]==crch)&&(buf[len-1]==crcl))  //判斷CRC校驗是否正確
  135.                         {
  136.                                 switch (buf[1])  //按功能碼執行操作
  137.                                 {
  138.                                         case 0x03:     //讀數據
  139.                                                 if((buf[2]==0x00)&&(buf[3]<=0x05))  //寄存器地址支持0x0000~0x0005
  140.                                                 {
  141.                                                        
  142.                                                         if(buf[3]<=0x04)
  143.                                                         {
  144.                                                                 i=buf[3];//提取寄存器地址
  145.                                                                 cnt=buf[5];  //提取待讀取的寄存器數量
  146.                                                                 buf[2]=cnt*2;  //讀取數據的字節數,為寄存器*2,因modbus定義的寄存器為16位
  147.                                                                 len=3;                                                       
  148.                                                                 while(cnt--)
  149.                                                                 {
  150.                                                                         buf[len++]=0x00;                                //寄存器高字節補0
  151.                                                                         buf[len++]=regGroup[i++];                //低字節
  152.                                                         }
  153.                                                        
  154.                                                 }
  155.                                                         break;
  156.                                         }
  157.                                                 else  //寄存器地址不被支持時,返回錯誤碼
  158.                                                 {   
  159.                                                         buf[1]=0x83;  //功能碼最高位置1
  160.                                                         buf[2]=0x02;  //設置異常碼為02-無效地址
  161.                                                         len=3;
  162.                                                         break;
  163.                                                 }
  164.                                         case 0x06:           //寫入單個寄存器
  165.                                                 if((buf[2]==0x00)&&(buf[3]<=0x05))   //寄存器地址支持0x0000-0x0005
  166.                                                 {
  167.                                                         if(buf[3]<=0x04)
  168.                                                         {
  169.                                                                 i=buf[3];                                //提取寄存器地址
  170.                                                                 regGroup[i]=buf[5];                //保存寄存器數據
  171.                                                                 led3=0;
  172.                                                         }
  173.                                                         len -=2;                 //長度-2以重新計算CRC并返回原幀
  174.                                                         break;
  175.                                                 }
  176.                                                 else  
  177.                                                 {                                                        //寄存器地址不被支持,返回錯誤碼
  178.                                                         buf[1]=0x86;           //功能碼最高位置1
  179.                                                         buf[2]=0x02;           //設置異常碼為02-無效地址
  180.                                                         len=3;
  181.                                                         break;
  182.                                         }
  183.                                         default:    //其他不支持的功能碼
  184.                                                     buf[1]=0x80;     //功能碼最高位置1
  185.                                                         buf[2]=0x01;     //設置異常碼為01—無效功能
  186.                                                         len=3;
  187.                                                         break;
  188.                                 }
  189.                             crc=GetCRC16(buf,len);           //計算CRC校驗值
  190.                                 buf[len++]=crc>>8;           //CRC高字節
  191.                                 buf[len++]=crc&0xff;        //CRC低字節
  192.                                 rs485_UartWrite(buf,len);  //發送響應幀
  193.                         }
  194.                 }
  195.         }
  196. }


  197.                                
  198. void UartRxMonitor(u8 ms) //串口接收監控
  199. {
  200.         static u8 USART2_RX_BKP=0;  //定義USART2_RC_BKP暫時存儲詩句長度與實際長度比較
  201.         static u8 idletmr=0;        //定義監控時間
  202.         if(USART2_RX_CNT>0)//接收計數器大于零時,監控總線空閑時間
  203.         {
  204.                 if(USART2_RX_BKP!=USART2_RX_CNT) //接收計數器改變,即剛接收到數據時,清零空閑計時
  205.                 {
  206.                         USART2_RX_BKP=USART2_RX_CNT;  //賦值操作,將實際長度給USART2_RX_BKP
  207.                         idletmr=0;                    //將監控時間清零
  208.                 }
  209.                 else                              ////接收計數器未改變,即總線空閑時,累計空閑時間
  210.                 {
  211.                         //如果在一幀數據完成之前有超過3.5個字節時間的停頓,接收設備將刷新當前的消息并假定下一個字節是一個新的數據幀的開始
  212.                         if(idletmr<5)                  //空閑時間小于1ms時,持續累加
  213.                         {
  214.                                 idletmr +=ms;
  215.                                 if(idletmr>=5)             //空閑時間達到1ms時,即判定為1幀接收完畢
  216.                                 {
  217.                                         flagFrame=1;//設置命令到達標志,幀接收完畢標志
  218.                                 }
  219.                         }
  220.                 }
  221.         }
  222.         else
  223.         {
  224.                 USART2_RX_BKP=0;
  225.         }
  226. }
  227.                                                        
  228.                                                
  229.                                                        
  230.                        
  231.                
  232. /*******************************************************************************
  233. * 函 數 名         : USART2_IRQHandler
  234. * 函數功能                   : USART2中斷函數
  235. * 輸    入         : 無
  236. * 輸    出         : 無
  237. *******************************************************************************/
  238. void USART2_IRQHandler(void)
  239. ……………………

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

所有資料51hei提供下載:
29. RS485通信實驗.rar (273.59 KB, 下載次數: 4563)



作者: 17351371760    時間: 2018-10-25 10:11
你好! 這個功能模塊能實現多機進行485通信嗎
作者: 簡鐺鐺鐺鐺    時間: 2018-10-25 13:27
17351371760 發表于 2018-10-25 10:11
你好! 這個功能模塊能實現多機進行485通信嗎

單主機,多從機?這個是從機源程序,多機通信可以在源程序的基礎上擴展一下哦
作者: 1911733869    時間: 2018-12-11 14:13
為什么會提示通訊超時
作者: 簡鐺鐺鐺鐺    時間: 2018-12-19 12:50
1911733869 發表于 2018-12-11 14:13
為什么會提示通訊超時

那就是沒通訊上,你是把程序移植過去,還是下到開發板直接用的?程序是我試驗過的,是能正常通訊的,或者你是不是讀寫碼的格式錯了,仔細檢查看看
作者: 清泥    時間: 2018-12-24 10:26
樓主我把這程序下載到stm32 用的c8t6,結果通訊超時。為什么呀
作者: 清泥    時間: 2018-12-24 11:12
清泥 發表于 2018-12-24 10:26
樓主我把這程序下載到stm32 用的c8t6,結果通訊超時。為什么呀

讀寫碼和你圖上的一樣的。就是通訊不上
作者: 周振宇    時間: 2018-12-24 12:29
樓主用的哪塊板子,是stm32f103嗎,我還是通訊超時,望指教
作者: 簡鐺鐺鐺鐺    時間: 2018-12-26 09:37
周振宇 發表于 2018-12-24 12:29
樓主用的哪塊板子,是stm32f103嗎,我還是通訊超時,望指教

我用的是開發板,stm32f103zet6,你程序有改動嗎?或者是端口設置之類的,你好好檢查下
作者: 簡鐺鐺鐺鐺    時間: 2018-12-26 09:42
清泥 發表于 2018-12-24 10:26
樓主我把這程序下載到stm32 用的c8t6,結果通訊超時。為什么呀

我用的開發板是stm32f103zet6,你要看看兩個芯片的程序能否兼容,我看到網上說啟動文件之類的要做些修改,具體的你網上搜搜看,看看用的端口和程序是否一致,一般也沒有別的問題了
作者: 123按時到崗    時間: 2018-12-26 12:56
最近在用stm32f103搞RES485 MODBUS通信沒弄好,,樓主發的不錯,學習了,測試一下可以,謝謝了
作者: mzb007    時間: 2018-12-27 00:41
非常有用的程序,謝謝樓主程序
作者: 簡鐺鐺鐺鐺    時間: 2018-12-27 08:10
123按時到崗 發表于 2018-12-26 12:56
最近在用stm32f103搞RES485 MODBUS通信沒弄好,,樓主發的不錯,學習了,測試一下可以,謝謝了


作者: pm1981    時間: 2018-12-28 14:15
不錯,學習了
作者: pm1981    時間: 2018-12-28 14:35
很實用
作者: xin111222333    時間: 2018-12-28 17:15
非常好,謝謝分享
作者: h283369481    時間: 2019-1-9 16:07
下載來看看,怎么樣!
作者: lsf002    時間: 2019-1-24 10:28
最近在用stm32f103搞RES485 MODBUS通信沒弄好,,樓主發的不錯,學習了,測試一下可以,謝謝了
作者: jeasey    時間: 2019-1-25 08:44
這個協議。如果讀寫數據是一個32bit的怎么操作呢?弄2個寄存器嗎?
作者: 1051695085    時間: 2019-2-16 11:50
樓主有主機源程序嗎?
作者: 計量王工    時間: 2019-2-16 12:45
謝謝分享
作者: 望月的兔    時間: 2019-2-17 14:02
感謝感謝
作者: staticx    時間: 2019-2-28 13:25
感謝感謝
作者: Xiaohaha424    時間: 2019-3-1 13:14
樓主,這個程序移植到C51上能行嗎,要注意些啥啊?
作者: lijunxing    時間: 2019-3-4 20:56
感謝樓主的無私奉獻
作者: chwncy    時間: 2019-3-6 09:29

感謝樓主的無私奉獻
作者: pm1981    時間: 2019-3-6 14:10
不錯,下來看看
作者: liujiacheng    時間: 2019-3-6 17:40
謝謝分享,學習了
作者: yangjiyou1969    時間: 2019-3-7 22:20
謝謝分享
作者: 簡鐺鐺鐺鐺    時間: 2019-3-8 09:50
jeasey 發表于 2019-1-25 08:44
這個協議。如果讀寫數據是一個32bit的怎么操作呢?弄2個寄存器嗎?

我是這樣做的
作者: 簡鐺鐺鐺鐺    時間: 2019-3-8 09:52
1051695085 發表于 2019-2-16 11:50
樓主有主機源程序嗎?

你可以根據這個從機修改一下,主機就是發命令,把你要讀或者要寫的數據發出去,發出去再接收數據
作者: xtuwz    時間: 2019-3-11 08:17
正好需要,樓主真好。我需要學習了解一下
作者: 938434518    時間: 2019-3-14 11:16
感謝分享,試一試
作者: 唱歌睡覺打豆豆    時間: 2019-3-15 10:06
感謝樓主分享,學到很多。
作者: zlbxuziming    時間: 2019-3-15 15:50
可以多機通訊嗎?
作者: 簡鐺鐺鐺鐺    時間: 2019-3-16 10:00
zlbxuziming 發表于 2019-3-15 15:50
可以多機通訊嗎?

這是一臺主機,一臺從機的,多機通訊的話要擴展一下哦
作者: lx159753    時間: 2019-3-18 16:21
為什么我用STM32C8板子出現通信超時,根據程序移植過來都沒問題
作者: 簡鐺鐺鐺鐺    時間: 2019-3-19 15:50
lx159753 發表于 2019-3-18 16:21
為什么我用STM32C8板子出現通信超時,根據程序移植過來都沒問題

肯定是哪里沒改好,好好看看修改的部分,好好檢查一下。主機從機的設置能不能對的上,引腳,配置
作者: cqx9999    時間: 2019-3-20 10:03
正好需要,下載下來看看.
作者: 西點鐘靈毓秀    時間: 2019-3-21 15:49
標記一下,寫的不錯
作者: 白歌    時間: 2019-3-22 17:57
感謝分享
作者: 夢然    時間: 2019-3-30 14:31
it's useful
作者: nkenen    時間: 2019-3-31 10:06
謝謝分享
作者: ship123    時間: 2019-4-1 19:45
謝謝樓主最近在看modbus
作者: kuangzxccxz    時間: 2019-4-8 09:45
謝謝分享
作者: 51hi/com    時間: 2019-4-8 22:52
非常感謝樓主,正在測試中,能否發一個主機程序?
作者: y8830600    時間: 2019-4-9 15:16
你好,我想問一下為什么我發送報文,01 06 00 01 00 01 19 CA,回復的是7F BE FD FF FD CD 6B這個。
作者: 簡鐺鐺鐺鐺    時間: 2019-4-10 17:01
本帖最后由 簡鐺鐺鐺鐺 于 2019-4-11 10:07 編輯
y8830600 發表于 2019-4-9 15:16
你好,我想問一下為什么我發送報文,01 06 00 01 00 01 19 CA,回復的是7F BE FD FF FD CD 6B這個。

是不是有一些信號的干擾,導致返回的數據出現異常。或者你可以發一個命令,控制指示燈亮滅,如果發送指令控制指示燈亮,指示燈亮了,說明接收程序是沒有問題的,再去看看發送部分的程序。
作者: 簡鐺鐺鐺鐺    時間: 2019-4-11 10:10
51hi/com 發表于 2019-4-8 22:52
非常感謝樓主,正在測試中,能否發一個主機程序?

主機程序,其實跟從機類似的,可以在從機的基礎上改動。主機是發送數據,再接收。從機是接收數據再發送到主機
作者: 小羅同學    時間: 2019-4-13 16:28
樓主大佬。這個程序stm32f407能用嗎
作者: canfly    時間: 2019-4-16 20:24
非常感謝樓主分享,學習了!
作者: flzt0898    時間: 2019-4-27 22:47
顯示通信超時怎么解決啊

作者: ltfltfltfltf    時間: 2019-4-28 16:15
不錯,學習一下
作者: w_smilove    時間: 2019-4-28 17:04
謝謝分享
作者: ltfltfltfltf    時間: 2019-4-29 17:37
樓主,我的也是STM32F103ZET6,結果通訊超時,請問是為什么呀?謝謝樓主
作者: 541312351    時間: 2019-5-2 17:16
謝謝分享,下載學習一下
作者: 一只想飛的豬    時間: 2019-5-5 16:37
可以在c8t6上運行嗎
作者: 一只想飛的豬    時間: 2019-5-5 16:40
請問樓主,485是不是只要配置串口(例如usart3)就可以實現了?我用的板子是已經集成了一個485模塊,我配置完之后還是不能通訊,但是串口可以收發數據
作者: 簡鐺鐺鐺鐺    時間: 2019-5-6 10:52
一只想飛的豬 發表于 2019-5-5 16:40
請問樓主,485是不是只要配置串口(例如usart3)就可以實現了?我用的板子是已經集成了一個485模塊,我配置 ...

485能正常通訊是嗎?那你要仔細看看你根據這個程序更改了哪些東西,程序本身是能正常通訊的。
作者: yywd4    時間: 2019-5-6 23:59
下載學習,謝謝發帖。
作者: 一只想飛的豬    時間: 2019-5-7 16:15
簡鐺鐺鐺鐺 發表于 2019-5-6 10:52
485能正常通訊是嗎?那你要仔細看看你根據這個程序更改了哪些東西,程序本身是能正常通訊的。

是配置好的usart3能正常收發數據,485不能用
作者: 一只想飛的豬    時間: 2019-5-7 16:18
而且為什么我下載不了你的壓縮文件·····
作者: mhunter    時間: 2019-5-7 20:58
謝謝分享!
作者: 簡鐺鐺鐺鐺    時間: 2019-5-8 08:08
一只想飛的豬 發表于 2019-5-7 16:18
而且為什么我下載不了你的壓縮文件·····

別人都可以下哦,是不是你黑幣不夠,485通訊就是在串口通訊的基礎上加一個收發控制引腳,你可以找一下例程看看
作者: 開心豆    時間: 2019-5-8 08:29
您好,請問為啥我連程序都打不開



作者: 開心豆    時間: 2019-5-8 08:52
為什么我編譯的時候出現了一個警告
warning:  #940-D: missing return statement at end of non-void function "rs485_UartWrite"
作者: 簡鐺鐺鐺鐺    時間: 2019-5-8 11:06
開心豆 發表于 2019-5-8 08:52
為什么我編譯的時候出現了一個警告
warning:  #940-D: missing return statement at end of non-void fun ...

缺少返回值,在語句后面加return o,不加也不會影響程序運行
作者: 一只想飛的豬    時間: 2019-5-9 09:39
為什么串口驅動函數中的flagFrame幀接收完成標志位一直是0,進入不了接收模式
作者: 一只想飛的豬    時間: 2019-5-11 18:08
lx159753 發表于 2019-3-18 16:21
為什么我用STM32C8板子出現通信超時,根據程序移植過來都沒問題

你好,請問你的問題解決了嗎?
作者: hahhah000    時間: 2019-5-12 17:59
小羅同學 發表于 2019-4-13 16:28
樓主大佬。這個程序stm32f407能用嗎

改一下就可以用啊,我用的也是SMT32F407的開發板。
作者: AveryLRG    時間: 2019-5-14 10:49
謝謝分享
作者: 15626168335    時間: 2019-5-15 13:06
請問樓主,我也是zet6的板,為什么第一次用的時候顯示可以,然后再次發送的時候就顯示通訊超時了呢
作者: 15626168335    時間: 2019-5-15 13:15
樓主,我用的也是這個芯片,為什么一開始是可以進行讀寫操作,之后就是通訊超時了

作者: 簡鐺鐺鐺鐺    時間: 2019-5-15 15:46
15626168335 發表于 2019-5-15 13:15
樓主,我用的也是這個芯片,為什么一開始是可以進行讀寫操作,之后就是通訊超時了

你看看你改動的部分
作者: 871862599    時間: 2019-5-15 20:06
樓主我的板子是stm32f103zet6的,這個程序可以直接移植直接用嗎?
作者: 871862599    時間: 2019-5-15 20:11
樓主我也是stm32f103zet6的板子,這個程序可以直接移植直接用嗎,我基礎不太好,謝謝了&#128514;
作者: 簡鐺鐺鐺鐺    時間: 2019-5-18 08:05
871862599 發表于 2019-5-15 20:11
樓主我也是stm32f103zet6的板子,這個程序可以直接移植直接用嗎,我基礎不太好,謝謝了&#128514;

可以直接用,串口要根據你的板子改一下,別的沒有什么要改的

作者: joy95611    時間: 2019-5-18 09:58

非常好,謝謝分享
作者: newhada    時間: 2019-5-18 11:19
寫得很好,謝謝分享
作者: irisice008    時間: 2019-5-19 22:02
謝謝分享,學習了
作者: 張君波    時間: 2019-5-20 07:55
樓主,我用的是STM32F103ZET6的精英版開發板,為什么也顯示通信超時
作者: itnoss    時間: 2019-5-21 11:55
正好需要,感謝樓主分享
作者: 11哈哈哈    時間: 2019-5-21 22:37
樓主,這個沒有實現modbus呢?

作者: fouroee    時間: 2019-5-23 13:16
感謝樓主,STM32F103VE上測試可用。發現了一個小問題,rs485.c里面定義Modbus寄存器組的時候只定義了5個,但后面程序是按6個寄存器寫的,不過這個問題也并不影響使用……
作者: coding1    時間: 2019-5-24 10:28
可以
作者: popkart123    時間: 2019-5-24 13:37
謝謝樓主分享
作者: 871862599    時間: 2019-5-25 15:36
簡鐺鐺鐺鐺 發表于 2019-5-18 08:05
可以直接用,串口要根據你的板子改一下,別的沒有什么要改的

[img][/img]真的很感謝樓主分享。移植程序以后接收端有數據,但卻提示你讀寫錯誤,那到底是對還是錯啊,不太懂
作者: 0212    時間: 2019-5-26 10:09
樓主 陰險  故意給代碼挖坑
作者: mod1595632    時間: 2019-5-27 19:06
請問樓主485轉ttl用的什么芯片啊,是max485么
作者: mod1595632    時間: 2019-5-27 19:08
fouroee 發表于 2019-5-23 13:16
感謝樓主,STM32F103VE上測試可用。發現了一個小問題,rs485.c里面定義Modbus寄存器組的時候只定義了5個, ...

您好,請問485轉ttl怎么實現的?用的什么芯片
作者: zhangyingpen    時間: 2019-5-29 07:56
謝謝,學習了,
作者: mod1595632    時間: 2019-5-29 11:15
zhangyingpen 發表于 2019-5-29 07:56
謝謝,學習了,

你好,你跑這個程序成功了么
作者: s08c820    時間: 2019-5-30 14:35
我的也提示通訊超時呢
作者: YZM168    時間: 2019-5-31 17:03
我的成功了,謝謝樓主
作者: 2018_51hei    時間: 2019-6-6 16:49
不錯

作者: xy51hei    時間: 2019-6-11 14:08
程序很完整,按塊劃分,正在弄rs485通訊,雖然不是stc8的單片機,但是值得借鑒,感謝樓主分享。
作者: 張君波    時間: 2019-6-12 21:31
Xiaohaha424 發表于 2019-3-1 13:14
樓主,這個程序移植到C51上能行嗎,要注意些啥啊?

定時器的配置,485掛接在哪個串口上,從機地址,定時器中斷配置,485配置,兩款單片機移植,比較難
作者: liyuloveyou1    時間: 2019-6-26 21:34
樓主你好有聯系方式嗎,我用了原子的精英版開發板芯片一樣的改了GPIO口還是通訊超時
作者: liyuloveyou1    時間: 2019-6-26 21:36
樓主,我用的是STM32F103ZET6的精英版開發板,改了GPIO口,為什么也顯示通信超時
作者: liyuloveyou1    時間: 2019-6-27 20:58
只能寫入不能讀出是為什么




歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 久草免费在线 | av永久免费 | 亚洲 欧美 日韩在线 | 中文字幕韩在线第一页 | 午夜伊人 | 这里有精品 | 成人av一区| 国产高清视频在线 | a亚洲精品 | 涩涩视频大全 | 欧美一区二区在线播放 | 国产探花在线精品一区二区 | 日本在线视 | 亚洲精品色 | 色婷婷综合成人av | 中国免费黄色片 | 久久国产精品一区二区三区 | 国产色网 | 超碰免费在线 | 亚洲 欧美 激情 另类 校园 | 久久精品免费观看 | 欧美无乱码久久久免费午夜一区 | 91精品国产综合久久久久 | 在线综合视频 | 夜夜骑综合 | 精品国产乱码久久久久久中文 | 成人一级片在线观看 | 亚洲人成网站777色婷婷 | 精品亚洲一区二区三区四区五区高 | 91美女视频| 一区二区不卡高清 | 狠狠色综合网站久久久久久久 | 日韩免费av一区二区 | 久久精品亚洲精品国产欧美kt∨ | 欧美操操操 | 国产日产欧产精品精品推荐蛮挑 | 热久久性 | 精品国产伦一区二区三区观看说明 | 精品欧美乱码久久久久久1区2区 | 日韩精品中文字幕在线 | h片在线观看免费 |