commit 3650b228f83adda7e5ee532e2b90429c03f7b9ec
Signed-off-by: Matthew Rosato <mjrosato@linux.ibm.com>
[aw: drop pvrdma_ring.h changes to avoid revert of d73415a315 ("qemu/atomic.h: rename atomic_ to qatomic_")]
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
		
	
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
 | 
						|
/*
 | 
						|
 * VFIO Region definitions for ZPCI devices
 | 
						|
 *
 | 
						|
 * Copyright IBM Corp. 2020
 | 
						|
 *
 | 
						|
 * Author(s): Pierre Morel <pmorel@linux.ibm.com>
 | 
						|
 *            Matthew Rosato <mjrosato@linux.ibm.com>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef _VFIO_ZDEV_H_
 | 
						|
#define _VFIO_ZDEV_H_
 | 
						|
 | 
						|
#include <linux/types.h>
 | 
						|
#include <linux/vfio.h>
 | 
						|
 | 
						|
/**
 | 
						|
 * VFIO_DEVICE_INFO_CAP_ZPCI_BASE - Base PCI Function information
 | 
						|
 *
 | 
						|
 * This capability provides a set of descriptive information about the
 | 
						|
 * associated PCI function.
 | 
						|
 */
 | 
						|
struct vfio_device_info_cap_zpci_base {
 | 
						|
	struct vfio_info_cap_header header;
 | 
						|
	__u64 start_dma;	/* Start of available DMA addresses */
 | 
						|
	__u64 end_dma;		/* End of available DMA addresses */
 | 
						|
	__u16 pchid;		/* Physical Channel ID */
 | 
						|
	__u16 vfn;		/* Virtual function number */
 | 
						|
	__u16 fmb_length;	/* Measurement Block Length (in bytes) */
 | 
						|
	__u8 pft;		/* PCI Function Type */
 | 
						|
	__u8 gid;		/* PCI function group ID */
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * VFIO_DEVICE_INFO_CAP_ZPCI_GROUP - Base PCI Function Group information
 | 
						|
 *
 | 
						|
 * This capability provides a set of descriptive information about the group of
 | 
						|
 * PCI functions that the associated device belongs to.
 | 
						|
 */
 | 
						|
struct vfio_device_info_cap_zpci_group {
 | 
						|
	struct vfio_info_cap_header header;
 | 
						|
	__u64 dasm;		/* DMA Address space mask */
 | 
						|
	__u64 msi_addr;		/* MSI address */
 | 
						|
	__u64 flags;
 | 
						|
#define VFIO_DEVICE_INFO_ZPCI_FLAG_REFRESH 1 /* Program-specified TLB refresh */
 | 
						|
	__u16 mui;		/* Measurement Block Update Interval */
 | 
						|
	__u16 noi;		/* Maximum number of MSIs */
 | 
						|
	__u16 maxstbl;		/* Maximum Store Block Length */
 | 
						|
	__u8 version;		/* Supported PCI Version */
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * VFIO_DEVICE_INFO_CAP_ZPCI_UTIL - Utility String
 | 
						|
 *
 | 
						|
 * This capability provides the utility string for the associated device, which
 | 
						|
 * is a device identifier string made up of EBCDID characters.  'size' specifies
 | 
						|
 * the length of 'util_str'.
 | 
						|
 */
 | 
						|
struct vfio_device_info_cap_zpci_util {
 | 
						|
	struct vfio_info_cap_header header;
 | 
						|
	__u32 size;
 | 
						|
	__u8 util_str[];
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * VFIO_DEVICE_INFO_CAP_ZPCI_PFIP - PCI Function Path
 | 
						|
 *
 | 
						|
 * This capability provides the PCI function path string, which is an identifier
 | 
						|
 * that describes the internal hardware path of the device. 'size' specifies
 | 
						|
 * the length of 'pfip'.
 | 
						|
 */
 | 
						|
struct vfio_device_info_cap_zpci_pfip {
 | 
						|
	struct vfio_info_cap_header header;
 | 
						|
	__u32 size;
 | 
						|
	__u8 pfip[];
 | 
						|
};
 | 
						|
 | 
						|
#endif
 |