| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef CCISS_IOCTLH | 
 | 2 | #define CCISS_IOCTLH | 
 | 3 |  | 
 | 4 | #include <linux/types.h> | 
 | 5 | #include <linux/ioctl.h> | 
 | 6 |  | 
 | 7 | #define CCISS_IOC_MAGIC 'B' | 
 | 8 |  | 
 | 9 |  | 
 | 10 | typedef struct _cciss_pci_info_struct | 
 | 11 | { | 
 | 12 | 	unsigned char 	bus; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | 	unsigned char 	dev_fn; | 
| mikem | 7f0d503 | 2005-11-18 22:00:17 +0100 | [diff] [blame] | 14 | 	unsigned short	domain; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | 	__u32 		board_id; | 
 | 16 | } cciss_pci_info_struct;  | 
 | 17 |  | 
 | 18 | typedef struct _cciss_coalint_struct | 
 | 19 | { | 
 | 20 | 	__u32  delay; | 
 | 21 | 	__u32  count; | 
 | 22 | } cciss_coalint_struct; | 
 | 23 |  | 
 | 24 | typedef char NodeName_type[16]; | 
 | 25 |  | 
 | 26 | typedef __u32 Heartbeat_type; | 
 | 27 |  | 
 | 28 | #define CISS_PARSCSIU2 	0x0001 | 
 | 29 | #define CISS_PARCSCIU3 	0x0002 | 
 | 30 | #define CISS_FIBRE1G	0x0100 | 
 | 31 | #define CISS_FIBRE2G	0x0200 | 
 | 32 | typedef __u32 BusTypes_type; | 
 | 33 |  | 
 | 34 | typedef char FirmwareVer_type[4]; | 
 | 35 | typedef __u32 DriverVer_type; | 
 | 36 |  | 
 | 37 | #define MAX_KMALLOC_SIZE 128000 | 
 | 38 |  | 
 | 39 | #ifndef CCISS_CMD_H | 
 | 40 | // This defines are duplicated in cciss_cmd.h in the driver directory  | 
 | 41 |  | 
 | 42 | //general boundary defintions | 
 | 43 | #define SENSEINFOBYTES          32//note that this value may vary between host implementations | 
 | 44 |  | 
 | 45 | //Command Status value | 
 | 46 | #define CMD_SUCCESS             0x0000 | 
 | 47 | #define CMD_TARGET_STATUS       0x0001 | 
 | 48 | #define CMD_DATA_UNDERRUN       0x0002 | 
 | 49 | #define CMD_DATA_OVERRUN        0x0003 | 
 | 50 | #define CMD_INVALID             0x0004 | 
 | 51 | #define CMD_PROTOCOL_ERR        0x0005 | 
 | 52 | #define CMD_HARDWARE_ERR        0x0006 | 
 | 53 | #define CMD_CONNECTION_LOST     0x0007 | 
 | 54 | #define CMD_ABORTED             0x0008 | 
 | 55 | #define CMD_ABORT_FAILED        0x0009 | 
 | 56 | #define CMD_UNSOLICITED_ABORT   0x000A | 
 | 57 | #define CMD_TIMEOUT             0x000B | 
 | 58 | #define CMD_UNABORTABLE		0x000C | 
 | 59 |  | 
 | 60 | //transfer direction | 
 | 61 | #define XFER_NONE               0x00 | 
 | 62 | #define XFER_WRITE              0x01 | 
 | 63 | #define XFER_READ               0x02 | 
 | 64 | #define XFER_RSVD               0x03 | 
 | 65 |  | 
 | 66 | //task attribute | 
 | 67 | #define ATTR_UNTAGGED           0x00 | 
 | 68 | #define ATTR_SIMPLE             0x04 | 
 | 69 | #define ATTR_HEADOFQUEUE        0x05 | 
 | 70 | #define ATTR_ORDERED            0x06 | 
 | 71 | #define ATTR_ACA                0x07 | 
 | 72 |  | 
 | 73 | //cdb type | 
 | 74 | #define TYPE_CMD				0x00 | 
 | 75 | #define TYPE_MSG				0x01 | 
 | 76 |  | 
 | 77 | // Type defs used in the following structs | 
 | 78 | #define BYTE __u8 | 
 | 79 | #define WORD __u16 | 
 | 80 | #define HWORD __u16 | 
 | 81 | #define DWORD __u32 | 
 | 82 |  | 
 | 83 | #define CISS_MAX_LUN	16	 | 
 | 84 |  | 
 | 85 | #define LEVEL2LUN   1   // index into Target(x) structure, due to byte swapping | 
 | 86 | #define LEVEL3LUN   0 | 
 | 87 |  | 
 | 88 | #pragma pack(1) | 
 | 89 |  | 
 | 90 | //Command List Structure | 
 | 91 | typedef union _SCSI3Addr_struct { | 
 | 92 |    struct { | 
 | 93 |     BYTE Dev; | 
 | 94 |     BYTE Bus:6; | 
 | 95 |     BYTE Mode:2;        // b00 | 
 | 96 |   } PeripDev; | 
 | 97 |    struct { | 
 | 98 |     BYTE DevLSB; | 
 | 99 |     BYTE DevMSB:6; | 
 | 100 |     BYTE Mode:2;        // b01 | 
 | 101 |   } LogDev; | 
 | 102 |    struct { | 
 | 103 |     BYTE Dev:5; | 
 | 104 |     BYTE Bus:3; | 
 | 105 |     BYTE Targ:6; | 
 | 106 |     BYTE Mode:2;        // b10 | 
 | 107 |   } LogUnit; | 
 | 108 | } SCSI3Addr_struct; | 
 | 109 |  | 
 | 110 | typedef struct _PhysDevAddr_struct { | 
 | 111 |   DWORD             TargetId:24; | 
 | 112 |   DWORD             Bus:6; | 
 | 113 |   DWORD             Mode:2; | 
 | 114 |   SCSI3Addr_struct  Target[2]; //2 level target device addr | 
 | 115 | } PhysDevAddr_struct; | 
 | 116 |    | 
 | 117 | typedef struct _LogDevAddr_struct { | 
 | 118 |   DWORD            VolId:30; | 
 | 119 |   DWORD            Mode:2; | 
 | 120 |   BYTE             reserved[4]; | 
 | 121 | } LogDevAddr_struct; | 
 | 122 |  | 
 | 123 | typedef union _LUNAddr_struct { | 
 | 124 |   BYTE               LunAddrBytes[8]; | 
 | 125 |   SCSI3Addr_struct   SCSI3Lun[4]; | 
 | 126 |   PhysDevAddr_struct PhysDev; | 
 | 127 |   LogDevAddr_struct  LogDev; | 
 | 128 | } LUNAddr_struct; | 
 | 129 |  | 
 | 130 | typedef struct _RequestBlock_struct { | 
 | 131 |   BYTE   CDBLen; | 
 | 132 |   struct { | 
 | 133 |     BYTE Type:3; | 
 | 134 |     BYTE Attribute:3; | 
 | 135 |     BYTE Direction:2; | 
 | 136 |   } Type; | 
 | 137 |   HWORD  Timeout; | 
 | 138 |   BYTE   CDB[16]; | 
 | 139 | } RequestBlock_struct; | 
 | 140 |  | 
 | 141 | typedef union _MoreErrInfo_struct{ | 
 | 142 |   struct { | 
 | 143 |     BYTE  Reserved[3]; | 
 | 144 |     BYTE  Type; | 
 | 145 |     DWORD ErrorInfo; | 
 | 146 |   }Common_Info; | 
 | 147 |   struct{ | 
 | 148 |     BYTE  Reserved[2]; | 
 | 149 |     BYTE  offense_size;//size of offending entry | 
 | 150 |     BYTE  offense_num; //byte # of offense 0-base | 
 | 151 |     DWORD offense_value; | 
 | 152 |   }Invalid_Cmd; | 
 | 153 | }MoreErrInfo_struct; | 
 | 154 | typedef struct _ErrorInfo_struct { | 
 | 155 |   BYTE               ScsiStatus; | 
 | 156 |   BYTE               SenseLen; | 
 | 157 |   HWORD              CommandStatus; | 
 | 158 |   DWORD              ResidualCnt; | 
 | 159 |   MoreErrInfo_struct MoreErrInfo; | 
 | 160 |   BYTE               SenseInfo[SENSEINFOBYTES]; | 
 | 161 | } ErrorInfo_struct; | 
 | 162 |  | 
 | 163 | #pragma pack() | 
 | 164 | #endif /* CCISS_CMD_H */  | 
 | 165 |  | 
 | 166 | typedef struct _IOCTL_Command_struct { | 
 | 167 |   LUNAddr_struct	   LUN_info; | 
 | 168 |   RequestBlock_struct      Request; | 
 | 169 |   ErrorInfo_struct  	   error_info;  | 
 | 170 |   WORD			   buf_size;  /* size in bytes of the buf */ | 
 | 171 |   BYTE			   __user *buf; | 
 | 172 | } IOCTL_Command_struct; | 
 | 173 |  | 
 | 174 | typedef struct _BIG_IOCTL_Command_struct { | 
 | 175 |   LUNAddr_struct	   LUN_info; | 
 | 176 |   RequestBlock_struct      Request; | 
 | 177 |   ErrorInfo_struct  	   error_info; | 
 | 178 |   DWORD			   malloc_size; /* < MAX_KMALLOC_SIZE in cciss.c */ | 
 | 179 |   DWORD			   buf_size;    /* size in bytes of the buf */ | 
 | 180 |   				        /* < malloc_size * MAXSGENTRIES */ | 
 | 181 |   BYTE			   __user *buf; | 
 | 182 | } BIG_IOCTL_Command_struct; | 
 | 183 |  | 
 | 184 | typedef struct _LogvolInfo_struct{ | 
 | 185 | 	__u32	LunID; | 
 | 186 | 	int	num_opens;  /* number of opens on the logical volume */ | 
 | 187 | 	int	num_parts;  /* number of partitions configured on logvol */ | 
 | 188 | } LogvolInfo_struct; | 
 | 189 |  | 
 | 190 | #define CCISS_GETPCIINFO _IOR(CCISS_IOC_MAGIC, 1, cciss_pci_info_struct) | 
 | 191 |  | 
 | 192 | #define CCISS_GETINTINFO _IOR(CCISS_IOC_MAGIC, 2, cciss_coalint_struct) | 
 | 193 | #define CCISS_SETINTINFO _IOW(CCISS_IOC_MAGIC, 3, cciss_coalint_struct) | 
 | 194 |  | 
 | 195 | #define CCISS_GETNODENAME _IOR(CCISS_IOC_MAGIC, 4, NodeName_type) | 
 | 196 | #define CCISS_SETNODENAME _IOW(CCISS_IOC_MAGIC, 5, NodeName_type) | 
 | 197 |  | 
 | 198 | #define CCISS_GETHEARTBEAT _IOR(CCISS_IOC_MAGIC, 6, Heartbeat_type) | 
 | 199 | #define CCISS_GETBUSTYPES  _IOR(CCISS_IOC_MAGIC, 7, BusTypes_type) | 
 | 200 | #define CCISS_GETFIRMVER   _IOR(CCISS_IOC_MAGIC, 8, FirmwareVer_type) | 
 | 201 | #define CCISS_GETDRIVVER   _IOR(CCISS_IOC_MAGIC, 9, DriverVer_type) | 
 | 202 | #define CCISS_REVALIDVOLS  _IO(CCISS_IOC_MAGIC, 10) | 
 | 203 | #define CCISS_PASSTHRU	   _IOWR(CCISS_IOC_MAGIC, 11, IOCTL_Command_struct) | 
 | 204 | #define CCISS_DEREGDISK	   _IO(CCISS_IOC_MAGIC, 12) | 
 | 205 |  | 
 | 206 | /* no longer used... use REGNEWD instead */  | 
 | 207 | #define CCISS_REGNEWDISK  _IOW(CCISS_IOC_MAGIC, 13, int) | 
 | 208 |  | 
 | 209 | #define CCISS_REGNEWD	   _IO(CCISS_IOC_MAGIC, 14) | 
 | 210 | #define CCISS_RESCANDISK   _IO(CCISS_IOC_MAGIC, 16) | 
 | 211 | #define CCISS_GETLUNINFO   _IOR(CCISS_IOC_MAGIC, 17, LogvolInfo_struct) | 
 | 212 | #define CCISS_BIG_PASSTHRU _IOWR(CCISS_IOC_MAGIC, 18, BIG_IOCTL_Command_struct) | 
 | 213 |  | 
 | 214 | #ifdef __KERNEL__ | 
 | 215 | #ifdef CONFIG_COMPAT | 
 | 216 |  | 
 | 217 | /* 32 bit compatible ioctl structs */ | 
 | 218 | typedef struct _IOCTL32_Command_struct { | 
 | 219 |   LUNAddr_struct	   LUN_info; | 
 | 220 |   RequestBlock_struct      Request; | 
 | 221 |   ErrorInfo_struct  	   error_info; | 
 | 222 |   WORD			   buf_size;  /* size in bytes of the buf */ | 
 | 223 |   __u32			   buf; /* 32 bit pointer to data buffer */ | 
 | 224 | } IOCTL32_Command_struct; | 
 | 225 |  | 
 | 226 | typedef struct _BIG_IOCTL32_Command_struct { | 
 | 227 |   LUNAddr_struct	   LUN_info; | 
 | 228 |   RequestBlock_struct      Request; | 
 | 229 |   ErrorInfo_struct  	   error_info; | 
 | 230 |   DWORD			   malloc_size; /* < MAX_KMALLOC_SIZE in cciss.c */ | 
 | 231 |   DWORD			   buf_size;    /* size in bytes of the buf */ | 
 | 232 |   				        /* < malloc_size * MAXSGENTRIES */ | 
 | 233 |   __u32 		buf;	/* 32 bit pointer to data buffer */ | 
 | 234 | } BIG_IOCTL32_Command_struct; | 
 | 235 |  | 
 | 236 | #define CCISS_PASSTHRU32   _IOWR(CCISS_IOC_MAGIC, 11, IOCTL32_Command_struct) | 
 | 237 | #define CCISS_BIG_PASSTHRU32 _IOWR(CCISS_IOC_MAGIC, 18, BIG_IOCTL32_Command_struct) | 
 | 238 |  | 
 | 239 | #endif /* CONFIG_COMPAT */ | 
 | 240 | #endif /* __KERNEL__ */ | 
 | 241 | #endif   |