 74f4d2279b
			
		
	
	
		74f4d2279b
		
	
	
	
	
		
			
			* qemu-kvm/uq/master: virtio/vhost: Add support for KVM in-kernel MSI injection msix: Add msix_nr_vectors_allocated kvm: Enable use of kvm_irqchip_in_kernel in hwlib code kvm: Introduce kvm_irqchip_add/remove_irqfd kvm: Make kvm_irqchip_commit_routes an internal service kvm: Publicize kvm_irqchip_release_virq kvm: Introduce kvm_irqchip_add_msi_route kvm: Rename kvm_irqchip_add_route to kvm_irqchip_add_irq_route msix: Introduce vector notifiers msix: Invoke msix_handle_mask_update on msix_mask_all msix: Factor out msix_get_message kvm: update vmxcap for EPT A/D, INVPCID, RDRAND, VMFUNC kvm: Enable in-kernel irqchip support by default kvm: Add support for direct MSI injections kvm: Update kernel headers kvm: x86: Wire up MSI support for in-kernel irqchip pc: Enable MSI support at APIC level kvm: Introduce basic MSI support for in-kernel irqchips Introduce MSIMessage structure kvm: Refactor KVMState::max_gsi to gsi_count
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Virtio PCI Bindings
 | |
|  *
 | |
|  * Copyright IBM, Corp. 2007
 | |
|  * Copyright (c) 2009 CodeSourcery
 | |
|  *
 | |
|  * Authors:
 | |
|  *  Anthony Liguori   <aliguori@us.ibm.com>
 | |
|  *  Paul Brook        <paul@codesourcery.com>
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2.  See
 | |
|  * the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #ifndef QEMU_VIRTIO_PCI_H
 | |
| #define QEMU_VIRTIO_PCI_H
 | |
| 
 | |
| #include "virtio-blk.h"
 | |
| #include "virtio-net.h"
 | |
| #include "virtio-serial.h"
 | |
| #include "virtio-scsi.h"
 | |
| 
 | |
| /* Performance improves when virtqueue kick processing is decoupled from the
 | |
|  * vcpu thread using ioeventfd for some devices. */
 | |
| #define VIRTIO_PCI_FLAG_USE_IOEVENTFD_BIT 1
 | |
| #define VIRTIO_PCI_FLAG_USE_IOEVENTFD   (1 << VIRTIO_PCI_FLAG_USE_IOEVENTFD_BIT)
 | |
| 
 | |
| typedef struct {
 | |
|     int virq;
 | |
|     unsigned int users;
 | |
| } VirtIOIRQFD;
 | |
| 
 | |
| typedef struct {
 | |
|     PCIDevice pci_dev;
 | |
|     VirtIODevice *vdev;
 | |
|     MemoryRegion bar;
 | |
|     MemoryRegion msix_bar;
 | |
|     uint32_t flags;
 | |
|     uint32_t class_code;
 | |
|     uint32_t nvectors;
 | |
|     VirtIOBlkConf blk;
 | |
|     NICConf nic;
 | |
|     uint32_t host_features;
 | |
| #ifdef CONFIG_LINUX
 | |
|     V9fsConf fsconf;
 | |
| #endif
 | |
|     virtio_serial_conf serial;
 | |
|     virtio_net_conf net;
 | |
|     VirtIOSCSIConf scsi;
 | |
|     bool ioeventfd_disabled;
 | |
|     bool ioeventfd_started;
 | |
|     VirtIOIRQFD *vector_irqfd;
 | |
| } VirtIOPCIProxy;
 | |
| 
 | |
| void virtio_init_pci(VirtIOPCIProxy *proxy, VirtIODevice *vdev);
 | |
| void virtio_pci_reset(DeviceState *d);
 | |
| 
 | |
| /* Virtio ABI version, if we increment this, we break the guest driver. */
 | |
| #define VIRTIO_PCI_ABI_VERSION          0
 | |
| 
 | |
| #endif
 |