1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57#ifndef _AICLIB_H
58#define _AICLIB_H
59
60struct scsi_sense
61{
62 uint8_t opcode;
63 uint8_t byte2;
64 uint8_t unused[2];
65 uint8_t length;
66 uint8_t control;
67};
68
69#define SCSI_REV_0 0
70#define SCSI_REV_CCS 1
71#define SCSI_REV_2 2
72#define SCSI_REV_SPC 3
73#define SCSI_REV_SPC2 4
74
75struct scsi_sense_data
76{
77 uint8_t error_code;
78#define SSD_ERRCODE 0x7F
79#define SSD_CURRENT_ERROR 0x70
80#define SSD_DEFERRED_ERROR 0x71
81#define SSD_ERRCODE_VALID 0x80
82 uint8_t segment;
83 uint8_t flags;
84#define SSD_KEY 0x0F
85#define SSD_KEY_NO_SENSE 0x00
86#define SSD_KEY_RECOVERED_ERROR 0x01
87#define SSD_KEY_NOT_READY 0x02
88#define SSD_KEY_MEDIUM_ERROR 0x03
89#define SSD_KEY_HARDWARE_ERROR 0x04
90#define SSD_KEY_ILLEGAL_REQUEST 0x05
91#define SSD_KEY_UNIT_ATTENTION 0x06
92#define SSD_KEY_DATA_PROTECT 0x07
93#define SSD_KEY_BLANK_CHECK 0x08
94#define SSD_KEY_Vendor_Specific 0x09
95#define SSD_KEY_COPY_ABORTED 0x0a
96#define SSD_KEY_ABORTED_COMMAND 0x0b
97#define SSD_KEY_EQUAL 0x0c
98#define SSD_KEY_VOLUME_OVERFLOW 0x0d
99#define SSD_KEY_MISCOMPARE 0x0e
100#define SSD_KEY_RESERVED 0x0f
101#define SSD_ILI 0x20
102#define SSD_EOM 0x40
103#define SSD_FILEMARK 0x80
104 uint8_t info[4];
105 uint8_t extra_len;
106 uint8_t cmd_spec_info[4];
107 uint8_t add_sense_code;
108 uint8_t add_sense_code_qual;
109 uint8_t fru;
110 uint8_t sense_key_spec[3];
111#define SSD_SCS_VALID 0x80
112#define SSD_FIELDPTR_CMD 0x40
113#define SSD_BITPTR_VALID 0x08
114#define SSD_BITPTR_VALUE 0x07
115#define SSD_MIN_SIZE 18
116 uint8_t extra_bytes[14];
117#define SSD_FULL_SIZE sizeof(struct scsi_sense_data)
118};
119
120
121
122
123#define SCSI_STATUS_OK 0x00
124#define SCSI_STATUS_CHECK_COND 0x02
125#define SCSI_STATUS_COND_MET 0x04
126#define SCSI_STATUS_BUSY 0x08
127#define SCSI_STATUS_INTERMED 0x10
128#define SCSI_STATUS_INTERMED_COND_MET 0x14
129#define SCSI_STATUS_RESERV_CONFLICT 0x18
130#define SCSI_STATUS_CMD_TERMINATED 0x22
131#define SCSI_STATUS_QUEUE_FULL 0x28
132#define SCSI_STATUS_ACA_ACTIVE 0x30
133#define SCSI_STATUS_TASK_ABORTED 0x40
134
135
136static inline int
137aic_sector_div(sector_t capacity, int heads, int sectors)
138{
139
140 sector_div(capacity, (heads * sectors));
141 return (int)capacity;
142}
143
144static inline uint32_t
145scsi_4btoul(uint8_t *bytes)
146{
147 uint32_t rv;
148
149 rv = (bytes[0] << 24) |
150 (bytes[1] << 16) |
151 (bytes[2] << 8) |
152 bytes[3];
153 return (rv);
154}
155
156
157
158#define GETID(v, s) (unsigned)(((v) >> (s)) & 0xFFFF ?: PCI_ANY_ID)
159
160#define ID_C(x, c) \
161{ \
162 GETID(x,32), GETID(x,48), GETID(x,0), GETID(x,16), \
163 (c) << 8, 0xFFFF00, 0 \
164}
165
166#define ID2C(x) \
167 ID_C(x, PCI_CLASS_STORAGE_SCSI), \
168 ID_C(x, PCI_CLASS_STORAGE_RAID)
169
170#define IDIROC(x) ((x) | ~ID_ALL_IROC_MASK)
171
172
173
174
175
176
177#define ID16(x) \
178 ID(x), \
179 ID((x) | 0x0001000000000000ull), \
180 ID((x) | 0x0002000000000000ull), \
181 ID((x) | 0x0003000000000000ull), \
182 ID((x) | 0x0004000000000000ull), \
183 ID((x) | 0x0005000000000000ull), \
184 ID((x) | 0x0006000000000000ull), \
185 ID((x) | 0x0007000000000000ull), \
186 ID((x) | 0x0008000000000000ull), \
187 ID((x) | 0x0009000000000000ull), \
188 ID((x) | 0x000A000000000000ull), \
189 ID((x) | 0x000B000000000000ull), \
190 ID((x) | 0x000C000000000000ull), \
191 ID((x) | 0x000D000000000000ull), \
192 ID((x) | 0x000E000000000000ull), \
193 ID((x) | 0x000F000000000000ull)
194
195#endif
196