Hubris项目中主机闪存双槽管理机制的技术解析
2025-06-26 19:28:27作者:傅爽业Veleda
背景与问题场景
在基于Gimlet硬件架构的Hubris项目中,主机闪存(host flash)采用双槽设计(QSPI 0和QSPI 1),通过模拟多路复用器实现启动槽的选择。当前实现中存在一个关键问题:当进行在线固件更新时,若主机意外重启,可能导致系统从半完成的镜像槽启动,造成系统不稳定。
硬件架构基础
系统采用两级信号路由机制:
- 第一级2:1多路复用器:选择QSPI信号来自服务处理器(SP)或主机
- 第二级1:2解复用器:将片选信号映射到具体闪存芯片
这种设计通过HostFlash.set_dev和HostFlash.set_mux两个RPC接口分别控制设备选择和信号路由。
现有机制的风险点
当前实现中,控制平面代理(control-plane-agent)执行以下典型操作序列时存在风险:
- 将启动设备从QSPI 0切换到QSPI 1
- 开始分块写入新固件镜像
- 若此时主机意外重启(如内核崩溃或MAPO事件)
此时系统会尝试从可能不完整的QSPI 1镜像启动,导致启动失败或运行异常。
改进方案设计
核心概念分离
新方案引入两个独立逻辑状态:
- 启动槽(Boot Slot):系统实际启动时使用的闪存槽
- 写入槽(Write Slot):执行固件更新时写入的目标槽
原子化写入操作
关键改进点是实现原子化的"写入目标槽"操作:
- 在内存中维护目标更新槽状态
- 写入时临时切换物理多路复用器
- 写入完成后立即恢复原始启动槽选择
这种设计既保证了写入的正确性,又最大限度减少了槽切换带来的风险窗口。
异常处理增强
结合硬件提供的RESET_L计数器,系统可以:
- 检测主机意外重启事件
- 自动回退到安全状态(A2)
- 根据预设策略决定是否自动恢复运行(A0)
实现考量
- 向后兼容性:新方案保持与现有Gimlet硬件的兼容
- 状态持久化:启动槽选择信息需要可靠存储在两块闪存上
- 错误恢复:与MAPO处理机制协同工作(#607相关)
- 操作原子性:确保写入过程中的多路复用器状态不会意外保持
预期收益
该改进方案能够:
- 显著降低固件更新过程中的系统风险
- 保持硬件兼容性的同时提升可靠性
- 为后续在线更新功能提供更健壮的基础
- 改善系统异常情况下的自恢复能力
总结
Hubris项目通过重构主机闪存的双槽管理机制,实现了启动槽与写入槽的逻辑分离,配合原子化写入操作和增强的异常检测,有效提升了系统在固件更新场景下的可靠性。这一改进既解决了现有架构下的潜在风险,又为未来的功能扩展奠定了良好基础。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0224
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0145
uni-appA cross-platform framework using Vue.jsJavaScript010
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook04
项目优选
收起
暂无描述
Dockerfile
781
5.1 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
890
2.04 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
470
471
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
707
1.41 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
760
970
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.26 K
677
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.11 K
1.15 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
272
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.14 K
224