当前位置:首页 > 单片机 > 单片机
[导读] 准备总结一下学习过程中的485通信知识!----------------------------------------------------先描述一下学习STM32与485通信的时候想实现的功能--------首先是完成双机通信中的双向通信----这里定义A为

准备总结一下学习过程中的485通信知识!----------------------------------------------------

先描述一下学习STM32与485通信的时候想实现的功能--------


首先是完成双机通信中的双向通信----这里定义A为主机发送指令给从机B,从机B在接收到主机A的指令后,判断有效位的正确性,如果正确将这个指令通过RS232串口显示到串口助手里,观察整个指令是否接收正确-----同时在从机B接收到主机A指令后,向主机A发送指定数据----主机A在接收到从机B数据后判断有效位的正确性,如果正确则通过RS232打印到串口助手,然后观察完整数据。--------这里的判断比较简单------只是判断接收数据的最后一位是否是规定的字符----为了数据的准确性,可以增加判断方法。

第一步是配置RS232的串口,这里使用USART1,测试printf函数的输出是否正常----------这里就不叙述了!


注意在主机的USART1中要打开接收中断--USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//打开接收终端


第二步是配置RS485,这里使用USART2,配置如下---------

void USART2_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;
//GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructure);

USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
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(USART2, &USART_InitStructure);
USART_Cmd(USART2, ENABLE);

USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//打开接收终端
USART_ClearFlag(USART2, USART_FLAG_TC);
}

void MyPrintfByte(unsigned char byte)//发送一个字节
{
USART_SendData(USART2, byte);
while( USART_GetFlagStatus(USART2,USART_FLAG_TC)!= SET);
}
void MyPrintfStr(unsigned char *s)//发送字符串
{
uint8_t i=0;

while(s[i]!='')
{
USART_SendData(USART2,s[i]);
while( USART_GetFlagStatus(USART2,USART_FLAG_TC)!= SET);
i++;
}
}
void MyPrintfArray(uint8_t send_array[],uint8_t num)//发送数组中指定个数
{
uint8_t i=0;

while(i {
USART_SendData(USART2,send_array[i]);
while( USART_GetFlagStatus(USART2,USART_FLAG_TC)!= SET);
i++;
}
}

第三部是在中断里写接收函数--------------

void USART1_IRQHandler(void)//232接收中断函数---主要是在主机中
{
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收到数据
{
USART_ClearITPendingBit(USART1, USART_IT_RXNE);//清标志位
RS232_RX_BUF[RS232_RX_CNT++]=USART_ReceiveData(USART1);
if( RS232_RX_CNT==4)
RS232_RX_CNT=0;
}
}

void USART2_IRQHandler(void) //485中断接收函数
{
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)//接收到数据
{
USART_ClearITPendingBit(USART2, USART_IT_RXNE);//清标志位
RS485_RX_BUF[RS485_RX_CNT++]=USART_ReceiveData(USART2); //将接收到的数据保存到指定数组
if( RS485_RX_CNT==9)//接收指定长度为9个数据
RS485_RX_CNT=0;
}
}

第四步是对中断的优先级进行配置----

static void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);

NVIC_InitStructure.NVIC_IRQChannel =USART1_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = ENABLE;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);

NVIC_InitStructure.NVIC_IRQChannel =USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = ENABLE;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}

第五部是主函数----------

---------------------------主机----------------------------------

int main(void)
{
uint8_t i,flag=0;

USART2_Config();
USART1_Config();
GPIO_Config();
NVIC_Configuration();

printf("485主机rn");

while(1)
{
GPIO_SetBits(GPIOB,GPIO_Pin_5);//发送模式
Delay(50000); //必要的延时
if(RS232_RX_BUF[3]=='1') //通过串口助手发送一组数据,根据不同数据下面向从机发送不同的指令
MyPrintfStr("12345678!");
else if(RS232_RX_BUF[3]=='2')
MyPrintfStr("abcdefgh@");
else if(RS232_RX_BUF[3]=='3')
MyPrintfStr("ABCDEFGH#");

RS485_RX_BUF[8]='-'; //将接收数据的最后一位设置为其它
Delay(50000);
GPIO_ResetBits(GPIOB,GPIO_Pin_5);//接收模式
Delay(50000);
//USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
flag=0;
while(!(RS485_RX_BUF[8]=='T')&&flag<20)//等待接收到数据,并且最后一位数据位---T---或者超时退出循环---超时数值比较重要,太小会使数据丢失。
{
Delay(0x666ee);
flag++;
}
for(i=0;i<9;i++) //打印出接收到从机的数据
{
if(i<8)
printf("%c",RS485_RX_BUF[i]);
else
printf("%crn",RS485_RX_BUF[i]);
}
Delay(0x6666ee);
}
}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

当地时间 9 月 8 日,SpaceX 与 EchoStar 正式达成一项价值 170 亿美元的频谱交易,SpaceX 将收购 EchoStar 旗下 AWS-4 频段(2GHz 频段)及 H 频段的频谱许可证,此举引发...

关键字: SpaceX EchoStar 星链 通信

在现代工业和汽车领域,控制器局域网(CAN)总线作为一种可靠且高效的通信方式,广泛应用于各种电子设备之间的数据传输。在 CAN 总线系统中,有一个看似毫不起眼却至关重要的元件 ——120Ω 终端电阻。这个小小的电阻,对于...

关键字: 控制器局域网 总线 通信

8月14日消息,今天,国务院新闻办公室举行“高质量完成‘十四五’规划”系列主题新闻发布会,国家数据局介绍“十四五”时期数字中国建设发展成就。

关键字: 算力 通信

北京2025年8月8日 /美通社/ -- 8月7日,浪潮信息发布面向万亿参数大模型的超节点AI服务器"元脑SD200"。该产品基于浪潮信息创新研发的多主机低延迟内存语义通信架构,以开放系统设计向上扩展...

关键字: 模型 节点 SD 通信

在现代通信技术的复杂网络中,射频(RF)滤波器犹如一位幕后英雄,虽鲜少被大众提及,却发挥着举足轻重的作用。从我们日常使用的智能手机,到构建通信基础设施的基站,再到新兴的物联网设备,RF 滤波器无处不在,默默保障着信号的顺...

关键字: 射频 滤波器 通信

在当今数字化时代,5G 通信技术以前所未有的速度改变着我们的生活,从高速的数据传输到实时的物联网应用,5G 的影响力无处不在。然而,在这一系列令人瞩目的技术背后,有一个常常被忽视却至关重要的角色 —— 晶振。它如同幕后的...

关键字: 通信 数据传输 晶振

德国斯图加特 2025年7月2日 /美通社/ -- 国际关键通信协会The Critical Communications Association (以下简称TCCA)宣布...

关键字: 通信 TETRA TC 测试流程

近日,欧洲统一专利法院曼海姆分庭更新的一则诉讼信息,引发了全球科技界震动——联发科子公司HFI Innovation起诉了华为旗下五家子公司侵犯其LTE专利EP2689624。这场诉讼标志着两家科技巨头持续两年的专利纠纷...

关键字: 通信

为了进一步推动电子通信半导体产业创新发展,“EIS 2025 中国电子通信半导体数智创新峰会", 以 “智联万物·芯创未来 ”为主题, 将于 2025 年 10月 24日在上海隆重举办。

关键字: 通信 半导体

6 月 5 日,市场研究机构 Omdia 发布最新报告指出,在人工智能技术的深度赋能下,全球 6G 网络商业化进程显著提速,预计 2027 年至 2030 年将成为 6G 技术的导入期,并于 2037 年起成为通信领域的...

关键字: 通信 人工智能 6G
关闭