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。

相关推荐
深圳市九鼎创展科技9 小时前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
森焱森12 小时前
嵌入式硬件工程师应知 白银快速分析报告
linux·c语言·arm开发·嵌入式硬件·去中心化
森G1 天前
七、04ledc-sdk--------makefile有变化
linux·c语言·arm开发·c++·ubuntu
VekiSon1 天前
Linux内核驱动——杂项设备驱动与内核模块编译
linux·c语言·arm开发·嵌入式硬件
AI+程序员在路上1 天前
Nand Flash与EMMC区别及ARM开发板中的应用对比
arm开发
17(无规则自律)1 天前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
梁洪飞2 天前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
代码游侠2 天前
学习笔记——Linux字符设备驱动
linux·运维·arm开发·嵌入式硬件·学习·架构
syseptember3 天前
Linux网络基础
linux·网络·arm开发