基于stm32F103ZE单片机的USART串口使用

寄存器及自定义变量

状态寄存器

USART_SR

主要关注该状态寄存器的以下两位:TC与RXNE。
TC:发送完成状态位。若置位,则代表串口发送完成
RXNE:读数据寄存器非空。若置位,则代表串口接收到数据

USART_RX_BUF[USART_REC_LEN]

定义该项为数组,用于接收缓存

u16 USART_RX_STA

该项为用户定义的变量,在本程序中将其视为寄存器,各个位定义如下:
bit15:接收完成标志位
bit14:接收到0x0D的标志位
bit13~0:数据位

串口初始化

uart_init(u32 bound)

void uart_init(u32 bound)
{
	//GPIO端口设置
	GPIO_InitTypeDef GPIO_InitStructure;
	USART_InitTypeDef USART_InitStructure;
	NVIC_InitTypeDef NVIC_InitStructure;

	RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|RCC_APB2Periph_GPIOA, ENABLE);	//使能USART1,GPIOA时钟

	//USART1_TX   GPIOA.9
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //PA.9
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;	//复用推挽输出
	GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.9

	//USART1_RX	  GPIOA.10初始化
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;//PA10
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入
	GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.10  

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

	//USART 初始化设置

	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_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启串口接受中断
	USART_Cmd(USART1, ENABLE);                    //使能串口1 
}

串口中断函数

USART1_IRQHandler(void)

void USART1_IRQHandler(void)                	//串口1中断服务程序
{
	u8 Res;
	if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中断(接收到的数据必须是0x0d 0x0a结尾)
	{
			Res =USART_ReceiveData(USART1);	//读取接收到的数据
			if((USART_RX_STA&0x8000)==0)//接收未完成
				{
					if(USART_RX_STA&0x4000)//接收到了0x0d
						{
							if(Res!=0x0a)
							{
								USART_RX_STA=0;//接收错误,重新开始
							}
							else
							{
								USART_RX_STA|=0x8000;	//接收完成了
							}								
						}
					else //还没收到0X0D
						{	
							if(Res==0x0d)
							{
								USART_RX_STA|=0x4000;
							}
							else
								{
									USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
									USART_RX_STA++;
									if(USART_RX_STA>(USART_REC_LEN-1))
									{
										USART_RX_STA=0;//接收数据错误,重新开始接收	  
									}

								}		 
						}
				}   		 
    } 
} 

代码运行逻辑:
首先判断状态寄存器USART_SR的RXNE状态,若置位,则代表接收到数据;
然后将接收到的数据放入Res中;
然后判断接收是否完成:根据自定义的变量USART_RX_STA的bit15和bit14位是否为1来判断是否接收到了回车键,若接收到了回车键,则接收完成,跳出中断函数。若没有接收完成,则将Res中的数据放入自定义数组USART_RX_BUF[]中,数组位数为USART_RX_STA&0X3FFF(USART_RX_STA的bit0~bit13位代表数据长度,bit14和bit15位为回车标志位)。

主函数

if(USART_RX_STA&0x8000)
{					   
	len=USART_RX_STA&0x3fff;//得到此次接收到的数据长度
	printf("\r\n您发送的消息为:\r\n\r\n");
	for(t=0;t<len;t++)
	{
		USART_SendData(USART1, USART_RX_BUF[t]);//向串口1发送数据
		while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待发送结束
	}
	printf("\r\n\r\n");//插入换行
	USART_RX_STA=0;
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在STM32F103ZE单片机使用串口中断接收字符串,可以按照以下步骤进行: 1. 配置串口参数,包括波特率、数据位、校验位和停止位等。 2. 使能串口接收中断,使用HAL库可以通过`HAL_UART_Receive_IT()`函数实现。 3. 在串口接收中断处理函数中,判断是否接收到了完整的字符串,可以通过判断接收缓冲区中是否存在结束符(例如'\0')或者接收到一定长度的字符串来确定。 4. 如果接收到了完整的字符串,可以将其保存到一个缓冲区中,等待后续处理。 下面是一个简单的示例代码,可以接收最长为20个字符的字符串: ``` #include "stm32f1xx_hal.h" #define RX_BUFFER_SIZE 20 UART_HandleTypeDef huart1; uint8_t rx_buffer[RX_BUFFER_SIZE]; uint8_t rx_index = 0; void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart) { if (huart == &huart1) { if (rx_index < RX_BUFFER_SIZE - 1) { // 判断是否超出缓冲区大小 if (rx_buffer[rx_index] == '\n' || rx_buffer[rx_index] == '\r') { // 判断是否接收到结束符 rx_buffer[rx_index] = '\0'; // 添加字符串结束符 // 处理接收到的字符串 } else { rx_index++; } } else { rx_index = 0; // 超出缓冲区大小,重新开始接收 } HAL_UART_Receive_IT(&huart1, &rx_buffer[rx_index], 1); // 继续接收下一个字符 } } int main(void) { HAL_Init(); // 配置串口参数 huart1.Instance = USART1; huart1.Init.BaudRate = 9600; huart1.Init.WordLength = UART_WORDLENGTH_8B; huart1.Init.StopBits = UART_STOPBITS_1; huart1.Init.Parity = UART_PARITY_NONE; huart1.Init.Mode = UART_MODE_TX_RX; huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; huart1.Init.OverSampling = UART_OVERSAMPLING_16; HAL_UART_Init(&huart1); // 使能串口接收中断 HAL_UART_Receive_IT(&huart1, &rx_buffer[rx_index], 1); while (1) { // 主循环 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值