Axvisor 架构
Axvisor 是基于 ArceOS 的统一组件化 Type-I Hypervisor。它既非直接包裹 KVM 的用户态工具,也非单体式虚拟机管理程序,而是建立在 ArceOS 运行时、虚拟化组件库与分层配置系统之上的 Hypervisor 软件 栈。
本文聚焦 Axvisor 的组织原理、配置体系与关键执行路径。若需要先运行 QEMU 示例,请先阅读 Axvisor 快速上手。
系统定位
Axvisor 与 ArceOS/StarryOS 的最大差异在于:代码、配置和 Guest 镜像同等重要。许多"看起来像代码 bug"的问题,根因通常是 .build.toml、vm_configs、kernel_path 或 tmp/rootfs.img 未对齐。
| 目标 | 含义 | 典型落点 |
|---|---|---|
| 统一 | 尽可能用同一套代码覆盖多架构平台 | hal/arch/*、configs/board/* |
| 组件化 | 将 VM、vCPU、虚拟设备、地址空间、API 注入等能力拆成独立组件 | components/axvm、axvcpu、axdevice、axaddrspace、axvisor_api |
| 可配置 | 通过板级配置与 VM 配置控制构建与运行行为 | configs/board/*.toml、configs/vms/*.toml |
| 可验证 | 通过 xtask、QEMU workflow 和统一测试入口形成闭环 | cargo xtask axvisor test qemu ... |
架构概览
Axvisor 的运行结构可概括为"ArceOS 作为宿主运行时 + 虚拟化组件作为能力核 + Axvisor 运行时负责编排 + Guest 作为最终负载"。
此图可从两条主线理解:
- 运行主线:
hardware → ArceOS base → virt components → Axvisor runtime → guests - 配置主线:
board config + vm config → Axvisor runtime / virt components
分层职责
Axvisor 从底部宿主运行时到顶部 Guest 系统,依次经过五层。每一层的职责边界清晰:宿主运行时提供调度和内存,虚拟化能力层提供 VM/vCPU/设备抽象,API 注入层桥接两者,编排层负责初始化和生命周期管理,配置与镜像层决定构建产物和运行负载。
| 层次 | 目录 | 职责 |
|---|---|---|
| 宿主运行时层 | ax-std、ax-hal、ax-alloc、ax-task | 提供宿主机上的调度、内存、时间、控制台与硬件抽象 |
| 虚拟化能力层 | components/axvm、axvcpu、axdevice、axaddrspace | 抽象 VM、vCPU、设备模拟/直通与客户机地址空间 |
| API 注入层 | components/axvisor_api、src/hal 中的 api_mod_impl | 将 ArceOS 的能力注入到更底层虚拟化组件 |
| Axvisor 编排层 | os/axvisor/src/* | 初始化、VMM、shell、任务组织、Guest 启停 |
| 配置与镜像层 | configs/board/*、configs/vms/*、tmp/*、镜像仓库 | 控制"构建什么"和"启动哪个 Guest" |