中移(苏州)软件技术有限公司面试问题与解答(4)—— virtio所创建的设备2

本文主要是介绍中移(苏州)软件技术有限公司面试问题与解答(4)—— virtio所创建的设备2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接前一篇文章:中移(苏州)软件技术有限公司面试问题与解答(4)—— virtio所创建的设备1

在上一篇文章中,对于面试所提出的问题“virtio会创建哪些设备?”,有了初步答案,即virtio后端设备分为两大类设备:virtio PCI控制设备和virtio设备。具体来说,就是virtio-pci设备和具体的virtio设备。本回对于细节进行讲解,在初步回答此面试问题的基础上,深入回答此问题。

virtio设备的初始化

virtio设备首先需要创建一个PCI设备,叫作 virtio PCI代理设备(就是上边的virtio PCI控制设备),这个代理设备挂到了PCI总线上;接着,virtio代理设备再创建一条virtio总线,这样virtio设备就可以挂到这条总线上了。

首先来看virtio PCI代理设备类型的定义,在hw/virtio/virtio-pci.c中,如下:

static const TypeInfo virtio_pci_info = {.name          = TYPE_VIRTIO_PCI,.parent        = TYPE_PCI_DEVICE,.instance_size = sizeof(VirtIOPCIProxy),.class_init    = virtio_pci_class_init,.class_size    = sizeof(VirtioPCIClass),.abstract      = true,
};

其中:

  • TYPE_VIRTIO_PCI

TYPE_VIRTIO_PCI的定义在include/hw/virtio/virtio-pci.h中,如下:

#define TYPE_VIRTIO_PCI "virtio-pci"
OBJECT_DECLARE_TYPE(VirtIOPCIProxy, VirtioPCIClass, VIRTIO_PCI)
  • TYPE_PCI_DEVICE

TYPE_PCI_DEVICE的定义在include/hw/pci/pci_device.h中,如下:

#define TYPE_PCI_DEVICE "pci-device"
typedef struct PCIDeviceClass PCIDeviceClass;
DECLARE_OBJ_CHECKERS(PCIDevice, PCIDeviceClass,PCI_DEVICE, TYPE_PCI_DEVICE)
  • VirtIOPCIProxy

VirtIOPCIProxy结构的定义也在include/hw/virtio/virtio-pci.h中,如下:

struct VirtIOPCIProxy {PCIDevice pci_dev;MemoryRegion bar;union {struct {VirtIOPCIRegion common;VirtIOPCIRegion isr;VirtIOPCIRegion device;VirtIOPCIRegion notify;VirtIOPCIRegion notify_pio;};VirtIOPCIRegion regs[5];};MemoryRegion modern_bar;MemoryRegion io_bar;uint32_t legacy_io_bar_idx;uint32_t msix_bar_idx;uint32_t modern_io_bar_idx;uint32_t modern_mem_bar_idx;int config_cap;uint32_t flags;bool disable_modern;bool ignore_backend_features;OnOffAuto disable_legacy;/* Transitional device id */uint16_t trans_devid;uint32_t class_code;uint32_t nvectors;uint32_t dfselect;uint32_t gfselect;uint32_t guest_features[2];VirtIOPCIQueue vqs[VIRTIO_QUEUE_MAX];VirtIOIRQFD *vector_irqfd;int nvqs_with_notifiers;VirtioBusState bus;
};
  • VirtioPCIClass

VirtioPCIClass结构的定义也在include/hw/virtio/virtio-pci.h中,如下:

struct VirtioPCIClass {PCIDeviceClass parent_class;DeviceRealize parent_dc_realize;void (*realize)(VirtIOPCIProxy *vpci_dev, Error **errp);
};

再回顾一下virtio PCI代理设备类型的定义:

static const TypeInfo virtio_pci_info = {.name          = TYPE_VIRTIO_PCI,.parent        = TYPE_PCI_DEVICE,.instance_size = sizeof(VirtIOPCIProxy),.class_init    = virtio_pci_class_init,.class_size    = sizeof(VirtioPCIClass),.abstract      = true,
};

由定义可知,virtio PCI代理设备的父设备是一个PCI设备(.parent        = TYPE_PCI_DEVICE,);virtio PCI代理设备的类型为VirtioPCIClass(.class_size    = sizeof(VirtioPCIClass),);virtio PCI代理设备的实例为VirtIOPCIProxy(.instance_size = sizeof(VirtIOPCIProxy),),注意这是一个抽象设备,所以并不能创建其实例,只能由其子类去创建。

QEMU(源码)中定义了所有virtio设备的PCI代理设备,如virtio balloon PCI设备、virtio scsi PCI设备、virtio crypto PCI设备等。以virtio scsi PCI设备为例,其定义在hw/virtio/virtio-scsi-pci.c中,如下:

static const VirtioPCIDeviceTypeInfo virtio_scsi_pci_info = {.base_name              = TYPE_VIRTIO_SCSI_PCI,.generic_name           = "virtio-scsi-pci",.transitional_name      = "virtio-scsi-pci-transitional",.non_transitional_name  = "virtio-scsi-pci-non-transitional",.instance_size = sizeof(VirtIOSCSIPCI),.instance_init = virtio_scsi_pci_instance_init,.class_init    = virtio_scsi_pci_class_init,
};

virtio设备在系统的设备树中的位置如下图所示:

所有的virtio设备都有一个共同的父类TYPE_VIRTIO_DEVICE。仍以virtio balloon设备为例,virtio balloon设备的定义在hw/virtio/virtio-balloon.c中,如下:

static const TypeInfo virtio_balloon_info = {.name = TYPE_VIRTIO_BALLOON,.parent = TYPE_VIRTIO_DEVICE,.instance_size = sizeof(VirtIOBalloon),.instance_init = virtio_balloon_instance_init,.class_init = virtio_balloon_class_init,
};

其中:

  • TYPE_VIRTIO_BALLOON

TYPE_VIRTIO_BALLOON的定义在include/hw/virtio/virtio-balloon.h中,如下:

#define TYPE_VIRTIO_BALLOON "virtio-balloon-device"
OBJECT_DECLARE_SIMPLE_TYPE(VirtIOBalloon, VIRTIO_BALLOON)
  • TYPE_VIRTIO_DEVICE

TYPE_VIRTIO_DEVICE的定义在include/hw/virtio/virtio.h中,如下:

#define TYPE_VIRTIO_DEVICE "virtio-device"
OBJECT_DECLARE_TYPE(VirtIODevice, VirtioDeviceClass, VIRTIO_DEVICE)
  • VirtIOBalloon

VirtIOBalloon结构的定义在中,如下:

struct VirtIOBalloon {VirtIODevice parent_obj;VirtQueue *ivq, *dvq, *svq, *free_page_vq, *reporting_vq;uint32_t free_page_hint_status;uint32_t num_pages;uint32_t actual;uint32_t free_page_hint_cmd_id;uint64_t stats[VIRTIO_BALLOON_S_NR];VirtQueueElement *stats_vq_elem;size_t stats_vq_offset;QEMUTimer *stats_timer;IOThread *iothread;QEMUBH *free_page_bh;/** Lock to synchronize threads to access the free page reporting related* fields (e.g. free_page_hint_status).*/QemuMutex free_page_lock;QemuCond  free_page_cond;/** Set to block iothread to continue reading free page hints as the VM is* stopped.*/bool block_iothread;NotifierWithReturn free_page_hint_notify;int64_t stats_last_update;int64_t stats_poll_interval;uint32_t host_features;bool qemu_4_0_config_size;uint32_t poison_val;
};

再来回顾一下virtio balloon设备的定义:

static const TypeInfo virtio_balloon_info = {.name = TYPE_VIRTIO_BALLOON,.parent = TYPE_VIRTIO_DEVICE,.instance_size = sizeof(VirtIOBalloon),.instance_init = virtio_balloon_instance_init,.class_init = virtio_balloon_class_init,
};

由定义可知,virtio balloon设备的实例对象为VirtIOBalloon。具体的virtio设备、virtio PCI代理设备以及virtio公共设备的关系如下图所示:

到此,就能够完全、完整地回答“virtio会创建哪些设备?”这一面试问题了:

virtio会创建两类设备:

  • virtio PCI控制设备(也可称作virtio PCI代理设备)

virtio PCI代理设备virtio-pci是一个抽象设备,并不能创建实例,只能由其子类去创建实例,如virtio balloon PCI设备virtio-balloon-pci-base、virtio scsi PCI设备virtio-scsi-pci-base、virtio crypto PCI设备virtio-crypto-pci等。

  • virtio设备

virtio 设备virtio-device是一个抽象设备,并不能创建实例,只能由其子类去创建实例,如virtio balloon设备virtio-balloon-device、virtio scsi设备virtio-scsi-device、virtio crypto设备virtio-crypto-device等。

这篇关于中移(苏州)软件技术有限公司面试问题与解答(4)—— virtio所创建的设备2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

ESP32 esp-idf esp-adf环境安装及.a库创建与编译

简介 ESP32 功能丰富的 Wi-Fi & 蓝牙 MCU, 适用于多样的物联网应用。使用freertos操作系统。 ESP-IDF 官方物联网开发框架。 ESP-ADF 官方音频开发框架。 文档参照 https://espressif-docs.readthedocs-hosted.com/projects/esp-adf/zh-cn/latest/get-started/index

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui--$message提示框被dialog遮罩层挡住问题解决

最近碰到一个先执行this.$message提示内容,然后接着弹出dialog带遮罩层弹框。那么问题来了,message提示框会默认被dialog遮罩层挡住,现在就是要解决这个问题。 由于都是弹框,问题肯定是出在z-index比重问题。由于用$message方式是写在js中而不是写在html中所以不是很好直接去改样式。 不过好在message组件中提供了customClass 属性,我们可以利用

Visual Studio中,MSBUild版本问题

假如项目规定了MSBUild版本,那么在安装完Visual Studio后,假如带的MSBUild版本与项目要求的版本不符合要求,那么可以把需要的MSBUild添加到系统中,然后即可使用。步骤如下:            假如项目需要使用V12的MSBUild,而安装的Visual Studio带的MSBUild版本为V14。 ①到MSDN下载V12 MSBUild包,把V12包解压到目录(