USART1_IRQHandler 函数的理解

发布时间:2024-08-12  

 1 void USART1_IRQHandler(void) //串口 1 中断服务程序

 2 {

 3   u8 Res;

 4   #if SYSTEM_SUPPORT_OS //如果 SYSTEM_SUPPORT_OS 为真,则需要支持 OS

 5   OSIntEnter();

 6   #endif

 7   if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)

 8   //接收中断(接收到的数据必须是 0x0d 0x0a 结尾)

 9   {

10     Res =USART_ReceiveData(USART1);//(USART1->DR); //读取接收到的数据

11     if((USART_RX_STA&0x8000)==0)//接收未完成15     {

16       if(USART_RX_STA&0x4000)//接收到了 0x0d

17       {

18         if(Res!=0x0a)USART_RX_STA=0;//接收错误,重新开始

19         else USART_RX_STA|=0x8000; //接收完成了

20       }

21       else //还没收到 0X0D

22       { 

23         if(Res==0x0d)USART_RX_STA|=0x4000;

24         else

25         {

26           USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;

27           USART_RX_STA++;

28           if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;

29           //接收数据错误,重新开始接收

30         } 

31       }

32     }

33   }

34 #if SYSTEM_SUPPORT_OS //如果 SYSTEM_SUPPORT_OS 为真,则需要支持 OS

35 OSIntExit();

36 #endif

37 }


下面这段话来自原子的stm32开发指南-库函数版本V1.3 129页。

当接收到从电脑发过来的数据,把接收到的数据保存在 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表明已经接收好了几个数据原文链接:https://blog.csdn.net/qq_36226810/article/details/82787905


 


个人理解:相当于数组存储数值,当作缓冲


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    他高级功能包括: 具有眼图掩蔽和错误计数器的核心独立 LFSR(线性反馈移位寄存器)训练模式,可提高训练准确性,同时减少训练时间。 独立通道数量翻倍,从 GDDR6 中的 2 个增加到 GDDR7 中的 4......
    为未加扰控制期(UCP),如下图所示的红色部分所示。除UCP外的整个控制周期称为扰频器同步控制周期(SSCP)。每个字段可以传输一个 SSCP,以保持字符同步。 下表显示了如何对不同的周期进行加扰和编码。 线性反馈移位寄存器......
    选择生成噪声,使用 LFSR(线性反馈移位寄存器)可以生成可变振幅的伪噪声。 LFSR中的预加载值为0xAAA。 5、生成三角波 将 WAVEx[1:0] 置为“10”即可选择 DAC 生成......
    成一个字节数据,存放在数据寄存器里。 当配置好USART的电路之后,直接读取数据寄存器,就可以自动发送数据和接收数据了。在发送和接收的模块有4个重要的寄存器 发送数据寄存器TDR 发送移位寄存器,把一......
    升沿或STB3的下降沿作用下,定时的移到移位寄存器A中,寄存器A和B控制输入端所要求的各种信号的逻辑关系如表2所列。   AD7543的主要特性如下:  ● 分辨率为12位。  ● 非线性为±1/2LSB......
    考虑顶层管脚资源的限制,使用压缩逻辑,将数目庞大的测试扫描链,压缩为若干个测试通道;扫描链的输出经过压缩逻辑,压缩成若干输出。 逻辑自测试启动后,伪随机图形产生器产生测试图形,经过内置有线性反馈移位寄存器......
    考虑顶层管脚资源的限制,使用压缩逻辑,将数目庞大的测试扫描链,压缩为若干个测试通道;扫描链的输出经过压缩逻辑,压缩成若干输出。 逻辑自测试启动后,伪随机图形产生器产生测试图形,经过内置有线性反馈移位寄存器......
    以省略隔离电阻。这种方法允许无限数量的芯片串联放置。 图1.三个DS1267串联,与反馈电阻串联,用于读取移位寄存器。 注意:反馈电阻应约为10kΩ,以便在I/O引脚2和C之间提供足够的隔离外当 I/O 引脚......
    有 8 位移位寄存器和一个存储器,三态输出功能。移位寄存器和存储器是分别的时钟。 数据在 SCK 的上升沿输入,在 RCK 的上升沿进入到存储器中。如果两个时钟连在一起,则移位寄存器......
    输出/从机输入数据线MOSI和低电平有效的从机选择线SSEL。这些外围器件可以是简单的TTL移位寄存器、复杂的LCD显示驱动器、Flash、RAM、A/D转换器、网络控制器及其他MCU等。 本文......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>