1/*	$OpenBSD: chio.h,v 1.8 2021/08/31 05:29:55 robert Exp $	*/
2/*	$NetBSD: chio.h,v 1.8 1996/04/03 00:25:21 thorpej Exp $	*/
3
4/*
5 * Copyright (c) 1996 Jason R. Thorpe <thorpej@and.com>
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 *    notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 *    notice, this list of conditions and the following disclaimer in the
15 *    documentation and/or other materials provided with the distribution.
16 * 3. All advertising materials mentioning features or use of this software
17 *    must display the following acknowledgements:
18 *	This product includes software developed by Jason R. Thorpe
19 *	for And Communications, http://www.and.com/
20 * 4. The name of the author may not be used to endorse or promote products
21 *    derived from this software without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
25 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
26 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
27 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
30 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
31 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * SUCH DAMAGE.
34 */
35
36#ifndef _SYS_CHIO_H_
37#define _SYS_CHIO_H_
38
39/*
40 * Element types.  Used as "to" and "from" type indicators in move
41 * and exchange operations.
42 *
43 * Note that code in sys/scsi/ch.c relies on these values (uses them
44 * as offsets in an array, and other evil), so don't muck with them
45 * unless you know what you're doing.
46 */
47#define CHET_MT		0	/* medium transport (picker) */
48#define CHET_ST		1	/* storage transport (slot) */
49#define CHET_IE		2	/* import/export (portal) */
50#define CHET_DT		3	/* data transfer (drive) */
51
52/*
53 * Maximum length of a volume identification string
54 */
55#define CH_VOLTAG_MAXLEN 32
56
57/*
58 * Structure used to execute a MOVE MEDIUM command.
59 */
60struct changer_move {
61	int	cm_fromtype;	/* element type to move from */
62	int	cm_fromunit;	/* logical unit of from element */
63	int	cm_totype;	/* element type to move to */
64	int	cm_tounit;	/* logical unit of to element */
65	int	cm_flags;	/* misc. flags */
66};
67
68/* cm_flags */
69#define CM_INVERT	0x01	/* invert media */
70
71/*
72 * Structure used to execute an EXCHANGE MEDIUM command.  In an
73 * exchange operation, the following steps occur:
74 *
75 *	- media from source is moved to first destination.
76 *
77 *	- media previously occupying first destination is moved
78 *	  to the second destination.
79 *
80 * The second destination may or may not be the same as the source.
81 * In the case of a simple exchange, the source and second destination
82 * are the same.
83 */
84struct changer_exchange {
85	int	ce_srctype;	/* element type of source */
86	int	ce_srcunit;	/* logical unit of source */
87	int	ce_fdsttype;	/* element type of first destination */
88	int	ce_fdstunit;	/* logical unit of first destination */
89	int	ce_sdsttype;	/* element type of second destination */
90	int	ce_sdstunit;	/* logical unit of second destination */
91	int	ce_flags;	/* misc. flags */
92};
93
94/* ce_flags */
95#define CE_INVERT1	0x01	/* invert media 1 */
96#define CE_INVERT2	0x02	/* invert media 2 */
97
98/*
99 * Structure used to execute a POSITION TO ELEMENT command.  This
100 * moves the current picker in front of the specified element.
101 */
102struct changer_position {
103	int	cp_type;	/* element type */
104	int	cp_unit;	/* logical unit of element */
105	int	cp_flags;	/* misc. flags */
106};
107
108/* cp_flags */
109#define CP_INVERT	0x01	/* invert picker */
110
111/*
112 * Data returned by CHIOGPARAMS.
113 */
114struct changer_params {
115	int	cp_curpicker;	/* current picker */
116	int	cp_npickers;	/* number of pickers */
117	int	cp_nslots;	/* number of slots */
118	int	cp_nportals;	/* number of import/export portals */
119	int	cp_ndrives;	/* number of drives */
120};
121
122struct changer_voltag {
123	u_char		cv_volid[CH_VOLTAG_MAXLEN + 1];
124	u_int16_t	cv_serial;
125};
126
127struct changer_element_status {
128	int	 		ces_type;		/* element type */
129	u_int8_t 		ces_flags;		/* flags */
130	u_int16_t		ces_addr;		/* logical element address */
131	u_int8_t		ces_sensecode;	  	/* additional sense code for element */
132	u_int8_t		ces_sensequal;	  	/* additional sense code qualifier */
133	u_int8_t		ces_source_type;  	/*  element type of source address */
134	u_int16_t		ces_source_addr;	/*  source address of medium */
135  	struct changer_voltag	ces_pvoltag;		/* primary voltag */
136	struct changer_voltag	ces_avoltag;		/* alternate voltag */
137};
138
139/*
140 * Command used to get element status.
141 */
142struct changer_element_status_request {
143	int				cesr_type;  /* element type */
144	int				cesr_flags;
145#define CESR_VOLTAGS 0x01
146
147	struct changer_element_status	*cesr_data; /* pre-allocated data storage */
148};
149
150/*
151 * Data returned by CHIOGSTATUS is an array of flags bytes.
152 * Not all flags have meaning for all element types.
153 */
154#define CESTATUS_FULL		0x01	/* element is full */
155#define CESTATUS_IMPEXP		0x02	/* media deposited by operator */
156#define CESTATUS_EXCEPT		0x04	/* element in abnormal state */
157#define CESTATUS_ACCESS		0x08	/* media accessible by picker */
158#define CESTATUS_EXENAB		0x10	/* element supports exporting */
159#define CESTATUS_INENAB		0x20	/* element supports importing */
160
161#define CESTATUS_PICKER_MASK	0x05	/* flags valid for pickers */
162#define CESTATUS_SLOT_MASK	0x0c	/* flags valid for slots */
163#define CESTATUS_PORTAL_MASK	0x3f	/* flags valid for portals */
164#define CESTATUS_DRIVE_MASK	0x0c	/* flags valid for drives */
165
166#define CESTATUS_BITS	\
167	"\20\6INEAB\5EXENAB\4ACCESS\3EXCEPT\2IMPEXP\1FULL"
168
169/*
170 * XXX we have to renumber this since it chashes w/ the
171 * cdio ioctls, O* interface goes away right after 3.3
172 */
173#define CHIOMOVE	_IOW('c', 0x41, struct changer_move)
174#define CHIOEXCHANGE	_IOW('c', 0x42, struct changer_exchange)
175#define CHIOPOSITION	_IOW('c', 0x43, struct changer_position)
176#define CHIOGPICKER	_IOR('c', 0x44, int)
177#define CHIOSPICKER	_IOW('c', 0x45, int)
178#define CHIOGPARAMS	_IOR('c', 0x46, struct changer_params)
179#define CHIOGSTATUS	_IOW('c', 0x48, struct changer_element_status_request)
180
181#endif /* _SYS_CHIO_H_ */
182