| Gerd Knorr | daa6eda | 2005-05-10 10:59:13 +0200 | [diff] [blame] | 1 | /* | 
|  | 2 | * ioctl interface for the scsi media changer driver | 
|  | 3 | */ | 
|  | 4 |  | 
|  | 5 | /* changer element types */ | 
|  | 6 | #define CHET_MT   0	/* media transport element (robot) */ | 
|  | 7 | #define CHET_ST   1	/* storage element (media slots) */ | 
|  | 8 | #define CHET_IE   2	/* import/export element */ | 
|  | 9 | #define CHET_DT   3	/* data transfer element (tape/cdrom/whatever) */ | 
|  | 10 | #define CHET_V1   4	/* vendor specific #1 */ | 
|  | 11 | #define CHET_V2   5	/* vendor specific #2 */ | 
|  | 12 | #define CHET_V3   6	/* vendor specific #3 */ | 
|  | 13 | #define CHET_V4   7	/* vendor specific #4 */ | 
|  | 14 |  | 
|  | 15 |  | 
|  | 16 | /* | 
|  | 17 | * CHIOGPARAMS | 
|  | 18 | *    query changer properties | 
|  | 19 | * | 
|  | 20 | * CHIOVGPARAMS | 
|  | 21 | *    query vendor-specific element types | 
|  | 22 | * | 
|  | 23 | *    accessing elements works by specifing type and unit of the element. | 
|  | 24 | *    for eample, storage elements are addressed with type = CHET_ST and | 
|  | 25 | *    unit = 0 .. cp_nslots-1 | 
|  | 26 | * | 
|  | 27 | */ | 
|  | 28 | struct changer_params { | 
|  | 29 | int cp_curpicker;  /* current transport element */ | 
|  | 30 | int cp_npickers;   /* number of transport elements      (CHET_MT) */ | 
|  | 31 | int cp_nslots;     /* number of storage elements        (CHET_ST) */ | 
|  | 32 | int cp_nportals;   /* number of import/export elements  (CHET_IE) */ | 
|  | 33 | int cp_ndrives;    /* number of data transfer elements  (CHET_DT) */ | 
|  | 34 | }; | 
|  | 35 | struct changer_vendor_params { | 
|  | 36 | int  cvp_n1;       /* number of vendor specific elems   (CHET_V1) */ | 
|  | 37 | char cvp_label1[16]; | 
|  | 38 | int  cvp_n2;       /* number of vendor specific elems   (CHET_V2) */ | 
|  | 39 | char cvp_label2[16]; | 
|  | 40 | int  cvp_n3;       /* number of vendor specific elems   (CHET_V3) */ | 
|  | 41 | char cvp_label3[16]; | 
|  | 42 | int  cvp_n4;       /* number of vendor specific elems   (CHET_V4) */ | 
|  | 43 | char cvp_label4[16]; | 
|  | 44 | int  reserved[8]; | 
|  | 45 | }; | 
|  | 46 |  | 
|  | 47 |  | 
|  | 48 | /* | 
|  | 49 | * CHIOMOVE | 
|  | 50 | *    move a medium from one element to another | 
|  | 51 | */ | 
|  | 52 | struct changer_move { | 
|  | 53 | int cm_fromtype;	/* type/unit of source element */ | 
|  | 54 | int cm_fromunit; | 
|  | 55 | int cm_totype;	/* type/unit of destination element */ | 
|  | 56 | int cm_tounit; | 
|  | 57 | int cm_flags; | 
|  | 58 | }; | 
|  | 59 | #define CM_INVERT   1   /* flag: rotate media (for double-sided like MOD) */ | 
|  | 60 |  | 
|  | 61 |  | 
|  | 62 | /* | 
|  | 63 | * CHIOEXCHANGE | 
|  | 64 | *    move one medium from element #1 to element #2, | 
|  | 65 | *    and another one from element #2 to element #3. | 
|  | 66 | *    element #1 and #3 are allowed to be identical. | 
|  | 67 | */ | 
|  | 68 | struct changer_exchange { | 
|  | 69 | int ce_srctype;	    /* type/unit of element #1 */ | 
|  | 70 | int ce_srcunit; | 
|  | 71 | int ce_fdsttype;    /* type/unit of element #2 */ | 
|  | 72 | int ce_fdstunit; | 
|  | 73 | int ce_sdsttype;    /* type/unit of element #3 */ | 
|  | 74 | int ce_sdstunit; | 
|  | 75 | int ce_flags; | 
|  | 76 | }; | 
|  | 77 | #define CE_INVERT1   1 | 
|  | 78 | #define CE_INVERT2   2 | 
|  | 79 |  | 
|  | 80 |  | 
|  | 81 | /* | 
|  | 82 | * CHIOPOSITION | 
|  | 83 | *    move the transport element (robot arm) to a specific element. | 
|  | 84 | */ | 
|  | 85 | struct changer_position { | 
|  | 86 | int cp_type; | 
|  | 87 | int cp_unit; | 
|  | 88 | int cp_flags; | 
|  | 89 | }; | 
|  | 90 | #define CP_INVERT   1 | 
|  | 91 |  | 
|  | 92 |  | 
|  | 93 | /* | 
|  | 94 | * CHIOGSTATUS | 
|  | 95 | *    get element status for all elements of a specific type | 
|  | 96 | */ | 
|  | 97 | struct changer_element_status { | 
|  | 98 | int             ces_type; | 
| viro@ZenIV.linux.org.uk | fe08ac3 | 2005-09-09 22:03:44 +0100 | [diff] [blame] | 99 | unsigned char   __user *ces_data; | 
| Gerd Knorr | daa6eda | 2005-05-10 10:59:13 +0200 | [diff] [blame] | 100 | }; | 
|  | 101 | #define CESTATUS_FULL     0x01 /* full */ | 
|  | 102 | #define CESTATUS_IMPEXP   0x02	/* media was imported (inserted by sysop) */ | 
|  | 103 | #define CESTATUS_EXCEPT   0x04	/* error condition */ | 
|  | 104 | #define CESTATUS_ACCESS   0x08	/* access allowed */ | 
|  | 105 | #define CESTATUS_EXENAB   0x10	/* element can export media */ | 
|  | 106 | #define CESTATUS_INENAB   0x20	/* element can import media */ | 
|  | 107 |  | 
|  | 108 |  | 
|  | 109 | /* | 
|  | 110 | * CHIOGELEM | 
|  | 111 | *    get more detailed status informtion for a single element | 
|  | 112 | */ | 
|  | 113 | struct changer_get_element { | 
|  | 114 | int	cge_type;	 /* type/unit */ | 
|  | 115 | int	cge_unit; | 
|  | 116 | int	cge_status;      /* status */ | 
|  | 117 | int     cge_errno;       /* errno */ | 
|  | 118 | int     cge_srctype;     /* source element of the last move/exchange */ | 
|  | 119 | int     cge_srcunit; | 
|  | 120 | int     cge_id;          /* scsi id  (for data transfer elements) */ | 
|  | 121 | int     cge_lun;         /* scsi lun (for data transfer elements) */ | 
|  | 122 | char    cge_pvoltag[36]; /* primary volume tag */ | 
|  | 123 | char    cge_avoltag[36]; /* alternate volume tag */ | 
|  | 124 | int     cge_flags; | 
|  | 125 | }; | 
|  | 126 | /* flags */ | 
|  | 127 | #define CGE_ERRNO     0x01       /* errno available       */ | 
|  | 128 | #define CGE_INVERT    0x02       /* media inverted        */ | 
|  | 129 | #define CGE_SRC       0x04       /* media src available   */ | 
|  | 130 | #define CGE_IDLUN     0x08       /* ID+LUN available      */ | 
|  | 131 | #define CGE_PVOLTAG   0x10       /* primary volume tag available */ | 
|  | 132 | #define CGE_AVOLTAG   0x20       /* alternate volume tag available */ | 
|  | 133 |  | 
|  | 134 |  | 
|  | 135 | /* | 
|  | 136 | * CHIOSVOLTAG | 
|  | 137 | *    set volume tag | 
|  | 138 | */ | 
|  | 139 | struct changer_set_voltag { | 
|  | 140 | int	csv_type;	 /* type/unit */ | 
|  | 141 | int	csv_unit; | 
|  | 142 | char    csv_voltag[36];  /* volume tag */ | 
|  | 143 | int     csv_flags; | 
|  | 144 | }; | 
|  | 145 | #define CSV_PVOLTAG   0x01       /* primary volume tag */ | 
|  | 146 | #define CSV_AVOLTAG   0x02       /* alternate volume tag */ | 
|  | 147 | #define CSV_CLEARTAG  0x04       /* clear volume tag */ | 
|  | 148 |  | 
|  | 149 | /* ioctls */ | 
|  | 150 | #define CHIOMOVE       _IOW('c', 1,struct changer_move) | 
|  | 151 | #define CHIOEXCHANGE   _IOW('c', 2,struct changer_exchange) | 
|  | 152 | #define CHIOPOSITION   _IOW('c', 3,struct changer_position) | 
|  | 153 | #define CHIOGPICKER    _IOR('c', 4,int)                        /* not impl. */ | 
|  | 154 | #define CHIOSPICKER    _IOW('c', 5,int)                        /* not impl. */ | 
|  | 155 | #define CHIOGPARAMS    _IOR('c', 6,struct changer_params) | 
|  | 156 | #define CHIOGSTATUS    _IOW('c', 8,struct changer_element_status) | 
|  | 157 | #define CHIOGELEM      _IOW('c',16,struct changer_get_element) | 
|  | 158 | #define CHIOINITELEM   _IO('c',17) | 
|  | 159 | #define CHIOSVOLTAG    _IOW('c',18,struct changer_set_voltag) | 
|  | 160 | #define CHIOGVPARAMS   _IOR('c',19,struct changer_vendor_params) | 
|  | 161 |  | 
|  | 162 | /* ---------------------------------------------------------------------- */ | 
|  | 163 |  | 
|  | 164 | /* | 
|  | 165 | * Local variables: | 
|  | 166 | * c-basic-offset: 8 | 
|  | 167 | * End: | 
|  | 168 | */ |