12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- /* 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 */
- /* End of version 1 */
- __u32 fh; /* PCI function handle */
- /* End of version 2 */
- };
- /**
- * 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 */
- /* End of version 1 */
- __u8 reserved;
- __u16 imaxstbl; /* Maximum Interpreted Store Block Length */
- /* End of version 2 */
- };
- /**
- * 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
|