[导读]很多STM32单片机初学者都是从裸机开始的,裸机确实也能开发出好的产品。但是,作为一个嵌入式软件工程师,况且用的并不是51那种低端单片机,如果只会用裸机开发产品,那肯定是不够的。要从裸机的思维转变到RTOS(RealTimeOperatingSystem)的思维,其实需要一个过程...
很多STM32单片机初学者都是从裸机开始的,裸机确实也能开发出好的产品。但是,作为一个嵌入式软件工程师,况且用的并不是51那种低端单片机,如果只会用裸机开发产品,那肯定是不够的。要从裸机的思维转变到RTOS(Real Time Operating System)的思维,其实需要一个过程,而且开始的一段时间会很痛苦。但过一段时间理解了一些内容,能写一些Demo之后,你会发现其实RTOS也不难。现在FreeRTOS在CubeMX工具中可以直接配置并使用,相当方便。
为什么需要RTOS 为什么我们需要RTOS?就像最开始学C编程时,老师告诉我们,指针很重要,那时你肯定有一个大的疑问,指针到底有什么好? 心里一直犯嘀咕着:不用指针不一样把程序编出来了? 现在想想看C语言没了指针,是不是“寸步难行”呢。
回到正题,我们到底为什么需要RTOS? 一般的简单的嵌入式设备的编程思路是下面这样的: 这是最常见的一种思路,对于简单的系统当然是够用了,但这样的系统实时性很差。 比如“事务1”如果是一个用户输入的检测,当用户输入时,如果程序正在处理事务1下面的那些事务,那么这次用户输入将失效,用户的体验是“这个按键不灵敏,这个机器很慢”,而我们如果把事务放到中断里去处理,虽然改善了实时性但会导致另外一个问题,有可能会引发中断丢失,这个后果有时候比“慢一点”更加严重和恶劣! 又比如事务2是一个只需要1s钟处理一次的任务,那么显然事务2会白白浪费CPU的时间。
改进思路 看到上面裸机开发的局限了吗? 这时,我们可能需要改进我们的编程思路,一般我们会尝试采用“时间片”的方式。这时候编程会变成下面的方式: 可以看到,这种改进后的思路,使得事务的执行时间得到控制,事务只在自己的时间片到来后,才会去执行。但这种方式仍然不能彻底解决“实时性”的问题,因为某个事务的时间片到来后,也不能立即就执行,必须等到当前事务的时间片用完,并且后面的事务时间片没到来,才有机会获得“执行时间”。 这时候我们需要继续改进思路,为了使得某个事务的时间片到来后能立即执行,我们需要在时钟中断里判断完时间片后,改变程序的返回位置,让程序不返回到刚刚被打断的位置,而从最新获得了时间片的事务处开始执行,这样就彻底解决了事务的实时问题。 我们在这个思路上,进行改进,我们需要在每次进入时钟中断前,保存CPU的当前状态和当前事务用到的一些数据,然后我们进入时钟中断进行时间片处理,若发现有新的更紧急的事务的时间片到来了,则我们改变中断的返回的地址,并在CPU中恢复这个更紧急的事务的现场,然后返回中断开始执行这个更紧急的事务。使用RTOS的好处 上面那段话,对于初学者来说,可能有些不好理解。 事实上,这是因为要实现这个过程是有些复杂和麻烦的,这时候我们就需要找一个操作系统(OS)帮我们做这些事了,如果你能自己用代码实现这个过程,事实上你就在自己写操作系统了。
其实从这里也可也看出,操作系统的原理其实并不那么神秘,只是一些细节你很难做好。我们常见的RTOS基本都是这样的一个操作系统,它能帮你完成这些事情,而且是很优雅的帮你完成!RTOS的用处远不止帮你完成这个“事务时间片的处理”,它还能帮你处理各种超时,进行内存管理,完成任务间的通信等。有了RTOS,程序的层次也更加清晰,给系统添加功能也更方便,这一切在大型项目中越发的明显!END来源:网络版权归原作者所有,如有侵权,请联系删除。▍
扫描二维码,关注更多精彩内容
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
在嵌入式实时系统中,任务切换速度是衡量RTOS实时性的核心指标。标准FreeRTOS在STM32F4系列上的任务切换时间通常在10-20微秒级别,但对于电机控制、高速通信等应用,这仍显不足。本文将探讨如何通过深度内核裁剪...
关键字:
RTOS
STM32
FreeRTOS
裸机
在实时操作系统(RTOS)驱动的嵌入式设备中,内存管理效率直接影响系统稳定性与实时性。传统软件实现的堆碎片整理和栈溢出检测存在性能损耗大、检测滞后等问题,而硬件辅助技术通过专用内存管理单元(MMU)或内存保护单元(MPU...
关键字:
RTOS
内存管理
硬件加速
在资源受限的嵌入式设备中部署TinyML(微型机器学习)模型时,实时性保障是核心挑战。传统RTOS(实时操作系统)通过优先级抢占式调度实现确定性响应,但TinyML的引入带来了计算负载与内存占用的双重压力。本文从任务调度...
关键字:
TinyML
RTOS
在物联网与工业智能化高速发展的当下,嵌入式系统早已深度融入医疗设备、工业控制、汽车电子等关键领域,这些场景对系统的安全性、稳定性与可靠性提出了近乎严苛的要求。实时操作系统(RTOS)凭借其任务调度的实时性与资源管理的高效...
关键字:
RTOS
MPU
在物联网(IoT)的生态系统中,微控制器(MCU)、实时操作系统(RTOS)和物联网技术三者构成了一个紧密协作的三角关系。微控制器作为硬件核心,提供计算与控制能力;RTOS作为软件桥梁,管理任务调度与资源分配;物联网则定...
关键字:
MCU
RTOS
嵌入式实时操作系统(RTOS)的开发中,任务间的数据共享与同步是系统设计的核心挑战。开发者面临的第一个关键抉择,就是选择合适的通信机制:是直接使用全局变量,还是借助RTOS提供的专业任务间通信机制(如消息队列、信号量、事...
关键字:
RTOS
全局变量
在嵌入式系统开发中,MCU主频与内存容量的选型直接影响系统性能与可靠性。以STM32F4系列为例,其主频高达180MHz,支持浮点运算单元(FPU)和DSP指令集,配合最高1MB Flash与192KB SRAM,成为工...
关键字:
MCU
STM32F4
RTOS
在嵌入式系统开发中,实时操作系统(RTOS)的选择直接影响项目开发效率、系统性能及维护成本。FreeRTOS与Zephyr作为两大主流RTOS,分别代表“轻量级精简设计”与“模块化物联网生态”两种技术路线。本文从架构特性...
关键字:
RTOS
FreeRTOS
Zephyr
在实时操作系统(RTOS)中,内存管理的效率与确定性直接影响系统响应速度和可靠性。本文针对嵌入式场景特点,分析动态内存分配算法的选型要点,并提出有效的堆碎片抑制策略,结合实际案例说明如何实现低延迟、高可靠性的内存管理。
关键字:
实时操作系统
RTOS
内存管理
在实时操作系统(RTOS)驱动的嵌入式系统中,任务优先级动态调整是优化系统响应速度、资源利用率和可靠性的核心技术。通过结合FreeRTOS、Zephyr等主流RTOS的实践案例,本文系统阐述优先级动态调整的实现方法及其应...
关键字:
RTOS
嵌入式任务
在实时操作系统(RTOS)的嵌入式开发中,HOOK函数(钩子函数)是一种强大的机制,允许开发者在不修改内核代码的前提下扩展系统功能。HOOK函数通过预定义的接口点,在特定事件发生时自动调用用户自定义的逻辑,这一特性在系统...
关键字:
RTOS
嵌入式
在嵌入式系统开发中,实时操作系统(RTOS)已成为提升效率、简化复杂任务管理的核心工具。随着技术演进,免费开源的RTOS选项日益丰富,为开发者提供了灵活性和成本优势。然而,面对众多选择,如何挑选最适合项目的RTOS?本文...
关键字:
RTOS
操作系统
在嵌入式系统开发中,实时操作系统(RTOS)的应用已成为提升多任务处理能力的标配。FreeRTOS作为一款轻量级、开源的RTOS,在STM32微控制器领域得到了广泛应用。STM32CubeMX作为ST官方推出的图形化配置...
关键字:
嵌入式系统
RTOS
当嵌入式微处理器与RTOS深度融合,一场关于确定性、可靠性与效率的革命正在重塑智能硬件的底层逻辑。选择RTOS如同为精密机械挑选齿轮组,需在性能、成本、生态与安全等维度间寻找最优解。某汽车电子团队曾面临这样的抉择:为AD...
关键字:
RTOS
在嵌入式微处理器
在计算机网络中,端口映射(Port Forwarding)是一项关键的技术,它允许外部网络通过特定端口访问内部网络中的服务。这种技术广泛应用于家庭网络、企业环境以及云计算场景,是实现远程访问、游戏服务器搭建、FTP共享等...
关键字:
嵌入式
RTOS
多任务系统类似于我们之前提到的多个轮询系统。在代码层面,我们可以将一个大while循环中的多项任务拆分成几个小任务,分别进行处理。这样,每个任务都能得到有序且高效的处理,从而提升了系统的整体性能和响应速度。
关键字:
RTOS
进程