找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1264|回复: 2
收起左侧

STM32单片机RS485通信程序

[复制链接]
ID:495367 发表于 2023-3-16 09:54 | 显示全部楼层 |阅读模式
#include "led.h"
#include "delay.h"
#include "sys.h"
#include "usart.h"         
#include "rs485.h"
                                         
int main(void)
{
        u8 buf[3]={3,4,5};
        delay_init();                       
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
        uart_init(115200);         
        LED_Init();                                          
        RS485_Init(9600);
  GPIO_ResetBits(GPIOF,GPIO_Pin_1);  
        GPIO_ResetBits(GPIOF,GPIO_Pin_2);  
        printf("\r\n开始\r\n");               
        RS485_Send_Data(buf,3);        
        printf("\r\n接收\r\n");
  while(1);
}


  1. #include "led.h"
  2. #include "delay.h"
  3. #include "sys.h"
  4. #include "usart.h"         
  5. #include "rs485.h"

  6. #ifdef EN_USART4_RX           //如果使能了接收

  7. //接收缓存区         
  8. u8 RS485_RX_BUF[64];          //接收缓冲,最大64个字节.
  9. //接收到的数据长度
  10. u8 RS485_RX_CNT=0;                     

  11. #endif                                                                                 

  12. void RS485_Init(u32 bound)
  13. {  
  14.   GPIO_InitTypeDef GPIO_InitStructure;
  15.   USART_InitTypeDef USART_InitStructure;
  16.          NVIC_InitTypeDef NVIC_InitStructure;

  17.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);//使能GPIOA,D时钟
  18.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART4,ENABLE);//使能USART2时钟
  19.         
  20.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;                                 
  21.          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  //推挽输出
  22.          GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  23.          GPIO_Init(GPIOC, &GPIO_InitStructure);

  24.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;        
  25.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;        //复用推挽
  26.   GPIO_Init(GPIOC, &GPIO_InitStructure);
  27.    
  28.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  29.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入
  30.   GPIO_Init(GPIOC, &GPIO_InitStructure);  

  31.         RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART4,ENABLE);//复位串口2
  32.         RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART4,DISABLE);//停止复位

  33.         
  34. #ifdef EN_USART4_RX                          //如果使能了接收
  35.         USART_InitStructure.USART_BaudRate = bound;//波特率设置
  36.         USART_InitStructure.USART_WordLength = USART_WordLength_8b;//8位数据长度
  37.         USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
  38.         USART_InitStructure.USART_Parity = USART_Parity_No;///奇偶校验位
  39.         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
  40.         USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//收发模式


  41.   
  42.         NVIC_InitStructure.NVIC_IRQChannel = UART4_IRQn; //使能串口4中断
  43.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //先占优先级3级
  44.         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //从优先级3级
  45.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //使能外部中断通道
  46.         NVIC_Init(&NVIC_InitStructure); //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
  47.   USART_Init(USART4, &USART_InitStructure); ; //初始化串口
  48.   USART_ITConfig(USART4, USART_IT_RXNE, ENABLE);//开启中断
  49.    
  50.   USART_Cmd(USART4, ENABLE);                    //使能串口

  51. #endif

  52.   RS485_TX_EN=0;                        //默认为接收模式

  53. }
  54. void RS485_Send_Data(u8 *buf,u8 len)
  55. {
  56.         u8 t;
  57.         RS485_TX_EN=1;                        //设置为发送模式
  58.         if(RS485_TX_EN==1)
  59.         {
  60.         printf("\r\n发送\r\n");        
  61.           for(t=0;t<len;t++)                //循环发送数据
  62.         {        
  63.                
  64.                         printf("%d\n",buf[0]);
  65.                         printf("%d\n",buf[1]);
  66.                         printf("%d\n",buf[2]);
  67.                 USART_SendData(USART4, buf[t]);         
  68.       while(USART_GetFlagStatus(USART4,USART_FLAG_TC)!=SET);
  69.         }        
  70. printf("\r\n已发送\r\n\r\n");        
  71.         USART_ClearFlag(USART4,USART_FLAG_TC);
  72. }
  73.         RS485_TX_EN=0;                                //设置为接收模式        

  74. }

  75. void UART4_IRQHandler(void)
  76. {
  77.                 u16 res=0;
  78.          if(USART_GetITStatus(USART4, USART_IT_RXNE) != RESET) //接收到数据
  79.         {         
  80.                 res =USART4->DR;
  81.    }
  82.                 printf("reserve=%x\n",res);
  83.     USART_ClearFlag(USART4,USART_IT_RXNE);
  84. }
复制代码


Keil代码.7z

212.42 KB, 下载次数: 42, 下载积分: 黑币 -5

485

评分

参与人数 1黑币 +20 收起 理由
admin + 20 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:291668 发表于 2023-3-17 10:30 | 显示全部楼层
485通讯注意要使能三根口线。比串口多配制一个,发送高电平接收低电平。尤其是分开定义的。以前调试modbus例程,就是因为口线定义出错,费了一天的时间。
回复

使用道具 举报

ID:287000 发表于 2024-3-30 18:43 | 显示全部楼层
最近需要读取绝对值编码器的,485通讯,我发现最小系统STM32F103的mini板子不支持,又买了一个ttl转485的模块,准备测试一下,看楼主的这个什么情况
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表