| // for user apps, make sure data size types are defined |
| // with |
| |
| |
| #define CCPQFCTS_IOC_MAGIC 'Z' |
| |
| typedef struct |
| { |
| __u8 bus; |
| __u8 dev_fn; |
| __u32 board_id; |
| } cpqfc_pci_info_struct; |
| |
| typedef __u32 DriverVer_type; |
| /* |
| typedef union |
| { |
| struct // Peripheral Unit Device |
| { |
| __u8 Bus:6; |
| __u8 Mode:2; // b00 |
| __u8 Dev; |
| } PeripDev; |
| struct // Volume Set Address |
| { |
| __u8 DevMSB:6; |
| __u8 Mode:2; // b01 |
| __u8 DevLSB; |
| } LogDev; |
| struct // Logical Unit Device (SCSI-3, SCC-2 defined) |
| { |
| __u8 Targ:6; |
| __u8 Mode:2; // b10 |
| __u8 Dev:5; |
| __u8 Bus:3; |
| |
| } LogUnit; |
| } SCSI3Addr_struct; |
| |
| |
| typedef struct |
| { |
| SCSI3Addr_struct FCP_Nexus; |
| __u8 cdb[16]; |
| } PassThru_Command_struct; |
| */ |
| |
| /* this is nearly duplicated in idashare.h */ |
| typedef struct { |
| int lc; /* Controller number */ |
| int node; /* Node (box) number */ |
| int ld; /* Logical Drive on this box, if required */ |
| __u32 nexus; /* SCSI Nexus */ |
| void *argp; /* Argument pointer */ |
| } VENDOR_IOCTL_REQ; |
| |
| |
| typedef struct { |
| char cdb[16]; /* SCSI CDB for the pass-through */ |
| ushort bus; /* Target bus on the box */ |
| ushort pdrive; /* Physical drive on the box */ |
| int len; /* Length of the data area of the CDB */ |
| int sense_len; /* Length of the sense data */ |
| char sense_data[40]; /* Sense data */ |
| void *bufp; /* Data area for the CDB */ |
| char rw_flag; /* Read CDB or Write CDB */ |
| } cpqfc_passthru_t; |
| |
| /* |
| ** Defines for the IOCTLS. |
| */ |
| |
| #define VENDOR_READ_OPCODE 0x26 |
| #define VENDOR_WRITE_OPCODE 0x27 |
| |
| #define CPQFCTS_GETPCIINFO _IOR( CCPQFCTS_IOC_MAGIC, 1, cpqfc_pci_info_struct) |
| #define CPQFCTS_GETDRIVVER _IOR( CCPQFCTS_IOC_MAGIC, 9, DriverVer_type) |
| |
| #define CPQFCTS_SCSI_PASSTHRU _IOWR( CCPQFCTS_IOC_MAGIC,11, VENDOR_IOCTL_REQ) |
| |
| /* We would rather have equivalent generic, low-level driver agnostic |
| ioctls that do what CPQFC_IOCTL_FC_TARGET_ADDRESS and |
| CPQFC_IOCTL_FC_TDR 0x5388 do, but currently, we do not have them, |
| consequently applications would have to know they are talking to cpqfc. */ |
| |
| /* Used to get Fibre Channel WWN and port_id from device */ |
| // #define CPQFC_IOCTL_FC_TARGET_ADDRESS 0x5387 |
| #define CPQFC_IOCTL_FC_TARGET_ADDRESS \ |
| _IOR( CCPQFCTS_IOC_MAGIC, 13, Scsi_FCTargAddress) |
| |
| /* Used to invoke Target Defice Reset for Fibre Channel */ |
| // #define CPQFC_IOCTL_FC_TDR 0x5388 |
| #define CPQFC_IOCTL_FC_TDR _IO( CCPQFCTS_IOC_MAGIC, 15) |
| |