本帖最后由 classroom 于 2023-3-6 10:31 编辑
文章将介绍实时操作系统RTOS,分析为什么在嵌入式系统中使用它。什么是实时操作系统 操作系统的定义: 一个计算机系统可以大致分为四个部分:硬件(Hardware),操作系统(operating system),应用程序(application programs),使用者(user)。 硬件包含了CPU,存储空间,输入输出设备等为整个系统提供了基础的计算资源。 操作系统是一个控制程序,作为硬件和应用程序之间的桥梁,主要是和硬件打交道,负责协调分配计算资源和内存资源给不同的应用程序使用,并防止系统出现故障。面对来自不同应用程序的大量且互相竞争的资源请求,操作系统通过一个调度算法和内存管理算法尽可能把资源公平,有效率地分配给不同的程序。 应用程序则通过调用操作系统提供的API接口获得相应资源完成指定的任务。 一个通用操作系统提供的主要功能有(可见下图蓝色的部分):
- 任务(应用程序)的调度管理
- 堆栈和内存管理
- 文件管理
- 队列管理
- 中断和定时器管理
- 资源管理
- 输入输出管理
值得注意的是,操作系统自身需要占用一定的计算资源和内存资源,对于片上资源有限的单片机,可能需要根据需求剪裁操作系统的大小和功能。实时性的含义 实时操作系统(RTOS-Real Time Operating System)中实时(Real Time)指的是任务(Task)或者说实现一个功能的线程(Thread)必须在给定的时间(Deadline)内完成。
业界总有种误解认为如果能堆砌更多的处理器核心数目,更高的处理器频率,更大的内存,更快的总线速度系统就能一定达到实时性的表现。但是强大的计算能力并不能保证系统的实时性。 举一个简单例子比如汽车中的安全气囊,在传感器检测到汽车发生碰撞后,安全气囊需要在30ms内完全打开,不然司机和乘客的人身安全将受到极大的威胁。即使车载ECU有很强大的计算能力,但是如果因为要执行其他复杂计算任务或者任务调度的问题导致对汽车状态的监测和安全气囊的响应时间超过规定的时间,实时性无法得到保障导致系统失效和人员伤亡,这将会是非常严重的系统问题。 再举个例子比如特斯拉的车载系统:车机系统采用的是Linux系统,而汽车的驱动模块和刹车模块使用的是各自独自的系统。整个娱乐系统,触摸屏以及智能驾驶系统,都与汽车的驱动完全分开,确保了系统的实时性。 一些其它的实时任务包括导弹的制导,无人驾驶等。为了保障这些实时任务能在给定的时间内完成,需要一个实时系统对这些任务进行调度和管理。一个实时操作系统能尽力保障每个任务能在一个已知的最大运行时间(Maximum Response Time)内完成,包括:
- 对中断和内部异常的处理
- 对安全相关的事件的处理
- 任务调度机制等
当然系统的稳定性不能仅仅依靠实时操作系统,安全功能(fail-safe function)相关的设计也是必须要考虑到的。在Netflix的纪录片《一落千丈:波音大调查》中就提到,导致两起波音最新机型737 Max的失事事故的直接原因在于当飞机的迎角传感器发生故障,机上装载的机动特性增强系统(MCAS)误认为飞机处于失速状态,无视飞行员的操纵强制自动接管飞机,持续压机头导致了惨剧的发生。可见纵使波音的飞控系统非常稳定,但如果对传感器的数值判定和使用不当并缺少安全性冗余设计,系统的整体稳定性依然无法得到保障。
操作系统的种类 目前比较流行的实时操作系统包括黑莓QNX,FreeRTOS,uCOS,RT-Thread等。在上图中可以看出,除了Linux和Windows通用操作系统外,接下来便是FreeRTOS受到广大开发者的青睐。图表中也罗列了一些国产的系统。比如腾讯发布和开源的TencentOS tiny,这是一个面向物联网的实时操作系统。华为也推出了鸿蒙LiteOS, 万物互联未来可期。和实时操作系统(Real Time Operating System)相对应的是通用操作系统(General Purpose Operating System)。 通用操作系统包括Linux,Windows,MAC等主流的操作系统。这些操作系统大家每天都在使用,功能也十分强大,只是它们有时为了保障系统的流畅运行,就不能保证每个程序都能实时响应,在易用性和实时性之间有所取舍。而且单片机有限的片上资源也不足以支撑通用操作系统的运行。 正所谓术业有专攻,在嵌入式领域中,嵌入式实时操作系统(RTOS)可以更合理、更有效地利用CPU的资源,简化应用软件的设计,缩短系统开发时间,从而更好地保证系统的实时性和可靠性。FreeRTOS的介绍 FreeRTOS 是一个迷你的实时操作系统内核。作为一个轻量级的操作系统,功能包括:任务管理、时间管理、信号量、消息队列、内存管理、记录功能、软件定时器、协程等,可基本满足较小系统的需要。由于RTOS需占用一定的系统资源(尤其是RAM资源),只有μC/OS-II、embOS、salvo、FreeRTOS等少数实时操作系统能在小RAM单片机上运行。相对μC/OS-II、embOS等商业操作系统,FreeRTOS操作系统是完全免费的操作系统,具有源码公开、可移植、可裁减、调度策略灵活的特点,可以方便地移植到各种单片机上运行。 FreeRTOS的官网地址:https://www.freertos.org/ 官网上会有关于FreeRTOS的最新新闻和技术文档,如果大家吃透了FreeRTOS的技术文档的话,其实也就不需要读文章了哈哈。FreeRTOS的特性
- 具有抢占式或者合作式的实时操作系统内核
- 功能可裁剪,最小占用10kB左右rom空间,0.5kB ram空间
- 具有低功耗模式
- 有互斥锁、信号量、消息队列等功能
- 运行过程可追踪
|