qemu用户态仿真代码分析

来源:互联网 发布:c语言 if break 编辑:程序博客网 时间:2024/05/19 05:30
1、 基本理论分析   
    qemu实现了两种模式的仿真:qemu系统仿真和qemu用户程序仿真。简单的理解,qemu系统仿真可以理解为仿真了一台PC,可以在上面安装OS,qemu用户程序仿真仅仅是对CPU的仿真,即可以运行不同体系结构的应用程序,可以理解为仿真了应用程序的运行环境。
    下面通过实际的代码来分析qemu用户程序仿真的实现过程,在此之前,首先思考下可执行文件的加载执行过程,理解了这个过程有助于对qemu用户程序仿真实现的理解。
    以ELF文件为例,其执行过程为:
    加载器分析ELF文件的header,按照一定的规则将ELF文件的指定segment加载到进程地址空间的某个地址处,linux下通常为0x804800,设置应用程序执行需要的相关条件,如环境变量,需要的其他动态链接库等,一切准备工作都完成后,将cs:ip的值设置为ELF文件的入口即可。
    从本质上来讲,qemu要实现用户程序的仿真,也无非做些类似的工作。

2、 详细代码分析
 




未完,待续 ,.. ...
原创粉丝点击