【QEMU系统分析之实例篇(九)】

2024-05-02 09:12
文章标签 实例 qemu 系统分析

本文主要是介绍【QEMU系统分析之实例篇(九)】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录

第九章 QEMU系统仿真的机器创建分析实例


文章目录

  • 系列文章目录
    • 第九章 QEMU系统仿真的机器创建分析实例
  • 前言
  • 一、QEMU是什么?
  • 二、QEMU系统仿真的机器创建分析实例
    • 1.系统仿真的命令行参数
    • 2.完成默认设备的设置工作
      • suspend_mux_open()
      • qemu_disable_default_devices()
  • 总结


前言

本文以 QEMU 8.2.2 为例,分析其作为系统仿真工具的工作过程,并为读者展示各种 QEMU 系统仿真的启动配置实例。
本文读者需要具备一定的 QEMU 系统仿真使用经验,并对 C 语言编程有一定了解。


一、QEMU是什么?

QEMU 是一个通用且开源的机器模拟器和虚拟机。
其官方主页是:https://www.qemu.org/


二、QEMU系统仿真的机器创建分析实例

1.系统仿真的命令行参数

QEMU 作为系统仿真工具,其入口代码在 system/main.c 文件中,初始化函数 qemu_init() 的实现在 system/vl.c 文件中。
前文完成创建目标机器的过程分析,本文将继续后续运行过程的分析,读者需要对 QEMU 系统启动过程的程序代码有所了解,相关内容可以参考《QEMU系统分析之启动篇》系列文章。

..\qemu\8.2.2-qkd\qemu-system-x86_64.exe -cpu "Penryn" -M  "q35,accel=whpx" -m "6G" -nodefaults

2.完成默认设备的设置工作

这部分代码在 system/vl.c 文件中,实现如下:

int qemu_init(int argc, char **argv)
{
...suspend_mux_open();qemu_disable_default_devices();qemu_setup_display();qemu_create_default_devices();
...
}

suspend_mux_open()

从函数 qemu_create_machine() 返回后,首先关闭分发器,代码如下:

/** Set to false by suspend_mux_open.  Open events are delayed until* resume_mux_open.  Usually suspend_mux_open is called before* command line processing and resume_mux_open afterwards.*/
static bool muxes_opened = true;
...
void suspend_mux_open(void)
{muxes_opened = false;
}

此操作比较简单,置标志位让分发器暂停工作。


qemu_disable_default_devices()

我们在调用函数 qemu_disable_default_devices() 观察 default_list[] 的内容变化,修改后跟踪代码如下:

int qemu_init(int argc, char **argv)
{
...huedbg_flag = 1;HUEDBG("\n");huedbg_dump_default_driver_list(1);qemu_disable_default_devices();huedbg_dump_default_driver_list(0);HUEDBG("\n");huedbg_flag = 0;
...
}

调试输出如下:

[16156]../system/vl.c/qemu_init(3775):
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(41):len=[20]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[0].driver=[xen-console] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[1].driver=[isa-serial] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[2].driver=[isa-parallel] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[3].driver=[isa-fdc] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[4].driver=[floppy] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[5].driver=[ide-cd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[6].driver=[ide-hd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[7].driver=[scsi-cd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[8].driver=[scsi-hd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[9].driver=[VGA] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[10].driver=[isa-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[11].driver=[cirrus-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[12].driver=[isa-cirrus-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[13].driver=[vmware-svga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[14].driver=[qxl-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[15].driver=[virtio-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[16].driver=[ati-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[17].driver=[vhost-user-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[18].driver=[virtio-vga-gl] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[19].driver=[virtio-vga-rutabaga] .flag=[0]
[16156]../qom/object.c/type_table_lookup(103):lookup type(machine) in hash table
[16156]../qom/object.c/type_get_parent(194):parent_type(object)
[16156]../qom/object.c/type_get_parent(196):no parent_type
[16156]../qom/object.c/type_get_parent(194):parent_type(generic-pc-machine)
[16156]../qom/object.c/type_get_parent(194):parent_type(x86-machine)
[16156]../qom/object.c/type_get_parent(194):parent_type(machine)
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(41):len=[20]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[0].driver=[xen-console] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[1].driver=[isa-serial] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[2].driver=[isa-parallel] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[3].driver=[isa-fdc] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[4].driver=[floppy] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[5].driver=[ide-cd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[6].driver=[ide-hd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[7].driver=[scsi-cd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[8].driver=[scsi-hd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[9].driver=[VGA] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[10].driver=[isa-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[11].driver=[cirrus-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[12].driver=[isa-cirrus-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[13].driver=[vmware-svga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[14].driver=[qxl-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[15].driver=[virtio-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[16].driver=[ati-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[17].driver=[vhost-user-vga] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[18].driver=[virtio-vga-gl] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[19].driver=[virtio-vga-rutabaga] .flag=[0]
[16156]../system/vl.c/qemu_init(3779):

可以看到,

运行函数 qemu_disable_default_devices() 前

[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[0].driver=[xen-console] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[1].driver=[isa-serial] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[2].driver=[isa-parallel] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[3].driver=[isa-fdc] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[4].driver=[floppy] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[5].driver=[ide-cd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[6].driver=[ide-hd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[7].driver=[scsi-cd] .flag=[1]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[8].driver=[scsi-hd] .flag=[1]

运行函数后,

[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[0].driver=[xen-console] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[1].driver=[isa-serial] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[2].driver=[isa-parallel] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[3].driver=[isa-fdc] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[4].driver=[floppy] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[5].driver=[ide-cd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[6].driver=[ide-hd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[7].driver=[scsi-cd] .flag=[0]
[16156]D:/msys64/home/yuhui/gitee/mingw-qemu/util/huedbg_inline-default_driver_list.c/huedbg_dump_default_driver_list(43):default_list[8].driver=[scsi-hd] .flag=[0]

总结

以上分析了系统初始化过程中关闭默认驱动的操作状态变化。

这篇关于【QEMU系统分析之实例篇(九)】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/953907

相关文章

PyQt6 键盘事件处理的实现及实例代码

《PyQt6键盘事件处理的实现及实例代码》本文主要介绍了PyQt6键盘事件处理的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录一、键盘事件处理详解1、核心事件处理器2、事件对象 QKeyEvent3、修饰键处理(1)、修饰键类

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Java Stream流以及常用方法操作实例

《JavaStream流以及常用方法操作实例》Stream是对Java中集合的一种增强方式,使用它可以将集合的处理过程变得更加简洁、高效和易读,:本文主要介绍JavaStream流以及常用方法... 目录一、Stream流是什么?二、stream的操作2.1、stream流创建2.2、stream的使用2.

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

Python跨文件实例化、跨文件调用及导入库示例代码

《Python跨文件实例化、跨文件调用及导入库示例代码》在Python开发过程中,经常会遇到需要在一个工程中调用另一个工程的Python文件的情况,:本文主要介绍Python跨文件实例化、跨文件调... 目录1. 核心对比表格(完整汇总)1.1 自定义模块跨文件调用汇总表1.2 第三方库使用汇总表1.3 导

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Apache Ignite缓存基本操作实例详解

《ApacheIgnite缓存基本操作实例详解》文章介绍了ApacheIgnite中IgniteCache的基本操作,涵盖缓存获取、动态创建、销毁、原子及条件更新、异步执行,强调线程池注意事项,避免... 目录一、获取缓存实例(Getting an Instance of a Cache)示例代码:二、动态

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA