串口接收模型与实时性的一点思考

在这里插入图片描述
UART 模块接收数据 进入DR接收寄存器,RXN表示接收非空标志位在 中断使能的情况下会调转进入 ISR中断服务函数
到这里这些过程都是由MCU自己完成,其中中断使能有两重含义
1.CPU未屏蔽中断
2.RXN事件的中断使能
中断使能后,如果对应的事件发生那么对应的中断标志位被悬起,CPU会转为处理ISR。

在这里插入图片描述

实时系统应该在事先先定义的时间范围内识别和处理离散事件。
如果ISR没有及时的把数据从DR数据寄存器中搬运出去,那么下一个数据到来的时候,DR数据寄存器就会被覆盖。这样上一个DR数据寄存器的数据就会丢失,导致错失信息。这里就产生一个实时要求,产生RXN事件后,需要在下一个数据到来前取出DR寄存器上的数据。
1.尽快的进入到 ISR
2.ISR尽可能快速处理完成,以免下一个RXN事件到来时ISR还未处理完成任务。

第一点:ISR的进入受到中断使能的制约
第二点:ISR尽可能的快速处理完成,这样以免事情积压。或者其他低优先级中断无法得到相应。

这样对整个嵌入式系统的设计提出了要求:
CPU 尽可能快的响应ISR,CPU 禁止中断的时间要极可能短,非必要不要禁用中断。
同时处理ISR的过程中,低优先级的中断是无法运行的。所以ISR函数要尽可能的短。

在这里插入图片描述
一般来说会把接收到的数据保存到FIFO BUFFER中(可以通过数组实现),这样数据就保存在了缓存数组中,实时性的需求被处理完成。
那么这个时候如何对数据进行处理,先思考一个问题
对数据的处理这件事的实时性,来看几个情景
1.数据代表当前的办公室室内气温
气温是一个变化缓慢的数据,这个数据可能显示屏幕上。路过的人看一下,知道今天的气温。
很显然这个数据的处理并不需要什么实时性。
2.数据代表 电动车当前的转速
很显然如果数据是提供给控制算法的,那么这个数据实时性就要高的多了。

数据有时候不是单个字节,需要组合为一串数据才有意义。
在process过程中去判断数据包是否完成,再去主动唤醒应用层处理数据。
或者process 每次接收到一个数据就去唤醒application,以便application能够最快的相应每个字节的数据。
在这里插入图片描述

1.process 本身需要耗费时间,增加ISR的开销
2.发送信号量本身是调用 操作系统,也会有相应的开销,甚至产生关中断的临界区。

另外一种结构,如下
在这里插入图片描述
application task根据其任务的需求周期去读取FIFO的数据。ISR只做数据保存。
结合两者的优点,下图所示

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值