1*f80ad8b4SAndroid Build Coastguard Worker /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2*f80ad8b4SAndroid Build Coastguard Worker /* 3*f80ad8b4SAndroid Build Coastguard Worker * Header File for FPGA DFL User API 4*f80ad8b4SAndroid Build Coastguard Worker * 5*f80ad8b4SAndroid Build Coastguard Worker * Copyright (C) 2017-2018 Intel Corporation, Inc. 6*f80ad8b4SAndroid Build Coastguard Worker * 7*f80ad8b4SAndroid Build Coastguard Worker * Authors: 8*f80ad8b4SAndroid Build Coastguard Worker * Kang Luwei <[email protected]> 9*f80ad8b4SAndroid Build Coastguard Worker * Zhang Yi <[email protected]> 10*f80ad8b4SAndroid Build Coastguard Worker * Wu Hao <[email protected]> 11*f80ad8b4SAndroid Build Coastguard Worker * Xiao Guangrong <[email protected]> 12*f80ad8b4SAndroid Build Coastguard Worker */ 13*f80ad8b4SAndroid Build Coastguard Worker 14*f80ad8b4SAndroid Build Coastguard Worker #ifndef _UAPI_LINUX_FPGA_DFL_H 15*f80ad8b4SAndroid Build Coastguard Worker #define _UAPI_LINUX_FPGA_DFL_H 16*f80ad8b4SAndroid Build Coastguard Worker 17*f80ad8b4SAndroid Build Coastguard Worker #include <linux/types.h> 18*f80ad8b4SAndroid Build Coastguard Worker #include <linux/ioctl.h> 19*f80ad8b4SAndroid Build Coastguard Worker 20*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_API_VERSION 0 21*f80ad8b4SAndroid Build Coastguard Worker 22*f80ad8b4SAndroid Build Coastguard Worker /* 23*f80ad8b4SAndroid Build Coastguard Worker * The IOCTL interface for DFL based FPGA is designed for extensibility by 24*f80ad8b4SAndroid Build Coastguard Worker * embedding the structure length (argsz) and flags into structures passed 25*f80ad8b4SAndroid Build Coastguard Worker * between kernel and userspace. This design referenced the VFIO IOCTL 26*f80ad8b4SAndroid Build Coastguard Worker * interface (include/uapi/linux/vfio.h). 27*f80ad8b4SAndroid Build Coastguard Worker */ 28*f80ad8b4SAndroid Build Coastguard Worker 29*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_MAGIC 0xB6 30*f80ad8b4SAndroid Build Coastguard Worker 31*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_BASE 0 32*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_BASE 0x40 33*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FME_BASE 0x80 34*f80ad8b4SAndroid Build Coastguard Worker 35*f80ad8b4SAndroid Build Coastguard Worker /* Common IOCTLs for both FME and AFU file descriptor */ 36*f80ad8b4SAndroid Build Coastguard Worker 37*f80ad8b4SAndroid Build Coastguard Worker /** 38*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_GET_API_VERSION - _IO(DFL_FPGA_MAGIC, DFL_FPGA_BASE + 0) 39*f80ad8b4SAndroid Build Coastguard Worker * 40*f80ad8b4SAndroid Build Coastguard Worker * Report the version of the driver API. 41*f80ad8b4SAndroid Build Coastguard Worker * Return: Driver API Version. 42*f80ad8b4SAndroid Build Coastguard Worker */ 43*f80ad8b4SAndroid Build Coastguard Worker 44*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_GET_API_VERSION _IO(DFL_FPGA_MAGIC, DFL_FPGA_BASE + 0) 45*f80ad8b4SAndroid Build Coastguard Worker 46*f80ad8b4SAndroid Build Coastguard Worker /** 47*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_CHECK_EXTENSION - _IO(DFL_FPGA_MAGIC, DFL_FPGA_BASE + 1) 48*f80ad8b4SAndroid Build Coastguard Worker * 49*f80ad8b4SAndroid Build Coastguard Worker * Check whether an extension is supported. 50*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 if not supported, otherwise the extension is supported. 51*f80ad8b4SAndroid Build Coastguard Worker */ 52*f80ad8b4SAndroid Build Coastguard Worker 53*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_CHECK_EXTENSION _IO(DFL_FPGA_MAGIC, DFL_FPGA_BASE + 1) 54*f80ad8b4SAndroid Build Coastguard Worker 55*f80ad8b4SAndroid Build Coastguard Worker /* IOCTLs for AFU file descriptor */ 56*f80ad8b4SAndroid Build Coastguard Worker 57*f80ad8b4SAndroid Build Coastguard Worker /** 58*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_RESET - _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 0) 59*f80ad8b4SAndroid Build Coastguard Worker * 60*f80ad8b4SAndroid Build Coastguard Worker * Reset the FPGA Port and its AFU. No parameters are supported. 61*f80ad8b4SAndroid Build Coastguard Worker * Userspace can do Port reset at any time, e.g. during DMA or PR. But 62*f80ad8b4SAndroid Build Coastguard Worker * it should never cause any system level issue, only functional failure 63*f80ad8b4SAndroid Build Coastguard Worker * (e.g. DMA or PR operation failure) and be recoverable from the failure. 64*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno of failure 65*f80ad8b4SAndroid Build Coastguard Worker */ 66*f80ad8b4SAndroid Build Coastguard Worker 67*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_RESET _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 0) 68*f80ad8b4SAndroid Build Coastguard Worker 69*f80ad8b4SAndroid Build Coastguard Worker /** 70*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_GET_INFO - _IOR(DFL_FPGA_MAGIC, DFL_PORT_BASE + 1, 71*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_port_info) 72*f80ad8b4SAndroid Build Coastguard Worker * 73*f80ad8b4SAndroid Build Coastguard Worker * Retrieve information about the fpga port. 74*f80ad8b4SAndroid Build Coastguard Worker * Driver fills the info in provided struct dfl_fpga_port_info. 75*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 76*f80ad8b4SAndroid Build Coastguard Worker */ 77*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_port_info { 78*f80ad8b4SAndroid Build Coastguard Worker /* Input */ 79*f80ad8b4SAndroid Build Coastguard Worker __u32 argsz; /* Structure length */ 80*f80ad8b4SAndroid Build Coastguard Worker /* Output */ 81*f80ad8b4SAndroid Build Coastguard Worker __u32 flags; /* Zero for now */ 82*f80ad8b4SAndroid Build Coastguard Worker __u32 num_regions; /* The number of supported regions */ 83*f80ad8b4SAndroid Build Coastguard Worker __u32 num_umsgs; /* The number of allocated umsgs */ 84*f80ad8b4SAndroid Build Coastguard Worker }; 85*f80ad8b4SAndroid Build Coastguard Worker 86*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_GET_INFO _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 1) 87*f80ad8b4SAndroid Build Coastguard Worker 88*f80ad8b4SAndroid Build Coastguard Worker /** 89*f80ad8b4SAndroid Build Coastguard Worker * FPGA_PORT_GET_REGION_INFO - _IOWR(FPGA_MAGIC, PORT_BASE + 2, 90*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_port_region_info) 91*f80ad8b4SAndroid Build Coastguard Worker * 92*f80ad8b4SAndroid Build Coastguard Worker * Retrieve information about a device memory region. 93*f80ad8b4SAndroid Build Coastguard Worker * Caller provides struct dfl_fpga_port_region_info with index value set. 94*f80ad8b4SAndroid Build Coastguard Worker * Driver returns the region info in other fields. 95*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 96*f80ad8b4SAndroid Build Coastguard Worker */ 97*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_port_region_info { 98*f80ad8b4SAndroid Build Coastguard Worker /* input */ 99*f80ad8b4SAndroid Build Coastguard Worker __u32 argsz; /* Structure length */ 100*f80ad8b4SAndroid Build Coastguard Worker /* Output */ 101*f80ad8b4SAndroid Build Coastguard Worker __u32 flags; /* Access permission */ 102*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_REGION_READ (1 << 0) /* Region is readable */ 103*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_REGION_WRITE (1 << 1) /* Region is writable */ 104*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_REGION_MMAP (1 << 2) /* Can be mmaped to userspace */ 105*f80ad8b4SAndroid Build Coastguard Worker /* Input */ 106*f80ad8b4SAndroid Build Coastguard Worker __u32 index; /* Region index */ 107*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_REGION_INDEX_AFU 0 /* AFU */ 108*f80ad8b4SAndroid Build Coastguard Worker #define DFL_PORT_REGION_INDEX_STP 1 /* Signal Tap */ 109*f80ad8b4SAndroid Build Coastguard Worker __u32 padding; 110*f80ad8b4SAndroid Build Coastguard Worker /* Output */ 111*f80ad8b4SAndroid Build Coastguard Worker __u64 size; /* Region size (bytes) */ 112*f80ad8b4SAndroid Build Coastguard Worker __u64 offset; /* Region offset from start of device fd */ 113*f80ad8b4SAndroid Build Coastguard Worker }; 114*f80ad8b4SAndroid Build Coastguard Worker 115*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_GET_REGION_INFO _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 2) 116*f80ad8b4SAndroid Build Coastguard Worker 117*f80ad8b4SAndroid Build Coastguard Worker /** 118*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_DMA_MAP - _IOWR(DFL_FPGA_MAGIC, DFL_PORT_BASE + 3, 119*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_port_dma_map) 120*f80ad8b4SAndroid Build Coastguard Worker * 121*f80ad8b4SAndroid Build Coastguard Worker * Map the dma memory per user_addr and length which are provided by caller. 122*f80ad8b4SAndroid Build Coastguard Worker * Driver fills the iova in provided struct afu_port_dma_map. 123*f80ad8b4SAndroid Build Coastguard Worker * This interface only accepts page-size aligned user memory for dma mapping. 124*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 125*f80ad8b4SAndroid Build Coastguard Worker */ 126*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_port_dma_map { 127*f80ad8b4SAndroid Build Coastguard Worker /* Input */ 128*f80ad8b4SAndroid Build Coastguard Worker __u32 argsz; /* Structure length */ 129*f80ad8b4SAndroid Build Coastguard Worker __u32 flags; /* Zero for now */ 130*f80ad8b4SAndroid Build Coastguard Worker __u64 user_addr; /* Process virtual address */ 131*f80ad8b4SAndroid Build Coastguard Worker __u64 length; /* Length of mapping (bytes)*/ 132*f80ad8b4SAndroid Build Coastguard Worker /* Output */ 133*f80ad8b4SAndroid Build Coastguard Worker __u64 iova; /* IO virtual address */ 134*f80ad8b4SAndroid Build Coastguard Worker }; 135*f80ad8b4SAndroid Build Coastguard Worker 136*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_DMA_MAP _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 3) 137*f80ad8b4SAndroid Build Coastguard Worker 138*f80ad8b4SAndroid Build Coastguard Worker /** 139*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_DMA_UNMAP - _IOW(FPGA_MAGIC, PORT_BASE + 4, 140*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_port_dma_unmap) 141*f80ad8b4SAndroid Build Coastguard Worker * 142*f80ad8b4SAndroid Build Coastguard Worker * Unmap the dma memory per iova provided by caller. 143*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 144*f80ad8b4SAndroid Build Coastguard Worker */ 145*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_port_dma_unmap { 146*f80ad8b4SAndroid Build Coastguard Worker /* Input */ 147*f80ad8b4SAndroid Build Coastguard Worker __u32 argsz; /* Structure length */ 148*f80ad8b4SAndroid Build Coastguard Worker __u32 flags; /* Zero for now */ 149*f80ad8b4SAndroid Build Coastguard Worker __u64 iova; /* IO virtual address */ 150*f80ad8b4SAndroid Build Coastguard Worker }; 151*f80ad8b4SAndroid Build Coastguard Worker 152*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_DMA_UNMAP _IO(DFL_FPGA_MAGIC, DFL_PORT_BASE + 4) 153*f80ad8b4SAndroid Build Coastguard Worker 154*f80ad8b4SAndroid Build Coastguard Worker /** 155*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_irq_set - the argument for DFL_FPGA_XXX_SET_IRQ ioctl. 156*f80ad8b4SAndroid Build Coastguard Worker * 157*f80ad8b4SAndroid Build Coastguard Worker * @start: Index of the first irq. 158*f80ad8b4SAndroid Build Coastguard Worker * @count: The number of eventfd handler. 159*f80ad8b4SAndroid Build Coastguard Worker * @evtfds: Eventfd handlers. 160*f80ad8b4SAndroid Build Coastguard Worker */ 161*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_irq_set { 162*f80ad8b4SAndroid Build Coastguard Worker __u32 start; 163*f80ad8b4SAndroid Build Coastguard Worker __u32 count; 164*f80ad8b4SAndroid Build Coastguard Worker __s32 evtfds[]; 165*f80ad8b4SAndroid Build Coastguard Worker }; 166*f80ad8b4SAndroid Build Coastguard Worker 167*f80ad8b4SAndroid Build Coastguard Worker /** 168*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_ERR_GET_IRQ_NUM - _IOR(DFL_FPGA_MAGIC, DFL_PORT_BASE + 5, 169*f80ad8b4SAndroid Build Coastguard Worker * __u32 num_irqs) 170*f80ad8b4SAndroid Build Coastguard Worker * 171*f80ad8b4SAndroid Build Coastguard Worker * Get the number of irqs supported by the fpga port error reporting private 172*f80ad8b4SAndroid Build Coastguard Worker * feature. Currently hardware supports up to 1 irq. 173*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 174*f80ad8b4SAndroid Build Coastguard Worker */ 175*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_ERR_GET_IRQ_NUM _IOR(DFL_FPGA_MAGIC, \ 176*f80ad8b4SAndroid Build Coastguard Worker DFL_PORT_BASE + 5, __u32) 177*f80ad8b4SAndroid Build Coastguard Worker 178*f80ad8b4SAndroid Build Coastguard Worker /** 179*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_ERR_SET_IRQ - _IOW(DFL_FPGA_MAGIC, DFL_PORT_BASE + 6, 180*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_irq_set) 181*f80ad8b4SAndroid Build Coastguard Worker * 182*f80ad8b4SAndroid Build Coastguard Worker * Set fpga port error reporting interrupt trigger if evtfds[n] is valid. 183*f80ad8b4SAndroid Build Coastguard Worker * Unset related interrupt trigger if evtfds[n] is a negative value. 184*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 185*f80ad8b4SAndroid Build Coastguard Worker */ 186*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_ERR_SET_IRQ _IOW(DFL_FPGA_MAGIC, \ 187*f80ad8b4SAndroid Build Coastguard Worker DFL_PORT_BASE + 6, \ 188*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_irq_set) 189*f80ad8b4SAndroid Build Coastguard Worker 190*f80ad8b4SAndroid Build Coastguard Worker /** 191*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_UINT_GET_IRQ_NUM - _IOR(DFL_FPGA_MAGIC, DFL_PORT_BASE + 7, 192*f80ad8b4SAndroid Build Coastguard Worker * __u32 num_irqs) 193*f80ad8b4SAndroid Build Coastguard Worker * 194*f80ad8b4SAndroid Build Coastguard Worker * Get the number of irqs supported by the fpga AFU interrupt private 195*f80ad8b4SAndroid Build Coastguard Worker * feature. 196*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 197*f80ad8b4SAndroid Build Coastguard Worker */ 198*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_UINT_GET_IRQ_NUM _IOR(DFL_FPGA_MAGIC, \ 199*f80ad8b4SAndroid Build Coastguard Worker DFL_PORT_BASE + 7, __u32) 200*f80ad8b4SAndroid Build Coastguard Worker 201*f80ad8b4SAndroid Build Coastguard Worker /** 202*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_PORT_UINT_SET_IRQ - _IOW(DFL_FPGA_MAGIC, DFL_PORT_BASE + 8, 203*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_irq_set) 204*f80ad8b4SAndroid Build Coastguard Worker * 205*f80ad8b4SAndroid Build Coastguard Worker * Set fpga AFU interrupt trigger if evtfds[n] is valid. 206*f80ad8b4SAndroid Build Coastguard Worker * Unset related interrupt trigger if evtfds[n] is a negative value. 207*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 208*f80ad8b4SAndroid Build Coastguard Worker */ 209*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_PORT_UINT_SET_IRQ _IOW(DFL_FPGA_MAGIC, \ 210*f80ad8b4SAndroid Build Coastguard Worker DFL_PORT_BASE + 8, \ 211*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_irq_set) 212*f80ad8b4SAndroid Build Coastguard Worker 213*f80ad8b4SAndroid Build Coastguard Worker /* IOCTLs for FME file descriptor */ 214*f80ad8b4SAndroid Build Coastguard Worker 215*f80ad8b4SAndroid Build Coastguard Worker /** 216*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_FME_PORT_PR - _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 0, 217*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_fme_port_pr) 218*f80ad8b4SAndroid Build Coastguard Worker * 219*f80ad8b4SAndroid Build Coastguard Worker * Driver does Partial Reconfiguration based on Port ID and Buffer (Image) 220*f80ad8b4SAndroid Build Coastguard Worker * provided by caller. 221*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 222*f80ad8b4SAndroid Build Coastguard Worker * If DFL_FPGA_FME_PORT_PR returns -EIO, that indicates the HW has detected 223*f80ad8b4SAndroid Build Coastguard Worker * some errors during PR, under this case, the user can fetch HW error info 224*f80ad8b4SAndroid Build Coastguard Worker * from the status of FME's fpga manager. 225*f80ad8b4SAndroid Build Coastguard Worker */ 226*f80ad8b4SAndroid Build Coastguard Worker 227*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_fme_port_pr { 228*f80ad8b4SAndroid Build Coastguard Worker /* Input */ 229*f80ad8b4SAndroid Build Coastguard Worker __u32 argsz; /* Structure length */ 230*f80ad8b4SAndroid Build Coastguard Worker __u32 flags; /* Zero for now */ 231*f80ad8b4SAndroid Build Coastguard Worker __u32 port_id; 232*f80ad8b4SAndroid Build Coastguard Worker __u32 buffer_size; 233*f80ad8b4SAndroid Build Coastguard Worker __u64 buffer_address; /* Userspace address to the buffer for PR */ 234*f80ad8b4SAndroid Build Coastguard Worker }; 235*f80ad8b4SAndroid Build Coastguard Worker 236*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_FME_PORT_PR _IO(DFL_FPGA_MAGIC, DFL_FME_BASE + 0) 237*f80ad8b4SAndroid Build Coastguard Worker 238*f80ad8b4SAndroid Build Coastguard Worker /** 239*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_FME_PORT_RELEASE - _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 1, 240*f80ad8b4SAndroid Build Coastguard Worker * int port_id) 241*f80ad8b4SAndroid Build Coastguard Worker * 242*f80ad8b4SAndroid Build Coastguard Worker * Driver releases the port per Port ID provided by caller. 243*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 244*f80ad8b4SAndroid Build Coastguard Worker */ 245*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_FME_PORT_RELEASE _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 1, int) 246*f80ad8b4SAndroid Build Coastguard Worker 247*f80ad8b4SAndroid Build Coastguard Worker /** 248*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_FME_PORT_ASSIGN - _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 2, 249*f80ad8b4SAndroid Build Coastguard Worker * int port_id) 250*f80ad8b4SAndroid Build Coastguard Worker * 251*f80ad8b4SAndroid Build Coastguard Worker * Driver assigns the port back per Port ID provided by caller. 252*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 253*f80ad8b4SAndroid Build Coastguard Worker */ 254*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_FME_PORT_ASSIGN _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 2, int) 255*f80ad8b4SAndroid Build Coastguard Worker 256*f80ad8b4SAndroid Build Coastguard Worker /** 257*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_FME_ERR_GET_IRQ_NUM - _IOR(DFL_FPGA_MAGIC, DFL_FME_BASE + 3, 258*f80ad8b4SAndroid Build Coastguard Worker * __u32 num_irqs) 259*f80ad8b4SAndroid Build Coastguard Worker * 260*f80ad8b4SAndroid Build Coastguard Worker * Get the number of irqs supported by the fpga fme error reporting private 261*f80ad8b4SAndroid Build Coastguard Worker * feature. Currently hardware supports up to 1 irq. 262*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 263*f80ad8b4SAndroid Build Coastguard Worker */ 264*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_FME_ERR_GET_IRQ_NUM _IOR(DFL_FPGA_MAGIC, \ 265*f80ad8b4SAndroid Build Coastguard Worker DFL_FME_BASE + 3, __u32) 266*f80ad8b4SAndroid Build Coastguard Worker 267*f80ad8b4SAndroid Build Coastguard Worker /** 268*f80ad8b4SAndroid Build Coastguard Worker * DFL_FPGA_FME_ERR_SET_IRQ - _IOW(DFL_FPGA_MAGIC, DFL_FME_BASE + 4, 269*f80ad8b4SAndroid Build Coastguard Worker * struct dfl_fpga_irq_set) 270*f80ad8b4SAndroid Build Coastguard Worker * 271*f80ad8b4SAndroid Build Coastguard Worker * Set fpga fme error reporting interrupt trigger if evtfds[n] is valid. 272*f80ad8b4SAndroid Build Coastguard Worker * Unset related interrupt trigger if evtfds[n] is a negative value. 273*f80ad8b4SAndroid Build Coastguard Worker * Return: 0 on success, -errno on failure. 274*f80ad8b4SAndroid Build Coastguard Worker */ 275*f80ad8b4SAndroid Build Coastguard Worker #define DFL_FPGA_FME_ERR_SET_IRQ _IOW(DFL_FPGA_MAGIC, \ 276*f80ad8b4SAndroid Build Coastguard Worker DFL_FME_BASE + 4, \ 277*f80ad8b4SAndroid Build Coastguard Worker struct dfl_fpga_irq_set) 278*f80ad8b4SAndroid Build Coastguard Worker 279*f80ad8b4SAndroid Build Coastguard Worker #endif /* _UAPI_LINUX_FPGA_DFL_H */ 280