LiteOS和RTOS 系统选型分析
本文对比分析了LiteOS和FreeRTOS两种实时操作系统。LiteOS分为针对微控制器的LiteOS-M(内存≤128KB,无MMU)和面向应用处理器的LiteOS-A(内存≥1MB,带MMU),前者采用微内核设计,后者为混合内核。FreeRTOS移植门槛低,支持40+处理器架构,内核Flash占用10-20KB,RAM需求10-40KB。对比显示:FreeRTOS移植更易、适配性广;Lite
一,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及以上),支持内存隔离与进程管理。
(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
对应tags 版本
https://github.com/LiteOS/LiteOS/releases/tag/LiteOSV200R001C50B038
https://github.com/LiteOS/LiteOS/tags
二, freertos系统分析
(1)、移植难度:适配性强,门槛低
FreeRTOS支持40+处理器架构(如ARM Cortex-M/RISC-V、8051等),官方提供标准化移植模板(如port.c、portmacro.h),核心移植仅需实现上下文切换、中断处理等底层接口。社区资源丰富,针对不同芯片的移植案例(如STM32、ESP32)可直接参考,尤其适合非华为生态的硬件平台,移植周期短、难度低。
(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系统Liteos和freertos的对比分析
(1)移植难度:FreeRTOS更易适配,LiteOS依赖华为生态
- FreeRTOS:移植门槛低,支持40+处理器架构(如ARM Cortex-M/RISC-V),官方提供标准化移植模板,社区资源丰富,适配新硬件时可参考大量开源案例。
- LiteOS:虽支持ARM Cortex-A/M系列,但对非华为合作芯片的适配文档较少,移植需依赖华为官方SDK或自行开发底层驱动,适合华为生态内硬件(如海思芯片)。
结论:非华为系硬件优先选FreeRTOS,华为生态设备可考虑LiteOS。
(2)Flash占用:LiteOS更轻量,FreeRTOS略高但灵活
- LiteOS:内核Flash占用极小(<10KB),组件高度模块化,仅保留核心功能时可进一步压缩,适合Flash资源极度受限(如<32KB)的场景。
- FreeRTOS:内核Flash约10-20KB,基础组件(如任务调度、信号量)需额外占用空间,但可通过裁剪移除非必要功能(如钩子函数、低功耗模式),灵活性更高。
结论:Flash≤32KB选LiteOS,需灵活扩展功能选FreeRTOS。
(3)内存需求:LiteOS更省RAM,FreeRTOS适配范围更广
- LiteOS:RAM占用极低(最小可至几KB),专为低功耗IoT设备优化,适合RAM≤16KB的微控制器(如8位/16位MCU)。
- FreeRTOS:RAM需求略高(典型10-40KB),但支持动态内存管理,可通过配置堆大小适配不同资源场景,从8位MCU到中高端处理器均能覆盖。
结论:RAM≤16KB选LiteOS,需动态内存管理或资源较充裕(RAM≥20KB)选FreeRTOS。
openvela 操作系统专为 AIoT 领域量身定制,以轻量化、标准兼容、安全性和高度可扩展性为核心特点。openvela 以其卓越的技术优势,已成为众多物联网设备和 AI 硬件的技术首选,涵盖了智能手表、运动手环、智能音箱、耳机、智能家居设备以及机器人等多个领域。
更多推荐

所有评论(0)