summaryrefslogtreecommitdiffstats
path: root/sys/mips/cavium/driveid.h
blob: b4805d905d86bfa67736208cfd4a7202931fef6f (plain)
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
/***********************license start***************
 *  Copyright (c) 2003-2008 Cavium Networks (support@cavium.com). All rights
 *  reserved.
 *
 *
 *  Redistribution and use in source and binary forms, with or without
 *  modification, are permitted provided that the following conditions are
 *  met:
 *
 *      * Redistributions of source code must retain the above copyright
 *        notice, this list of conditions and the following disclaimer.
 *
 *      * Redistributions in binary form must reproduce the above
 *        copyright notice, this list of conditions and the following
 *        disclaimer in the documentation and/or other materials provided
 *        with the distribution.
 *
 *      * Neither the name of Cavium Networks nor the names of
 *        its contributors may be used to endorse or promote products
 *        derived from this software without specific prior written
 *        permission.
 *
 *  TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS"
 *  AND WITH ALL FAULTS AND CAVIUM NETWORKS MAKES NO PROMISES, REPRESENTATIONS
 *  OR WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH
 *  RESPECT TO THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY
 *  REPRESENTATION OR DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT
 *  DEFECTS, AND CAVIUM SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES
 *  OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR
 *  PURPOSE, LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET
 *  POSSESSION OR CORRESPONDENCE TO DESCRIPTION.  THE ENTIRE RISK ARISING OUT
 *  OF USE OR PERFORMANCE OF THE SOFTWARE LIES WITH YOU.
 *
 *
 *  For any questions regarding licensing please contact marketing@caviumnetworks.com
 *
 ***********************license end**************************************/

/* $FreeBSD$ */

/*
 * driveid.h
 *
 */

#ifndef __DRIVEID_H__
#define __DRIVEID_H__


struct hd_driveid {
        unsigned short  config;         /* lots of obsolete bit flags */
        unsigned short  cyls;           /* Obsolete, "physical" cyls */
        unsigned short  reserved2;      /* reserved (word 2) */
        unsigned short  heads;          /* Obsolete, "physical" heads */
        unsigned short  track_bytes;    /* unformatted bytes per track */
        unsigned short  sector_bytes;   /* unformatted bytes per sector */
        unsigned short  sectors;        /* Obsolete, "physical" sectors per track */
        unsigned short  vendor0;        /* vendor unique */
        unsigned short  vendor1;        /* vendor unique */
        unsigned short  vendor2;        /* Retired vendor unique */
        unsigned char   serial_no[20];  /* 0 = not_specified */
        unsigned short  buf_type;       /* Retired */
        unsigned short  buf_size;       /* Retired, 512 byte increments
                                         * 0 = not_specified
                                         */
        unsigned short  ecc_bytes;      /* for r/w long cmds; 0 = not_specified */
        unsigned char   fw_rev[8];      /* 0 = not_specified */
        unsigned char   model[40];      /* 0 = not_specified */
        unsigned char   max_multsect;   /* 0=not_implemented */
        unsigned char   vendor3;        /* vendor unique */
        unsigned short  dword_io;       /* 0=not_implemented; 1=implemented */
        unsigned char   vendor4;        /* vendor unique */
        unsigned char   capability;     /* (upper byte of word 49)
                                         *  3:  IORDYsup
                                         *  2:  IORDYsw
                                         *  1:  LBA
                                         *  0:  DMA
                                         */
        unsigned short  reserved50;     /* reserved (word 50) */
        unsigned char   vendor5;        /* Obsolete, vendor unique */
        unsigned char   tPIO;           /* Obsolete, 0=slow, 1=medium, 2=fast */
        unsigned char   vendor6;        /* Obsolete, vendor unique */
        unsigned char   tDMA;           /* Obsolete, 0=slow, 1=medium, 2=fast */
        unsigned short  field_valid;    /* (word 53)
                                         *  2:  ultra_ok        word  88
                                         *  1:  eide_ok         words 64-70
                                         *  0:  cur_ok          words 54-58
                                         */
        unsigned short  cur_cyls;       /* Obsolete, logical cylinders */
        unsigned short  cur_heads;      /* Obsolete, l heads */
        unsigned short  cur_sectors;    /* Obsolete, l sectors per track */
        unsigned short  cur_capacity0;  /* Obsolete, l total sectors on drive */
	unsigned short  cur_capacity1;  /* Obsolete, (2 words, misaligned int)     */
        unsigned char   multsect;       /* current multiple sector count */
        unsigned char   multsect_valid; /* when (bit0==1) multsect is ok */
        unsigned int    lba_capacity;   /* Obsolete, total number of sectors */
        unsigned short  dma_1word;      /* Obsolete, single-word dma info */
        unsigned short  dma_mword;      /* multiple-word dma info */
        unsigned short  eide_pio_modes; /* bits 0:mode3 1:mode4 */
        unsigned short  eide_dma_min;   /* min mword dma cycle time (ns) */
        unsigned short  eide_dma_time;  /* recommended mword dma cycle time (ns) */
        unsigned short  eide_pio;       /* min cycle time (ns), no IORDY  */
        unsigned short  eide_pio_iordy; /* min cycle time (ns), with IORDY */
        unsigned short  words69_70[2];  /* reserved words 69-70
                                         * future command overlap and queuing
                                         */
        /* HDIO_GET_IDENTITY currently returns only words 0 through 70 */
        unsigned short  words71_74[4];  /* reserved words 71-74
                                         * for IDENTIFY PACKET DEVICE command
                                         */
        unsigned short  queue_depth;    /* (word 75)
                                         * 15:5 reserved
                                         *  4:0 Maximum queue depth -1
                                         */
        unsigned short  words76_79[4];  /* reserved words 76-79 */
        unsigned short  major_rev_num;  /* (word 80) */
        unsigned short  minor_rev_num;  /* (word 81) */
        unsigned short  command_set_1;  /* (word 82) supported
                                         * 15:  Obsolete
                                         * 14:  NOP command
                                         * 13:  READ_BUFFER
                                         * 12:  WRITE_BUFFER
                                         * 11:  Obsolete
                                         * 10:  Host Protected Area
                                         *  9:  DEVICE Reset
                                         *  8:  SERVICE Interrupt
                                         *  7:  Release Interrupt
                                         *  6:  look-ahead
                                         *  5:  write cache
                                         *  4:  PACKET Command
                                         *  3:  Power Management Feature Set
                                         *  2:  Removable Feature Set
                                         *  1:  Security Feature Set
                                         *  0:  SMART Feature Set
                                         */
	unsigned short  command_set_2;  /* (word 83)
                                         * 15:  Shall be ZERO
                                         * 14:  Shall be ONE
                                         * 13:  FLUSH CACHE EXT
                                         * 12:  FLUSH CACHE
                                         * 11:  Device Configuration Overlay
                                         * 10:  48-bit Address Feature Set
                                         *  9:  Automatic Acoustic Management
                                         *  8:  SET MAX security
                                         *  7:  reserved 1407DT PARTIES
                                         *  6:  SetF sub-command Power-Up
                                         *  5:  Power-Up in Standby Feature Set
                                         *  4:  Removable Media Notification
                                         *  3:  APM Feature Set
                                         *  2:  CFA Feature Set
                                         *  1:  READ/WRITE DMA QUEUED
                                         *  0:  Download MicroCode
                                         */
        unsigned short  cfsse;          /* (word 84)
                                         * cmd set-feature supported extensions
                                         * 15:  Shall be ZERO
                                         * 14:  Shall be ONE
                                         * 13:6 reserved
                                         *  5:  General Purpose Logging
                                         *  4:  Streaming Feature Set
                                         *  3:  Media Card Pass Through
                                         *  2:  Media Serial Number Valid
                                         *  1:  SMART selt-test supported
                                         *  0:  SMART error logging
                                         */
        unsigned short  cfs_enable_1;   /* (word 85)
                                         * command set-feature enabled
                                         * 15:  Obsolete
                                         * 14:  NOP command
                                         * 13:  READ_BUFFER
                                         * 12:  WRITE_BUFFER
                                         * 11:  Obsolete
                                         * 10:  Host Protected Area
                                         *  9:  DEVICE Reset
                                         *  8:  SERVICE Interrupt
                                         *  7:  Release Interrupt
                                         *  6:  look-ahead
                                         *  5:  write cache
                                         *  4:  PACKET Command
					 *  3:  Power Management Feature Set
                                         *  2:  Removable Feature Set
                                         *  1:  Security Feature Set
                                         *  0:  SMART Feature Set
                                         */
        unsigned short  cfs_enable_2;   /* (word 86)
                                         * command set-feature enabled
                                         * 15:  Shall be ZERO
                                         * 14:  Shall be ONE
                                         * 13:  FLUSH CACHE EXT
                                         * 12:  FLUSH CACHE
                                         * 11:  Device Configuration Overlay
                                         * 10:  48-bit Address Feature Set
                                         *  9:  Automatic Acoustic Management
                                         *  8:  SET MAX security
                                         *  7:  reserved 1407DT PARTIES
                                         *  6:  SetF sub-command Power-Up
                                         *  5:  Power-Up in Standby Feature Set
                                         *  4:  Removable Media Notification
                                         *  3:  APM Feature Set
                                         *  2:  CFA Feature Set
                                         *  1:  READ/WRITE DMA QUEUED
                                         *  0:  Download MicroCode
                                         */
        unsigned short  csf_default;    /* (word 87)
                                         * command set-feature default
                                         * 15:  Shall be ZERO
                                         * 14:  Shall be ONE
                                         * 13:6 reserved
                                         *  5:  General Purpose Logging enabled
                                         *  4:  Valid CONFIGURE STREAM executed
                                         *  3:  Media Card Pass Through enabled
                                         *  2:  Media Serial Number Valid
                                         *  1:  SMART selt-test supported
                                         *  0:  SMART error logging
                                         */
        unsigned short  dma_ultra;      /* (word 88) */
        unsigned short  trseuc;         /* time required for security erase */
        unsigned short  trsEuc;         /* time required for enhanced erase */
        unsigned short  CurAPMvalues;   /* current APM values */
        unsigned short  mprc;           /* master password revision code */
        unsigned short  hw_config;      /* hardware config (word 93)
 					 * 15:  Shall be ZERO
                                         * 14:  Shall be ONE
                                         * 13:
                                         * 12:
                                         * 11:
                                         * 10:
                                         *  9:
                                         *  8:
                                         *  7:
                                         *  6:
                                         *  5:
                                         *  4:
                                         *  3:
                                         *  2:
                                         *  1:
                                         *  0:  Shall be ONE
                                         */
        unsigned short  acoustic;       /* (word 94)
                                         * 15:8 Vendor's recommended value
                                         *  7:0 current value
                                         */
        unsigned short  msrqs;          /* min stream request size */
        unsigned short  sxfert;         /* stream transfer time */
        unsigned short  sal;            /* stream access latency */
        unsigned int    spg;            /* stream performance granularity */
        unsigned long long lba_capacity_2;/* 48-bit total number of sectors */
        unsigned short  words104_125[22];/* reserved words 104-125 */
        unsigned short  last_lun;       /* (word 126) */
        unsigned short  word127;        /* (word 127) Feature Set
                                         * Removable Media Notification
                                         * 15:2 reserved
                                         *  1:0 00 = not supported
                                         *      01 = supported
                                         *      10 = reserved
                                         *      11 = reserved
                                         */
        unsigned short  dlf;            /* (word 128)
                                         * device lock function
                                         * 15:9 reserved
                                         *  8   security level 1:max 0:high
                                         *  7:6 reserved
					 *  5   enhanced erase
                                         *  4   expire
                                         *  3   frozen
                                         *  2   locked
                                         *  1   en/disabled
                                         *  0   capability
                                         */
        unsigned short  csfo;           /*  (word 129)
                                         * current set features options
                                         * 15:4 reserved
                                         *  3:  auto reassign
                                         *  2:  reverting
                                         *  1:  read-look-ahead
                                         *  0:  write cache
                                         */
        unsigned short  words130_155[26];/* reserved vendor words 130-155 */
        unsigned short  word156;        /* reserved vendor word 156 */
        unsigned short  words157_159[3];/* reserved vendor words 157-159 */
        unsigned short  cfa_power;      /* (word 160) CFA Power Mode
                                         * 15 word 160 supported
                                         * 14 reserved
                                         * 13
                                         * 12
                                         * 11:0
                                         */
        unsigned short  words161_175[15];/* Reserved for CFA */
        unsigned short  words176_205[30];/* Current Media Serial Number */
        unsigned short  words206_254[49];/* reserved words 206-254 */
        unsigned short  integrity_word; /* (word 255)
                                         * 15:8 Checksum
                                         *  7:0 Signature
                                         */
};

#endif /* __DRIVEID_H__ */

OpenPOWER on IntegriCloud