KVMTOOL: PCI设备的模拟
在 KVMTOOL 中对pci设备进行模拟,使得前端virtio设备以pci设备的形式挂载在模拟的(虚拟的)pci总线上,每个 virtio 后端驱动都会有如下类似这样的调用来初始化后端,例如virtio-vsock:virtio_vsock_init_one -> virtio_init -> virtio_pci__init(vdev->ops->init)。 virtio_pci__init 函数就是在模拟一个PCI 设备的配置空间。
int virtio_pci__init(struct kvm *kvm, void *dev, struct virtio_device *vdev,int device_id, int subsys_id, int class)
{struct virtio_pci *vpci = vdev->virtio;u32 mmio_addr, msix_io_block;u16 port_addr;int r;vpci->kvm = kvm;vpci->dev = dev;BUILD_BUG_ON(!is_power_of_two(PCI_IO_SIZE)); //pci设备io空间大小0x100port_addr = pci_get_io_port_block(PCI_IO_SIZE);//从PCI_IOPORT_START(x86是//0x6200)开始分配pci设备io port空间mmio_addr = pci_get_mmio_block(PCI_IO_SIZE); //对于x86,从0xD2000000开始为pci设备分//配mmio空间msix_io_block = pci_get_mmio_block(VIRTIO
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
