STM32串口中断接收方式详细对比_第1页
STM32串口中断接收方式详细对比_第2页
STM32串口中断接收方式详细对比_第3页
STM32串口中断接收方式详细对比_第4页
STM32串口中断接收方式详细对比_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

本文格式为Word版,下载可任意编辑——STM32串口中断接收方式详细对比

STM32串口中断接收方式详细比较

串口中断接收方式详细比较

串口调试,以前也调过,只是没这么深入的琢磨过,最近又在弄,感觉串口很基本,也很有学问,要是出现BUG可能导致系统奔溃。。。现在贴出来,欢迎拍砖指正!!!

本例程通过PC机的串口调试助手将数据发送至STM32,STM32通过SP3232芯片采用中断接收方式完成,然后接收数据后将所接收的数据又发送至PC机,具体下面详谈。。。

实例一:

voidUSART1_IRQHandler(u8GetData)

{

u8BackData;

if(USART_GetITStatus(USART1,USART_IT_RXNE)!=RESET)//中断产生{

USART_ClearITPendingBit(USART1,USART_IT_RXNE);//清除中断标志.GetData=UART1_GetByte(BackData);//也行GetData=USART1-DR;

USART1_SendByte(GetData);//发送数据

GPIO_SetBits(GPIOE,GPIO_Pin_8);//LED闪烁,接收成功发送完成delay(1000);

GPIO_ResetBits(GPIOE,GPIO_Pin_8);

}

}

这是最基本的,将数据接收完成后又发送出去,接收和发送在中断函数里执行,main函数里无其他要处理的。

优点:简单,适合很少量数据传输。

缺点:无缓存区,并且对数据的正确性没有判断,数据量稍大可能导致数据丢失。

实例二:

voidUSART2_IRQHandler()

{

if(USART_GetITStatus(USART2,USART_IT_RXNE)!=RESET)//中断产生{

USART_ClearITPendingBit(USART2,USART_IT_RXNE);//清除中断标志Uart2_Buffer[Uart2_Rx_Num]=USART_ReceiveData(USART2);

Uart2_Rx_Num++;

}

if((Uart2_Buffer[0]==0x5A)(Uart2_Buffer[Uart2_Rx_Num-1]==0xA5))//判断最终接收的数据是否为设定值,确定数据正确性

Uart2_Sta=1;

if(USART_GetFlagStatus(USART2,USART_FLAG_ORE)==SET)//溢出

STM32串口中断接收方式详细比较

{

USART_ClearFlag(USART2,USART_FLAG_ORE);//读SR

USART_ReceiveData(USART2);//读DR

}

}

if(Uart2_Sta)

{

for(Uart2_Tx_Num=0;Uart2_Tx_NumUart2_Rx_Num;Uart2_Tx_Num++)

USART2_SendByte(Uart2_Buffer[Uart2_Tx_Num]);//发送数据

Uart2_Rx_Num=0;//初始化

Uart2_Tx_Num=0;

Uart2_Sta=0;

}

这是加了数据头和数据尾的接收方式,数据头和尾的个数可增加,此处只用于调试之用。中断函数用于接收数据以及判断数据的头尾,其次个函数在main函数里依照查询方式执行。

优点:较简单,采用缓存区接收,对提高数据的正确行有一定的改善。

缺点:要是第一次数据接收错误,回不到初始化状态,必需复位操作。

实例三:

vvoidUSART2_IRQHandler()

{

if(USART_GetITStatus(USART2,USART_IT_RXNE)!=RESET)//中断产生{

USART_ClearITPendingBit(USART2,USART_IT_RXNE);//清除中断标志.Uart2_Buffer[Uart2_Rx]=USART_ReceiveData(USART2);

Uart2_Rx++;

Uart2_Rx=0x3F;//判断是否计数到最大

}

if(USART_GetFlagStatus(USART2,USART_FLAG_ORE)==SET)//溢出{

USART_ClearFlag(USART2,USART_FLAG_ORE);//读SR

USART_ReceiveData(USART2);//读DR

}

}

if(Uart2_Tx!=Uart2_Rx)

{

USART2_SendByte(Uart2_Buffer[Uart2_Tx]);//发送数据

Uart2_Tx++;

Uart2_Tx=0x3F;//判断是否计数到最大

}

采用FIFO方式接收数据,由0x3F可知此处最大接收量为64个,可变,中断函数只负责

STM32串口中断接收方式详细比较

收,另一函数在main函数里执行,FIFO方式发送。

优点:发送和接收都很自由,中断占用时间少,有利于MCU处理其它。

缺点:对数据的正确性没有判断,一概全部接收。

实例四:

voidUSART2_IRQHandler()

{

if(USART_GetITStatus(USART2,USART_IT_RXNE)!=RESET)//中断产生{

USART_ClearITPendingBit(USART2,USART_IT_RXNE);//清除中断标志Uart2_Buffer[Uart2_Rx]=USART_ReceiveData(USART2);

Uart2_Rx++;

Uart2_Rx=0xFF;

}

if(Uart2_Buffer[Uart2_Rx-1]==0x5A)//头

Uart2_Tx=Uart2_Rx-1;

if((Uart2_Buffer[Uart2_Tx]==0x5A)(Uart2_Buffer[Uart2_Rx-1]==0xA5))//检测到头的状况下检测到尾

{

Uart2_Len=Uart2_Rx-1-Uart2_Tx;//长度

Uart2_Sta=1;//标志位

}

if(USART_GetFlagStatus(USART2,USART_FLAG_ORE)==SET)//溢出{

USART_ClearFlag(USART2,USART_FLAG_ORE);//读SR

USART_ReceiveData(USART2);//读DR

}

}

if(Uart2_Sta)

{

for(tx2=0;tx2=Uart2_Len;tx2++,Uart2_Tx++)

USART2_SendByte(Uart2_Buffer[Uart2_Tx]);//发送数据Uart2_Rx=0;//初始化

Uart2_Tx=0;

Uart2_Sta=0;

}

数据采用数据包的形式接收,接收后存放于缓存区,通过判断数据头和数据尾(可变)来判断数据的“包〞及有效性,中断函数用于接收数据和判

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论