Blame view

drivers/scsi/st.h 7.26 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  /* SPDX-License-Identifier: GPL-2.0 */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2
3
4
5
6
  
  #ifndef _ST_H
  #define _ST_H
  
  #include <linux/completion.h>
28f85009e   Matthias Kaehlcke   [SCSI] st: Use mu...
7
  #include <linux/mutex.h>
f03a56705   Kai Makisara   [SCSI] drivers/sc...
8
  #include <linux/kref.h>
8b05b773b   Mike Christie   [SCSI] convert st...
9
  #include <scsi/scsi_cmnd.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
10
11
12
13
14
15
  
  /* Descriptor for analyzed sense data */
  struct st_cmdstatus {
  	int midlevel_result;
  	struct scsi_sense_hdr sense_hdr;
  	int have_sense;
40f6b36c6   Kai Makisara   [SCSI] st: add op...
16
  	int residual;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
17
18
19
20
21
22
  	u64 uremainder64;
  	u8 flags;
  	u8 remainder_valid;
  	u8 fixed_format;
  	u8 deferred;
  };
8b05b773b   Mike Christie   [SCSI] convert st...
23
24
25
26
27
28
29
30
31
  struct scsi_tape;
  
  /* scsi tape command */
  struct st_request {
  	unsigned char cmd[MAX_COMMAND_SIZE];
  	unsigned char sense[SCSI_SENSE_BUFFERSIZE];
  	int result;
  	struct scsi_tape *stp;
  	struct completion *waiting;
13b53b443   FUJITA Tomonori   [SCSI] st: add st...
32
  	struct bio *bio;
8b05b773b   Mike Christie   [SCSI] convert st...
33
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
34
35
  /* The tape buffer descriptor. */
  struct st_buffer {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
36
  	unsigned char dma;	/* DMA-able buffer */
40f6b36c6   Kai Makisara   [SCSI] st: add op...
37
  	unsigned char cleared;  /* internal buffer cleared after open? */
7c018a901   David Jeffery   [SCSI] st: fix me...
38
  	unsigned short do_dio;  /* direct i/o set up? */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
39
40
41
42
43
44
  	int buffer_size;
  	int buffer_blocks;
  	int buffer_bytes;
  	int read_pointer;
  	int writing;
  	int syscall_result;
8b05b773b   Mike Christie   [SCSI] convert st...
45
  	struct st_request *last_SRpnt;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
46
  	struct st_cmdstatus cmdstat;
d0e1ae31b   FUJITA Tomonori   [SCSI] st: add st...
47
  	struct page **reserved_pages;
c982c368b   FUJITA Tomonori   [SCSI] st: fix md...
48
  	int reserved_page_order;
6620742f7   FUJITA Tomonori   [SCSI] st: conver...
49
  	struct page **mapped_pages;
d0e1ae31b   FUJITA Tomonori   [SCSI] st: add st...
50
  	struct rq_map_data map_data;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
51
52
53
  	unsigned char *b_data;
  	unsigned short use_sg;	/* zero or max number of s/g segments for this adapter */
  	unsigned short sg_segs;		/* number of segments in s/g list */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
54
  	unsigned short frp_segs;	/* number of buffer segments */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
55
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
56
57
58
59
60
61
62
63
64
65
66
  /* The tape mode definition */
  struct st_modedef {
  	unsigned char defined;
  	unsigned char sysv;	/* SYS V semantics? */
  	unsigned char do_async_writes;
  	unsigned char do_buffer_writes;
  	unsigned char do_read_ahead;
  	unsigned char defaults_for_writes;
  	unsigned char default_compression;	/* 0 = don't touch, etc */
  	short default_density;	/* Forced density, -1 = no value */
  	int default_blksize;	/* Forced blocksize, -1 = no value */
6c648d95a   Jeff Mahoney   [SCSI] st: get ri...
67
  	struct scsi_tape *tape;
26898afd6   Jeff Mahoney   [SCSI] st: clean ...
68
  	struct device *devs[2];  /* Auto-rewind and non-rewind devices */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
69
70
71
72
73
74
75
76
77
  	struct cdev *cdevs[2];  /* Auto-rewind and non-rewind devices */
  };
  
  /* Number of modes can be changed by changing ST_NBR_MODE_BITS. The maximum
     number of modes is 16 (ST_NBR_MODE_BITS 4) */
  #define ST_NBR_MODE_BITS 2
  #define ST_NBR_MODES (1 << ST_NBR_MODE_BITS)
  #define ST_MODE_SHIFT (7 - ST_NBR_MODE_BITS)
  #define ST_MODE_MASK ((ST_NBR_MODES - 1) << ST_MODE_SHIFT)
6ed33a4a0   Jeff Mahoney   [SCSI] st: raise ...
78
  #define ST_MAX_TAPES (1 << (20 - (ST_NBR_MODE_BITS + 1)))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
79
80
81
82
83
84
85
86
87
88
89
90
  #define ST_MAX_TAPE_ENTRIES  (ST_MAX_TAPES << (ST_NBR_MODE_BITS + 1))
  
  /* The status related to each partition */
  struct st_partstat {
  	unsigned char rw;
  	unsigned char eof;
  	unsigned char at_sm;
  	unsigned char last_block_valid;
  	u32 last_block_visited;
  	int drv_block;		/* The block where the drive head is */
  	int drv_file;
  };
05545c92d   Seymour, Shane M   st: implement tap...
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
  /* Tape statistics */
  struct scsi_tape_stats {
  	atomic64_t read_byte_cnt;  /* bytes read */
  	atomic64_t write_byte_cnt; /* bytes written */
  	atomic64_t in_flight;      /* Number of I/Os in flight */
  	atomic64_t read_cnt;       /* Count of read requests */
  	atomic64_t write_cnt;      /* Count of write requests */
  	atomic64_t other_cnt;      /* Count of other requests either
  				    * implicit or from user space
  				    * ioctl. */
  	atomic64_t resid_cnt;      /* Count of resid_len > 0 */
  	atomic64_t tot_read_time;  /* ktime spent completing reads */
  	atomic64_t tot_write_time; /* ktime spent completing writes */
  	atomic64_t tot_io_time;    /* ktime spent doing any I/O */
  	ktime_t read_time;         /* holds ktime request was queued */
  	ktime_t write_time;        /* holds ktime request was queued */
  	ktime_t other_time;        /* holds ktime request was queued */
  	atomic_t last_read_size;   /* Number of bytes issued for last read */
  	atomic_t last_write_size;  /* Number of bytes issued for last write */
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
111
112
113
114
115
116
  #define ST_NBR_PARTITIONS 4
  
  /* The tape drive descriptor */
  struct scsi_tape {
  	struct scsi_driver *driver;
  	struct scsi_device *device;
28f85009e   Matthias Kaehlcke   [SCSI] st: Use mu...
117
  	struct mutex lock;	/* For serialization */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
118
119
  	struct completion wait;	/* For SCSI commands */
  	struct st_buffer *buffer;
6c648d95a   Jeff Mahoney   [SCSI] st: get ri...
120
  	int index;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
  
  	/* Drive characteristics */
  	unsigned char omit_blklims;
  	unsigned char do_auto_lock;
  	unsigned char can_bsr;
  	unsigned char can_partitions;
  	unsigned char two_fm;
  	unsigned char fast_mteom;
  	unsigned char immediate;
  	unsigned char restr_dma;
  	unsigned char scsi2_logical;
  	unsigned char default_drvbuffer;	/* 0xff = don't touch, value 3 bits */
  	unsigned char cln_mode;			/* 0 = none, otherwise sense byte nbr */
  	unsigned char cln_sense_value;
  	unsigned char cln_sense_mask;
  	unsigned char use_pf;			/* Set Page Format bit in all mode selects? */
9abe16c67   Kai Makisara   [SCSI] st: fix Ta...
137
138
  	unsigned char try_dio;			/* try direct i/o in general? */
  	unsigned char try_dio_now;		/* try direct i/o before next close? */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
139
140
  	unsigned char c_algo;			/* compression algorithm */
  	unsigned char pos_unknown;			/* after reset position unknown */
40f6b36c6   Kai Makisara   [SCSI] st: add op...
141
  	unsigned char sili;			/* use SILI when reading in variable b mode */
c743e44fb   Lee Duncan   [SCSI] st: expand...
142
  	unsigned char immediate_filemark;	/* write filemark immediately */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
143
144
  	int tape_type;
  	int long_timeout;	/* timeout for commands known to take long time */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
  	/* Mode characteristics */
  	struct st_modedef modes[ST_NBR_MODES];
  	int current_mode;
  
  	/* Status variables */
  	int partition;
  	int new_partition;
  	int nbr_partitions;	/* zero until partition support enabled */
  	struct st_partstat ps[ST_NBR_PARTITIONS];
  	unsigned char dirty;
  	unsigned char ready;
  	unsigned char write_prot;
  	unsigned char drv_write_prot;
  	unsigned char in_use;
  	unsigned char blksize_changed;
  	unsigned char density_changed;
  	unsigned char compression_changed;
  	unsigned char drv_buffer;
  	unsigned char density;
  	unsigned char door_locked;
  	unsigned char autorew_dev;   /* auto-rewind device */
  	unsigned char rew_at_close;  /* rewind necessary at close */
  	unsigned char inited;
  	unsigned char cleaning_req;  /* cleaning requested? */
  	int block_size;
  	int min_block;
  	int max_block;
  	int recover_count;     /* From tape opening */
  	int recover_reg;       /* From last status call */
  
  #if DEBUG
  	unsigned char write_pending;
  	int nbr_finished;
  	int nbr_waits;
  	int nbr_requests;
  	int nbr_dio;
  	int nbr_pages;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
182
183
184
185
  	unsigned char last_cmnd[6];
  	unsigned char last_sense[16];
  #endif
  	struct gendisk *disk;
f03a56705   Kai Makisara   [SCSI] drivers/sc...
186
  	struct kref     kref;
05545c92d   Seymour, Shane M   st: implement tap...
187
  	struct scsi_tape_stats *stats;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
  };
  
  /* Bit masks for use_pf */
  #define USE_PF      1
  #define PF_TESTED   2
  
  /* Values of eof */
  #define	ST_NOEOF	0
  #define ST_FM_HIT       1
  #define ST_FM           2
  #define ST_EOM_OK       3
  #define ST_EOM_ERROR	4
  #define	ST_EOD_1        5
  #define ST_EOD_2        6
  #define ST_EOD		7
  /* EOD hit while reading => ST_EOD_1 => return zero => ST_EOD_2 =>
     return zero => ST_EOD, return ENOSPC */
  /* When writing: ST_EOM_OK == early warning found, write OK
  		 ST_EOD_1  == allow trying new write after early warning
  		 ST_EOM_ERROR == early warning found, not able to write all */
  
  /* Values of rw */
  #define	ST_IDLE		0
  #define	ST_READING	1
  #define	ST_WRITING	2
  
  /* Values of ready state */
  #define ST_READY	0
  #define ST_NOT_READY	1
  #define ST_NO_TAPE	2
  
  /* Values for door lock state */
  #define ST_UNLOCKED	0
  #define ST_LOCKED_EXPLICIT 1
  #define ST_LOCKED_AUTO  2
  #define ST_LOCK_FAILS   3
  
  /* Positioning SCSI-commands for Tandberg, etc. drives */
  #define	QFA_REQUEST_BLOCK	0x02
  #define	QFA_SEEK_BLOCK		0x0c
  
  /* Setting the binary options */
  #define ST_DONT_TOUCH  0
  #define ST_NO          1
  #define ST_YES         2
  
  #define EXTENDED_SENSE_START  18
  
  /* Masks for some conditions in the sense data */
  #define SENSE_FMK   0x80
  #define SENSE_EOM   0x40
  #define SENSE_ILI   0x20
  
  #endif