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 大小减少三分之一以上。”