mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	 a0e2cb6a90
			
		
	
	
		a0e2cb6a90
		
	
	
	
	
		
			
			Implement a new virtual PCI driver based on the VFIO framework. This driver allows users to pass through PCI devices to UML via VFIO. Currently, only MSI-X capable devices are supported, and it is assumed that drivers will use MSI-X. Signed-off-by: Tiwei Bie <tiwei.btw@antgroup.com> Link: https://patch.msgid.link/20250413154421.517878-1-tiwei.btw@antgroup.com Signed-off-by: Johannes Berg <johannes.berg@intel.com>
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef __UM_VFIO_USER_H
 | |
| #define __UM_VFIO_USER_H
 | |
| 
 | |
| struct uml_vfio_user_device {
 | |
| 	int device;
 | |
| 
 | |
| 	struct {
 | |
| 		uint64_t size;
 | |
| 		uint64_t offset;
 | |
| 	} *region;
 | |
| 	int num_regions;
 | |
| 
 | |
| 	int32_t *irqfd;
 | |
| 	int irq_count;
 | |
| };
 | |
| 
 | |
| int uml_vfio_user_open_container(void);
 | |
| int uml_vfio_user_setup_iommu(int container);
 | |
| 
 | |
| int uml_vfio_user_get_group_id(const char *device);
 | |
| int uml_vfio_user_open_group(int group_id);
 | |
| int uml_vfio_user_set_container(int container, int group);
 | |
| int uml_vfio_user_unset_container(int container, int group);
 | |
| 
 | |
| int uml_vfio_user_setup_device(struct uml_vfio_user_device *dev,
 | |
| 			       int group, const char *device);
 | |
| void uml_vfio_user_teardown_device(struct uml_vfio_user_device *dev);
 | |
| 
 | |
| int uml_vfio_user_activate_irq(struct uml_vfio_user_device *dev, int index);
 | |
| void uml_vfio_user_deactivate_irq(struct uml_vfio_user_device *dev, int index);
 | |
| int uml_vfio_user_update_irqs(struct uml_vfio_user_device *dev);
 | |
| 
 | |
| int uml_vfio_user_cfgspace_read(struct uml_vfio_user_device *dev,
 | |
| 				unsigned int offset, void *buf, int size);
 | |
| int uml_vfio_user_cfgspace_write(struct uml_vfio_user_device *dev,
 | |
| 				 unsigned int offset, const void *buf, int size);
 | |
| 
 | |
| int uml_vfio_user_bar_read(struct uml_vfio_user_device *dev, int bar,
 | |
| 			   unsigned int offset, void *buf, int size);
 | |
| int uml_vfio_user_bar_write(struct uml_vfio_user_device *dev, int bar,
 | |
| 			    unsigned int offset, const void *buf, int size);
 | |
| 
 | |
| #endif /* __UM_VFIO_USER_H */
 |