0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

为什么我们需要从裸机转RTOS?

GReq_mcu168 来源:嵌入式专栏 作者:嵌入式专栏 2021-04-25 16:39 次阅读

很多单片机初学者都是从裸机开始的,裸机确实也能开发出好的产品,但作为一个嵌入式软件工程师,如果只能用裸机开发产品,那肯定是不够的。

要从裸机的思维转变到RTOS的思维,其实需要一个过程,而且开始的一段时间会很痛苦。但过一段时间理解了一些内容,能写一些Demo之后,你会发现其实RTOS也不难。

1

为什么需要RTOS?为什么我们需要RTOS?就像最开始学C编程时,老师告诉我们,指针很重要,那时你肯定有一个大的疑问,指针到底有什么好?

心里一直犯嘀咕着:不用指针不一样把程序编出来了? 现在想想看C语言没了指针,是不是“寸步难行”呢。

回到正题,我们到底为什么需要RTOS? 一般的简单的嵌入式设备的编程思路是下面这样的:

main{ {处理事务1}; {处理事务2}; {处理事务3}; 。..。..。 {处理事务N};}

isr_server{ {处理中断};}

这是最常见的一种思路,对于简单的系统当然是够用了,但这样的系统实时性很差。

比如“事务1”如果是一个用户输入的检测,当用户输入时,如果程序正在处理事务1下面的那些事务,那么这次用户输入将失效,用户的体验是“这个按键不灵敏,这个机器很慢”,

而我们如果把事务放到中断里去处理,虽然改善了实时性但会导致另外一个问题,有可能会引发中断丢失,这个后果有时候比“慢一点”更加严重和恶劣!

又比如事务2是一个只需要1s钟处理一次的任务,那么显然事务2会白白浪费CPU的时间。

2

改变思维看到上面裸机开发的局限了吗?

这时,我们可能需要改进我们的编程思路,一般我们会尝试采用“时间片”的方式。这时候编程会变成下面的方式:

main{ {事务1的时间片到了则处理事务1}; {事务2的时间片到了则处理事务2}; 。..。..。 {事务N的时间片到了则处理事务N};}

time_isr_server{ {判断每个事务的时间片是否到来,并进行标记};}

isr_server{ {处理中断};}

我们可以看到,这种改进后的思路,使得事务的执行时间得到控制,事务只在自己的时间片到来后,才会去执行,但我们发现,这种方式仍然不能彻底解决“实时性”的问题,因为某个事务的时间片到来后,也不能立即就执行,她必须等到当前事务的时间片用完,并且后面的事务时间片没到来,她才有机会获得“执行时间”。

这时候我们需要继续改进思路,为了使得某个事务的时间片到来后能立即执行,我们需要在时钟中断里判断完时间片后,改变程序的返回位置,让程序不返回到刚刚被打断的位置,而从最新获得了时间片的事务处开始执行,这样就彻底解决了事务的实时问题。

我们在这个思路上,进行改进,我们需要在每次进入时钟中断前,保存CPU的当前状态和当前事务用到的一些数据,然后我们进入时钟中断进行时间片处理,若发现有新的更紧急的事务的时间片到来了,则我们改变中断的返回的地址,并在CPU中恢复这个更紧急的事务的现场,然后返回中断开始执行这个更紧急的事务。

3

使用RTOS替代这种方式上面那段话,对于初学者来说,可能有些不好理解。

事实上,这是因为要实现这个过程是有些复杂和麻烦的,这时候我们就需要找一个操作系统(OS)帮我们做这些事了,如果你能自己用代码实现这个过程,事实上你就在自己写操作系统了。

其实从这里也可也看出,操作系统的原理其实并不那么神秘,只是一些细节你很难做好。u我们常见的RTOS基本都是这样的一个操作系统,它能帮你完成这些事情,而且是很优雅的帮你完成!

到这里,我们终于知道了为什么我们需要RTOS了。事实上,RTOS的用处远不止帮你完成这个“事务时间片的处理”,它还能帮你处理各种超时,进行内存管理,完成任务间的通信等。

有了RTOS,程序的层次也更加清晰,给系统添加功能也更方便,这一切在大型项目中越发的明显!

分享到这里,你知道为什么我们需要从 裸机 转 RTOS了吧。

原文标题:从 裸机 到 RTOS 思维的转变

文章出处:【微信公众号:玩转单片机】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • RTOS
    +关注

    关注

    20

    文章

    776

    浏览量

    118796
  • 裸机
    +关注

    关注

    0

    文章

    37

    浏览量

    6154

原文标题:从 裸机 到 RTOS 思维的转变

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32mp135裸机开发无法使用DDR吗?

    /STM32CubeMP13_Package_-_Getting_started#Integrating_AzureRTOS_middleware 咨询一下关于DDR的使用问题: 1.只有RTOS的才能对DDR进行配置吗? 2.单纯裸机开发(无
    发表于 03-11 07:01

    何时选择裸机?何时选择RTOS?何时选择GPOS?

    在每个开发项目的初期,你都必须选择软件开发的基础。虽然有很多选择,但它们通常分为三类:裸机、实时操作系统(RTOS)或通用操作系统(GPOS)。
    的头像 发表于 02-27 11:42 356次阅读

    分享几点RTOS相比裸机的优势

    嵌入式系统中,有很多方式实现任务调度。功能有限的小系统中,无限循环足够实现小系统的功能。当软件设计变得庞大且复杂时,开发者应该考虑使用实时操作系统RTOS
    的头像 发表于 01-24 18:23 978次阅读
    分享几点<b class='flag-5'>RTOS</b>相比<b class='flag-5'>裸机</b>的优势

    RTOS内核源码,非必要不建议阅读

    在2011、12年读书的时候,RTOS还不像现在这么流行(那时还是以“裸机”为主),那个时候网上RTOS的教程大多都还是以μCOS为主,其他RTOS的资料相对很少。像FreeRTOS、
    的头像 发表于 10-30 16:37 297次阅读
    <b class='flag-5'>RTOS</b>内核源码,非必要不建议阅读

    RTOS相比裸机有什么优点?RTOS相比裸机更方便吗?

    RTOS相比裸机有什么优点?RTOS相比裸机更方便吗? RTOS代表实时操作系统,专门为需要高可
    的头像 发表于 10-29 16:33 1009次阅读

    Linux裸机点灯

    Linux裸机
    怎么啦
    发布于 :2023年10月27日 08:47:24

    RTOS会比裸机实时性好吗?

    RTOS会比裸机实时性好么
    发表于 10-13 07:17

    低功耗应用是用RTOS还是裸机,哪个省电?

    低功耗应用是用RTOS还是裸机,哪个省电?
    发表于 09-20 07:43

    “国产双系统”出炉,RK3568J非对称AMP:Linux+RTOS/裸机

    ,如Linux+RTOS/裸机,但需一个主核心来控制整个系统以及其它从核心。每个处理器核心相互隔离,拥有属于自己的内存,既可各自独立运行不同的任务又可多个核心之间进行核间通信
    的头像 发表于 09-13 08:07 825次阅读
    “国产双系统”出炉,RK3568J非对称AMP:Linux+<b class='flag-5'>RTOS</b>/<b class='flag-5'>裸机</b>

    构建RTOS Kernel指南 (上)

    1 前言 试想与我们相伴的MCU如若只存在裸机程序,那么运行到一个包含延时的线程时,我们的CPU就开始“摸鱼”了。 为了最大化运行CPU,就需要用到
    的头像 发表于 08-03 08:45 387次阅读
    构建<b class='flag-5'>RTOS</b> Kernel指南 (上)

    朱天龙:学习和掌握RTOS最好的方法

    在讨论“ 如何学习和掌握RTOS “这件事情之前,我们首先要明确一点:我们是否有必要学习RTOS? 关于这一点,可以看我18年的时候写的一篇文章 《该不该用
    的头像 发表于 07-28 20:45 723次阅读
    朱天龙:学习和掌握<b class='flag-5'>RTOS</b>最好的方法

    求助,什么时候用RTOS

    本菜鸟一直是用的裸机开发,也学习过操作系统,但是一直没明白什么时候用RTOS,感觉用裸 机开发一点问题没有啊,什么情况下用RTOS
    发表于 06-28 06:54

    分享一下Cortex-M裸机环境下临界区保护的几种实现方法

    RTOS有临界区,裸机依然有临界区。今天给大家分享一下Cortex-M裸机环境下临界区保护的几种实现方法。
    发表于 06-13 09:08 317次阅读
    分享一下Cortex-M<b class='flag-5'>裸机</b>环境下临界区保护的几种实现方法

    为什么NodeMCU不需要外部电源来闪烁而裸机ESP***-E需要它?

    为什么 NodeMCU 不需要外部电源来闪烁而裸机 ESP***-E 需要它? 是因为USB串口转换器吗?
    发表于 05-31 06:57

    RTOS常用的调度算法

    裸机(前后台架构)的软件开发过渡到使用实时操作系统(RTOS)可能是一项困难的工作。
    的头像 发表于 05-29 09:22 498次阅读
    <b class='flag-5'>RTOS</b>常用的调度算法