嵌入式开发交流网论坛

标题: 朱天龙:该不该用RTOS?我们只做对的选择(上) [打印本页]

作者: 又冷又饿4    时间: 2018-11-15 18:39
标题: 朱天龙:该不该用RTOS?我们只做对的选择(上)
[attach]17211[/attach]朱天龙
RT-Thread技术总监
Github中国区C语言类排名第24


嵌入式设备网络化、功能复杂化的趋势,使越来越多的、过去可以用裸奔实现的嵌入式产品,产生了应用操作系统的需求。芯片成本的连续下降,以及cpu性能和内存资源的迅速提高,又为大面积应用操作系统提供了物质基础。那么我们到底该不该从裸奔走向操作系统呢?

本文图片均来源于Unsplash无版权图库



回顾裸机时代

我第一次接触到嵌入式,大概是在 2008 年,那时候还是大二,刚开始学 51 单片机,自然还是要从裸机开始跑。因为自己是计算机系的,以前写程序都是跑在 PC 机上的,现在竟然能在电路板上执行软件,感觉完全不一样,至今还记得我第一次跑通流水灯的喜悦。但是随着写的裸机软件越来越多,裸机所暴露的问题也越来越多,这里我给大家总结下吧:


[attach]17212[/attach]



并发性:程序并发工作效率低
在写裸机软件时,不可避免的在主程序中会有一个超级大的 while(1) 循环,这里面几乎包含整个项目的所有业务逻辑。因为每个业务逻辑里面都会有 delay 这样的循环等待函数,这样导致了所有的业务逻辑几乎都是串行起来工作的。这个时候 CPU 就会有很多时间都浪费在了延时函数里,一直在空转,导致软件的并发效率非常差。


模块化:从软件工程的角度,我们在做软件开发时,都会强调高内聚、低耦合的原则。而裸机的模块化开发难度非常大,模块间的耦合较重,这也导致了无法在大型项目使用裸机来开发。


生态:很多高级软件组件,必须依赖于操作系统来实现


实时性:功能复杂的情况下,实时性无法保证
软件的实时性在一些领域会有一定的要求,软件的每个步骤必须在指定的时间被触发。工控领域就是最常见到的场景,如果实时性无法保证,机械设备可能就无法按照指定时序要求去动作,以至于发生机械事故,甚至会威胁到人的生命。回过来接着看裸机软件,如果软件变得庞大以后,可以想象到,主程序中那么大的一个 while(1) 循环,代码耦合严重,到处都是 delay 延时,要保证实时性几乎是不可能的。


可重用性:软件可重用性差,总是重复造轮子
可重用性与模块化程度有直接的关系。相信大家每个人在工作中都不想做很多重复性的工作,同样在写代码时,也想着尽可能少写一些功能相似的代码。但在这个嵌入式碎片化极其严重的时代,各式各样的芯片,想要让同样的代码,在裸机环境下同时适配不同的硬件,难度非常大。这样也就导致了裸机的代码会过多的依赖于底层硬件,重复造轮子的过程也就不可避免。


操作系统带来的优势

第一次接触操作系统,是在 2010 年左右,那时 STM32 已经开始流行起来,这么强大的单片机,有很多人都在上面跑操作系统,我也跟着移植了 ucos ,在上面还跑了 ucgui ,这个时候写应用完全是一种全新的体验,爽了很多,玩了一年了 ucos ,后来接触到咱们国产的 RT-Thread ,在它上面有很多现成的、拿来即用组件,试用以后发现更爽,就一直用到了今天,大概有 8 年了。也跟大家也聊一聊操作系统的优势:
线程方式的并发任务处理,解决模块化问题,同时保证实时性

模块化:使用了操作系统以后,整个软件的工作被拆分成了由多个任务来构成(也会被称为线程),每个线程有自己独立的运行空间,即线程堆栈,这个时候每个线程你玩你的,我做我的,咱们大家互补干涉,模块化程度得到很好的提高。
并发性:从并发的角度来看,各个线程在使用 delay/事件等待 这类函数时,会自动的让出 CPU 给其他有需要的线程,不仅书写 delay 延时函数操的心少了,整个 CPU 的利用率也得到了提高,最终提升并发性。
实时性:再来看实时性,像 ucos/RT-Thread 这些 RTOS 本身就被设计为实时的操作系统,各个线程都有不同的优先级别,重要的线程可以设为高优先级,不重要的线程可以降低优先级,做好全局的统筹规划后,这样整个软件的实时性也能得到保证。
开发效率:
由于操作系统提供了统一的抽象接口层,方便了可重用组件的积累,提高开发效率
软件生态:
生态的丰富带来了量变到质变的过程(自己玩->大家一起玩


常见RTOS优势对比

ucos/freertos/RT-Thread,选择这三款 OS 的原因是,它们的年限都比较长了,在市面上都蛮有知名度,用过的人比较多,更有说服力。


基本功能、性能:各家 RTOS 差异很小,可比性并不是很大
易用性/可读性:这块 FreeRTOS 应该说是最差,奇葩的匈牙利命名法,代码实现用了很多宏,可读性非常差。ucos 可读性还可以,注释也很全。这块做的比较好的是 RT-Thread ,它是类 Linux 的代码风格,面向对象的设计模式,代码简洁易懂。在保证了体积(最小 ROM:3K RAM:1.5K)的同时,还借鉴了 Linux 的设备驱动框架、虚拟文件系统、Shell 等功能,设计更加优雅。
组件丰富性:RT-Thread 比起传统 UCOS、FreeRTOS 不仅仅在基础功能上多而全,多达 50 个以上的可重用软件组件,还有很多物联网组件,对于物联网产品几乎做到开箱即用。RT-Thread 还可以运行 Python、JavaScript、Lua 这些高级语言的脚本,进一步降低开发难度。


[attach]17213[/attach]

RT-Thread架构图



开发资料:这块 ucos 做的最好,还有配套相关的书籍,FreeRTOS 属于后起之秀,网上也有很多相关资料。RT-Thread 这块之前还是略显薄弱的,不过现在 RT-Thread 对这块非常重视,最直观的可以看到官网上的应用笔记越来越多了,还有一些配套教学视频。

版权:ucos 商业是要收费的,FreeRTOS 和 RT-Thread 版权都很宽松,特别是RT-Thread刚刚使用了Apache许可协议
社区生态:这三款 RTOS 的社区都比较活跃,现在可以感觉到 ucos 慢慢的用的人越来越少了,RT-Thread 和 FreeRTOS 用的人都在增多。RT-Thread 也是开发者最多的国产 RTOS,并且还拥有国内最大的嵌入式开源软件社区。




近期活动

1.在公众号后台回复【野火RT-Thread】即可下载《RT-Thread内核实现与应用开发实战指南》基于STM32完整电子版。


2.RT-Thread 2018开发者大会 南京站:1、你将有机会与RT-Thread 团队直接交流探讨 2、看到来自RTT的合作伙伴或社区开发者的最新产品、作品 3、亲身参与到RT-Thread的动手实操,学习和体验一个IoT应用作品的诞生 4、还有多款开发板抽奖噢~
[attach]17214[/attach]
你可以添加微信13924608367为好友,注明:公司+姓名,拉进 RT-Thread 官方微信交流群
[attach]17215[/attach]
RT-Thread


让物联网终端的开发变得简单、快速,芯片的价值得到最大化发挥。GPLv2+协议,可免费在商业产品中使用。

长按二维码,关注我们


[attach]17216[/attach]点“阅读原文” 报名开发者大会




欢迎光临 嵌入式开发交流网论坛 (http://www.dianzixuexi.com/bbs/) Powered by Discuz! X3.2