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、 详细代码分析
未完,待续 ,.. ...
qemu实现了两种模式的仿真:qemu系统仿真和qemu用户程序仿真。简单的理解,qemu系统仿真可以理解为仿真了一台PC,可以在上面安装OS,qemu用户程序仿真仅仅是对CPU的仿真,即可以运行不同体系结构的应用程序,可以理解为仿真了应用程序的运行环境。
下面通过实际的代码来分析qemu用户程序仿真的实现过程,在此之前,首先思考下可执行文件的加载执行过程,理解了这个过程有助于对qemu用户程序仿真实现的理解。
以ELF文件为例,其执行过程为:
加载器分析ELF文件的header,按照一定的规则将ELF文件的指定segment加载到进程地址空间的某个地址处,linux下通常为0x804800,设置应用程序执行需要的相关条件,如环境变量,需要的其他动态链接库等,一切准备工作都完成后,将cs:ip的值设置为ELF文件的入口即可。
从本质上来讲,qemu要实现用户程序的仿真,也无非做些类似的工作。
2、 详细代码分析
未完,待续 ,.. ...
- qemu用户态仿真代码分析
- QEMU代码结构分析
- qemu-kvm 代码分析
- qemu-kvm代码分析
- qemu-kvm 代码分析
- qemu启动参数代码分析
- 1.1Qemu 用户态架构
- qemu skyeye 仿真
- QEMU 仿真 rtems pc386
- Qemu 系统仿真
- Openwrt使用Qemu仿真
- QEMU 仿真嵌入式开发
- qemu仿真系统
- qemu-kvm 中断虚拟化代码分析
- 几篇QEMU/KVM代码分析文章
- qemu-kvm 中断虚拟化代码分析
- qemu-kvm 中断虚拟化代码分析
- qemu-kvm (QEMU2.0.0)代码分析
- 创建FileInputStream读取,显示数据
- 第18周报告2:二维数组
- LCS
- 从FileInputStream使用FileChannel
- Oracle Sqlplus
- qemu用户态仿真代码分析
- Android开发学习之三 Log,DDMS和AVD
- 跳过N字节阅读文件,使用FileInputStream
- 复制文件读取(字节数据) ,写字节数据
- 谈迭代方法与递归方法
- Linux内核常见数据结构及操作——HASH表
- 文件读字节
- 安装和利用john破解linux密码
- JNDI配置原理详解