newosp 调试 Shell: 多后端架构与运行时控制命令设计

工业嵌入式系统需要在 TCP telnet、串口、stdin 等不同环境下统一调试。newosp 的 Shell 模块通过函数指针 I/O 抽象实现多后端统一架构,通过 TCLAP 风格的子命令分发实现运行时控制(日志级别、配置修改、统计重置、生命周期转换),18 个命令覆盖诊断与控制两大需求,全程零堆分配、-fno-exceptions 兼容。

February 17, 2026 · 10 min · 1954 words · map[name:DeguiLiu]

MCCC 消息总线零堆分配优化与性能实测

从 MCCC 消息总线优化实践中提炼 5 个零堆分配模式 (Envelope 内嵌、编译期类型索引、函数指针 RAII、FixedFunction/FixedVector/FixedString、编译期配置矩阵),并附完整性能数据: BARE_METAL 18.7 M/s (54 ns/msg),FULL_FEATURED 5.8 M/s (172 ns/msg),HIGH 优先级零丢失,E2E P99 仅 449 ns。

February 17, 2026 · 8 min · 1673 words · map[name:DeguiLiu]

newosp ospgen: YAML 驱动的嵌入式 C++17 零堆分配消息代码生成

newosp ospgen 是一个 200 行 Python 的 YAML->C++ 代码生成器,面向嵌入式 C++17 场景。生成 trivially_copyable POD 结构体、enum class、std::variant Payload、sizeof 编译期断言、event-message 零开销绑定、Validate() 范围检查、Dump() 调试打印。通过 streaming_protocol 流媒体协议示例展示真实应用集成: 删除手写 messages.hpp,用生成代码获得输入校验、结构化调试、类型安全枚举、拓扑常量和编译期保护。对比 Protobuf/FlatBuffers/nanopb,展示为什么嵌入式场景需要比 Protobuf 更轻、比手写更安全的第三条路。

February 16, 2026 · 8 min · 1630 words · map[name:DeguiLiu]

嵌入式线程间消息传递重构: 用 MCCC 无锁消息总线替代 mutex + priority_queue

本文基于一个实际的线程间消息传递需求(Windows 风格的 SendMessage/PostMessage),分析传统 mutex + priority_queue + promise/future 方案的工程缺陷,然后用 MCCC 无锁消息总线重新实现,并通过完整的测试和 Sanitizer 验证。

February 16, 2026 · 7 min · 1422 words · map[name:DeguiLiu]

ztask: 零动态分配的裸机合作式任务调度器设计分析

分析 ztask 裸机合作式调度器的设计: 静态内存池管理、基于 Tick 的排序链表调度(O(1) poll)、低功耗休眠计算。附完整 C 源码(~200 行)和典型应用示例。适用于无 RTOS 的资源受限 MCU 环境。

February 15, 2026 · 3 min · 583 words · map[name:DeguiLiu]