LiteOS和RTOS 系统选型分析

一,​LiteOS​系统分析

(1),硬件支持与资源需求

  • LiteOS-M ‌:面向微控制器(MCU),支持Cortex-M3/M4/M7、RISC-V等架构,典型硬件配置为内存≤128KB(部分可扩展至256KB)、Flash≤256KB,不支持内存管理单元(MMU)‌。
  • LiteOS-A ‌:面向应用处理器,支持Cortex-A等带MMU的架构(如Hi3518EV300、Hi3516DV300),内存需求≥1MB(推荐2MB及以上),支持内存隔离与进程管理‌34。

(2),内核架构与设计理念

  • LiteOS-M‌:典型微内核(Microkernel)设计,仅保留任务调度、IPC、内存管理等核心功能,文件系统、网络协议栈等以用户态组件形式运行,故障隔离性好,适合资源极度受限场景‌。
  • LiteOS-A‌:基于微内核思想演进的"轻量级宏内核"(混合内核),集成文件系统、网络协议栈、图形引擎等功能至内核态,减少用户态/内核态切换开销,平衡性能与资源占用‌。‌
  • C核(Cortex-A) ‌:就是上面的‌LiteOS-A‌,面向中高端应用处理器,支持‌**内存管理单元(MMU)**‌,可实现内存隔离、虚拟内存,适用于资源丰富的场景(内存≥1MB)‌。
  • ‌**M核(Cortex-M)**‌:面向微控制器(MCU),无MMU,资源受限(内存≥128KB,典型≤256KB),聚焦低功耗和实时性‌。

(3),功能特性与系统安全性

  • LiteOS-M‌:不支持MMU,内核与应用共享地址空间,应用崩溃可能导致系统故障;不支持POSIX接口,开源软件兼容性有限‌。
  • LiteOS-A‌:支持MMU,实现内核与应用内存隔离、多应用空间隔离,系统健壮性更高;兼容POSIX接口,可直接运行大量开源软件‌。

(4),应用场景

  • LiteOS-M‌:适用于超低功耗、简单功能设备,如传感器、智能穿戴、智能家居小设备等‌35。
  • LiteOS-A ‌:面向中等资源能力设备,如智能音箱、摄像头、工业控制模块等,需兼顾功能丰富度与实时性‌。

(5),liteos代码路径分析

1,移植LiteOS

LiteOS/doc/LiteOS_Porting_Guide.md at master · LiteOS/LiteOS · GitHub

2,维测

doc/LiteOS_Maintenance_Guide.md · Huawei LiteOS/LiteOS - 码云 - 开源中国

3,代码路径

M核代码

https://github.com/openharmony/kernel_liteos_m

git clone https://gitcode.com/openharmony/kernel_liteos_m.git

C核代码(LiteOS-A‌)

https://github.com/openharmony/kernel_liteos_a.git

git clone https://gitcode.com/openharmony/kernel_liteos_a.git

二, freertos系统分析

‌(1)、移植难度:适配性强,门槛低

FreeRTOS支持40+处理器架构(如ARM Cortex-M/RISC-V、8051等),官方提供标准化移植模板(如port.cportmacro.h),核心移植仅需实现上下文切换、中断处理等底层接口。社区资源丰富,针对不同芯片的移植案例(如STM32、ESP32)可直接参考,尤其适合非华为生态的硬件平台,移植周期短、难度低‌24。

‌(2)、Flash占用:灵活可控,基础功能约10-20KB

FreeRTOS内核Flash占用随功能裁剪动态变化:

  • 最小配置‌(仅任务调度、信号量):约10KB,适合资源极度受限的8位/16位MCU;
  • 标准配置‌(含消息队列、定时器):约15-20KB;
  • 扩展功能 ‌(如事件组、内存管理):需额外增加5-10KB。
    可通过FreeRTOSConfig.h关闭非必要功能(如钩子函数、低功耗模式),进一步压缩体积,适配Flash≥32KB的场景‌。

‌(3)、内存需求:RAM占用适中,支持动态管理

  • RAM最小需求‌:核心调度功能仅需几KB(如任务栈、系统堆),典型场景下(3-5个任务)约10-20KB;
  • 动态内存管理 ‌:支持堆内存动态分配(pvPortMalloc),可通过configTOTAL_HEAP_SIZE配置堆大小,适配RAM≥16KB的设备;
  • 静态内存优化 ‌:支持静态任务创建(xTaskCreateStatic),避免堆碎片,适合对内存稳定性要求高的场景‌。

(4),代码路径

git clone https://github.com/FreeRTOS/FreeRTOS.git --recurse-submodules

三,rtos系统Liteosfreertos的对比分析

(1)移植难度:FreeRTOS更易适配,LiteOS依赖华为生态

  • FreeRTOS‌:移植门槛低,支持40+处理器架构(如ARM Cortex-M/RISC-V),官方提供标准化移植模板,社区资源丰富,适配新硬件时可参考大量开源案例‌12。
  • LiteOS‌:虽支持ARM Cortex-A/M系列,但对非华为合作芯片的适配文档较少,移植需依赖华为官方SDK或自行开发底层驱动,适合华为生态内硬件(如海思芯片)‌2。

结论‌:非华为系硬件优先选FreeRTOS,华为生态设备可考虑LiteOS。

(2)Flash占用:LiteOS更轻量,FreeRTOS略高但灵活

  • LiteOS‌:内核Flash占用极小(<10KB),组件高度模块化,仅保留核心功能时可进一步压缩,适合Flash资源极度受限(如<32KB)的场景‌1。
  • FreeRTOS‌:内核Flash约10-20KB,基础组件(如任务调度、信号量)需额外占用空间,但可通过裁剪移除非必要功能(如钩子函数、低功耗模式),灵活性更高‌1。

结论‌:Flash≤32KB选LiteOS,需灵活扩展功能选FreeRTOS。

(3)内存需求:LiteOS更省RAM,FreeRTOS适配范围更广

  • LiteOS‌:RAM占用极低(最小可至几KB),专为低功耗IoT设备优化,适合RAM≤16KB的微控制器(如8位/16位MCU)‌1。
  • FreeRTOS‌:RAM需求略高(典型10-40KB),但支持动态内存管理,可通过配置堆大小适配不同资源场景,从8位MCU到中高端处理器均能覆盖‌12。

结论‌:RAM≤16KB选LiteOS,需动态内存管理或资源较充裕(RAM≥20KB)选FreeRTOS。

相关推荐
猫猫的小茶馆13 小时前
【Python】函数与模块化编程
linux·开发语言·arm开发·驱动开发·python·stm32
霞姐聊IT14 小时前
x86程序移植到arm平台的四种场景及解决方案简介
arm开发
楼兰公子18 小时前
《深入理解Linux网络技术内幕》配套学习大纲 + 源码Demo + 进阶实战实例
linux·arm开发·学习
lljss20201 天前
Arm GNU 工具链 命名规则
服务器·arm开发·gnu
底层开发智库2 天前
无需硬件开发板,从零构建并运行ARM aemfvp-a-rme软件栈
arm开发·arm
HMS工业网络2 天前
主从结合,安全互联:Anybus工业通信解决方案全栈升级
arm开发
XINVRY-FPGA2 天前
XC7Z010-2CLG400I Xilinx Zynq-7000 FPGA
arm开发·嵌入式硬件·算法·fpga开发·硬件工程·dsp开发·fpga
Emtronix英创3 天前
RK3568 CAN驱动测试及使用说明
linux·arm开发·rk3568·全国产主板
时空自由民.4 天前
Arm Coretex-M核MCU做IAP/OTA升级时候为什么要做中断向量表地址偏移?
arm开发·单片机·嵌入式硬件
黑猫学长呀4 天前
存储宝典第1篇:Nand SCA是什么
arm开发·arm·nand·存储芯片·nandflash·onfi