1/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2/*
  3 * ioctl interface for the scsi media changer driver
  4 */
  5
  6#ifndef _LINUX_CHIO_H
  7#define _LINUX_CHIO_H
  8
  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 */
 18
 19
 20/*
 21 * CHIOGPARAMS
 22 *    query changer properties
 23 *
 24 * CHIOVGPARAMS
 25 *    query vendor-specific element types
 26 *
 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
 30 *
 31 */
 32struct 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) */
 38};
 39struct changer_vendor_params {
 40	int  cvp_n1;       /* number of vendor specific elems   (CHET_V1) */
 41	char cvp_label1[16];
 42	int  cvp_n2;       /* number of vendor specific elems   (CHET_V2) */
 43	char cvp_label2[16];
 44	int  cvp_n3;       /* number of vendor specific elems   (CHET_V3) */
 45	char cvp_label3[16];
 46	int  cvp_n4;       /* number of vendor specific elems   (CHET_V4) */
 47	char cvp_label4[16];
 48	int  reserved[8];
 49};
 50
 51
 52/*
 53 * CHIOMOVE
 54 *    move a medium from one element to another
 55 */
 56struct changer_move {
 57	int cm_fromtype;	/* type/unit of source element */
 58	int cm_fromunit;	
 59	int cm_totype;	/* type/unit of destination element */
 60	int cm_tounit;
 61	int cm_flags;
 62};
 63#define CM_INVERT   1   /* flag: rotate media (for double-sided like MOD) */
 64
 65
 66/*
 67 * CHIOEXCHANGE
 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.
 71 */
 72struct changer_exchange {
 73	int ce_srctype;	    /* type/unit of element #1 */
 74	int ce_srcunit;
 75	int ce_fdsttype;    /* type/unit of element #2 */
 76	int ce_fdstunit;
 77	int ce_sdsttype;    /* type/unit of element #3 */
 78	int ce_sdstunit;
 79	int ce_flags;
 80};
 81#define CE_INVERT1   1
 82#define CE_INVERT2   2
 83
 84
 85/*
 86 * CHIOPOSITION
 87 *    move the transport element (robot arm) to a specific element.
 88 */
 89struct changer_position {
 90	int cp_type;
 91	int cp_unit;
 92	int cp_flags;
 93};
 94#define CP_INVERT   1
 95
 96
 97/*
 98 * CHIOGSTATUS
 99 *    get element status for all elements of a specific type
100 */
101struct changer_element_status {
102	int             ces_type;
103	unsigned char   *ces_data;
104};
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 */
111
112
113/*
114 * CHIOGELEM
115 *    get more detailed status information for a single element
116 */
117struct changer_get_element {
118	int	cge_type;	 /* type/unit */
119	int	cge_unit;
120	int	cge_status;      /* status */
121	int     cge_errno;       /* errno */
122	int     cge_srctype;     /* source element of the last move/exchange */
123	int     cge_srcunit;
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 */
128	int     cge_flags;
129};
130/* flags */
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 */
137
138
139/*
140 * CHIOSVOLTAG
141 *    set volume tag
142 */
143struct changer_set_voltag {
144	int	csv_type;	 /* type/unit */
145	int	csv_unit;
146	char    csv_voltag[36];  /* volume tag */
147	int     csv_flags;
148};
149#define CSV_PVOLTAG   0x01       /* primary volume tag */
150#define CSV_AVOLTAG   0x02       /* alternate volume tag */
151#define CSV_CLEARTAG  0x04       /* clear volume tag */
152
153/* ioctls */
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)
165
166#endif /* _LINUX_CHIO_H */