void USART1_IRQHandler(void)//´®¿Ú1ÖжϷþÎñ³ÌÐò
{
u8 Res;
#ifdef OS_TICKS_PER_SEC//Èç¹ûʱÖÓ½ÚÅÄÊý¶¨ÒåÁË,˵Ã÷ҪʹÓÃucosIIÁË.
OSIntEnter();
#endif
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)//¶ÁÊý¾Ý¼Ä´æÆ÷·Ç¿Õ ½ÓÊÕÖжÏ(½ÓÊÕµ½µÄÊý¾Ý±ØÐëÊÇ0x0d 0x0a½áβ)
{
Res =USART_ReceiveData(USART1);//(USART1->DR);//¶ÁȽÓÊÕµ½µÄÊý¾Ý
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;//½ÓÊÕÊý¾Ý´íÎó,ÖØпªÊ¼½ÓÊÕ
}
}
}
}
下面这段话来自原子的stm32开发攻略143页。
当接纳到从电脑发过来的数据,把接纳到的数据保存在 USART_RX_BUF 中,一起在接纳状况寄存器(USART_RX_STA)中计数接纳到的有用数据个数,当收到回车(回车的标明由 2 个字节组成:0X0D 和 0X0A)的榜首个字节 0X0D 时,计数器将不再添加,等候0X0A 的到来,而假如 0X0A 没有来到,则以为这次接纳失利,从头开端下一次接纳。假如顺畅接纳到 0X0A,则符号 USART_RX_STA 的第 15 位,这样完结一次接纳,并等候该位被其他程序铲除,然后开端下一次的接纳,而假如迟迟没有收到 0X0D,那么在接纳数据超越 USART_REC_LEN 的时分,则会丢掉前面的数据,从头接纳。
计算机向串口发送一串字符,一般不止一个,例如发送”abcdefg回车“。那么串口中止函数会履行9次,回车要履行两次串口中止。
当串口中止函数榜首次履行时,USART1->DR里边装的是字符a,下面以串口榜首次履行来剖析这个串口中止函数。
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)这是判别读数据寄存器是否空,由于承受到了a,所以不是空的,这个判别建立。
Res =USART_ReceiveData(USART1);//(USART1->DR);已然承受到了字符a,那么就要把他读取出来
if((USART_RX_STA&0x8000)==0) 由于现在承受的是榜首个字符,所以接纳必定没有完结,USART_RX_STA仍是它的初始化值,所以第15位仍是0,这个判别句子建立。所以要履行下面这句话
if(USART_RX_STA&0x4000)USART_RX_STA的第14位仍然是0,所以这个判别不建立,所以会履行下面这句话
if(Res==0x0d) 当然这个判别也不建立,所以要履行下面这句话
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;计算出接纳的是第几个字符,然后装到缓存里边
USART_RX_STA++;加1标明现已接纳好了几个数据
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/zhizao/257432.html