STM32&rs485串口通信

在32串口通信的基础上,修改代码实现RS485的数据收发,可以直接移植使用

预览截图

应用介绍

#include "sys.h"     
#include "rs485.h"  
#include "delay.h"

#ifdef EN_USART2_RX    //如果使能了接收


//接收缓存区
u8 RS485_RX_BUF[64];  //接收缓冲,最大64个字节.
//接收到的数据长度
u8 RS485_RX_CNT=0;      
  
void USART3_IRQHandler(void)
{
u8 res;     
 
  if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET) //接收到数据
{  
 
res =USART_ReceiveData(USART3); //读取接收到的数据
//  USART_SendData(USART3,res);
if(RS485_RX_CNT<64)
{
RS485_RX_BUF[RS485_RX_CNT]=res; //记录接收到的值
RS485_RX_CNT++; //接收数据增加1 

 

#endif  
//初始化IO 串口3
//pclk1:PCLK1时钟频率(Mhz)
//bound:波特率   
void RS485_Init(u32 bound)
{  
  GPIO_InitTypeDef GPIO_InitStructure;
  USART_InitTypeDef USART_InitStructure;
  NVIC_InitTypeDef NVIC_InitStructure;
 
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);//使能GPIOA,D时钟
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE);//使能USART3时钟

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; //PB2端口配置,控制RS485收发,1发送,0接收
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOB, &GPIO_InitStructure);
// GPIO_SetBits(GPIOB,GPIO_Pin_2);

 
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //PA2
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽
  GPIO_Init(GPIOB, &GPIO_InitStructure);
   
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;//PA3
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入
  GPIO_Init(GPIOB, &GPIO_InitStructure);  

RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART3,ENABLE);//复位串口2
RCC_APB1PeriphResetCmd(RCC_APB1Periph_USART3,DISABLE);//停止复位
 

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

  USART_Init(USART3, &USART_InitStructure); ; //初始化串口
  
NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn; //使能串口3中断
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; //先占优先级2级
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //从优先级2级
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //使能外部中断通道
NVIC_Init(&NVIC_InitStructure); //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器
 
  USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);//开启中断
   
  USART_Cmd(USART3, ENABLE);                    //使能串口 

 #endif

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

//RS485发送len个字节.
//buf:发送区首地址
//len:发送的字节数(为了和本代码的接收匹配,这里建议不要超过64个字节)
void RS485_Send_Data(u8 *buf,u8 len)
{
u8 t;
RS485_TX_EN=1; //设置为发送模式
  for(t=0;t<len;t++) //循环发送数据
{    
while(USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);   
USART_SendData(USART3,buf[t]);
}  
 
while(USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);
RS485_RX_CNT=0;   
RS485_TX_EN=0; //设置为接收模式
}
//RS485查询接收到的数据
//buf:接收缓存首地址
//len:读到的数据长度
void RS485_Receive_Data(u8 *buf,u8 *len)

{
u8 rxlen=RS485_RX_CNT;
u8 i=0;
*len=0; //默认为0
delay_ms(10); //等待10ms,连续超过10ms没有接收到一个数据,则认为接收结束
if(rxlen==RS485_RX_CNT&&rxlen)//接收到了数据,且接收完成了
{
for(i=0;i<rxlen;i++)
{
buf[i]=RS485_RX_BUF[i];
}
*len=RS485_RX_CNT; //记录本次数据长度
RS485_RX_CNT=0; //清零
}
}





















文件列表(部分)

名称 大小 修改日期
DOC0.00 KB2022-02-18
Readme.txt0.06 KB2022-02-44
Libraries0.00 KB2022-02-40
CMSIS0.00 KB2022-07-08
core_cm3.c16.87 KB2010-06-02
core_cm3.h83.71 KB2011-02-36
Startup0.00 KB2022-02-06
startup_stm32f10x_cl.s15.40 KB2011-03-16
startup_stm32f10x_hd.s15.14 KB2011-03-14
startup_stm32f10x_hd_vl.s15.32 KB2011-03-10
startup_stm32f10x_ld.s12.09 KB2011-03-08
startup_stm32f10x_ld_vl.s13.34 KB2011-03-06
startup_stm32f10x_md.s12.47 KB2011-03-02
startup_stm32f10x_md_vl.s13.74 KB2011-03-58
startup_stm32f10x_xl.s15.58 KB2011-03-52
stm32f10x.h619.08 KB2011-03-32
system_stm32f10x.c36.54 KB2022-07-08
system_stm32f10x.h2.04 KB2011-03-22
FWLib0.00 KB2022-02-32
inc0.00 KB2022-02-32
misc.h8.77 KB2011-03-16
stm32f10x_adc.h21.18 KB2011-03-16
stm32f10x_bkp.h7.38 KB2011-03-16
stm32f10x_can.h26.91 KB2011-03-16
stm32f10x_cec.h6.42 KB2011-03-16
stm32f10x_crc.h2.11 KB2011-03-16
stm32f10x_dac.h14.88 KB2011-03-16
stm32f10x_dbgmcu.h3.73 KB2011-03-16
stm32f10x_dma.h20.27 KB2011-03-16
stm32f10x_exti.h6.66 KB2011-03-16
stm32f10x_flash.h24.85 KB2011-03-16
stm32f10x_fsmc.h26.38 KB2011-03-16

立即下载

相关下载

[STM32&rs485串口通信] 在32串口通信的基础上,修改代码实现RS485的数据收发,可以直接移植使用
[STM32单片机和51单片机有何区别?] 51单片机是对所有兼容Intel8031指令系统的单片机的统称,这一系列的单片机的始祖是Intel的8031单片机。 后来随着flash ROM技术的发展,8031单片机取得了长足的进展成为了应用最广泛的8bit单片机之一,它的代表型号就是ATMEL公司的AT89系列。
[基于STM32车辆位置信息定位系统] 以“TASK:F2,L90,D2,”为例 以TASK:开头 后面表示一连串连续的动作: F(forward,2表示走两个轮子周长的距离), L(left,90代表向左转的角度,向右同理,L变为R), D(delay,表示暂停几秒,此处表示在原地等待2秒) 命令之间以英文逗号(",")隔开,且最后的逗号不可省略
[STM32连接onenet] 基于STM32硬件连接OneNET,stm32通过ESP8266使用TCP协议连接ONENET云平台

评论列表 共有 0 条评论

暂无评论

微信捐赠

微信扫一扫体验

立即
上传
发表
评论
返回
顶部