qemu用户态仿真代码分析

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

2、 详细代码分析
 




未完,待续 ,.. ...
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值