xref: /freebsd/sys/cam/scsi/scsi_sa.h (revision f05948d4e98d3abd0965a2994e9e42add6908ff3)
1 /*-
2  * Structure and function declarations for the
3  * SCSI Sequential Access Peripheral driver for CAM.
4  *
5  * SPDX-License-Identifier: BSD-2-Clause
6  *
7  * Copyright (c) 1999, 2000 Matthew Jacob
8  * Copyright (c) 2013, 2014, 2015 Spectra Logic Corporation
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification, immediately at the beginning of the file.
17  * 2. The name of the author may not be used to endorse or promote products
18  *    derived from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
24  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30  * SUCH DAMAGE.
31  *
32  * $FreeBSD$
33  */
34 
35 #ifndef	_SCSI_SCSI_SA_H
36 #define _SCSI_SCSI_SA_H 1
37 
38 #include <sys/cdefs.h>
39 
40 struct scsi_read_block_limits
41 {
42 	uint8_t opcode;
43 	uint8_t byte2;
44 	uint8_t unused[3];
45 	uint8_t control;
46 };
47 
48 struct scsi_read_block_limits_data
49 {
50 	uint8_t gran;
51 #define	RBL_GRAN_MASK	0x1F
52 #define RBL_GRAN(rblim) ((rblim)->gran & RBL_GRAN_MASK)
53 	uint8_t maximum[3];
54 	uint8_t minimum[2];
55 };
56 
57 struct scsi_sa_rw
58 {
59 	uint8_t opcode;
60         uint8_t sli_fixed;
61 #define SAR_SLI		0x02
62 #define SARW_FIXED	0x01
63 	uint8_t length[3];
64         uint8_t control;
65 };
66 
67 struct scsi_load_unload
68 {
69 	uint8_t opcode;
70         uint8_t immediate;
71 #define SLU_IMMED	0x01
72 	uint8_t reserved[2];
73 	uint8_t eot_reten_load;
74 #define SLU_EOT		0x04
75 #define SLU_RETEN	0x02
76 #define SLU_LOAD	0x01
77         uint8_t control;
78 };
79 
80 struct scsi_rewind
81 {
82 	uint8_t opcode;
83         uint8_t immediate;
84 #define SREW_IMMED	0x01
85 	uint8_t reserved[3];
86         uint8_t control;
87 };
88 
89 typedef enum {
90 	SS_BLOCKS,
91 	SS_FILEMARKS,
92 	SS_SEQFILEMARKS,
93 	SS_EOD,
94 	SS_SETMARKS,
95 	SS_SEQSETMARKS
96 } scsi_space_code;
97 
98 struct scsi_space
99 {
100 	uint8_t opcode;
101         uint8_t code;
102 #define SREW_IMMED	0x01
103 	uint8_t count[3];
104         uint8_t control;
105 };
106 
107 struct scsi_write_filemarks
108 {
109 	uint8_t opcode;
110         uint8_t byte2;
111 #define SWFMRK_IMMED	0x01
112 #define SWFMRK_WSMK	0x02
113 	uint8_t num_marks[3];
114         uint8_t control;
115 };
116 
117 /*
118  * Reserve and release unit have the same exact cdb format, but different
119  * opcodes.
120  */
121 struct scsi_reserve_release_unit
122 {
123 	uint8_t opcode;
124 	uint8_t lun_thirdparty;
125 #define SRRU_LUN_MASK	0xE0
126 #define SRRU_3RD_PARTY	0x10
127 #define SRRU_3RD_SHAMT	1
128 #define SRRU_3RD_MASK	0xE
129 	uint8_t reserved[3];
130 	uint8_t control;
131 };
132 
133 /*
134  * Erase a tape
135  */
136 struct scsi_erase
137 {
138 	uint8_t opcode;
139 	uint8_t lun_imm_long;
140 #define SE_LUN_MASK	0xE0
141 #define SE_LONG		0x1
142 #define SE_IMMED	0x2
143 	uint8_t reserved[3];
144 	uint8_t control;
145 };
146 
147 /*
148  * Set tape capacity.
149  */
150 struct scsi_set_capacity
151 {
152 	uint8_t opcode;
153 	uint8_t byte1;
154 #define	SA_SSC_IMMED		0x01
155 	uint8_t reserved;
156 	uint8_t cap_proportion[2];
157 	uint8_t control;
158 };
159 
160 /*
161  * Format tape media.  The CDB opcode is the same as the disk-specific
162  * FORMAT UNIT command, but the fields are different inside the CDB.  Thus
163  * the reason for a separate definition here.
164  */
165 struct scsi_format_medium
166 {
167 	uint8_t opcode;
168 	uint8_t byte1;
169 #define	SFM_IMMED		0x01
170 #define	SFM_VERIFY		0x02
171 	uint8_t byte2;
172 #define	SFM_FORMAT_DEFAULT	0x00
173 #define	SFM_FORMAT_PARTITION	0x01
174 #define	SFM_FORMAT_DEF_PART	0x02
175 #define	SFM_FORMAT_MASK		0x0f
176 	uint8_t length[2];
177 	uint8_t control;
178 };
179 
180 struct scsi_allow_overwrite
181 {
182 	uint8_t opcode;
183 	uint8_t reserved1;
184 	uint8_t allow_overwrite;
185 #define	SAO_ALLOW_OVERWRITE_DISABLED	0x00
186 #define	SAO_ALLOW_OVERWRITE_CUR_POS	0x01
187 #define	SAO_ALLOW_OVERWRITE_FORMAT	0x02
188 	uint8_t partition;
189 	uint8_t logical_id[8];
190 	uint8_t reserved2[3];
191 	uint8_t control;
192 };
193 
194 /*
195  * Dev specific mode page masks.
196  */
197 #define SMH_SA_WP		0x80
198 #define	SMH_SA_BUF_MODE_MASK	0x70
199 #define SMH_SA_BUF_MODE_NOBUF	0x00
200 #define SMH_SA_BUF_MODE_SIBUF	0x10	/* Single-Initiator buffering */
201 #define SMH_SA_BUF_MODE_MIBUF	0x20	/* Multi-Initiator buffering */
202 #define SMH_SA_SPEED_MASK	0x0F
203 #define SMH_SA_SPEED_DEFAULT	0x00
204 
205 /*
206  * Sequential-access specific mode page numbers.
207  */
208 #define SA_DEVICE_CONFIGURATION_PAGE	0x10
209 #define SA_MEDIUM_PARTITION_PAGE_1	0x11
210 #define SA_MEDIUM_PARTITION_PAGE_2	0x12
211 #define SA_MEDIUM_PARTITION_PAGE_3	0x13
212 #define SA_MEDIUM_PARTITION_PAGE_4	0x14
213 #define SA_DATA_COMPRESSION_PAGE	0x0f	/* SCSI-3 */
214 
215 /*
216  * Mode page definitions.
217  */
218 
219 /* See SCSI-II spec 9.3.3.1 */
220 struct scsi_dev_conf_page {
221 	uint8_t pagecode;	/* 0x10 */
222 	uint8_t pagelength;	/* 0x0e */
223 	uint8_t byte2;		/* CAP, CAF, Active Format */
224 	uint8_t active_partition;
225 	uint8_t wb_full_ratio;
226 	uint8_t rb_empty_ratio;
227 	uint8_t wrdelay_time[2];
228 	uint8_t byte8;
229 #define	SA_DBR			0x80	/* data buffer recovery */
230 #define	SA_BIS			0x40	/* block identifiers supported */
231 #define	SA_RSMK			0x20	/* report setmarks */
232 #define	SA_AVC			0x10	/* automatic velocity control */
233 #define	SA_SOCF_MASK		0x0c	/* stop on consecutive formats */
234 #define	SA_RBO			0x02	/* recover buffer order */
235 #define	SA_REW			0x01	/* report early warning */
236 	uint8_t gap_size;
237 	uint8_t byte10;
238 /* from SCSI-3: SSC-4 Working draft (2/14) 8.3.3 */
239 #define	SA_EOD_DEF_MASK		0xe0	/* EOD defined */
240 #define	SA_EEG			0x10	/* Enable EOD Generation */
241 #define	SA_SEW			0x08	/* Synchronize at Early Warning */
242 #define	SA_SOFT_WP		0x04	/* Software Write Protect */
243 #define	SA_BAML			0x02	/* Block Address Mode Lock */
244 #define	SA_BAM			0x01	/* Block Address Mode */
245 	uint8_t ew_bufsize[3];
246 	uint8_t sel_comp_alg;
247 #define	SA_COMP_NONE		0x00
248 #define	SA_COMP_DEFAULT		0x01
249 	/* the following is 'reserved' in SCSI-2 but is defined in SSC-r22 */
250 	uint8_t extra_wp;
251 #define	SA_ASOC_WP		0x04	/* Associated Write Protect */
252 #define	SA_PERS_WP		0x02	/* Persistent Write Protect */
253 #define	SA_PERM_WP		0x01	/* Permanent Write Protect */
254 };
255 
256 /* from SCSI-3: SSC-Rev10 (6/97) */
257 struct scsi_data_compression_page {
258 	uint8_t page_code;	/* 0x0f */
259 	uint8_t page_length;	/* 0x0e */
260 	uint8_t dce_and_dcc;
261 #define SA_DCP_DCE		0x80 	/* Data compression enable */
262 #define SA_DCP_DCC		0x40	/* Data compression capable */
263 	uint8_t dde_and_red;
264 #define SA_DCP_DDE		0x80	/* Data decompression enable */
265 #define SA_DCP_RED_MASK		0x60	/* Report Exception on Decomp. */
266 #define SA_DCP_RED_SHAMT	5
267 #define SA_DCP_RED_0		0x00
268 #define SA_DCP_RED_1		0x20
269 #define SA_DCP_RED_2		0x40
270 	uint8_t comp_algorithm[4];
271 	uint8_t decomp_algorithm[4];
272 	uint8_t reserved[4];
273 };
274 
275 typedef union {
276 	struct { uint8_t pagecode, pagelength; } hdr;
277 	struct scsi_dev_conf_page dconf;
278 	struct scsi_data_compression_page dcomp;
279 } sa_comp_t;
280 
281 /*
282  * Control Data Protection subpage.  This is as defined in SSC3r03.
283  */
284 struct scsi_control_data_prot_subpage {
285 	uint8_t page_code;
286 #define	SA_CTRL_DP_PAGE_CODE		0x0a
287 	uint8_t subpage_code;
288 #define	SA_CTRL_DP_SUBPAGE_CODE		0xf0
289 	uint8_t length[2];
290 	uint8_t prot_method;
291 #define	SA_CTRL_DP_NO_LBP		0x00
292 #define	SA_CTRL_DP_REED_SOLOMON		0x01
293 #define	SA_CTRL_DP_METHOD_MAX		0xff
294 	uint8_t pi_length;
295 #define	SA_CTRL_DP_PI_LENGTH_MASK	0x3f
296 #define	SA_CTRL_DP_RS_LENGTH		4
297 	uint8_t prot_bits;
298 #define	SA_CTRL_DP_LBP_W		0x80
299 #define	SA_CTRL_DP_LBP_R		0x40
300 #define	SA_CTRL_DP_RBDP			0x20
301 	uint8_t reserved[];
302 };
303 
304 /*
305  * This is the Read/Write Control mode page used on IBM Enterprise Tape
306  * Drives.  They are known as 3592, TS, or Jaguar drives.  The SCSI inquiry
307  * data will show a Product ID "03592XXX", where XXX is 'J1A', 'E05' (TS1120),
308  * 'E06' (TS1130), 'E07' (TS1140) or 'E08' (TS1150).
309  *
310  * This page definition is current as of the 3592 SCSI Reference v6,
311  * released on December 16th, 2014.
312  */
313 struct scsi_tape_ibm_rw_control {
314 	uint8_t page_code;
315 #define SA_IBM_RW_CTRL_PAGE_CODE		0x25
316 	uint8_t page_length;
317 	uint8_t ignore_seq_checks;
318 #define	SA_IBM_RW_CTRL_LOC_IGNORE_SEQ		0x04
319 #define	SA_IBM_RW_CTRL_SPC_BLK_IGNORE_SEQ	0x02
320 #define	SA_IBM_RW_CTRL_SPC_FM_IGNORE_SEQ	0x01
321 	uint8_t ignore_data_checks;
322 #define	SA_IBM_RW_CTRL_LOC_IGNORE_DATA		0x04
323 #define	SA_IBM_RW_CTRL_SPC_BLK_IGNORE_DATA	0x02
324 #define	SA_IBM_RW_CTRL_SPC_FM_IGNORE_DATA	0x01
325 	uint8_t reserved1;
326 	uint8_t leop_method;
327 #define	SA_IBM_RW_CTRL_LEOP_DEFAULT		0x00
328 #define	SA_IBM_RW_CTRL_LEOP_MAX_CAP		0x01
329 #define	SA_IBM_RW_CTRL_LEOP_CONST_CAP		0x02
330 	uint8_t leop_ew[2];
331 	uint8_t byte8;
332 #define	SA_IBM_RW_CTRL_DISABLE_FASTSYNC		0x80
333 #define	SA_IBM_RW_CTRL_DISABLE_SKIPSYNC		0x40
334 #define	SA_IBM_RW_CTRL_DISABLE_CROSS_EOD	0x08
335 #define	SA_IBM_RW_CTRL_DISABLE_CROSS_PERM_ERR	0x04
336 #define	SA_IBM_RW_CTRL_REPORT_SEG_EW		0x02
337 #define	SA_IBM_RW_CTRL_REPORT_HOUSEKEEPING_ERR	0x01
338 	uint8_t default_write_dens_bop_0;
339 	uint8_t pending_write_dens_bop_0;
340 	uint8_t reserved2[21];
341 };
342 
343 struct scsi_tape_read_position {
344 	uint8_t opcode;		/* READ_POSITION */
345 	uint8_t byte1;			/* set LSB to read hardware block pos */
346 #define	SA_RPOS_SHORT_FORM	0x00
347 #define	SA_RPOS_SHORT_VENDOR	0x01
348 #define	SA_RPOS_LONG_FORM	0x06
349 #define	SA_RPOS_EXTENDED_FORM	0x08
350 	uint8_t reserved[5];
351 	uint8_t length[2];
352 	uint8_t control;
353 };
354 
355 struct scsi_tape_position_data	{	/* Short Form */
356 	uint8_t flags;
357 #define	SA_RPOS_BOP		0x80	/* Beginning of Partition */
358 #define	SA_RPOS_EOP		0x40	/* End of Partition */
359 #define	SA_RPOS_BCU		0x20	/* Block Count Unknown (SCSI3) */
360 #define	SA_RPOS_BYCU		0x10	/* Byte Count Unknown (SCSI3) */
361 #define	SA_RPOS_BPU		0x04	/* Block Position Unknown */
362 #define	SA_RPOS_PERR		0x02	/* Position Error (SCSI3) */
363 #define	SA_RPOS_BPEW		0x01	/* Beyond Programmable Early Warning */
364 #define	SA_RPOS_UNCERTAIN	SA_RPOS_BPU
365 	uint8_t partition;
366 	uint8_t reserved[2];
367 	uint8_t firstblk[4];
368 	uint8_t lastblk[4];
369 	uint8_t reserved2;
370 	uint8_t nbufblk[3];
371 	uint8_t nbufbyte[4];
372 };
373 
374 struct scsi_tape_position_long_data {
375 	uint8_t flags;
376 #define	SA_RPOS_LONG_BOP	0x80	/* Beginning of Partition */
377 #define	SA_RPOS_LONG_EOP	0x40	/* End of Partition */
378 #define	SA_RPOS_LONG_MPU	0x08	/* Mark Position Unknown */
379 #define	SA_RPOS_LONG_LONU	0x04	/* Logical Object Number Unknown */
380 #define	SA_RPOS_LONG_BPEW	0x01	/* Beyond Programmable Early Warning */
381 	uint8_t reserved[3];
382 	uint8_t partition[4];
383 	uint8_t logical_object_num[8];
384 	uint8_t logical_file_num[8];
385 	uint8_t set_id[8];
386 };
387 
388 struct scsi_tape_position_ext_data {
389 	uint8_t flags;
390 #define	SA_RPOS_EXT_BOP		0x80	/* Beginning of Partition */
391 #define	SA_RPOS_EXT_EOP		0x40	/* End of Partition */
392 #define	SA_RPOS_EXT_LOCU	0x20	/* Logical Object Count Unknown */
393 #define	SA_RPOS_EXT_BYCU	0x10	/* Byte Count Unknown */
394 #define	SA_RPOS_EXT_LOLU	0x04	/* Logical Object Location Unknown */
395 #define	SA_RPOS_EXT_PERR	0x02	/* Position Error */
396 #define	SA_RPOS_EXT_BPEW	0x01	/* Beyond Programmable Early Warning */
397 	uint8_t partition;
398 	uint8_t length[2];
399 	uint8_t reserved;
400 	uint8_t num_objects[3];
401 	uint8_t first_object[8];
402 	uint8_t last_object[8];
403 	uint8_t bytes_in_buffer[8];
404 };
405 
406 struct scsi_tape_locate {
407 	uint8_t opcode;
408 	uint8_t byte1;
409 #define	SA_SPOS_IMMED		0x01
410 #define	SA_SPOS_CP		0x02
411 #define	SA_SPOS_BT		0x04
412 	uint8_t reserved1;
413 	uint8_t blkaddr[4];
414 #define	SA_SPOS_MAX_BLK		0xffffffff
415 	uint8_t reserved2;
416 	uint8_t partition;
417 	uint8_t control;
418 };
419 
420 struct scsi_locate_16 {
421 	uint8_t opcode;
422 	uint8_t byte1;
423 #define	SA_LC_IMMEDIATE		0x01
424 #define	SA_LC_CP		0x02
425 #define	SA_LC_DEST_TYPE_MASK	0x38
426 #define	SA_LC_DEST_TYPE_SHIFT	3
427 #define	SA_LC_DEST_OBJECT	0x00
428 #define	SA_LC_DEST_FILE		0x01
429 #define	SA_LC_DEST_SET		0x02
430 #define	SA_LC_DEST_EOD		0x03
431 	uint8_t byte2;
432 #define	SA_LC_BAM_IMPLICIT	0x00
433 #define	SA_LC_BAM_EXPLICIT	0x01
434 	uint8_t partition;
435 	uint8_t logical_id[8];
436 	uint8_t reserved[3];
437 	uint8_t control;
438 };
439 
440 struct scsi_report_density_support {
441 	uint8_t opcode;
442 	uint8_t byte1;
443 #define	SRDS_MEDIA		0x01
444 #define	SRDS_MEDIUM_TYPE	0x02
445 	uint8_t reserved[5];
446 	uint8_t length[2];
447 #define	SRDS_MAX_LENGTH		0xffff
448 	uint8_t control;
449 };
450 
451 struct scsi_density_hdr {
452 	uint8_t length[2];
453 	uint8_t reserved[2];
454 	uint8_t descriptor[];
455 };
456 
457 struct scsi_density_data {
458 	uint8_t primary_density_code;
459 	uint8_t secondary_density_code;
460 	uint8_t byte2;
461 #define	SDD_DLV			0x01
462 #define	SDD_DEFLT		0x20
463 #define	SDD_DUP			0x40
464 #define SDD_WRTOK		0x80
465 	uint8_t length[2];
466 #define	SDD_DEFAULT_LENGTH	52
467 	uint8_t bits_per_mm[3];
468 	uint8_t media_width[2];
469 	uint8_t tracks[2];
470 	uint8_t capacity[4];
471 	uint8_t assigning_org[8];
472 	uint8_t density_name[8];
473 	uint8_t description[20];
474 };
475 
476 struct scsi_medium_type_data {
477 	uint8_t medium_type;
478 	uint8_t reserved1;
479 	uint8_t length[2];
480 #define	SMTD_DEFAULT_LENGTH	52
481 	uint8_t num_density_codes;
482 	uint8_t primary_density_codes[9];
483 	uint8_t media_width[2];
484 	uint8_t medium_length[2];
485 	uint8_t reserved2[2];
486 	uint8_t assigning_org[8];
487 	uint8_t medium_type_name[8];
488 	uint8_t description[20];
489 };
490 
491 /*
492  * Manufacturer-assigned Serial Number VPD page.
493  * Current as of SSC-5r03, 28 September 2016.
494  */
495 struct scsi_vpd_mfg_serial_number
496 {
497 	uint8_t device;
498 	uint8_t page_code;
499 #define	SVPD_MFG_SERIAL_NUMBER_PAGE_CODE 0xB1
500 	uint8_t page_length[2];
501 	uint8_t mfg_serial_num[];
502 };
503 
504 /*
505  * Security Protocol Specific values for the Tape Data Encryption protocol
506  * (0x20) used with SECURITY PROTOCOL IN.  See below for values used with
507  * SECURITY PROTOCOL OUT.  Current as of SSC4r03.
508  */
509 #define	TDE_IN_SUPPORT_PAGE		0x0000
510 #define	TDE_OUT_SUPPORT_PAGE		0x0001
511 #define	TDE_DATA_ENC_CAP_PAGE		0x0010
512 #define	TDE_SUPPORTED_KEY_FORMATS_PAGE	0x0011
513 #define	TDE_DATA_ENC_MAN_CAP_PAGE	0x0012
514 #define	TDE_DATA_ENC_STATUS_PAGE	0x0020
515 #define	TDE_NEXT_BLOCK_ENC_STATUS_PAGE	0x0021
516 #define	TDE_GET_ENC_MAN_ATTR_PAGE	0x0022
517 #define	TDE_RANDOM_NUM_PAGE		0x0030
518 #define	TDE_KEY_WRAP_PK_PAGE		0x0031
519 
520 /*
521  * Tape Data Encryption protocol pages used with SECURITY PROTOCOL IN and
522  * SECURITY PROTOCOL OUT.
523  */
524 /*
525  * Tape Data Encryption In Support page (0x0000).
526  */
527 struct tde_in_support_page {
528 	uint8_t page_code[2];
529 	uint8_t page_length[2];
530 	uint8_t page_codes[];
531 };
532 
533 /*
534  * Tape Data Encryption Out Support page (0x0001).
535  */
536 struct tde_out_support_page {
537 	uint8_t page_code[2];
538 	uint8_t page_length[2];
539 	uint8_t page_codes[];
540 };
541 
542 /*
543  * Logical block encryption algorithm descriptor.  This is reported in the
544  * Data Encryption Capabilities page.
545  */
546 struct tde_block_enc_alg_desc {
547 	uint8_t alg_index;
548 	uint8_t reserved1;
549 	uint8_t desc_length[2];
550 	uint8_t byte4;
551 #define	TDE_BEA_AVFMV			0x80
552 #define	TDE_BEA_SDK_C			0x40
553 #define	TDE_BEA_MAC_C			0x20
554 #define	TDE_BEA_DELB_C			0x10
555 #define	TDE_BEA_DECRYPT_C_MASK		0x0c
556 #define	TDE_BEA_DECRYPT_C_EXT		0x0c
557 #define	TDE_BEA_DECRYPT_C_HARD		0x08
558 #define	TDE_BEA_DECRYPT_C_SOFT		0x04
559 #define	TDE_BEA_DECRYPT_C_NO_CAP	0x00
560 #define	TDE_BEA_ENCRYPT_C_MASK		0x03
561 #define	TDE_BEA_ENCRYPT_C_EXT		0x03
562 #define	TDE_BEA_ENCRYPT_C_HARD		0x02
563 #define	TDE_BEA_ENCRYPT_C_SOFT		0x01
564 #define	TDE_BEA_ENCRYPT_C_NO_CAP	0x00
565 	uint8_t byte5;
566 #define	TDE_BEA_AVFCLP_MASK		0xc0
567 #define	TDE_BEA_AVFCLP_VALID		0x80
568 #define	TDE_BEA_AVFCLP_NOT_VALID	0x40
569 #define	TDE_BEA_AVFCLP_NOT_APP		0x00
570 #define	TDE_BEA_NONCE_C_MASK		0x30
571 #define	TDE_BEA_NONCE_C_SUPPORTED	0x30
572 #define	TDE_BEA_NONCE_C_PROVIDED	0x20
573 #define	TDE_BEA_NONCE_C_GENERATED	0x10
574 #define	TDE_BEA_NONCE_C_NOT_REQUIRED	0x00
575 #define	TDE_BEA_KADF_C			0x08
576 #define	TDE_BEA_VCELB_C			0x04
577 #define	TDE_BEA_UKADF			0x02
578 #define	TDE_BEA_AKADF			0x01
579 	uint8_t max_unauth_key_bytes[2];
580 	uint8_t max_auth_key_bytes[2];
581 	uint8_t lbe_key_size[2];
582 	uint8_t byte12;
583 #define	TDE_BEA_DKAD_C_MASK		0xc0
584 #define	TDE_BEA_DKAD_C_CAPABLE		0xc0
585 #define	TDE_BEA_DKAD_C_NOT_ALLOWED	0x80
586 #define	TDE_BEA_DKAD_C_REQUIRED		0x40
587 #define	TDE_BEA_EEMC_C_MASK		0x30
588 #define	TDE_BEA_EEMC_C_ALLOWED		0x20
589 #define	TDE_BEA_EEMC_C_NOT_ALLOWED	0x10
590 #define	TDE_BEA_EEMC_C_NOT_SPECIFIED	0x00
591 	/*
592 	 * Raw Decryption Mode Control Capabilities (RDMC_C) field.  The
593 	 * descriptions are too complex to represent as a simple name.
594 	 */
595 #define	TDE_BEA_RDMC_C_MASK		0x0e
596 #define	TDE_BEA_RDMC_C_MODE_7		0x0e
597 #define	TDE_BEA_RDMC_C_MODE_6		0x0c
598 #define	TDE_BEA_RDMC_C_MODE_5		0x0a
599 #define	TDE_BEA_RDMC_C_MODE_4		0x08
600 #define	TDE_BEA_RDMC_C_MODE_1		0x02
601 #define	TDE_BEA_EAREM			0x01
602 	uint8_t byte13;
603 #define	TDE_BEA_MAX_EEDKS_MASK		0x0f
604 	uint8_t msdk_count[2];
605 	uint8_t max_eedk_size[2];
606 	uint8_t reserved2[2];
607 	uint8_t security_algo_code[4];
608 };
609 
610 /*
611  * Data Encryption Capabilities page (0x0010).
612  */
613 struct tde_data_enc_cap_page {
614 	uint8_t page_code[2];
615 	uint8_t page_length;
616 	uint8_t byte4;
617 #define	DATA_ENC_CAP_EXTDECC_MASK		0x0c
618 #define	DATA_ENC_CAP_EXTDECC_NOT_REPORTED	0x00
619 #define	DATA_ENC_CAP_EXTDECC_NOT_CAPABLE	0x04
620 #define	DATA_ENC_CAP_EXTDECC_CAPABLE		0x08
621 #define	DATA_ENC_CAP_CFG_P_MASK			0x03
622 #define	DATA_ENC_CAP_CFG_P_NOT_REPORTED		0x00
623 #define	DATA_ENC_CAP_CFG_P_ALLOWED		0x01
624 #define	DATA_ENC_CAP_CFG_P_NOT_ALLOWED		0x02
625 	uint8_t reserved[15];
626 	struct tde_block_enc_alg_desc alg_descs[];
627 };
628 
629 /*
630  * Tape Data Encryption Supported Key Formats page (0x0011).
631  */
632 struct tde_supported_key_formats_page {
633 	uint8_t page_code[2];
634 	uint8_t page_length[2];
635 	uint8_t key_formats_list[];
636 };
637 
638 /*
639  * Tape Data Encryption Management Capabilities page (0x0012).
640  */
641 struct tde_data_enc_man_cap_page {
642 	uint8_t page_code[2];
643 	uint8_t page_length[2];
644 	uint8_t byte4;
645 #define	TDE_DEMC_LOCK_C		0x01
646 	uint8_t byte5;
647 #define	TDE_DEMC_CKOD_C		0x04
648 #define	TDE_DEMC_CKORP_C	0x02
649 #define	TDE_DEMC_CKORL_C	0x01
650 	uint8_t reserved1;
651 	uint8_t byte7;
652 #define	TDE_DEMC_AITN_C		0x04
653 #define	TDE_DEMC_LOCAL_C	0x02
654 #define	TDE_DEMC_PUBLIC_C	0x01
655 	uint8_t reserved2[8];
656 };
657 
658 /*
659  * Tape Data Encryption Status Page (0x0020).
660  */
661 struct tde_data_enc_status_page {
662 	uint8_t page_code[2];
663 	uint8_t page_length[2];
664 	uint8_t scope;
665 #define	TDE_DES_IT_NEXUS_SCOPE_MASK	0xe0
666 #define	TDE_DES_LBE_SCOPE_MASK		0x07
667 	uint8_t encryption_mode;
668 	uint8_t decryption_mode;
669 	uint8_t algo_index;
670 	uint8_t key_instance_counter[4];
671 	uint8_t byte12;
672 #define	TDE_DES_PARAM_CTRL_MASK		0x70
673 #define	TDE_DES_PARAM_CTRL_MGMT		0x40
674 #define	TDE_DES_PARAM_CTRL_CHANGER	0x30
675 #define	TDE_DES_PARAM_CTRL_DRIVE	0x20
676 #define	TDE_DES_PARAM_CTRL_EXT		0x10
677 #define	TDE_DES_PARAM_CTRL_NOT_REPORTED	0x00
678 #define	TDE_DES_VCELB			0x08
679 #define	TDE_DES_CEEMS_MASK		0x06
680 #define	TDE_DES_RDMD			0x01
681 	uint8_t enc_params_kad_format;
682 	uint8_t asdk_count[2];
683 	uint8_t reserved[8];
684 	uint8_t key_assoc_data_desc[];
685 };
686 
687 /*
688  * Tape Data Encryption Next Block Encryption Status page (0x0021).
689  */
690 struct tde_next_block_enc_status_page {
691 	uint8_t page_code[2];
692 	uint8_t page_length[2];
693 	uint8_t logical_obj_number[8];
694 	uint8_t status;
695 #define	TDE_NBES_COMP_STATUS_MASK	0xf0
696 #define	TDE_NBES_COMP_INCAPABLE		0x00
697 #define	TDE_NBES_COMP_NOT_YET		0x10
698 #define	TDE_NBES_COMP_NOT_A_BLOCK	0x20
699 #define	TDE_NBES_COMP_NOT_COMPRESSED	0x30
700 #define	TDE_NBES_COMP_COMPRESSED	0x40
701 #define	TDE_NBES_ENC_STATUS_MASK	0x0f
702 #define	TDE_NBES_ENC_INCAPABLE		0x00
703 #define	TDE_NBES_ENC_NOT_YET		0x01
704 #define	TDE_NBES_ENC_NOT_A_BLOCK	0x02
705 #define	TDE_NBES_ENC_NOT_ENCRYPTED	0x03
706 #define	TDE_NBES_ENC_ALG_NOT_SUPPORTED	0x04
707 #define	TDE_NBES_ENC_SUPPORTED_ALG	0x05
708 #define	TDE_NBES_ENC_NO_KEY		0x06
709 	uint8_t algo_index;
710 	uint8_t byte14;
711 #define	TDE_NBES_EMES			0x02
712 #define	TDE_NBES_RDMDS			0x01
713 	uint8_t next_block_kad_format;
714 	uint8_t key_assoc_data_desc[];
715 };
716 
717 /*
718  * Tape Data Encryption Get Encryption Management Attributes page (0x0022).
719  */
720 struct tde_get_enc_man_attr_page {
721 	uint8_t page_code[2];
722 	uint8_t reserved[3];
723 	uint8_t byte5;
724 #define	TDE_GEMA_CAOD			0x01
725 	uint8_t page_length[2];
726 	uint8_t enc_mgmt_attr_desc[];
727 };
728 
729 /*
730  * Tape Data Encryption Random Number page (0x0030).
731  */
732 struct tde_random_num_page {
733 	uint8_t page_code[2];
734 	uint8_t page_length[2];
735 	uint8_t random_number[32];
736 };
737 
738 /*
739  * Tape Data Encryption Device Server Key Wrapping Public Key page (0x0031).
740  */
741 struct tde_key_wrap_pk_page {
742 	uint8_t page_code[2];
743 	uint8_t page_length[2];
744 	uint8_t public_key_type[4];
745 	uint8_t public_key_format[4];
746 	uint8_t public_key_length[2];
747 	uint8_t public_key[];
748 };
749 
750 /*
751  * Security Protocol Specific values for the Tape Data Encryption protocol
752  * (0x20) used with SECURITY PROTOCOL OUT.  See above for values used with
753  * SECURITY PROTOCOL IN.  Current as of SSCr03.
754  */
755 #define	TDE_SET_DATA_ENC_PAGE		0x0010
756 #define	TDE_SA_ENCAP_PAGE		0x0011
757 #define	TDE_SET_ENC_MGMT_ATTR_PAGE	0x0022
758 
759 /*
760  * Tape Data Encryption Set Data Encryption page (0x0010).
761  */
762 struct tde_set_data_enc_page {
763 	uint8_t page_code[2];
764 	uint8_t page_length[2];
765 	uint8_t byte4;
766 #define	TDE_SDE_SCOPE_MASK		0xe0
767 #define	TDE_SDE_SCOPE_ALL_IT_NEXUS	0x80
768 #define	TDE_SDE_SCOPE_LOCAL		0x40
769 #define	TDE_SDE_SCOPE_PUBLIC		0x00
770 #define	TDE_SDE_LOCK			0x01
771 	uint8_t byte5;
772 #define	TDE_SDE_CEEM_MASK		0xc0
773 #define	TDE_SDE_CEEM_ENCRYPT		0xc0
774 #define	TDE_SDE_CEEM_EXTERNAL		0x80
775 #define	TDE_SDE_CEEM_NO_CHECK		0x40
776 #define	TDE_SDE_RDMC_MASK		0x30
777 #define	TDE_SDE_RDMC_DISABLED		0x30
778 #define	TDE_SDE_RDMC_ENABLED		0x20
779 #define	TDE_SDE_RDMC_DEFAULT		0x00
780 #define	TDE_SDE_SDK			0x08
781 #define	TDE_SDE_CKOD			0x04
782 #define	TDE_SDE_CKORP			0x02
783 #define	TDE_SDE_CKORL			0x01
784 	uint8_t encryption_mode;
785 #define	TDE_SDE_ENC_MODE_DISABLE	0x00
786 #define	TDE_SDE_ENC_MODE_EXTERNAL	0x01
787 #define	TDE_SDE_ENC_MODE_ENCRYPT	0x02
788 	uint8_t decryption_mode;
789 #define	TDE_SDE_DEC_MODE_DISABLE	0x00
790 #define	TDE_SDE_DEC_MODE_RAW		0x01
791 #define	TDE_SDE_DEC_MODE_DECRYPT	0x02
792 #define	TDE_SDE_DEC_MODE_MIXED		0x03
793 	uint8_t algo_index;
794 	uint8_t lbe_key_format;
795 #define	TDE_SDE_KEY_PLAINTEXT		0x00
796 #define	TDE_SDE_KEY_VENDOR_SPEC		0x01
797 #define	TDE_SDE_KEY_PUBLIC_WRAP		0x02
798 #define	TDE_SDE_KEY_ESP_SCSI		0x03
799 	uint8_t kad_format;
800 #define	TDE_SDE_KAD_ASCII		0x02
801 #define	TDE_SDE_KAD_BINARY		0x01
802 #define	TDE_SDE_KAD_UNSPECIFIED		0x00
803 	uint8_t reserved[7];
804 	uint8_t lbe_key_length[2];
805 	uint8_t lbe_key[];
806 };
807 
808 /*
809  * Used for the Vendor Specific key format (0x01).
810  */
811 struct tde_key_format_vendor {
812 	uint8_t t10_vendor_id[8];
813 	uint8_t vendor_key[];
814 };
815 
816 /*
817  * Used for the public key wrapped format (0x02).
818  */
819 struct tde_key_format_public_wrap {
820 	uint8_t parameter_set[2];
821 #define	TDE_PARAM_SET_RSA2048		0x0000
822 #define	TDE_PARAM_SET_ECC521		0x0010
823 	uint8_t label_length[2];
824 	uint8_t label[];
825 };
826 
827 /*
828  * Tape Data Encryption SA Encapsulation page (0x0011).
829  */
830 struct tde_sa_encap_page {
831 	uint8_t page_code[2];
832 	uint8_t data_desc[];
833 };
834 
835 /*
836  * Tape Data Encryption Set Encryption Management Attributes page (0x0022).
837  */
838 struct tde_set_enc_mgmt_attr_page {
839 	uint8_t page_code[2];
840 	uint8_t reserved[3];
841 	uint8_t byte5;
842 #define	TDE_SEMA_CAOD			0x01
843 	uint8_t page_length[2];
844 	uint8_t attr_desc[];
845 };
846 
847 /*
848  * Tape Data Encryption descriptor format.
849  * SSC4r03 Section 8.5.4.2.1 Table 197
850  */
851 struct tde_data_enc_desc {
852 	uint8_t key_desc_type;
853 #define	TDE_KEY_DESC_WK_KAD		0x04
854 #define	TDE_KEY_DESC_M_KAD		0x03
855 #define	TDE_KEY_DESC_NONCE_VALUE	0x02
856 #define	TDE_KEY_DESC_A_KAD		0x01
857 #define	TDE_KEY_DESC_U_KAD		0x00
858 	uint8_t byte2;
859 #define	TDE_KEY_DESC_AUTH_MASK		0x07
860 #define	TDE_KEY_DESC_AUTH_FAILED	0x04
861 #define	TDE_KEY_DESC_AUTH_SUCCESS	0x03
862 #define	TDE_KEY_DESC_AUTH_NO_ATTEMPT	0x02
863 #define	TDE_KEY_DESC_AUTH_U_KAD		0x01
864 	uint8_t key_desc_length[2];
865 	uint8_t key_desc[];
866 };
867 
868 /*
869  * Wrapped Key descriptor format.
870  * SSC4r03 Section 8.5.4.3.1 Table 200
871  */
872 struct tde_wrapped_key_desc {
873 	uint8_t wrapped_key_type;
874 #define	TDE_WRAP_KEY_DESC_LENGTH	0x04
875 #define	TDE_WRAP_KEY_DESC_IDENT		0x03
876 #define	TDE_WRAP_KEY_DESC_INFO		0x02
877 #define	TDE_WRAP_KEY_DESC_ENTITY_ID	0x01
878 #define	TDE_WRAP_KEY_DESC_DEVICE_ID	0x00
879 	uint8_t reserved;
880 	uint8_t wrapped_desc_length[2];
881 	uint8_t wrapped_desc[];
882 };
883 
884 /*
885  * Encryption management attributes descriptor format.
886  * SSC4r03 Section 8.5.4.4.1 Table 202
887  */
888 struct tde_enc_mgmt_attr_desc {
889 	uint8_t enc_mgmt_attr_type[2];
890 #define	TDE_EMAD_DESIRED_KEY_MGR_OP	0x0000
891 #define	TDE_EMAD_LOG_BLOCK_ENC_KEY_CRIT	0x0001
892 #define	TDE_EMAD_LOG_BLOCK_ENC_KEY_WRAP	0x0002
893 	uint8_t reserved;
894 	uint8_t byte2;
895 #define	TDE_EMAD_CRIT			0x80
896 	uint8_t attr_length[2];
897 	uint8_t attributes[];
898 #define	TDE_EMAD_DESIRED_KEY_CREATE	0x0001
899 #define	TDE_EMAD_DESIRED_KEY_RESOLVE	0x0002
900 };
901 
902 /*
903  * Logical block encryption key selection criteria descriptor format.
904  * SSC4r03 Section 8.5.4.4.3.1 Table 206
905  */
906 struct tde_lb_enc_key_sel_desc {
907 	uint8_t lbe_key_sel_crit_type[2];
908 	/*
909 	 * The CRIT bit is the top bit of the first byte of the type.
910 	 */
911 #define	TDE_LBE_KEY_SEL_CRIT		0x80
912 #define	TDE_LBE_KEY_SEL_ALGO		0x0001
913 #define	TDE_LBE_KEY_SEL_ID		0x0002
914 	uint8_t lbe_key_sel_crit_length[2];
915 	uint8_t lbe_key_sel_crit[];
916 };
917 
918 /*
919  * Logical block encryption key wrapping attribute descriptor format.
920  * SSC4r03 Section 8.5.4.4.4.1 Table 209
921  */
922 struct tde_lb_enc_key_wrap_desc {
923 	uint8_t lbe_key_wrap_type[2];
924 	/*
925 	 * The CRIT bit is the top bit of the first byte of the type.
926 	 */
927 #define	TDE_LBE_KEY_WRAP_CRIT		0x80
928 #define	TDE_LBE_KEY_WRAP_KEKS		0x0001
929 	uint8_t lbe_key_wrap_length[2];
930 	uint8_t lbe_key_wrap_attr[];
931 };
932 
933 /*
934  * Opcodes
935  */
936 #define REWIND			0x01
937 #define FORMAT_MEDIUM		0x04
938 #define READ_BLOCK_LIMITS	0x05
939 #define SA_READ			0x08
940 #define SA_WRITE		0x0A
941 #define SET_CAPACITY		0x0B
942 #define WRITE_FILEMARKS		0x10
943 #define SPACE			0x11
944 #define RESERVE_UNIT		0x16
945 #define RELEASE_UNIT		0x17
946 #define ERASE			0x19
947 #define LOAD_UNLOAD		0x1B
948 #define	LOCATE			0x2B
949 #define	READ_POSITION		0x34
950 #define	REPORT_DENSITY_SUPPORT	0x44
951 #define	ALLOW_OVERWRITE		0x82
952 #define	LOCATE_16		0x92
953 
954 /*
955  * Tape specific density codes- only enough of them here to recognize
956  * some specific older units so we can choose 2FM@EOD or FIXED blocksize
957  * quirks.
958  */
959 #define SCSI_DENSITY_HALFINCH_800	0x01
960 #define SCSI_DENSITY_HALFINCH_1600	0x02
961 #define SCSI_DENSITY_HALFINCH_6250	0x03
962 #define SCSI_DENSITY_HALFINCH_6250C	0xC3	/* HP Compressed 6250 */
963 #define SCSI_DENSITY_QIC_11_4TRK	0x04
964 #define SCSI_DENSITY_QIC_11_9TRK	0x84	/* Vendor Unique Emulex */
965 #define SCSI_DENSITY_QIC_24		0x05
966 #define SCSI_DENSITY_HALFINCH_PE	0x06
967 #define SCSI_DENSITY_QIC_120		0x0f
968 #define SCSI_DENSITY_QIC_150		0x10
969 #define	SCSI_DENSITY_QIC_525_320	0x11
970 #define	SCSI_DENSITY_QIC_1320		0x12
971 #define	SCSI_DENSITY_QIC_2GB		0x22
972 #define	SCSI_DENSITY_QIC_4GB		0x26
973 #define	SCSI_DENSITY_QIC_3080		0x29
974 
975 __BEGIN_DECLS
976 void	scsi_read_block_limits(struct ccb_scsiio *, uint32_t,
977 			       void (*cbfcnp)(struct cam_periph *, union ccb *),
978 			       uint8_t, struct scsi_read_block_limits_data *,
979 			       uint8_t , uint32_t);
980 
981 void	scsi_sa_read_write(struct ccb_scsiio *csio, uint32_t retries,
982 			   void (*cbfcnp)(struct cam_periph *, union ccb *),
983 			   uint8_t tag_action, int readop, int sli,
984 			   int fixed, uint32_t length, uint8_t *data_ptr,
985 			   uint32_t dxfer_len, uint8_t sense_len,
986 			   uint32_t timeout);
987 
988 void	scsi_rewind(struct ccb_scsiio *csio, uint32_t retries,
989 		    void (*cbfcnp)(struct cam_periph *, union ccb *),
990 		    uint8_t tag_action, int immediate, uint8_t sense_len,
991 		    uint32_t timeout);
992 
993 void	scsi_space(struct ccb_scsiio *csio, uint32_t retries,
994 		   void (*cbfcnp)(struct cam_periph *, union ccb *),
995 		   uint8_t tag_action, scsi_space_code code,
996 		   uint32_t count, uint8_t sense_len, uint32_t timeout);
997 
998 void	scsi_load_unload(struct ccb_scsiio *csio, uint32_t retries,
999 			 void (*cbfcnp)(struct cam_periph *, union ccb *),
1000 			 uint8_t tag_action, int immediate,   int eot,
1001 			 int reten, int load, uint8_t sense_len,
1002 			 uint32_t timeout);
1003 
1004 void	scsi_write_filemarks(struct ccb_scsiio *csio, uint32_t retries,
1005 			     void (*cbfcnp)(struct cam_periph *, union ccb *),
1006 			     uint8_t tag_action, int immediate, int setmark,
1007 			     uint32_t num_marks, uint8_t sense_len,
1008 			     uint32_t timeout);
1009 
1010 void	scsi_reserve_release_unit(struct ccb_scsiio *csio, uint32_t retries,
1011 				  void (*cbfcnp)(struct cam_periph *,
1012 				  union ccb *), uint8_t tag_action,
1013 				  int third_party, int third_party_id,
1014 				  uint8_t sense_len, uint32_t timeout,
1015 				  int reserve);
1016 
1017 void	scsi_erase(struct ccb_scsiio *csio, uint32_t retries,
1018 		   void (*cbfcnp)(struct cam_periph *, union ccb *),
1019 		   uint8_t tag_action, int immediate, int long_erase,
1020 		   uint8_t sense_len, uint32_t timeout);
1021 
1022 void	scsi_data_comp_page(struct scsi_data_compression_page *page,
1023 			    uint8_t dce, uint8_t dde, uint8_t red,
1024 			    uint32_t comp_algorithm,
1025 			    uint32_t decomp_algorithm);
1026 
1027 void	scsi_read_position(struct ccb_scsiio *csio, uint32_t retries,
1028                            void (*cbfcnp)(struct cam_periph *, union ccb *),
1029                            uint8_t tag_action, int hardsoft,
1030                            struct scsi_tape_position_data *sbp,
1031                            uint8_t sense_len, uint32_t timeout);
1032 void	scsi_read_position_10(struct ccb_scsiio *csio, uint32_t retries,
1033 			      void (*cbfcnp)(struct cam_periph *, union ccb *),
1034 			      uint8_t tag_action, int service_action,
1035 			      uint8_t *data_ptr, uint32_t length,
1036 			      uint32_t sense_len, uint32_t timeout);
1037 
1038 void	scsi_set_position(struct ccb_scsiio *csio, uint32_t retries,
1039                          void (*cbfcnp)(struct cam_periph *, union ccb *),
1040                          uint8_t tag_action, int hardsoft, uint32_t blkno,
1041                          uint8_t sense_len, uint32_t timeout);
1042 
1043 void	scsi_locate_10(struct ccb_scsiio *csio, uint32_t retries,
1044 		       void (*cbfcnp)(struct cam_periph *, union ccb *),
1045 		       uint8_t tag_action, int immed, int cp, int hard,
1046 		       int64_t partition, uint32_t block_address,
1047 		       int sense_len, uint32_t timeout);
1048 
1049 void	scsi_locate_16(struct ccb_scsiio *csio, uint32_t retries,
1050 		       void (*cbfcnp)(struct cam_periph *, union ccb *),
1051 		       uint8_t tag_action, int immed, int cp,
1052 		       uint8_t dest_type, int bam, int64_t partition,
1053 		       uint64_t logical_id, int sense_len,
1054 		       uint32_t timeout);
1055 
1056 void	scsi_report_density_support(struct ccb_scsiio *csio, uint32_t retries,
1057 				    void (*cbfcnp)(struct cam_periph *,
1058 						   union ccb *),
1059 				    uint8_t tag_action, int media,
1060 				    int medium_type, uint8_t *data_ptr,
1061 				    uint32_t length, uint32_t sense_len,
1062 				    uint32_t timeout);
1063 
1064 void	scsi_set_capacity(struct ccb_scsiio *csio, uint32_t retries,
1065 			  void (*cbfcnp)(struct cam_periph *, union ccb *),
1066 			  uint8_t tag_action, int byte1, uint32_t proportion,
1067 			  uint32_t sense_len, uint32_t timeout);
1068 
1069 void	scsi_format_medium(struct ccb_scsiio *csio, uint32_t retries,
1070 			   void (*cbfcnp)(struct cam_periph *, union ccb *),
1071 			   uint8_t tag_action, int byte1, int byte2,
1072 			   uint8_t *data_ptr, uint32_t length,
1073 			   uint32_t sense_len, uint32_t timeout);
1074 
1075 void	scsi_allow_overwrite(struct ccb_scsiio *csio, uint32_t retries,
1076 			     void (*cbfcnp)(struct cam_periph *, union ccb *),
1077 			     uint8_t tag_action, int allow_overwrite,
1078 			     int partition, uint64_t logical_id,
1079 			     uint32_t sense_len, uint32_t timeout);
1080 
1081 __END_DECLS
1082 
1083 #endif /* _SCSI_SCSI_SA_H */
1084