当前位置:首页 > 嵌入式 > 嵌入式分享
[导读]大多数非常复杂的嵌入式系统都采用某种操作系统——通常是 RTOS。最终,操作系统是一种开销,它使用了应用程序代码本来可以使用的时间和内存。由于嵌入式系统的资源有限,因此需要仔细评估这种开销,这通常会导致有关 RTOS 内存占用的问题。本文探讨了 RTOS 如何使用内存以及为什么内存占用问题可能很难回答。

大多数非常复杂的嵌入式系统都采用某种操作系统——通常是 RTOS。最终,操作系统是一种开销,它使用了应用程序代码本来可以使用的时间和内存。由于嵌入式系统的资源有限,因此需要仔细评估这种开销,这通常会导致有关 RTOS 内存占用的问题。本文探讨了 RTOS 如何使用内存以及为什么内存占用问题可能很难回答。

RTOS 有多大?

如果您正在考虑购买实时操作系统(或者,就此而言,嵌入式应用程序的任何软件 IP),您可能希望获得有关其使用的内存量的明确信息。 RTOS 供应商很可能不愿意(或者更准确地说,实际上)无法为您提供如此看似显而易见的信息。其原因在于存在大量的变数。

什么类型的内存?

问题是我们要考虑什么样的内存。从广义上讲,有只读存储器(ROM——现在通常是闪存)和读/写存储器(RAM)。 ROM是存储代码和常量数据的地方; RAM 用于变量。然而,为了提高性能,在启动时将代码/数据从 ROM 复制到 RAM,然后使用 RAM 副本的情况并不罕见。这是有效的,因为 RAM 通常比 ROM 的访问速度更快。因此,在考虑 RTOS 占用空间时,您需要考虑 ROM 和 RAM 大小,包括 RAM 复制的可能性。

这个问题可能会变得更加复杂。可能有片上 RAM 和外部存储器可用。片上存储可能更快,因此确保 RTOS 代码/数据存储在那里可能是有利的,因为其性能将影响整个应用程序。以类似的方式,代码/数据可以被锁定到高速缓冲存储器中,这往往会提供更高的性能。

代码大小问题

有多种因素会影响代码的大小:

CPU 架构

CPU 架构对 RTOS 内存占用量有很大影响。例如,PowerPC 的代码大小可能与 ARM 有很大不同。为 Thumb-2 构建的代码可能比 ARM 小得多。唯一可接受的数字是为您计划使用的特定 CPU 构建的代码的数字

编译器优化

在构建代码(如 RTOS)时,应用于编译器的优化设置会影响大小和执行速度。大多数时候,为最高性能(即最快)构建的代码会更大;优化为较小的代码运行速度会较慢。 RTOS 通常是为了性能而不是尺寸而构建的。尽管 RTOS 供应商想要强调其产品的小尺寸,可能会做出不同的选择。

RTOS 配置

实时操作系统往往是非常可配置的,并且该配置可以极大地改变 RTOS 的大小。大多数 RTOS 产品都是可扩展的,因此内存占用量由应用程序使用的实际服务决定。这种可扩展性的粒度因产品而异。在某些情况下,每项单独的服务都是可选的;在其他情况下,包括或排除整个服务组 - 即,如果需要支持特定类型的 RTOS 对象(例如信号量),则包括所有相关服务。在更大的范围内,其他选项(例如图形、网络和其他连接)将影响代码大小,因为可能需要或不需要/包括这些选项。

运行时库

通常,运行时库将与 RTOS 一起使用;需要容纳此代码。同样,作为库的代码可以根据特定应用程序的需要很好地扩展。

数据大小问题

除了变量的基准存储量之外,RTOS 的 RAM 要求同样会受到许多因素的影响:

编译器优化

与代码一样,编译器优化也会影响数据大小。打包(压缩)数据较小,但需要更多指令,因此需要更多时间来访问。

RTOS 对象

应用程序使用的 RTOS 对象(任务、邮箱、信号量等)的数量将影响 RTOSRAM 的使用,因为每个对象都需要一些 RAM 空间。

堆栈

通常,操作系统有一个堆栈,每个任务都有自己的堆栈;这些都必须存储在 RAM 中。在每个 RTOS 中,该空间的分配可能会有所不同,但永远不能忽略。

动态内存

如果 RTOS 提供动态(分区/块)内存分配并由应用程序使用,则需要为内存池提供空间。

静态和动态 RTOS 配置

早期的 RTOS 产品需要在构建时(即静态)执行配置。随着技术的进步,动态创建(和销毁)RTOS 对象的工具变得司空见惯。现在很难找到允许静态配置的 RTOS。这些选项对内存利用率的影响很有趣。

静态配置的 RTOS 保存了 ROM 中有关 RTOS 对象的大部分数据。有些信息需要复制到RAM,因为它在执行过程中会改变,但需要初始化。其他对象在运行时需要额外的 RAM 空间。

动态配置的 RTOS 将所有对象数据保存在 RAM 中,而不保存在 ROM 中。然而,对 ROM 空间的影响很大,因为需要额外的服务调用来执行对象创建和销毁。

现实的答案

现在应该清楚为什么期望对“xyz RTOS 有多大?”这个问题给出直接而简单的答案是不合理的。实际上,预期的最佳响应可能是这样的:

“在 ARM 模式下在 ARM Cortex A8 上运行的 Nucleus RTOS 产生 12-30 K 的 ROM 大小和 500 字节的 RAM。低端 ROM 大小包括基本服务;高值包括所有服务。不包括运行时库。为 Thumb-2 模式构建 RTOS 可将 ROM 大小减少三分之一以上。”

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭