(以下内容来自网络,仅供讨论交流之用,版权归作者@坚强的山猫所有)4 m" `9 B/ c+ d6 j8 w% r
7 h# V( ~' k! I" M0 U9 M9 H3 S: k& \( a+ ]3 ~" l' ?! \' ]: D& x$ w
1. FreeRTOS FreeRTOS是专为小型嵌入式系统设计的可扩展的实时内核。
- [" g& v6 e( i, \3 n0 Q亮点包括: - 微小的封装形式。
- 免费的RTOS调度程序
- 免费嵌入式软件源代码。
- 免版税。
- 抢占式,协作式和混合配置选项,可选时间分片。
- SafeRTOS衍生产品对代码完整性提供了高度的信心。
- 包括一个为低功耗应用设计的tickless模式。
- 可以使用动态或静态分配的RAM来创建RTOS对象(任务,队列,信号量,软件定时器,互斥体和事件组)。
- 官方支持>30个嵌入式系统架构(以ARM7和ARM Cortex-M3为一体架构)。
- FreeRTOS-MPU支持ARM Cortex-M3内存保护单元(MPU)。
- 设计小巧,简单易用。通常,RTOS内核二进制映像将在4K到9K字节的区域内。
- 可移植性非常好的源代码结构,主要用C.
- 支持实时任务和协同程序。
- 直接到任务通知,队列,二进制信号量,计数信号量,递归信号量和互斥体,用于任务之间的通信和同步,或实时任务和中断之间。
- 创新事件组(或事件标志)实施。
- 具有优先级继承的互斥体。
- 高效的软件定时器。
- 强大的执行跟踪功能。
- 堆栈溢出检测选项。
- 免费监控的论坛支持或可选的商业支持和许可。
- 对可创建的实时任务数量没有软件限制。
- 对可以使用的任务优先级的数量没有软件限制。
- 对任务优先级分配没有限制 - 可以为多个实时任务分配相同的优先级。
- 许多支持的架构的免费开发工具。
- 从标准的Windows主机开发。% s1 w3 L! H8 z# U1 Q& S2 C- B
* b1 f6 K& G8 g# O% _# @: |# C. x
/ g# P" j; i7 G/ t2 j
% F/ C% V; E' M/ v' v8 C9 f5 y- C: B) E8 K! x
2. uCOS家族(I/II/III) μC/ OS-II和μC/ OS-III是抢占式,高度便携式和可扩展的实时内核。这些内核旨在便于在大量CPU架构上使用,这些内核是μC/ OS实时操作系统的关键组件。 关键价值(Key Values): - 可移植性。 提供前所未有的易用性,μC/OS内核提供完整的源代码和深入的文档。 μC/ OS内核运行在大量处理器架构上,端口可供下载。
- 可扩展性。 μC/ OS内核允许无限制的任务和内核对象。内核的内存占用可以缩小,仅包含应用程序所需的功能,通常为6-24 KB的代码空间和1KB的数据空间。
- 可靠。 μC/ OS内核包括减少开发时间的调试功能。内核提供广泛的范围检查,包括检查API调用中传递的指针,来自ISR的任务级服务,允许范围内的参数以及有效的指定选项。
- 高效。 Micrium的内核还包括有价值的运行时统计信息,使您的应用程序的内部可视化。 识别性能瓶颈,并在开发周期的早期优化电源使用。
! j4 Y7 C" i8 r6 T
μC/ OS内核的特性包括以下亮点(Highlights): - 抢占式多任务实时内核,可选择循环调度
- 提供完整,干净,一致的源代码,具有深入的文档。
- 高可扩展性:无限数量的任务,优先级和内核对象
- 同时等待多个内核对象
- 直接向任务发送信号/消息
- 资源高效:6K至24K字节代码空间,1K +字节数据空间)
- 非常低的中断禁用时间
- 广泛的性能测量指标(可配置)
- 可用于关注安全型应用
& T! c$ T! X* _4 H# T
下表显示了µC/OS 多年来的演变, 比较了每个版本中可用的功能。 特点(Features) | µC/OS | µC/OSII | µC/OSIII | 发布年份 | 1992 | 1998 | 2009 | 提供源代码 | √ | √ | √ | 书(Book) | √ | √ | √ | 抢占式多任务 | √ | √ | √ | 最大任务量 | 64 | 255 | 无限 | 每个优先级别的任务数 | 1 | 1 | 无限 | 时间片轮转调度 | × | × | √ | 信号量 | √ | √ | √ | 互斥信号量 | × | √ | √(可嵌套) | 事件标志组 | × | √ | √ | 消息邮箱 | √ | √ | ×(不需要) | 消息队列 | √ | √ | √ | 固定大小的内存管理 | × | √ | √ | 直接向任务发送信号量 | × | × | √ | 无需调度的信号发送选项 | × | × | √ | 直接向任务发送消息 | × | × | √ | 软件定时器 | × | √ | √ | 任务挂起/恢复 | × | √ | √(可嵌套) | 防止死锁 | √ | √ | √ | 可裁剪 | √ | √ | √ | 代码量 | 3K-8K | 6K-26K | 6K-24K | 数据量 | 1K+ | 1K+ | 1K+ | 代码可固化 | √ | √ | √ | 运行时可配置 | × | × | √ | 编译时可配置 | √ | √ | √ | 支持内核对象的 ASCII 命名 | × | √ | √ | 同时等待多个内核对象 | × | √ | √ | 任务寄存器 | × | √ | √ | 内置性能测试 | × | 基本 | 增强 | 内置追踪点 | × | × | √ | 用户可定义的钩子函数 | × | √ | √ | POST 操作可加时间戳 | × | × | √ | 内核察觉式调试 | × | √ | √ | 用汇编语言优化的调度器 | × | × | √ | 捕获退出的任务 | × | × | √ | 任务级时钟节拍处理 | × | √ | √ | 系统服务函数的数目 | ~20 | ~90 | ~75 |
9 R! Y0 i1 m I2 H% } O& n" Q: n& K3 o
$ C& L& w: \4 t& j+ ?" v: C% O% C5 w: N, `6 u
3. RT-Thread- Tips:在markdown中实现段落缩进 ! A+ e, }- \! G$ i0 [: L$ V
- - 半方大的空白 或 ' g$ ~+ S+ w# Z( C8 c3 U3 g4 e. n- a
- - 全方大的空白 或
: E; x, V: ^0 Q0 ] - - 不断行的空白格 或
复制代码 : v3 P6 U) d+ A! h
RT-Thread是一款来自中国的开源嵌入式实时操作系统,由国内一些专业开发人员从2006年开始开发、维护,除了类似FreeRTOS和UCOS的实时操作系统内核外,也包括一系列应用组件和驱动框架,如TCP/IP协议栈,虚拟文件系统,POSIX接口,图形用户界面,FreeModbus主从协议栈,CAN框架,动态模块等,因为系统稳定,功能丰富的特性被广泛用于新能源,电网,风机等高可靠性行业和设备上,已经被验证是一款高可靠的实时操作系统。 RT-Thread实时操作系统遵循GPLv2+许可证,实时操作系统内核及所有开源组件可以免费在商业产品中使用,不需要公布应用源码,没有任何潜在商业风险。 " f- n8 n& M# `0 G1 @7 z# Q
RT-Thread实时操作系统核心是一个高效的硬实时核心,它具备非常优异的实时性、稳定性、可剪裁性,当进行最小配置时,内核体积可以到 3k ROM 占用、1k RAM 占用。 在RT-Thread中线程是最小的调度单位,线程调度算法是基于优先级的全抢占式多线程调度算法,支持256个线程优先级(也能通过配置文件更改为最大支持32个或8个线程优先级),0优先级代表最高优先级,255优先级留给空闲线程使用;支持创建相同优先级线程,相同优先级的线程采用可设置时间片的轮转调度算法;调度器寻找下一个最高优先级就绪线程的时间是恒定的(时间复杂度是1,即O(1))。系统不限制线程数量的多少,只和硬件平台的具体内存相关。 - 任务同步机制
9 ]5 g, L+ | w; l( O) A/ }
系统支持semaphore(信号量)、mutex(互斥锁)作为线程间同步机制。mutex采用优先级继存方式以解决优先级翻转问题。semaphore的释放动作可安全用于中断服务例程中。同步机制支持线程按优先级等待或按先进先出方式获取信号量或互斥锁。 - 任务间通信机制: m9 m' v! }' T Y8 y% ]
系统支持event(事件)、mbox(邮箱)和MessageQueue(消息队列)等通信机制。event支持多事件”或触发”及”与触发”,适合于线程等待多个事件情况。mbox中一封邮件的长度固定为4字节,效率较MessageQueue更为高效。通信设施中的发送动作可安全用于中断服务例程中。通信机制支持线程按优先级等待或按先进先出方式获取。 - 时间管理5 ~4 R$ M( ^6 J. H" O
系统使用时钟节拍来完成同优先级任务的时间片轮转调度;线程对内核对象的时间敏感性是通过系统定时器来实现的;定时器支持软定时器及硬定时器(软定时器的处理在系统线程的上下文中,硬定时器的处理在中断的上下文中);定时器支持一次性超时及周期性超时。 - 内存管理
: h% s! s7 U% a/ q; h- p
系统支持静态内存池管理及动态内存堆管理。从静态内存池中获取内存块时间恒定,当内存池为空时,可把申请内存块的线程阻塞(或立刻返回,或等待一段时间后仍未获得内存块返回。这取决于内存块申请时设置的等待时间),当其他线程释内存块到内存池时,将把相应阻塞线程唤醒。动态堆内存管理对于不同的系统资源情况,提供了面向小内存系统的小内存管理算法及大内存系统的SLAB内存管理算法。 系统实现了按名称访问的设备管理子系统,可按照统一的API界面访问硬件设备。在设备驱动接口上,根据嵌入式系统的特点,对不同的设备可以挂接相应的事件,当设备事件触发时,通知给上层的应用程序。 - RT-Thread这个系统还是有很多自己的想法在里面的,比如Finish,设备树等都是参照Linux的思想来设计的。
复制代码
4 N8 l* e& q; u6 `8 @
" q3 T8 n& C5 `5 c
4. RTX Keil RTX是为ARM和Cortex-M设备设计的免版税,确定性的实时操作系统。它允许您创建同时执行多个功能的程序,并帮助创建更好的结构和更容易维护的应用程序。 特征 - 具有源代码的免版权,确定性RTOS
- 灵活的调度:循环,抢占和协作
- 具有低中断延迟的高速实时操作
- 为资源有限的系统提供小封装
- 无限数量的任务每个具有254个优先级
- 无限数量的邮箱,信号量,互斥量和计时器
- 支持多线程和线程安全操作
- 内核感知调试支持MDK-ARM
- 使用μVision配置向导的基于对话框的设置4 |# m2 h. }, ^5 i* f& n
优点 尽管无需实时操作系统(通过在超级循环中执行一个或多个功能)就可以创建实时程序,但KeilRTX为您解决的RTOS有许多调度,维护和计时问题。 注意事项 3 ?7 _. U. ]) {, h* \
所有MDK-ARM版本都包含RTX源代码。 - 这个系统我只是用过一次,感觉最大的特点就是用起来简单,不需要那么多的注意事项,拿来就用的感觉,还有就是没有关中断的操作,所以你懂的~
复制代码 % ~* U2 \& L8 ~: R7 P
3 U" q- w: m+ F [; P0 L6 z8 }0 L) C1 n/ h4 n9 P
|
rt_HAL_CM.h中4 D+ J4 w3 R$ _ C) Q2 B8 F8 p8 C: S
__enable_irq
__disable_irq
不是吗?