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

    文章

    1367

    浏览量

    114533
  • API
    API
    +关注

    关注

    2

    文章

    1486

    浏览量

    61820
  • RTOS
    +关注

    关注

    22

    文章

    809

    浏览量

    119439
收藏 人收藏

    评论

    相关推荐

    如何优化RAM内存使用

    :使用任务管理器查看当前运行的程序和服务,关闭那些不需要的。 禁用启动程序 :减少开机启动项,只保留必要的程序。 2. 优化操作系统设置 调整虚拟内存 :合理设置虚拟内存,避免过多占用硬盘空间。 清理磁盘 :定期进行磁盘清理,
    的头像 发表于 11-11 09:58 177次阅读

    freertos最多支持多少个任务

    以下几个因素: 系统资源 :FreeRTOS能够支持的任务数量受到系统硬件资源的限制,特别是处理器的RAM大小和性能。RAM用于存储任务的控制块(TCB)和任务堆栈,因此RAM越大,理
    的头像 发表于 09-02 14:21 694次阅读

    在不影响性能或占用空间的情况下隔离您的CAN系统

    电子发烧友网站提供《在不影响性能或占用空间的情况下隔离您的CAN系统.pdf》资料免费下载
    发表于 08-29 10:49 0次下载
    在不影响性能或<b class='flag-5'>占用</b><b class='flag-5'>空间</b>的情况下隔离您的CAN系统

    ESP32-S2的循环运行速度比ESP32慢很多是怎么回事?

    我想测试一下ESP32-S2的sqrtf的运算速度, 结果发现运行速度特别慢,sqrtf()需要3微秒以上,占用了接近1000个时钟周期. 然后又写了一个循环的测试.发现也很慢. 1000次循环
    发表于 06-21 17:11

    芯海通用 MCU 应用笔记:在 MDK 开发环境下代码重定向到 RAM 执行的几种方法

    空间写入新的代码。此外还具备执行效率高,寿命长优点。 本文档介绍和说明在 MDK 开发环境下将代码重定向到 RAM执行的方法。本文档
    发表于 05-16 11:58

    请问Block RAM的资源如何计算?

    当使用ram时,width是960bit,depth是16bit,只有15Kb大小, 为什么占用了很多个BRAM?
    的头像 发表于 05-06 14:12 496次阅读
    请问Block <b class='flag-5'>RAM</b>的资源如何计算?

    怎么解决MCU RAM空间不够用的问题?

    之前使用沁恒公司的一款BLE芯片CH573,随着代码量的增多,开发到后期时遇到了RAM空间不够用的问题,当时吓了我一跳,以为需要重新换更大RAM的芯片。
    的头像 发表于 05-01 09:57 1305次阅读
    怎么解决MCU <b class='flag-5'>RAM</b><b class='flag-5'>空间</b>不够用的问题?

    STM32是如何从flash读取指令执行的?

    的时候就要解密,现在衍生了另一个问题就是我STM32是如何从flash读取指令执行的?是读一句执行依据还是将flash里面的程序整体读到内部ram里面再
    发表于 04-24 07:09

    请问使用FreeRTOS与LWIP不算应用程序消耗600K Byte RAM是否够用?

    大家好! 最近新项目中需要使用FreeRTOS + LWIP,选MCU时候,对内部RAM资源无法准确评估: 请问使用FreeRTOS与LWIP 不算应用程序消耗 600K Byte RAM
    发表于 04-18 07:37

    你以为的RAM不是你以为的RAM~

    一、DTCM和AXI连接的RAMSTM32H7系列处理器内部有多个RAM空间,每个RAM空间的大小和响应速度都不一样。这里面我们重点关注DT
    的头像 发表于 04-05 08:09 902次阅读
    你以为的<b class='flag-5'>RAM</b>不是你以为的<b class='flag-5'>RAM</b>~

    G431CB把stack heap全分配到ccmram,代码执行速度并未改善是怎么回事?

    把stack heap全分配到ccmram发现函数执行时间也没有什么改善,附图是我的结果 函数执行速度非但没有改善,反而发现在ccmram执行很不稳定; 测试手段:用定时器3计数来实现该函数
    发表于 03-27 08:23

    BlueRNG-M2SA运用FreeRTOS空间不足怎么解决?

    溢出1788bytes FreeRTOSConfig.h 其中的参数有牵扯到空间大小,所以我进行调整尺寸后即可以编译过,但烧录完后并不会有动作,请问有人有试过合拼FreeRTOS成功的案例吗?
    发表于 03-22 07:26

    stm32h743是不是可以直接用ICache加快一些速度

    stm32h743是不是可以直接用ICache加快一些速度,而不用DCache,DCache配置ram麻烦?
    发表于 03-08 08:01

    G120电机运行速度怎么设置?

    G120电机运行速度怎么设置? 例如我在触摸屏=1是高速=2中速=3是低速。 这个速度怎么设置?
    发表于 01-09 07:37

    FreeRTOS中的任务管理

    任务是 FreeRTOS 中最基本的调度单元,它是一段可执行的代码,可以独立运行。FreeRTOS 中的任务是基于优先级的抢占式调度,优先级高的任务可以抢占优先级低的任务的 CPU 资源。任务的创建、删除、挂起、恢复、设置优先级
    的头像 发表于 11-27 17:03 953次阅读