1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
3 * ioctl interface for the scsi media changer driver
6 #ifndef _UAPI_LINUX_CHIO_H
7 #define _UAPI_LINUX_CHIO_H
9 /* changer element types */
10 #define CHET_MT 0 /* media transport element (robot) */
11 #define CHET_ST 1 /* storage element (media slots) */
12 #define CHET_IE 2 /* import/export element */
13 #define CHET_DT 3 /* data transfer element (tape/cdrom/whatever) */
14 #define CHET_V1 4 /* vendor specific #1 */
15 #define CHET_V2 5 /* vendor specific #2 */
16 #define CHET_V3 6 /* vendor specific #3 */
17 #define CHET_V4 7 /* vendor specific #4 */
22 * query changer properties
25 * query vendor-specific element types
27 * accessing elements works by specifing type and unit of the element.
28 * for example, storage elements are addressed with type = CHET_ST and
29 * unit = 0 .. cp_nslots-1
32 struct changer_params
{
33 int cp_curpicker
; /* current transport element */
34 int cp_npickers
; /* number of transport elements (CHET_MT) */
35 int cp_nslots
; /* number of storage elements (CHET_ST) */
36 int cp_nportals
; /* number of import/export elements (CHET_IE) */
37 int cp_ndrives
; /* number of data transfer elements (CHET_DT) */
39 struct changer_vendor_params
{
40 int cvp_n1
; /* number of vendor specific elems (CHET_V1) */
42 int cvp_n2
; /* number of vendor specific elems (CHET_V2) */
44 int cvp_n3
; /* number of vendor specific elems (CHET_V3) */
46 int cvp_n4
; /* number of vendor specific elems (CHET_V4) */
54 * move a medium from one element to another
57 int cm_fromtype
; /* type/unit of source element */
59 int cm_totype
; /* type/unit of destination element */
63 #define CM_INVERT 1 /* flag: rotate media (for double-sided like MOD) */
68 * move one medium from element #1 to element #2,
69 * and another one from element #2 to element #3.
70 * element #1 and #3 are allowed to be identical.
72 struct changer_exchange
{
73 int ce_srctype
; /* type/unit of element #1 */
75 int ce_fdsttype
; /* type/unit of element #2 */
77 int ce_sdsttype
; /* type/unit of element #3 */
87 * move the transport element (robot arm) to a specific element.
89 struct changer_position
{
99 * get element status for all elements of a specific type
101 struct changer_element_status
{
103 unsigned char __user
*ces_data
;
105 #define CESTATUS_FULL 0x01 /* full */
106 #define CESTATUS_IMPEXP 0x02 /* media was imported (inserted by sysop) */
107 #define CESTATUS_EXCEPT 0x04 /* error condition */
108 #define CESTATUS_ACCESS 0x08 /* access allowed */
109 #define CESTATUS_EXENAB 0x10 /* element can export media */
110 #define CESTATUS_INENAB 0x20 /* element can import media */
115 * get more detailed status information for a single element
117 struct changer_get_element
{
118 int cge_type
; /* type/unit */
120 int cge_status
; /* status */
121 int cge_errno
; /* errno */
122 int cge_srctype
; /* source element of the last move/exchange */
124 int cge_id
; /* scsi id (for data transfer elements) */
125 int cge_lun
; /* scsi lun (for data transfer elements) */
126 char cge_pvoltag
[36]; /* primary volume tag */
127 char cge_avoltag
[36]; /* alternate volume tag */
131 #define CGE_ERRNO 0x01 /* errno available */
132 #define CGE_INVERT 0x02 /* media inverted */
133 #define CGE_SRC 0x04 /* media src available */
134 #define CGE_IDLUN 0x08 /* ID+LUN available */
135 #define CGE_PVOLTAG 0x10 /* primary volume tag available */
136 #define CGE_AVOLTAG 0x20 /* alternate volume tag available */
143 struct changer_set_voltag
{
144 int csv_type
; /* type/unit */
146 char csv_voltag
[36]; /* volume tag */
149 #define CSV_PVOLTAG 0x01 /* primary volume tag */
150 #define CSV_AVOLTAG 0x02 /* alternate volume tag */
151 #define CSV_CLEARTAG 0x04 /* clear volume tag */
154 #define CHIOMOVE _IOW('c', 1,struct changer_move)
155 #define CHIOEXCHANGE _IOW('c', 2,struct changer_exchange)
156 #define CHIOPOSITION _IOW('c', 3,struct changer_position)
157 #define CHIOGPICKER _IOR('c', 4,int) /* not impl. */
158 #define CHIOSPICKER _IOW('c', 5,int) /* not impl. */
159 #define CHIOGPARAMS _IOR('c', 6,struct changer_params)
160 #define CHIOGSTATUS _IOW('c', 8,struct changer_element_status)
161 #define CHIOGELEM _IOW('c',16,struct changer_get_element)
162 #define CHIOINITELEM _IO('c',17)
163 #define CHIOSVOLTAG _IOW('c',18,struct changer_set_voltag)
164 #define CHIOGVPARAMS _IOR('c',19,struct changer_vendor_params)
166 #endif /* _UAPI_LINUX_CHIO_H */