Updated binary toolchain for kernel 2.4 target (gcc 4.2.4, binutils 2.20.1)
[tomato.git] / tools / brcm / K24 / hndtools-mipsel-uclibc-4.2.4 / include / linux / cciss_ioctl.h
blob9fd18856a791ff0f6e4b3efbf809f0791443fc37
1 #ifndef CCISS_IOCTLH
2 #define CCISS_IOCTLH
4 #include <linux/types.h>
5 #include <linux/ioctl.h>
7 #define CCISS_IOC_MAGIC 'B'
10 typedef struct _cciss_pci_info_struct
12 unsigned char bus;
13 unsigned char dev_fn;
14 __u32 board_id;
15 } cciss_pci_info_struct;
17 typedef struct _cciss_coalint_struct
19 __u32 delay;
20 __u32 count;
21 } cciss_coalint_struct;
23 typedef char NodeName_type[16];
25 typedef __u32 Heartbeat_type;
27 #define CISS_PARSCSIU2 0x0001
28 #define CISS_PARCSCIU3 0x0002
29 #define CISS_FIBRE1G 0x0100
30 #define CISS_FIBRE2G 0x0200
31 typedef __u32 BusTypes_type;
33 typedef char FirmwareVer_type[4];
34 typedef __u32 DriverVer_type;
37 #ifndef CCISS_CMD_H
38 // This defines are duplicated in cciss_cmd.h in the driver directory
40 //general boundary defintions
41 #define SENSEINFOBYTES 32//note that this value may vary between host implementations
43 //Command Status value
44 #define CMD_SUCCESS 0x0000
45 #define CMD_TARGET_STATUS 0x0001
46 #define CMD_DATA_UNDERRUN 0x0002
47 #define CMD_DATA_OVERRUN 0x0003
48 #define CMD_INVALID 0x0004
49 #define CMD_PROTOCOL_ERR 0x0005
50 #define CMD_HARDWARE_ERR 0x0006
51 #define CMD_CONNECTION_LOST 0x0007
52 #define CMD_ABORTED 0x0008
53 #define CMD_ABORT_FAILED 0x0009
54 #define CMD_UNSOLICITED_ABORT 0x000A
55 #define CMD_TIMEOUT 0x000B
56 #define CMD_UNABORTABLE 0x000C
58 //transfer direction
59 #define XFER_NONE 0x00
60 #define XFER_WRITE 0x01
61 #define XFER_READ 0x02
62 #define XFER_RSVD 0x03
64 //task attribute
65 #define ATTR_UNTAGGED 0x00
66 #define ATTR_SIMPLE 0x04
67 #define ATTR_HEADOFQUEUE 0x05
68 #define ATTR_ORDERED 0x06
69 #define ATTR_ACA 0x07
71 //cdb type
72 #define TYPE_CMD 0x00
73 #define TYPE_MSG 0x01
75 // Type defs used in the following structs
76 typedef __u8 BYTE;
77 typedef __u16 WORD;
78 typedef __u16 HWORD;
79 typedef __u32 DWORD;
81 #define CISS_MAX_LUN 16
83 #define LEVEL2LUN 1 // index into Target(x) structure, due to byte swapping
84 #define LEVEL3LUN 0
86 #pragma pack(1)
88 //Command List Structure
89 typedef union _SCSI3Addr_struct {
90 struct {
91 BYTE Dev;
92 BYTE Bus:6;
93 BYTE Mode:2; // b00
94 } PeripDev;
95 struct {
96 BYTE DevLSB;
97 BYTE DevMSB:6;
98 BYTE Mode:2; // b01
99 } LogDev;
100 struct {
101 BYTE Dev:5;
102 BYTE Bus:3;
103 BYTE Targ:6;
104 BYTE Mode:2; // b10
105 } LogUnit;
106 } SCSI3Addr_struct;
108 typedef struct _PhysDevAddr_struct {
109 DWORD TargetId:24;
110 DWORD Bus:6;
111 DWORD Mode:2;
112 SCSI3Addr_struct Target[2]; //2 level target device addr
113 } PhysDevAddr_struct;
115 typedef struct _LogDevAddr_struct {
116 DWORD VolId:30;
117 DWORD Mode:2;
118 BYTE reserved[4];
119 } LogDevAddr_struct;
121 typedef union _LUNAddr_struct {
122 BYTE LunAddrBytes[8];
123 SCSI3Addr_struct SCSI3Lun[4];
124 PhysDevAddr_struct PhysDev;
125 LogDevAddr_struct LogDev;
126 } LUNAddr_struct;
128 typedef struct _RequestBlock_struct {
129 BYTE CDBLen;
130 struct {
131 BYTE Type:3;
132 BYTE Attribute:3;
133 BYTE Direction:2;
134 } Type;
135 HWORD Timeout;
136 BYTE CDB[16];
137 } RequestBlock_struct;
139 typedef union _MoreErrInfo_struct{
140 struct {
141 BYTE Reserved[3];
142 BYTE Type;
143 DWORD ErrorInfo;
144 }Common_Info;
145 struct{
146 BYTE Reserved[2];
147 BYTE offense_size;//size of offending entry
148 BYTE offense_num; //byte # of offense 0-base
149 DWORD offense_value;
150 }Invalid_Cmd;
151 }MoreErrInfo_struct;
152 typedef struct _ErrorInfo_struct {
153 BYTE ScsiStatus;
154 BYTE SenseLen;
155 HWORD CommandStatus;
156 DWORD ResidualCnt;
157 MoreErrInfo_struct MoreErrInfo;
158 BYTE SenseInfo[SENSEINFOBYTES];
159 } ErrorInfo_struct;
161 #pragma pack()
162 #endif /* CCISS_CMD_H */
164 typedef struct _IOCTL_Command_struct {
165 LUNAddr_struct LUN_info;
166 RequestBlock_struct Request;
167 ErrorInfo_struct error_info;
168 WORD buf_size; /* size in bytes of the buf */
169 BYTE *buf;
170 } IOCTL_Command_struct;
172 #define MAX_KMALLOC_SIZE 128000
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 *buf;
182 } BIG_IOCTL_Command_struct;
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;
190 #define CCISS_GETPCIINFO _IOR(CCISS_IOC_MAGIC, 1, cciss_pci_info_struct)
192 #define CCISS_GETINTINFO _IOR(CCISS_IOC_MAGIC, 2, cciss_coalint_struct)
193 #define CCISS_SETINTINFO _IOW(CCISS_IOC_MAGIC, 3, cciss_coalint_struct)
195 #define CCISS_GETNODENAME _IOR(CCISS_IOC_MAGIC, 4, NodeName_type)
196 #define CCISS_SETNODENAME _IOW(CCISS_IOC_MAGIC, 5, NodeName_type)
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) /* obsolete */
203 #define CCISS_PASSTHRU _IOWR(CCISS_IOC_MAGIC, 11, IOCTL_Command_struct)
204 #define CCISS_DEREGDISK _IO(CCISS_IOC_MAGIC, 12)
205 #define CCISS_REGNEWDISK _IOW(CCISS_IOC_MAGIC, 13, __u64)
206 #define CCISS_REGNEWD _IO(CCISS_IOC_MAGIC, 14)
207 #define CCISS_RESCANDISK _IO(CCISS_IOC_MAGIC, 16)
208 #define CCISS_GETLUNINFO _IOR(CCISS_IOC_MAGIC, 17, LogvolInfo_struct)
209 #define CCISS_BIG_PASSTHRU _IOWR(CCISS_IOC_MAGIC, 18, BIG_IOCTL_Command_struct)
211 #ifdef __KERNEL__
212 #ifdef __x86_64__
214 /* 32 bit compatible ioctl structs */
215 typedef struct _IOCTL32_Command_struct {
216 LUNAddr_struct LUN_info;
217 RequestBlock_struct Request;
218 ErrorInfo_struct error_info;
219 WORD buf_size; /* size in bytes of the buf */
220 __u32 buf; /* 32 bit pointer to data buffer */
221 } IOCTL32_Command_struct;
223 typedef struct _BIG_IOCTL32_Command_struct {
224 LUNAddr_struct LUN_info;
225 RequestBlock_struct Request;
226 ErrorInfo_struct error_info;
227 DWORD malloc_size; /* < MAX_KMALLOC_SIZE in cciss.c */
228 DWORD buf_size; /* size in bytes of the buf */
229 /* < malloc_size * MAXSGENTRIES */
230 __u32 buf; /* 32 bit pointer to data buffer */
231 } BIG_IOCTL32_Command_struct;
233 #define CCISS_PASSTHRU32 _IOWR(CCISS_IOC_MAGIC, 11, IOCTL32_Command_struct)
234 #define CCISS_BIG_PASSTHRU32 _IOWR(CCISS_IOC_MAGIC, 18, BIG_IOCTL32_Command_struct)
236 #endif /* __x86_64__ */
237 #endif /* __KERNEL__ */
238 #endif