Qemu-softmmu

原文网址:http://vm-kernel.org/blog/2009/07/10/qemu-internal-part-2-softmmu/

Qemu使用softmmu来加速guest物理地址和host虚拟地址的映射,以及guest I/O和qemu I/O仿真函数的映射。这篇文章中假设guest page table大小是4K。

 

1 双层guest physical page

       Qemu使用一个两层的guest physicalpage描述表来维系guest内存空间与MMIO空间。l1_phys_map table指向这个表。[31:22]位用来索引第一层entry,[21:12]位用来索引第二层entry。第二层表的entry是PHysPageDesc。

 

exec.c

 

146 typedef structPhysPageDesc {

147     /* offset in host memory of the page + io_indexin the low bits */

148     ram_addr_t phys_offset;

149     ram_addr_t region_offset;

150 } PhysPageDesc;

 

如果内存区域是RAM,phys_offset的[31:12]位是这一页在仿真物理内存中的偏移地址。如果这个内存区域是映射的I/O,phys_offset的[11:3]位是io_mem_write/io_mem_read索引号。当访问这个内存区域时,phys_offset索引的io_mem_write/io_mem_read函数将被呼叫。

 

2注册guest物理内存

cpu_register_physical_memory函数用来注册guest内存区域。如果phys_offset是IO_MEN_RAM,意味着这个区域是guest RAM空间。如果phys_offset>IO_MEM_ROM,那这是MMIO空间。

 

898 static inline voidcpu_register_physical_memory(target_phys_addr_t start_addr,

899                                                ram_addr_t size,

900                                                ram_addr_t phys_offset)

901 {

902    cpu_register_physical_memory_offset(start_addr, size, phys_offset, 0);

903 }

 

cpu_register_physical_memory_offset函数会先使用guest物理地址在l1_phys_map中查找PHysPageDesc。如果找到entry,qemu会更新这个entry。如果没找到,qemu会新建一个entry,更新它的值,将它插入表尾。

在malta仿真中,用下面的代码来注册malta的RAM空间

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值