android qemu-kvm内存管理和IO映射

本文探讨了KVM如何区分MMIO和普通内存,以及在执行过程中如何处理KVM_EXIT_MMIO和KVM_EXIT_IO退出状态。内容涉及MMIO与内存管理的关系,KVM内存虚拟化,QEMU内存管理,以及在Android QEMU中的具体实现。读者需具备MMU、页表和KVM基础知识。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么内存管理和IO映射要放一起呢?因为IO映射有memory map io(MMIO)和port map io(PMIO)两种,其中MMIO和内存管理有关的。

MMIO和普通内存的访问的汇编指令是相同的;PMIO有自己的汇编指令。

kvm如果执行到了PMIO的指令,那么退出状态是KVM_EXIT_IO。

kvm怎么知道某段内存是MMIO,从而退出状态是KVM_EXIT_MMIO,而某段内存是普通内存,由kvm处理缺页,而不退出呢?这是本文想要探究的一个东西。

PS:kvm退出状态是KVM_EXIT_IO或者KVM_EXIT_MMIO,那么将由qemu进行读写虚拟设备IO端口的模拟,如何模拟?

PMIO的看《android qemu-kvm i8254 pit虚拟设备》,MMIO的看《android emulator虚拟设备分析第一篇之battery》。



阅读本文前,需要对MMU,页表,虚拟内存空间,物理内存空间有一些了解。对于kvm的影子页表的工作原理,kvm的vcpu的执行,以及kvm的ioctl有一些了解。

前提知识:

KVM之内存虚拟化:http://royluo.org/2016/03/13/kvm-mmu-virtualization/,重点看GVA,GPA,HVA,HPA,影子页表的东西

kvm api:https://kernel.org/doc/Documentation/virtual/kvm/api.txt,重点看ioctl的东西,并对kvm的使用有所印象

kvm api使用实例:https://lwn.net/Articles/658511/https://lwn.net/Articles/658512/ 

QEMU-MEMORY-MANAGEMENT.TXT:https://android.googlesource.com/platform/external/qemu.git/+/master/docs/QEMU-MEMORY-MANAGEMENT.TXT

本文使用的android版本是5.1.0,x86的img;host机器是intel x86_64,ubuntu12.04



先来一个大图:



普通内存的申请(external/qemu/hw/i386/pc.c):

     /*
      * Allocate a single contiguous RAM so that the goldfish
      * framebuffer can work well especially when the frame buffer is
      * large.
      */
     ram_addr = qemu_ram_alloc(NULL, "pc.ram", below_4g_mem_size);
     cpu_register_physical_memory(0, below_4g_mem_size, ram_addr);


由于kvm可以使用硬件提供的EPT影子页表,所以我们只需要将HVA和GPA的关系通过ioctl告知kvm即可(KVM_SET_USER_MEMORY_REGION)。

先介绍一下qemu内存管理中重要的ram_list和RAMBlock

RAMList ram_l
<think>好的,我需要回答用户关于qemu-kvm程序功能与用途的问题。首先,我得回顾一下用户提供的引用内容,确保引用正确,并结合自己的知识来组织答案。 根据引用[1],Qemu整合了KVM,通过ioctl调用内核的/dev/kvm接口,处理CPU内存的虚拟化,而Qemu本身负责模拟IO设备。引用[2]提到qemu-system-x86_64模拟整个PC,而qemu-x86_64仅模拟CPU。引用[3]说明了QEMU-KVM虚拟机中每个客户机作为QEMU进程运行,vCPU作为线程存在。这些信息帮助我理解两者的分工协作。 接下来,我需要分点阐述qemu-kvm的功能作用。首先,功能方面应包括CPU虚拟化、内存虚拟化、设备模拟以及硬件加速。作用方面,应该强调资源效率、跨平台兼容性、实时迁移灵活配置。同时,用户提到生成相关问题,我需要根据回答内容提出相关的问题,比如与KVM的关系、优势、应用场景等。 需要注意使用正确的LaTeX格式,比如行内公式用$...$,独立公式用$$...$$,不过这个问题可能较少涉及数学公式,但如果有相关术语可能需要用LaTeX。另外,确保回答结构清晰,步骤明确,符合用户要求的系统级指令可见层格式。 最后,检查引用是否正确标注,比如在提到QEMUKVM协作时引用[1],在解释qemu-system-x86_64时引用[2],实时迁移部分引用[3]。同时,确保生成的相关问题与内容相关,帮助用户进一步了解。</think>### QEMU-KVM 程序的功能与用途 #### 功能 1. **硬件虚拟化** QEMU-KVM 结合了 QEMU 的设备模拟能力与 KVM 的硬件加速功能,通过以下方式实现高效虚拟化: - **CPU 虚拟化**:KVM 利用 Intel VT/AMD-V 硬件扩展直接执行虚拟机指令,避免软件模拟的性能损耗[^1]。 - **内存虚拟化**:KVM 管理虚拟机的内存映射(如 EPT/NPT 技术),QEMU 负责分配物理内存给虚拟机[^1]。 - **设备模拟**:QEMU 模拟网卡、磁盘控制器等 I/O 设备,例如通过 virtio 驱动实现高性能半虚拟化[^1]。 2. **系统级模拟** `qemu-system-x86_64` 可模拟完整的 x86 物理机环境,包括 BIOS、PCI 总线等组件,支持运行不同操作系统(如 Linux/Windows)[^2]。 3. **资源管理** - 每个虚拟机对应独立的 QEMU 进程,其 vCPU 以线程形式运行在宿主机上[^3]。 - 支持动态调整虚拟机的 CPU 核心数、内存大小等参数。 #### 用途 1. **服务器虚拟化** 适用于云计算平台(如 OpenStack),通过 QEMU-KVM 实现多租户隔离与资源分配,提升物理服务器利用率。 2. **开发与测试** 开发者可快速创建隔离的测试环境,例如: ```bash qemu-system-x86_64 -enable-kvm -m 4G -hda ubuntu.img ``` 此命令启动一个启用 KVM 加速、分配 4GB 内存的虚拟机。 3. **实时迁移** 支持将运行中的虚拟机从一台物理主机迁移到另一台,保证服务连续性,过程可表示为: $$ \text{迁移时间} = \frac{\text{内存数据量}}{\text{网络带宽}} $$ 4. **跨平台兼容** QEMU 可模拟多种架构(如 ARM、RISC-V),结合 KVM 后可在 x86 主机上高效运行非原生架构的系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值