VirtualBox的源码学习

VMM重要的组件

  • TRPM (Trap Manager)
  • PGM (Page Manager)
  • REM (Recompiled Execution Manager)
  • EM (Execution Manager)
  • HWACCM (Hardware Acceleration Manager)
  • SSM (Saved State Manager)

接口

Main是VMM对外的接口,所以Client进程都通过调用Main提供的API来请求VMM内部各个组件的服务,而不是直接调用各个组件。

 

软件虚拟化

VirtualBox让Guest中的Ring 3的应用程序像普通应用程序一样运行在Ring 3层,而让Guest OS运行在Ring 1层,Ring 1层不能执行特权指令,因此遇到特权指令会trap到Ring 0层的VMM里。

 

但是这种工作模式有很多限制,为了解决这些限制,VirtualBox通过CSAM(Code Scanning and Analyzing Manager)反汇编Guest的代码,并且通过PATM(Patch Manager)把问题指令通过in-situ(原地替换)的方式进行替换,以便进行有效的处理。

posted @ 2013-12-18 10:29  Daniel King  阅读(1672)  评论(0编辑  收藏  举报