STM32F407 USART串口通信介绍(普中开发板)

声明:文章部分图片引自网络,如若侵权立即删帖致歉

USART与UART

USART全称为同步异步收发器,而UART仅仅为异步收发器

全双工,半双工,单工

全双工:就像我们现在用的手机电话,我既能听到你的声音,还能在听到声音的时候说话
半双工:对讲机,你说话我只能听,我说话你只能听
单工:我能说话你不能说话,你只能听,设定好了永远就只能听,不可能说话(这里面的说话与否对应着数据传输)

RS232

串口通信有很多接口标准
RS-232C有DB25和DB9这两种,分别对应25针和9针,目前使用最多的是9针,连接器的每个插针排列方式都有明确的定义,公头和母头的定义顺序是不一样的

1、TXD RXD数据线上
逻辑1的电平为-3~-15V
逻辑0的电平为3~15V 可见与我们平时所见到的TTL电平是相反的
2、在RTS、CTS、DSR、DTR、DCD等控制线上
信号有效为3~15V
信号无效为-3~-15V
3、两个通信设备之间要共地,发送口对接收口,接收口对发送口

异步通信

异步通信是以字符(构成的帧)进行传输的,字符与字符之间的间隔是任意的,即每个帧之间相隔多少时间传输我们是不管的,但是字符内部,各个位是以固定的时间传送的
总的来说异步通信简单开销小,但是传输效率低
在这里插入图片描述

串口通信库函数配置

1、首先串口是在GPIO上的,所以我们得开启对应的GPIO和USART时钟
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能GPIOA时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//使能USART1时钟
2、接下来是配置GPIO的复用功能

GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1); //GPIOA9复用为USART1
GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1); //GPIOA10复用为USART1 
3、初始化串口参数,包含波特率、字长、奇偶校验等参数


void USART_Init(USART_TypeDef* USARTx, USART_InitTypeDef* 
USART_InitStruct);
typedef struct
{
  uint32_t USART_BaudRate;            //波特率
  uint16_t USART_WordLength;          //字长
  uint16_t USART_StopBits;            //停止位
  uint16_t USART_Parity;              //校验位
  uint16_t USART_Mode;                //USART模式
  uint16_t USART_HardwareFlowControl; //硬件流控制
} USART_InitTypeDef;
4、同时不要忘记对GPIO的初始化+使能和USART的使能(GPIO初始化记得选复用模式)

综合库函数配置代码如下:

#include "usart.h"		 

/*******************************************************************************
* 函 数 名         : USART1_Init
* 函数功能		   : USART1初始化函数
* 输    入         : bound:波特率
* 输    出         : 无
*******************************************************************************/ 
void USART1_Init(u32 bound)
{
   //GPIO端口设置
	GPIO_InitTypeDef GPIO_InitStructure;
	USART_InitTypeDef USART_InitStructure;
	NVIC_InitTypeDef NVIC_InitStructure;
	
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能GPIOA时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//使能USART1时钟
 
	//串口1对应引脚复用映射
	GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1); //GPIOA9复用为USART1
	GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1); //GPIOA10复用为USART1
	
	//USART1端口配置
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10 ; //GPIOA9与GPIOA10
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用功能
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;	//速度50MHz
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //推挽复用输出
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //上拉
	GPIO_Init(GPIOA,&GPIO_InitStructure); //初始化PA9,PA10
	

   //USART1 初始化设置
	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(USART1, &USART_InitStructure); //初始化串口1
	
	USART_Cmd(USART1, ENABLE);  //使能串口1 
	
	USART_ClearFlag(USART1, USART_FLAG_TC);
		
	USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启相关中断//开启的是接收完成中断

	//Usart1 NVIC 配置
	NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//串口1中断通道
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//抢占优先级3
	NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;		//子优先级3
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能
	NVIC_Init(&NVIC_InitStructure);	//根据指定的参数初始化VIC寄存器、	
}

/*******************************************************************************
* 函 数 名         : USART1_IRQHandler
* 函数功能		   : USART1中断函数
* 输    入         : 无
* 输    出         : 无
*******************************************************************************/ 
void USART1_IRQHandler(void)                	//串口1中断服务程序
{
	u8 r;
	if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中断
	{
		r =USART_ReceiveData(USART1);//(USART1->DR);	//读取接收到的数据
		USART_SendData(USART1,r);
		while(USART_GetFlagStatus(USART1,USART_FLAG_TC) != SET);
	} 
	USART_ClearFlag(USART1,USART_FLAG_TC);
} 	

 




  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 单片机之间可以使用串口通信进行数据的传输和通信。对于stm32开发板中的两个单片机,一般可以通过它们上面的串口引脚来建立串口通信。首先,需要在代码中配置每个单片机的串口参数,例如波特率、数据位、停止位等。然后,一个单片机作为发送方,通过串口将数据发送给另一个单片机作为接收方。 在发送方的代码中,使用串口发送函数将要发送的数据写入发送缓冲区,然后等待发送完成。而接收方的代码中,需要使用串口接收函数来获取接收缓冲区中的数据,并进行处理。另外,为了保证通信的可靠性,可以在发送方和接收方之间添加一定的数据帧格式,例如起始字节和结束字节,以便接收方能够正确地识别并解析接收到的数据。 此外,在实际的单片机串口通信中,还需要考虑通信的帧同步、数据校验、数据流控制等问题。为了实现高效的通信,可以选择合适的通信协议,如使用帧中止字符或使用硬件流控制功能。 总之,通过配置正确的串口参数和使用相应的发送和接收函数,可以实现stm32两个单片机之间的串口通信,从而实现数据的传输和通信。在实际应用中,需要根据具体的需求和系统设计来选择合适的通信方式和协议,以确保通信的可靠性和稳定性。 ### 回答2: 要实现两个STM32单片机之间的串口通信,可以按照以下步骤进行操作: 1. 首先,确定通信参数。包括串口波特率、数据位、停止位和校验位等。确保两个单片机的通信参数一致。 2. 在发送方单片机上,配置串口。使用STM32提供的库函数,初始化串口的相关寄存器和中断。设置好发送缓冲区和接收缓冲区。 3. 在接收方单片机上,同样配置串口。同样使用STM32提供的库函数,初始化串口的相关寄存器和中断。设置好发送缓冲区和接收缓冲区。 4. 在发送方单片机上,将要发送的数据写入发送缓冲区,并启动发送操作。此时,串口将自动将缓冲区中的数据发送出去。 5. 在接收方单片机上,通过中断来接收数据。当接收到数据时,中断将被触发,可以在中断服务函数中处理接收到的数据。 6. 在接收方单片机上,将接收到的数据读取出来,并进行相关操作。可以存储、显示或者进行其他处理。 7. 如果需要发送方和接收方之间进行双向通信,可以在发送方单片机和接收方单片机上重复上述步骤。 需要注意的是,串口通信需要保证发送方和接收方的数据格式一致,以及正确处理数据帧的起始、结束和校验。在项目中,可以使用协议来约定数据的格式和处理方式,以保证通信的可靠性和正确性。 总结:通过配置串口参数、初始化缓冲区、中断处理函数等步骤,可以在STM32单片机之间实现串口通信。这种通信方式可以用于数据的传输、控制信号的发送等应用场景。 ### 回答3: STM32是一种常见的单片机系列,经常用于嵌入式系统开发。串口通信是一种常用的通信方式,可以实现单片机与其他外部设备的数据交互。 在STM32中,可以通过配置两个UART(通用异步收发传输器)来实现两个单片机之间的串口通信。首先,需要在单片机的引脚配置中,将两个UART的引脚连接到对应的串口通信线路上。 接下来,在STM32的代码中,需要使用相应的库函数来配置和控制UART模块。首先,需要初始化两个UART通信模块,分别设置波特率、数据位、停止位和校验位等参数。然后,可以使用相应的发送和接收函数来实现数据的发送和接收操作。 在发送方单片机中,可以使用发送函数将数据发送到接收方单片机。接收方单片机则可以通过接收函数来接收到来自发送方的数据。通过在代码中指定不同的UART通信模块和引脚配置,可以同时实现多个串口通信通道。 需要注意的是,在进行串口通信时,要确保两个单片机的串口配置是一致的,包括波特率、数据位、停止位和校验位等参数。同时,在数据传输过程中,还需要进行数据的解析和处理,以确保数据的正确性和可靠性。 总之,通过配置和控制两个UART通信模块,可以在STM32中实现两个单片机之间的串口通信。通过合理地配置参数和使用相应的库函数,可以实现数据的可靠传输和快速交互。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值