virtio设备状态

2023-11-03 20:30
文章标签 状态 设备 virtio

本文主要是介绍virtio设备状态,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

spec描述

驱动初始化探测的大致过程:

virtio_pci_probe->pci_enable_device->virtio_pci_modern_probe->register_virtio_device->virtio_dev_probe

virtio_pci_modern_probe->设置回调vp_config_vector->设置回调setup_vq

drivers/virtio/virtio_pci_common.c

virtblk_probe->init_vq(virtio_blk.c)->virtio_find_vqs->find_vqs->vp_modern_find_vqs->vp_find_vqs->vp_find_vqs_msix->vp_request_msix_vectors->vp_setup_vq->setup_vq->request_irq->vring_interrupt

virtnet_probe->init_vqs->virtnet_find_vqs->find_vqs->同上

例如virtio_net驱动中用于初始化queue,创建网络设备并初始化一些必要的数据结构

当后端模拟出virtio_net设备后,驱动扫描到virtio设备,然后调用virtio_pci_driver中virtio_pci_probe函数完成pci设备的启动。

注册一条virtio_bus,同时在virtio总线进行注册设备。当virtio总线进行注册设备register_virtio_device,设置virtio总线后将调用virtio总线的probe函数:virtio_dev_probe。

该函数遍历驱动,找到支持驱动关联到该设备并且调用

virtio_driver probe,virtnet_probe函数

static int virtio_dev_probe(struct device *_d)
{int err, i;struct virtio_device *dev = dev_to_virtio(_d);struct virtio_driver *drv = drv_to_virtio(dev->dev.driver);u64 device_features;u64 driver_features;u64 driver_features_legacy;/* We have a driver! */virtio_add_status(dev, VIRTIO_CONFIG_S_DRIVER);//置位状态,知道是什么驱动/* Figure out what features the device supports. * 回调函数vp_get_features->vp_modern_get_features* vp_modern_get_features 中会和后端设备协商feature*/device_features = dev->config->get_features(dev);/* Figure out what features the driver supports. */driver_features = 0;for (i = 0; i < drv->feature_table_size; i++) {unsigned int f = drv->feature_table[i];BUG_ON(f >= 64);driver_features |= (1ULL << f);}/* Some drivers have a separate feature table for virtio v1.0 */if (drv->feature_table_legacy) {driver_features_legacy = 0;for (i = 0; i < drv->feature_table_size_legacy; i++) {unsigned int f = drv->feature_table_legacy[i];BUG_ON(f >= 64);driver_features_legacy |= (1ULL << f);}} else {driver_features_legacy = driver_features;}if (device_features & (1ULL << VIRTIO_F_VERSION_1))dev->features = driver_features & device_features;elsedev->features = driver_features_legacy & device_features;/* Transport features always preserved to pass to finalize_features. */for (i = VIRTIO_TRANSPORT_F_START; i < VIRTIO_TRANSPORT_F_END; i++)if (device_features & (1ULL << i))__virtio_set_bit(dev, i);if (drv->validate) {err = drv->validate(dev);if (err)goto err;}// 协商结果,成功会置位VIRTIO_CONFIG_S_FEATURES_OK,表示前后端协商成功err = virtio_finalize_features(dev);if (err)goto err;err = drv->probe(dev); //virtio_drive回调函数 virtnet_probe 或者 virtblk_probeif (err)goto err;/* If probe didn't do it, mark device DRIVER_OK ourselves. */if (!(dev->config->get_status(dev) & VIRTIO_CONFIG_S_DRIVER_OK))virtio_device_ready(dev);if (drv->scan)drv->scan(dev);virtio_config_enable(dev);return 0;
err:virtio_add_status(dev, VIRTIO_CONFIG_S_FAILED);return err;}

下面分别描述探测过程中几个状态的前端发生过程。

VIRTIO_CONFIG_S_ACKNOWLEDGE

前端:

virtio_pci_probe ->register_virtio_device

->virtio_add_status(dev, VIRTIO_CONFIG_S_ACKNOWLEDGE);//通知后端已发现此virtio设备

后端

todo

VIRTIO_CONFIG_S_DRIVER

virtio_dev_probe->virtio_add_status(dev, VIRTIO_CONFIG_S_DRIVER)

VIRTIO_CONFIG_S_FEATURES_OK

virtio_dev_probe->>virtio_finalize_features

virtio_add_status(dev, VIRTIO_CONFIG_S_FEATURES_OK);

VIRTIO_CONFIG_S_DRIVER_OK

virtio_dev_probe->virtio_device_ready-

dev->config->set_status(dev, status | VIRTIO_CONFIG_S_DRIVER_OK);

后端:(以qemu为例)

 hw/virtio/virtio-pci.c: virtio_pci_bus_class_init->virtio_pci_device_plugged->

virtio_pci_modern_regions_init->virtio_pci_common_write->

    case VIRTIO_PCI_COMMON_STATUS:if (!(val & VIRTIO_CONFIG_S_DRIVER_OK)) {virtio_pci_stop_ioeventfd(proxy);}virtio_set_status(vdev, val & 0xFF);if (val & VIRTIO_CONFIG_S_DRIVER_OK) {virtio_pci_start_ioeventfd(proxy);//启动ioeventfd}if (vdev->status == 0) {virtio_pci_reset(DEVICE(proxy));}

这篇关于virtio设备状态的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

hdu3006状态dp

给你n个集合。集合中均为数字且数字的范围在[1,m]内。m<=14。现在问用这些集合能组成多少个集合自己本身也算。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.Inp

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo

状态模式state

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/state 在一个对象的内部状态变化时改变其行为, 使其看上去就像改变了自身所属的类一样。 在状态模式中,player.getState()获取的是player的当前状态,通常是一个实现了状态接口的对象。 onPlay()是状态模式中定义的一个方法,不同状态下(例如“正在播放”、“暂停

qml states 状态

states 状态 在QML中,states用于定义对象在不同状态下的属性变化。每个状态可以包含一组属性设置,当状态改变时,这些属性设置会被应用到对象上。 import QtQuick 2.15import QtQuick.Controls 2.15// 定义应用程序的主窗口ApplicationWindow {visible: true // 使窗口可见width: 640 /

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《考虑燃料电池和电解槽虚拟惯量支撑的电力系统优化调度方法》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源程序擅长文章解读,论文与完整源程序,等方面的知识,电网论文源程序关注python