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

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

3天内不再提示

FreeRTOS如何减少RAM占用空间并加快执行速度?

工程师 来源:strongerHuang 作者:strongerHuang 2020-10-14 14:52 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

之前分享了《FreeRTOS V10.4.0更新了哪些功能?》,今天就来详细讲述其中的一个知识点:FreeRTOS的直接任务(消息)通知,这样做的目的就是减少RAM占用空间并加快执行速度。

一、写在前面

几乎所有RTOS操作系统都提供了队列和信号量的功能,对于大部分新手来说,使用队列和信号量是必备技能。

但是,在大多数情况下,他们都是使用“中介对象”进行通信,而并非“直接任务消息”通信。

通过“中介对象”进行通信,每一组队列或信号量都会分配一段内存(消息缓冲区和流缓冲区)。就存在一个问题,如果队列或信号量比较多,势必造成更大的内存开支。

但是,如果通过本文说的“直接消息”通信,会节约很多内存。

二、什么是直接任务通知?

大多数任务间通信方法都通过中介对象,例如队列,信号量或事件组。发送任务写入通信对象,接收任务从通信对象读取。

比如FreeRTOS的队列通信,首先创建队列之前要定义一个队列:

QueueHandle_t xQueue;xQueue = xQueueCreate(10, sizeof( /* 长度 */ ) );

而这个队列包含了很多中介对象:

大家可以算一下这个“中介对象”会占用多少RAM空间?

通过一个代码示意图理解中介对象通信:

直接任务通知:

当使用直接任务通知时,顾名思义,发送任务将通知直接发送给接收任务,而无需中介对象。

通过一个代码示意图理解:

从FreeRTOS V10.4.0开始,每个任务都有一系列通知。每个通知都包含一个32位值和一个布尔状态,它们一起仅消耗5个字节的RAM。

就像任务可以阻止二进制信号量等待该信号量变为“可用”一样,任务可以阻止通知以等待该通知的状态变为“待处理”。同样,就像任务可以阻止计数信号量以等待该信号量的计数变为非零一样,任务可以阻止通知以等待该通知的值变为非零。下面的第一个示例演示了这种情况。

通知不仅可以传达事件,还可以通过多种方式传达数据。

三、进一步分析直接任务通知

通过对比FreeRTOS V10.4.0和之前版本,你会发现V10.4.0多了一些API,比如ulTaskNotifyTake / ulTaskNotifyTakeIndexed:

在官网也有针对这些API的详细介绍和说明,以及应用代码例子:

直接任务通信API说明地址:

https://www.freertos.org/RTOS-task-notification-API.html

(公号不支持外链接,请复制链接到浏览器打开)

四、使用直接任务通知性能优势和使用限制

任务通知的灵活性使它们可以在需要创建单独的队列、 二进制信号量、 数信号量或事件组的情况下使用。

与使用中介对象(例如信号量)来取消阻止任务相比,使用直接通知取消阻止RTOS任务的速度快了45% (来自官方数据) ,并且使用的RAM更少。

当然,有这些性能优势,也肯定一些限制:

仅当只有一个任务可以作为事件的接收者时,才可以使用RTOS任务通知。但是,在大多数实际使用情况下都可以满足此条件,例如中断使执行任务处理的任务中断时,该任务将处理该中断接收的数据。

仅在使用RTOS任务通知代替队列的情况下:接收任务可以在“阻塞”状态下等待通知(因此不占用任何CPU时间),而发送任务不能在“阻塞”状态下等待消息。如果发送无法立即完成,则发送完成。

五、使用方法

使用方法其实很简单,只要你会使用RTOS的队列、信号量,基本看一眼官方例子就能使用。

我这里也拿官方例子说明一下:

/* main() 创建的两个任务的原型 */static void prvTask1( void *pvParameters );static void prvTask2( void *pvParameters );/* 处理由main() 创建的任务的句柄 */static TaskHandle_t xTask1 = NULL, xTask2 = NULL;/* 创建两个任务,来回发送通知,然后启动RTOS调度程序 */void main( void ){ xTaskCreate( prvTask1, “Task1”, 200, NULL, tskIDLE_PRIORITY, &xTask1 ); xTaskCreate( prvTask2, “Task2”, 200, NULL, tskIDLE_PRIORITY, &xTask2 ); vTaskStartScheduler();}/*———————————————————–*//* prvTask1() 使用API的“索引”版本 */static void prvTask1( void *pvParameters ){ for( ;; ) { /* 发送通知到prvTask2() ,使其脱离“已阻止”状态。*/ xTaskNotifyGiveIndexed( xTask2, 0 ); /* 阻止等待prvTask2() 通知此任务 */ ulTaskNotifyTakeIndexed( 0, pdTRUE, portMAX_DELAY ); }}/*———————————————————–*//* prvTask2()使用API的原始版本(不带“索引”) */static void prvTask2( void *pvParameters ){ for( ;; ) { /* 等待prvTask1()通知此任务 */ ulTaskNotifyTake( pdTRUE, portMAX_DELAY ); /* 向prvTask1()发送通知,使它退出“已阻止”状态 */ xTaskNotifyGive( xTask1 ); }}

责任编辑:haq

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

    关注

    8

    文章

    1398

    浏览量

    119805
  • API
    API
    +关注

    关注

    2

    文章

    2146

    浏览量

    66205
  • RTOS
    +关注

    关注

    25

    文章

    862

    浏览量

    122574
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ucos与freertos哪个好?

    选择uCOS或FreeRTOS取决于项目的具体需求和资源限制。 FreeRTOS的优点包括: 更小的内核ROM和RAM占用,特别是在RAM
    发表于 12-05 07:13

    FreeRTOS 空闲任务

    FreeRTOS 中很多人会注意到为什么有一个叫IDLE task的任务占用了CPU百分之九十多的使用权,但是这个任务并没有自己手动创建。原因就是这个空闲任务是系统自己创建的,每当系统没有其他任务要运行时
    发表于 12-04 07:35

    单片机程序的执行

    更快的SRAM中,以得到更快的执行速度。而对于,单片机而言工作频率也就几M,几十M,从Flash中与从RAM中读的差异可能并不明显,不会成为程序执行的瓶颈。 而对于PC而言,Flash的速度
    发表于 12-04 06:20

    请问单片机RAM空间不够用了怎么办?

    单片机RAM空间不够用了怎么办?
    发表于 11-25 08:09

    请问Keil的优化等级到底该如何选择?

    在Keil MDK(Microcontroller Development Kit)中,优化等级是编译器的核心设置之一,它直接影响生成代码的大小、执行速度和调试便利性。选择合适的优化等级是平衡性
    发表于 11-20 07:51

    程序运行速度很慢如何优化?

    ;gt;外设,内存<->内存)交给DMA,释放CPU资源。 优化算法: 选择时间复杂度更低的算法。避免不必要的循环和重复计算。 减少函数调用开销: 对于频繁调用的小函数
    发表于 11-17 06:12

    【CW32】uart_obj_fw 轻量级串口框架

    轻量级跨平台串口通信框架,专为资源受限的嵌入式设备设计。单个对象RAM占用最小68字节左右(不算缓冲区),ROM占用1-2k字节左右,功能支持裁剪,资源占用小并不代表低性能,该库参考
    的头像 发表于 09-29 18:02 7419次阅读

    如何降低视频占用空间

    我发现不同分辨率图像保存的视频大小接近,1分钟的视频都是30MB,如下图 我最终目的是希望保存视频占用空间小一点,同时我也没有找到降低帧率的方法,目前只能使用默认的30帧
    发表于 08-14 06:25

    TLE9893 怎么将代码放在ram中运行?

    如题,我希望将我的中断回调函数放进ram中运行以保证他的运行速度更快。那么我该怎么修改程序才能做到呢?或者有没有相关的例程给我参考一下。
    发表于 07-14 08:00

    TRCX应用:显示面板电容指纹分析

    在大尺寸面板上扫描指纹是捕捉指纹上脊谷间的电容差异。为了加快计算执行速度,通过分布式计算对仿真区域进行划分,自动合并为包含指纹信息的结果。工程师可以通过快速精确的仿真算法,根据布局结果分析电势分布和电容轮廓。 分割模拟区域
    发表于 06-17 08:54

    瑞萨RA-T系列芯片马达类工程TCM加速化设置(上)提高电流环执行速度

    本篇介绍在使用 RA8-T系列芯片 ,建立 马 达类工程应用 时,如何将 电 流环部分的指令和变量 设置到 TCM单元 ,以提高电流环执行速度,从而提高系统整体的运行性能,在伺服和高端工业领域有很高
    的头像 发表于 06-04 18:02 1156次阅读
    瑞萨RA-T系列芯片马达类工程TCM加速化设置(上)提高电流环<b class='flag-5'>执行速度</b>

    详解FreeRTOS与SAFERTOS的区别

    开源免费的FreeRTOS由Richard Barry在WHIS工作时创建,WHIS基于FreeRTOS的功能模型,通过完整的HAZOP分析,确定了功能模型和API中的所有的弱点,减轻所有薄弱环节,采用IEC 61508 SI
    的头像 发表于 06-04 16:58 677次阅读
    详解<b class='flag-5'>FreeRTOS</b>与SAFERTOS的区别

    HarmonyOS优化应用内存占用问题性能优化一

    出现崩溃和卡顿的情况。因此,主动减少应用内存的占用对于整个系统至关重要。通过减少应用内存的占用,可以有效提高应用的性能和响应速度,节省系统资
    发表于 05-21 11:27

    RVCT编译器是否比GNU的编译器的代码执行速度更快?

    ,是rvct3.1还是rvct4.0?如何把rvct编译器集成到ide中? 2、RVCT编译器是否比GNU的编译器的代码执行速度更快?
    发表于 05-08 07:49

    如何提高弧光保护装置的动作速度

    ,提高故障判断的速度和准确性。 提升硬件性能:选用响应速度更快的弧光传感器,确保能迅速感知弧光的产生输出信号;同时,配备高性能的主控单元和通信模块,加快信号处理和传输
    发表于 05-06 10:09