2 SCSI Tape Driver for Linux version 1.1 and newer. See the accompanying
3 file Documentation/scsi/st.txt for more information.
6 Rewritten from Dwayne Forsyth's SCSI tape driver by Kai Makisara.
7 Contribution and ideas from several people including (in alphabetical
8 order) Klaus Ehrenfried, Eugene Exarevsky, Eric Lee Green, Wolfgang Denk,
9 Steve Hirsch, Andreas Koppenh"ofer, Michael Leodolter, Eyal Lebedinsky,
10 Michael Schaefer, J"org Weule, and Eric Youngdale.
12 Copyright 1992 - 2008 Kai Makisara
13 email Kai.Makisara@kolumbus.fi
15 Some small formal changes - aeb, 950809
17 Last modified: 18-JAN-1998 Richard Gooch <rgooch@atnf.csiro.au> Devfs support
20 static const char *verstr = "20080504";
22 #include <linux/module.h>
25 #include <linux/kernel.h>
26 #include <linux/sched.h>
28 #include <linux/init.h>
29 #include <linux/string.h>
30 #include <linux/errno.h>
31 #include <linux/mtio.h>
32 #include <linux/cdrom.h>
33 #include <linux/ioctl.h>
34 #include <linux/fcntl.h>
35 #include <linux/spinlock.h>
36 #include <linux/blkdev.h>
37 #include <linux/moduleparam.h>
38 #include <linux/cdev.h>
39 #include <linux/delay.h>
40 #include <linux/mutex.h>
41 #include <linux/smp_lock.h>
43 #include <asm/uaccess.h>
45 #include <asm/system.h>
47 #include <scsi/scsi.h>
48 #include <scsi/scsi_dbg.h>
49 #include <scsi/scsi_device.h>
50 #include <scsi/scsi_driver.h>
51 #include <scsi/scsi_eh.h>
52 #include <scsi/scsi_host.h>
53 #include <scsi/scsi_ioctl.h>
57 /* The driver prints some debugging information on the console if DEBUG
58 is defined and non-zero. */
62 /* The message level for the debug messages is currently set to KERN_NOTICE
63 so that people can easily see the messages. Later when the debugging messages
64 in the drivers are more widely classified, this may be changed to KERN_DEBUG. */
65 #define ST_DEB_MSG KERN_NOTICE
67 #define DEBC(a) if (debugging) { a ; }
73 #define ST_KILOBYTE 1024
75 #include "st_options.h"
78 static int buffer_kbs;
79 static int max_sg_segs;
80 static int try_direct_io = TRY_DIRECT_IO;
81 static int try_rdio = 1;
82 static int try_wdio = 1;
84 static int st_dev_max;
87 static struct class *st_sysfs_class;
89 MODULE_AUTHOR("Kai Makisara");
90 MODULE_DESCRIPTION("SCSI tape (st) driver");
91 MODULE_LICENSE("GPL");
92 MODULE_ALIAS_CHARDEV_MAJOR(SCSI_TAPE_MAJOR);
93 MODULE_ALIAS_SCSI_DEVICE(TYPE_TAPE);
95 /* Set 'perm' (4th argument) to 0 to disable module_param's definition
96 * of sysfs parameters (which module_param doesn't yet support).
97 * Sysfs parameters defined explicitly later.
99 module_param_named(buffer_kbs, buffer_kbs, int, 0);
100 MODULE_PARM_DESC(buffer_kbs, "Default driver buffer size for fixed block mode (KB; 32)");
101 module_param_named(max_sg_segs, max_sg_segs, int, 0);
102 MODULE_PARM_DESC(max_sg_segs, "Maximum number of scatter/gather segments to use (256)");
103 module_param_named(try_direct_io, try_direct_io, int, 0);
104 MODULE_PARM_DESC(try_direct_io, "Try direct I/O between user buffer and tape drive (1)");
106 /* Extra parameters for testing */
107 module_param_named(try_rdio, try_rdio, int, 0);
108 MODULE_PARM_DESC(try_rdio, "Try direct read i/o when possible");
109 module_param_named(try_wdio, try_wdio, int, 0);
110 MODULE_PARM_DESC(try_wdio, "Try direct write i/o when possible");
113 static int write_threshold_kbs; /* retained for compatibility */
114 static struct st_dev_parm {
117 } parms[] __initdata = {
119 "buffer_kbs", &buffer_kbs
121 { /* Retained for compatibility with 2.4 */
122 "write_threshold_kbs", &write_threshold_kbs
128 "try_direct_io", &try_direct_io
133 /* Restrict the number of modes so that names for all are assigned */
134 #if ST_NBR_MODES > 16
135 #error "Maximum number of modes is 16"
137 /* Bit reversed order to get same names for same minors with all
139 static const char *st_formats[] = {
140 "", "r", "k", "s", "l", "t", "o", "u",
141 "m", "v", "p", "x", "a", "y", "q", "z"};
143 /* The default definitions have been moved to st_options.h */
145 #define ST_FIXED_BUFFER_SIZE (ST_FIXED_BUFFER_BLOCKS * ST_KILOBYTE)
147 /* The buffer size should fit into the 24 bits for length in the
148 6-byte SCSI read and write commands. */
149 #if ST_FIXED_BUFFER_SIZE >= (2 << 24 - 1)
150 #error "Buffer size should not exceed (2 << 24 - 1) bytes!"
153 static int debugging = DEBUG;
155 #define MAX_RETRIES 0
156 #define MAX_WRITE_RETRIES 0
157 #define MAX_READY_RETRIES 0
158 #define NO_TAPE NOT_READY
160 #define ST_TIMEOUT (900 * HZ)
161 #define ST_LONG_TIMEOUT (14000 * HZ)
163 /* Remove mode bits and auto-rewind bit (7) */
164 #define TAPE_NR(x) ( ((iminor(x) & ~255) >> (ST_NBR_MODE_BITS + 1)) | \
165 (iminor(x) & ~(-1 << ST_MODE_SHIFT)) )
166 #define TAPE_MODE(x) ((iminor(x) & ST_MODE_MASK) >> ST_MODE_SHIFT)
168 /* Construct the minor number from the device (d), mode (m), and non-rewind (n) data */
169 #define TAPE_MINOR(d, m, n) (((d & ~(255 >> (ST_NBR_MODE_BITS + 1))) << (ST_NBR_MODE_BITS + 1)) | \
170 (d & (255 >> (ST_NBR_MODE_BITS + 1))) | (m << ST_MODE_SHIFT) | ((n != 0) << 7) )
172 /* Internal ioctl to set both density (uppermost 8 bits) and blocksize (lower
174 #define SET_DENS_AND_BLK 0x10001
176 static DEFINE_RWLOCK(st_dev_arr_lock);
178 static int st_fixed_buffer_size = ST_FIXED_BUFFER_SIZE;
179 static int st_max_sg_segs = ST_MAX_SG;
181 static struct scsi_tape **scsi_tapes = NULL;
183 static int modes_defined;
185 static struct st_buffer *new_tape_buffer(int, int, int);
186 static int enlarge_buffer(struct st_buffer *, int, int);
187 static void clear_buffer(struct st_buffer *);
188 static void normalize_buffer(struct st_buffer *);
189 static int append_to_buffer(const char __user *, struct st_buffer *, int);
190 static int from_buffer(struct st_buffer *, char __user *, int);
191 static void move_buffer_data(struct st_buffer *, int);
192 static void buf_to_sg(struct st_buffer *, unsigned int);
194 static int sgl_map_user_pages(struct scatterlist *, const unsigned int,
195 unsigned long, size_t, int);
196 static int sgl_unmap_user_pages(struct scatterlist *, const unsigned int, int);
198 static int st_probe(struct device *);
199 static int st_remove(struct device *);
201 static int do_create_sysfs_files(void);
202 static void do_remove_sysfs_files(void);
203 static int do_create_class_files(struct scsi_tape *, int, int);
205 static struct scsi_driver st_template = {
206 .owner = THIS_MODULE,
214 static int st_compression(struct scsi_tape *, int);
216 static int find_partition(struct scsi_tape *);
217 static int switch_partition(struct scsi_tape *);
219 static int st_int_ioctl(struct scsi_tape *, unsigned int, unsigned long);
221 static void scsi_tape_release(struct kref *);
223 #define to_scsi_tape(obj) container_of(obj, struct scsi_tape, kref)
225 static DEFINE_MUTEX(st_ref_mutex);
228 #include "osst_detect.h"
229 #ifndef SIGS_FROM_OSST
230 #define SIGS_FROM_OSST \
231 {"OnStream", "SC-", "", "osst"}, \
232 {"OnStream", "DI-", "", "osst"}, \
233 {"OnStream", "DP-", "", "osst"}, \
234 {"OnStream", "USB", "", "osst"}, \
235 {"OnStream", "FW-", "", "osst"}
238 static struct scsi_tape *scsi_tape_get(int dev)
240 struct scsi_tape *STp = NULL;
242 mutex_lock(&st_ref_mutex);
243 write_lock(&st_dev_arr_lock);
245 if (dev < st_dev_max && scsi_tapes != NULL)
246 STp = scsi_tapes[dev];
249 kref_get(&STp->kref);
254 if (scsi_device_get(STp->device))
260 kref_put(&STp->kref, scsi_tape_release);
263 write_unlock(&st_dev_arr_lock);
264 mutex_unlock(&st_ref_mutex);
268 static void scsi_tape_put(struct scsi_tape *STp)
270 struct scsi_device *sdev = STp->device;
272 mutex_lock(&st_ref_mutex);
273 kref_put(&STp->kref, scsi_tape_release);
274 scsi_device_put(sdev);
275 mutex_unlock(&st_ref_mutex);
278 struct st_reject_data {
282 char *driver_hint; /* Name of the correct driver, NULL if unknown */
285 static struct st_reject_data reject_list[] = {
286 /* {"XXX", "Yy-", "", NULL}, example */
290 /* If the device signature is on the list of incompatible drives, the
291 function returns a pointer to the name of the correct driver (if known) */
292 static char * st_incompatible(struct scsi_device* SDp)
294 struct st_reject_data *rp;
296 for (rp=&(reject_list[0]); rp->vendor != NULL; rp++)
297 if (!strncmp(rp->vendor, SDp->vendor, strlen(rp->vendor)) &&
298 !strncmp(rp->model, SDp->model, strlen(rp->model)) &&
299 !strncmp(rp->rev, SDp->rev, strlen(rp->rev))) {
301 return rp->driver_hint;
309 static inline char *tape_name(struct scsi_tape *tape)
311 return tape->disk->disk_name;
315 static void st_analyze_sense(struct st_request *SRpnt, struct st_cmdstatus *s)
318 const u8 *sense = SRpnt->sense;
320 s->have_sense = scsi_normalize_sense(SRpnt->sense,
321 SCSI_SENSE_BUFFERSIZE, &s->sense_hdr);
327 scsi_get_sense_info_fld(sense, SCSI_SENSE_BUFFERSIZE, &s->uremainder64);
328 switch (sense[0] & 0x7f) {
333 s->flags = sense[2] & 0xe0;
339 ucp = scsi_sense_desc_find(sense, SCSI_SENSE_BUFFERSIZE, 4);
340 s->flags = ucp ? (ucp[3] & 0xe0) : 0;
347 /* Convert the result to success code */
348 static int st_chk_result(struct scsi_tape *STp, struct st_request * SRpnt)
350 int result = SRpnt->result;
352 DEB(const char *stp;)
353 char *name = tape_name(STp);
354 struct st_cmdstatus *cmdstatp;
359 cmdstatp = &STp->buffer->cmdstat;
360 st_analyze_sense(SRpnt, cmdstatp);
362 if (cmdstatp->have_sense)
363 scode = STp->buffer->cmdstat.sense_hdr.sense_key;
369 printk(ST_DEB_MSG "%s: Error: %x, cmd: %x %x %x %x %x %x\n",
371 SRpnt->cmd[0], SRpnt->cmd[1], SRpnt->cmd[2],
372 SRpnt->cmd[3], SRpnt->cmd[4], SRpnt->cmd[5]);
373 if (cmdstatp->have_sense)
374 __scsi_print_sense(name, SRpnt->sense, SCSI_SENSE_BUFFERSIZE);
376 if (!debugging) { /* Abnormal conditions for tape */
377 if (!cmdstatp->have_sense)
379 "%s: Error %x (sugg. bt 0x%x, driver bt 0x%x, host bt 0x%x).\n",
380 name, result, suggestion(result),
381 driver_byte(result) & DRIVER_MASK, host_byte(result));
382 else if (cmdstatp->have_sense &&
384 scode != RECOVERED_ERROR &&
385 /* scode != UNIT_ATTENTION && */
386 scode != BLANK_CHECK &&
387 scode != VOLUME_OVERFLOW &&
388 SRpnt->cmd[0] != MODE_SENSE &&
389 SRpnt->cmd[0] != TEST_UNIT_READY) {
391 __scsi_print_sense(name, SRpnt->sense, SCSI_SENSE_BUFFERSIZE);
395 if (cmdstatp->fixed_format &&
396 STp->cln_mode >= EXTENDED_SENSE_START) { /* Only fixed format sense */
397 if (STp->cln_sense_value)
398 STp->cleaning_req |= ((SRpnt->sense[STp->cln_mode] &
399 STp->cln_sense_mask) == STp->cln_sense_value);
401 STp->cleaning_req |= ((SRpnt->sense[STp->cln_mode] &
402 STp->cln_sense_mask) != 0);
404 if (cmdstatp->have_sense &&
405 cmdstatp->sense_hdr.asc == 0 && cmdstatp->sense_hdr.ascq == 0x17)
406 STp->cleaning_req = 1; /* ASC and ASCQ => cleaning requested */
408 STp->pos_unknown |= STp->device->was_reset;
410 if (cmdstatp->have_sense &&
411 scode == RECOVERED_ERROR
412 #if ST_RECOVERED_WRITE_FATAL
413 && SRpnt->cmd[0] != WRITE_6
414 && SRpnt->cmd[0] != WRITE_FILEMARKS
417 STp->recover_count++;
422 if (SRpnt->cmd[0] == READ_6)
424 else if (SRpnt->cmd[0] == WRITE_6)
428 printk(ST_DEB_MSG "%s: Recovered %s error (%d).\n", name, stp,
432 if (cmdstatp->flags == 0)
439 /* Wakeup from interrupt */
440 static void st_sleep_done(void *data, char *sense, int result, int resid)
442 struct st_request *SRpnt = data;
443 struct scsi_tape *STp = SRpnt->stp;
445 memcpy(SRpnt->sense, sense, SCSI_SENSE_BUFFERSIZE);
446 (STp->buffer)->cmdstat.midlevel_result = SRpnt->result = result;
447 (STp->buffer)->cmdstat.residual = resid;
448 DEB( STp->write_pending = 0; )
451 complete(SRpnt->waiting);
454 static struct st_request *st_allocate_request(void)
456 return kzalloc(sizeof(struct st_request), GFP_KERNEL);
459 static void st_release_request(struct st_request *streq)
464 /* Do the scsi command. Waits until command performed if do_wait is true.
465 Otherwise write_behind_check() is used to check that the command
467 static struct st_request *
468 st_do_scsi(struct st_request * SRpnt, struct scsi_tape * STp, unsigned char *cmd,
469 int bytes, int direction, int timeout, int retries, int do_wait)
471 struct completion *waiting;
473 /* if async, make sure there's no command outstanding */
474 if (!do_wait && ((STp->buffer)->last_SRpnt)) {
475 printk(KERN_ERR "%s: Async command already active.\n",
477 if (signal_pending(current))
478 (STp->buffer)->syscall_result = (-EINTR);
480 (STp->buffer)->syscall_result = (-EBUSY);
485 SRpnt = st_allocate_request();
487 DEBC( printk(KERN_ERR "%s: Can't get SCSI request.\n",
489 if (signal_pending(current))
490 (STp->buffer)->syscall_result = (-EINTR);
492 (STp->buffer)->syscall_result = (-EBUSY);
498 /* If async IO, set last_SRpnt. This ptr tells write_behind_check
499 which IO is outstanding. It's nulled out when the IO completes. */
501 (STp->buffer)->last_SRpnt = SRpnt;
503 waiting = &STp->wait;
504 init_completion(waiting);
505 SRpnt->waiting = waiting;
507 if (!STp->buffer->do_dio)
508 buf_to_sg(STp->buffer, bytes);
510 memcpy(SRpnt->cmd, cmd, sizeof(SRpnt->cmd));
511 STp->buffer->cmdstat.have_sense = 0;
512 STp->buffer->syscall_result = 0;
514 if (scsi_execute_async(STp->device, cmd, COMMAND_SIZE(cmd[0]), direction,
515 &((STp->buffer)->sg[0]), bytes, (STp->buffer)->sg_segs,
516 timeout, retries, SRpnt, st_sleep_done, GFP_KERNEL)) {
517 /* could not allocate the buffer or request was too large */
518 (STp->buffer)->syscall_result = (-EBUSY);
519 (STp->buffer)->last_SRpnt = NULL;
522 wait_for_completion(waiting);
523 SRpnt->waiting = NULL;
524 (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt);
531 /* Handle the write-behind checking (waits for completion). Returns -ENOSPC if
532 write has been correct but EOM early warning reached, -EIO if write ended in
533 error or zero if write successful. Asynchronous writes are used only in
534 variable block mode. */
535 static int write_behind_check(struct scsi_tape * STp)
538 struct st_buffer *STbuffer;
539 struct st_partstat *STps;
540 struct st_cmdstatus *cmdstatp;
541 struct st_request *SRpnt;
543 STbuffer = STp->buffer;
544 if (!STbuffer->writing)
548 if (STp->write_pending)
554 wait_for_completion(&(STp->wait));
555 SRpnt = STbuffer->last_SRpnt;
556 STbuffer->last_SRpnt = NULL;
557 SRpnt->waiting = NULL;
559 (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt);
560 st_release_request(SRpnt);
562 STbuffer->buffer_bytes -= STbuffer->writing;
563 STps = &(STp->ps[STp->partition]);
564 if (STps->drv_block >= 0) {
565 if (STp->block_size == 0)
568 STps->drv_block += STbuffer->writing / STp->block_size;
571 cmdstatp = &STbuffer->cmdstat;
572 if (STbuffer->syscall_result) {
574 if (cmdstatp->have_sense && !cmdstatp->deferred &&
575 (cmdstatp->flags & SENSE_EOM) &&
576 (cmdstatp->sense_hdr.sense_key == NO_SENSE ||
577 cmdstatp->sense_hdr.sense_key == RECOVERED_ERROR)) {
578 /* EOM at write-behind, has all data been written? */
579 if (!cmdstatp->remainder_valid ||
580 cmdstatp->uremainder64 == 0)
584 STps->drv_block = -1;
586 STbuffer->writing = 0;
588 DEB(if (debugging && retval)
589 printk(ST_DEB_MSG "%s: Async write error %x, return value %d.\n",
590 tape_name(STp), STbuffer->cmdstat.midlevel_result, retval);) /* end DEB */
596 /* Step over EOF if it has been inadvertently crossed (ioctl not used because
597 it messes up the block number). */
598 static int cross_eof(struct scsi_tape * STp, int forward)
600 struct st_request *SRpnt;
601 unsigned char cmd[MAX_COMMAND_SIZE];
604 cmd[1] = 0x01; /* Space FileMarks */
609 cmd[2] = cmd[3] = cmd[4] = 0xff; /* -1 filemarks */
612 DEBC(printk(ST_DEB_MSG "%s: Stepping over filemark %s.\n",
613 tape_name(STp), forward ? "forward" : "backward"));
615 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE,
616 STp->device->timeout, MAX_RETRIES, 1);
618 return (STp->buffer)->syscall_result;
620 st_release_request(SRpnt);
623 if ((STp->buffer)->cmdstat.midlevel_result != 0)
624 printk(KERN_ERR "%s: Stepping over filemark %s failed.\n",
625 tape_name(STp), forward ? "forward" : "backward");
627 return (STp->buffer)->syscall_result;
631 /* Flush the write buffer (never need to write if variable blocksize). */
632 static int st_flush_write_buffer(struct scsi_tape * STp)
636 unsigned char cmd[MAX_COMMAND_SIZE];
637 struct st_request *SRpnt;
638 struct st_partstat *STps;
640 result = write_behind_check(STp);
645 if (STp->dirty == 1) {
647 transfer = STp->buffer->buffer_bytes;
648 DEBC(printk(ST_DEB_MSG "%s: Flushing %d bytes.\n",
649 tape_name(STp), transfer));
651 memset(cmd, 0, MAX_COMMAND_SIZE);
654 blks = transfer / STp->block_size;
659 SRpnt = st_do_scsi(NULL, STp, cmd, transfer, DMA_TO_DEVICE,
660 STp->device->timeout, MAX_WRITE_RETRIES, 1);
662 return (STp->buffer)->syscall_result;
664 STps = &(STp->ps[STp->partition]);
665 if ((STp->buffer)->syscall_result != 0) {
666 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
668 if (cmdstatp->have_sense && !cmdstatp->deferred &&
669 (cmdstatp->flags & SENSE_EOM) &&
670 (cmdstatp->sense_hdr.sense_key == NO_SENSE ||
671 cmdstatp->sense_hdr.sense_key == RECOVERED_ERROR) &&
672 (!cmdstatp->remainder_valid ||
673 cmdstatp->uremainder64 == 0)) { /* All written at EOM early warning */
675 (STp->buffer)->buffer_bytes = 0;
676 if (STps->drv_block >= 0)
677 STps->drv_block += blks;
680 printk(KERN_ERR "%s: Error on flush.\n",
682 STps->drv_block = (-1);
686 if (STps->drv_block >= 0)
687 STps->drv_block += blks;
689 (STp->buffer)->buffer_bytes = 0;
691 st_release_request(SRpnt);
698 /* Flush the tape buffer. The tape will be positioned correctly unless
699 seek_next is true. */
700 static int flush_buffer(struct scsi_tape *STp, int seek_next)
702 int backspace, result;
703 struct st_buffer *STbuffer;
704 struct st_partstat *STps;
706 STbuffer = STp->buffer;
709 * If there was a bus reset, block further access
712 if (STp->pos_unknown)
715 if (STp->ready != ST_READY)
717 STps = &(STp->ps[STp->partition]);
718 if (STps->rw == ST_WRITING) /* Writing */
719 return st_flush_write_buffer(STp);
721 if (STp->block_size == 0)
724 backspace = ((STp->buffer)->buffer_bytes +
725 (STp->buffer)->read_pointer) / STp->block_size -
726 ((STp->buffer)->read_pointer + STp->block_size - 1) /
728 (STp->buffer)->buffer_bytes = 0;
729 (STp->buffer)->read_pointer = 0;
732 if (STps->eof == ST_FM_HIT) {
733 result = cross_eof(STp, 0); /* Back over the EOF hit */
735 STps->eof = ST_NOEOF;
737 if (STps->drv_file >= 0)
742 if (!result && backspace > 0)
743 result = st_int_ioctl(STp, MTBSR, backspace);
744 } else if (STps->eof == ST_FM_HIT) {
745 if (STps->drv_file >= 0)
748 STps->eof = ST_NOEOF;
754 /* Set the mode parameters */
755 static int set_mode_densblk(struct scsi_tape * STp, struct st_modedef * STm)
759 char *name = tape_name(STp);
761 if (!STp->density_changed &&
762 STm->default_density >= 0 &&
763 STm->default_density != STp->density) {
764 arg = STm->default_density;
768 arg <<= MT_ST_DENSITY_SHIFT;
769 if (!STp->blksize_changed &&
770 STm->default_blksize >= 0 &&
771 STm->default_blksize != STp->block_size) {
772 arg |= STm->default_blksize;
775 arg |= STp->block_size;
777 st_int_ioctl(STp, SET_DENS_AND_BLK, arg)) {
779 "%s: Can't set default block size to %d bytes and density %x.\n",
780 name, STm->default_blksize, STm->default_density);
788 /* Lock or unlock the drive door. Don't use when st_request allocated. */
789 static int do_door_lock(struct scsi_tape * STp, int do_lock)
792 DEB(char *name = tape_name(STp);)
795 cmd = do_lock ? SCSI_IOCTL_DOORLOCK : SCSI_IOCTL_DOORUNLOCK;
796 DEBC(printk(ST_DEB_MSG "%s: %socking drive door.\n", name,
797 do_lock ? "L" : "Unl"));
798 retval = scsi_ioctl(STp->device, cmd, NULL);
800 STp->door_locked = do_lock ? ST_LOCKED_EXPLICIT : ST_UNLOCKED;
803 STp->door_locked = ST_LOCK_FAILS;
809 /* Set the internal state after reset */
810 static void reset_state(struct scsi_tape *STp)
813 struct st_partstat *STps;
815 STp->pos_unknown = 0;
816 for (i = 0; i < ST_NBR_PARTITIONS; i++) {
817 STps = &(STp->ps[i]);
819 STps->eof = ST_NOEOF;
821 STps->last_block_valid = 0;
822 STps->drv_block = -1;
825 if (STp->can_partitions) {
826 STp->partition = find_partition(STp);
827 if (STp->partition < 0)
829 STp->new_partition = STp->partition;
833 /* Test if the drive is ready. Returns either one of the codes below or a negative system
835 #define CHKRES_READY 0
836 #define CHKRES_NEW_SESSION 1
837 #define CHKRES_NOT_READY 2
838 #define CHKRES_NO_TAPE 3
840 #define MAX_ATTENTIONS 10
842 static int test_ready(struct scsi_tape *STp, int do_wait)
844 int attentions, waits, max_wait, scode;
845 int retval = CHKRES_READY, new_session = 0;
846 unsigned char cmd[MAX_COMMAND_SIZE];
847 struct st_request *SRpnt = NULL;
848 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
850 max_wait = do_wait ? ST_BLOCK_SECONDS : 0;
852 for (attentions=waits=0; ; ) {
853 memset((void *) &cmd[0], 0, MAX_COMMAND_SIZE);
854 cmd[0] = TEST_UNIT_READY;
855 SRpnt = st_do_scsi(SRpnt, STp, cmd, 0, DMA_NONE,
856 STp->long_timeout, MAX_READY_RETRIES, 1);
859 retval = (STp->buffer)->syscall_result;
863 if (cmdstatp->have_sense) {
865 scode = cmdstatp->sense_hdr.sense_key;
867 if (scode == UNIT_ATTENTION) { /* New media? */
869 if (attentions < MAX_ATTENTIONS) {
879 if (scode == NOT_READY) {
880 if (waits < max_wait) {
881 if (msleep_interruptible(1000)) {
889 if ((STp->device)->scsi_level >= SCSI_2 &&
890 cmdstatp->sense_hdr.asc == 0x3a) /* Check ASC */
891 retval = CHKRES_NO_TAPE;
893 retval = CHKRES_NOT_READY;
899 retval = (STp->buffer)->syscall_result;
901 retval = new_session ? CHKRES_NEW_SESSION : CHKRES_READY;
906 st_release_request(SRpnt);
911 /* See if the drive is ready and gather information about the tape. Return values:
912 < 0 negative error code from errno.h
914 1 drive not ready (possibly no tape)
916 static int check_tape(struct scsi_tape *STp, struct file *filp)
918 int i, retval, new_session = 0, do_wait;
919 unsigned char cmd[MAX_COMMAND_SIZE], saved_cleaning;
920 unsigned short st_flags = filp->f_flags;
921 struct st_request *SRpnt = NULL;
922 struct st_modedef *STm;
923 struct st_partstat *STps;
924 char *name = tape_name(STp);
925 struct inode *inode = filp->f_path.dentry->d_inode;
926 int mode = TAPE_MODE(inode);
928 STp->ready = ST_READY;
930 if (mode != STp->current_mode) {
931 DEBC(printk(ST_DEB_MSG "%s: Mode change from %d to %d.\n",
932 name, STp->current_mode, mode));
934 STp->current_mode = mode;
936 STm = &(STp->modes[STp->current_mode]);
938 saved_cleaning = STp->cleaning_req;
939 STp->cleaning_req = 0;
941 do_wait = ((filp->f_flags & O_NONBLOCK) == 0);
942 retval = test_ready(STp, do_wait);
947 if (retval == CHKRES_NEW_SESSION) {
948 STp->pos_unknown = 0;
949 STp->partition = STp->new_partition = 0;
950 if (STp->can_partitions)
951 STp->nbr_partitions = 1; /* This guess will be updated later
953 for (i = 0; i < ST_NBR_PARTITIONS; i++) {
954 STps = &(STp->ps[i]);
956 STps->eof = ST_NOEOF;
958 STps->last_block_valid = 0;
965 STp->cleaning_req |= saved_cleaning;
967 if (retval == CHKRES_NOT_READY || retval == CHKRES_NO_TAPE) {
968 if (retval == CHKRES_NO_TAPE)
969 STp->ready = ST_NO_TAPE;
971 STp->ready = ST_NOT_READY;
973 STp->density = 0; /* Clear the erroneous "residue" */
976 STp->ps[0].drv_file = STp->ps[0].drv_block = (-1);
977 STp->partition = STp->new_partition = 0;
978 STp->door_locked = ST_UNLOCKED;
979 return CHKRES_NOT_READY;
983 if (STp->omit_blklims)
984 STp->min_block = STp->max_block = (-1);
986 memset((void *) &cmd[0], 0, MAX_COMMAND_SIZE);
987 cmd[0] = READ_BLOCK_LIMITS;
989 SRpnt = st_do_scsi(SRpnt, STp, cmd, 6, DMA_FROM_DEVICE,
990 STp->device->timeout, MAX_READY_RETRIES, 1);
992 retval = (STp->buffer)->syscall_result;
996 if (!SRpnt->result && !STp->buffer->cmdstat.have_sense) {
997 STp->max_block = ((STp->buffer)->b_data[1] << 16) |
998 ((STp->buffer)->b_data[2] << 8) | (STp->buffer)->b_data[3];
999 STp->min_block = ((STp->buffer)->b_data[4] << 8) |
1000 (STp->buffer)->b_data[5];
1001 if ( DEB( debugging || ) !STp->inited)
1003 "%s: Block limits %d - %d bytes.\n", name,
1004 STp->min_block, STp->max_block);
1006 STp->min_block = STp->max_block = (-1);
1007 DEBC(printk(ST_DEB_MSG "%s: Can't read block limits.\n",
1012 memset((void *) &cmd[0], 0, MAX_COMMAND_SIZE);
1013 cmd[0] = MODE_SENSE;
1016 SRpnt = st_do_scsi(SRpnt, STp, cmd, 12, DMA_FROM_DEVICE,
1017 STp->device->timeout, MAX_READY_RETRIES, 1);
1019 retval = (STp->buffer)->syscall_result;
1023 if ((STp->buffer)->syscall_result != 0) {
1024 DEBC(printk(ST_DEB_MSG "%s: No Mode Sense.\n", name));
1025 STp->block_size = ST_DEFAULT_BLOCK; /* Educated guess (?) */
1026 (STp->buffer)->syscall_result = 0; /* Prevent error propagation */
1027 STp->drv_write_prot = 0;
1029 DEBC(printk(ST_DEB_MSG
1030 "%s: Mode sense. Length %d, medium %x, WBS %x, BLL %d\n",
1032 (STp->buffer)->b_data[0], (STp->buffer)->b_data[1],
1033 (STp->buffer)->b_data[2], (STp->buffer)->b_data[3]));
1035 if ((STp->buffer)->b_data[3] >= 8) {
1036 STp->drv_buffer = ((STp->buffer)->b_data[2] >> 4) & 7;
1037 STp->density = (STp->buffer)->b_data[4];
1038 STp->block_size = (STp->buffer)->b_data[9] * 65536 +
1039 (STp->buffer)->b_data[10] * 256 + (STp->buffer)->b_data[11];
1040 DEBC(printk(ST_DEB_MSG
1041 "%s: Density %x, tape length: %x, drv buffer: %d\n",
1042 name, STp->density, (STp->buffer)->b_data[5] * 65536 +
1043 (STp->buffer)->b_data[6] * 256 + (STp->buffer)->b_data[7],
1046 STp->drv_write_prot = ((STp->buffer)->b_data[2] & 0x80) != 0;
1048 st_release_request(SRpnt);
1052 if (STp->block_size > 0)
1053 (STp->buffer)->buffer_blocks =
1054 (STp->buffer)->buffer_size / STp->block_size;
1056 (STp->buffer)->buffer_blocks = 1;
1057 (STp->buffer)->buffer_bytes = (STp->buffer)->read_pointer = 0;
1059 DEBC(printk(ST_DEB_MSG
1060 "%s: Block size: %d, buffer size: %d (%d blocks).\n", name,
1061 STp->block_size, (STp->buffer)->buffer_size,
1062 (STp->buffer)->buffer_blocks));
1064 if (STp->drv_write_prot) {
1065 STp->write_prot = 1;
1067 DEBC(printk(ST_DEB_MSG "%s: Write protected\n", name));
1070 ((st_flags & O_ACCMODE) == O_WRONLY ||
1071 (st_flags & O_ACCMODE) == O_RDWR)) {
1077 if (STp->can_partitions && STp->nbr_partitions < 1) {
1078 /* This code is reached when the device is opened for the first time
1079 after the driver has been initialized with tape in the drive and the
1080 partition support has been enabled. */
1081 DEBC(printk(ST_DEB_MSG
1082 "%s: Updating partition number in status.\n", name));
1083 if ((STp->partition = find_partition(STp)) < 0) {
1084 retval = STp->partition;
1087 STp->new_partition = STp->partition;
1088 STp->nbr_partitions = 1; /* This guess will be updated when necessary */
1091 if (new_session) { /* Change the drive parameters for the new mode */
1092 STp->density_changed = STp->blksize_changed = 0;
1093 STp->compression_changed = 0;
1094 if (!(STm->defaults_for_writes) &&
1095 (retval = set_mode_densblk(STp, STm)) < 0)
1098 if (STp->default_drvbuffer != 0xff) {
1099 if (st_int_ioctl(STp, MTSETDRVBUFFER, STp->default_drvbuffer))
1101 "%s: Can't set default drive buffering to %d.\n",
1102 name, STp->default_drvbuffer);
1106 return CHKRES_READY;
1113 \f/* Open the device. Needs to take the BKL only because of incrementing the SCSI host
1115 static int st_open(struct inode *inode, struct file *filp)
1117 int i, retval = (-EIO);
1118 struct scsi_tape *STp;
1119 struct st_partstat *STps;
1120 int dev = TAPE_NR(inode);
1125 * We really want to do nonseekable_open(inode, filp); here, but some
1126 * versions of tar incorrectly call lseek on tapes and bail out if that
1127 * fails. So we disallow pread() and pwrite(), but permit lseeks.
1129 filp->f_mode &= ~(FMODE_PREAD | FMODE_PWRITE);
1131 if (!(STp = scsi_tape_get(dev))) {
1136 write_lock(&st_dev_arr_lock);
1137 filp->private_data = STp;
1138 name = tape_name(STp);
1141 write_unlock(&st_dev_arr_lock);
1144 DEB( printk(ST_DEB_MSG "%s: Device already in use.\n", name); )
1149 write_unlock(&st_dev_arr_lock);
1150 STp->rew_at_close = STp->autorew_dev = (iminor(inode) & 0x80) == 0;
1152 if (!scsi_block_when_processing_errors(STp->device)) {
1157 /* See that we have at least a one page buffer available */
1158 if (!enlarge_buffer(STp->buffer, PAGE_SIZE, STp->restr_dma)) {
1159 printk(KERN_WARNING "%s: Can't allocate one page tape buffer.\n",
1161 retval = (-EOVERFLOW);
1165 (STp->buffer)->cleared = 0;
1166 (STp->buffer)->writing = 0;
1167 (STp->buffer)->syscall_result = 0;
1169 STp->write_prot = ((filp->f_flags & O_ACCMODE) == O_RDONLY);
1172 for (i = 0; i < ST_NBR_PARTITIONS; i++) {
1173 STps = &(STp->ps[i]);
1176 STp->try_dio_now = STp->try_dio;
1177 STp->recover_count = 0;
1178 DEB( STp->nbr_waits = STp->nbr_finished = 0;
1179 STp->nbr_requests = STp->nbr_dio = STp->nbr_pages = 0; )
1181 retval = check_tape(STp, filp);
1184 if ((filp->f_flags & O_NONBLOCK) == 0 &&
1185 retval != CHKRES_READY) {
1186 if (STp->ready == NO_TAPE)
1187 retval = (-ENOMEDIUM);
1196 normalize_buffer(STp->buffer);
1205 /* Flush the tape buffer before close */
1206 static int st_flush(struct file *filp, fl_owner_t id)
1208 int result = 0, result2;
1209 unsigned char cmd[MAX_COMMAND_SIZE];
1210 struct st_request *SRpnt;
1211 struct scsi_tape *STp = filp->private_data;
1212 struct st_modedef *STm = &(STp->modes[STp->current_mode]);
1213 struct st_partstat *STps = &(STp->ps[STp->partition]);
1214 char *name = tape_name(STp);
1216 if (file_count(filp) > 1)
1219 if (STps->rw == ST_WRITING && !STp->pos_unknown) {
1220 result = st_flush_write_buffer(STp);
1221 if (result != 0 && result != (-ENOSPC))
1225 if (STp->can_partitions &&
1226 (result2 = switch_partition(STp)) < 0) {
1227 DEBC(printk(ST_DEB_MSG
1228 "%s: switch_partition at close failed.\n", name));
1234 DEBC( if (STp->nbr_requests)
1235 printk(KERN_DEBUG "%s: Number of r/w requests %d, dio used in %d, pages %d.\n",
1236 name, STp->nbr_requests, STp->nbr_dio, STp->nbr_pages));
1238 if (STps->rw == ST_WRITING && !STp->pos_unknown) {
1239 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
1241 DEBC(printk(ST_DEB_MSG "%s: Async write waits %d, finished %d.\n",
1242 name, STp->nbr_waits, STp->nbr_finished);
1245 memset(cmd, 0, MAX_COMMAND_SIZE);
1246 cmd[0] = WRITE_FILEMARKS;
1247 cmd[4] = 1 + STp->two_fm;
1249 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE,
1250 STp->device->timeout, MAX_WRITE_RETRIES, 1);
1252 result = (STp->buffer)->syscall_result;
1256 if (STp->buffer->syscall_result == 0 ||
1257 (cmdstatp->have_sense && !cmdstatp->deferred &&
1258 (cmdstatp->flags & SENSE_EOM) &&
1259 (cmdstatp->sense_hdr.sense_key == NO_SENSE ||
1260 cmdstatp->sense_hdr.sense_key == RECOVERED_ERROR) &&
1261 (!cmdstatp->remainder_valid || cmdstatp->uremainder64 == 0))) {
1262 /* Write successful at EOM */
1263 st_release_request(SRpnt);
1265 if (STps->drv_file >= 0)
1267 STps->drv_block = 0;
1272 else { /* Write error */
1273 st_release_request(SRpnt);
1275 printk(KERN_ERR "%s: Error on write filemark.\n", name);
1280 DEBC(printk(ST_DEB_MSG "%s: Buffer flushed, %d EOF(s) written\n",
1282 } else if (!STp->rew_at_close) {
1283 STps = &(STp->ps[STp->partition]);
1284 if (!STm->sysv || STps->rw != ST_READING) {
1286 result = flush_buffer(STp, 0);
1287 else if (STps->eof == ST_FM_HIT) {
1288 result = cross_eof(STp, 0);
1290 if (STps->drv_file >= 0)
1292 STps->drv_block = 0;
1295 STps->eof = ST_NOEOF;
1297 } else if ((STps->eof == ST_NOEOF &&
1298 !(result = cross_eof(STp, 1))) ||
1299 STps->eof == ST_FM_HIT) {
1300 if (STps->drv_file >= 0)
1302 STps->drv_block = 0;
1308 if (STp->rew_at_close) {
1309 result2 = st_int_ioctl(STp, MTREW, 1);
1317 /* Close the device and release it. BKL is not needed: this is the only thread
1318 accessing this tape. */
1319 static int st_release(struct inode *inode, struct file *filp)
1322 struct scsi_tape *STp = filp->private_data;
1324 if (STp->door_locked == ST_LOCKED_AUTO)
1325 do_door_lock(STp, 0);
1327 normalize_buffer(STp->buffer);
1328 write_lock(&st_dev_arr_lock);
1330 write_unlock(&st_dev_arr_lock);
1336 /* The checks common to both reading and writing */
1337 static ssize_t rw_checks(struct scsi_tape *STp, struct file *filp, size_t count)
1342 * If we are in the middle of error recovery, don't let anyone
1343 * else try and use this device. Also, if error recovery fails, it
1344 * may try and take the device offline, in which case all further
1345 * access to the device is prohibited.
1347 if (!scsi_block_when_processing_errors(STp->device)) {
1352 if (STp->ready != ST_READY) {
1353 if (STp->ready == ST_NO_TAPE)
1354 retval = (-ENOMEDIUM);
1360 if (! STp->modes[STp->current_mode].defined) {
1367 * If there was a bus reset, block further access
1370 if (STp->pos_unknown) {
1380 printk(ST_DEB_MSG "%s: Incorrect device.\n", tape_name(STp));
1385 if (STp->can_partitions &&
1386 (retval = switch_partition(STp)) < 0)
1389 if (STp->block_size == 0 && STp->max_block > 0 &&
1390 (count < STp->min_block || count > STp->max_block)) {
1395 if (STp->do_auto_lock && STp->door_locked == ST_UNLOCKED &&
1396 !do_door_lock(STp, 1))
1397 STp->door_locked = ST_LOCKED_AUTO;
1404 static int setup_buffering(struct scsi_tape *STp, const char __user *buf,
1405 size_t count, int is_read)
1407 int i, bufsize, retval = 0;
1408 struct st_buffer *STbp = STp->buffer;
1411 i = STp->try_dio_now && try_rdio;
1413 i = STp->try_dio_now && try_wdio;
1415 if (i && ((unsigned long)buf & queue_dma_alignment(
1416 STp->device->request_queue)) == 0) {
1417 i = sgl_map_user_pages(&(STbp->sg[0]), STbp->use_sg,
1418 (unsigned long)buf, count, (is_read ? READ : WRITE));
1421 STbp->buffer_bytes = 0; /* can be used as transfer counter */
1424 STbp->do_dio = 0; /* fall back to buffering with any error */
1425 STbp->sg_segs = STbp->do_dio;
1426 STbp->frp_sg_current = 0;
1430 STp->nbr_pages += STbp->do_dio;
1435 DEB( STp->nbr_requests++; )
1437 if (!STbp->do_dio) {
1438 if (STp->block_size)
1439 bufsize = STp->block_size > st_fixed_buffer_size ?
1440 STp->block_size : st_fixed_buffer_size;
1443 /* Make sure that data from previous user is not leaked even if
1444 HBA does not return correct residual */
1445 if (is_read && STp->sili && !STbp->cleared)
1449 if (bufsize > STbp->buffer_size &&
1450 !enlarge_buffer(STbp, bufsize, STp->restr_dma)) {
1451 printk(KERN_WARNING "%s: Can't allocate %d byte tape buffer.\n",
1452 tape_name(STp), bufsize);
1453 retval = (-EOVERFLOW);
1456 if (STp->block_size)
1457 STbp->buffer_blocks = bufsize / STp->block_size;
1465 /* Can be called more than once after each setup_buffer() */
1466 static void release_buffering(struct scsi_tape *STp, int is_read)
1468 struct st_buffer *STbp;
1472 sgl_unmap_user_pages(&(STbp->sg[0]), STbp->do_dio, is_read);
1481 st_write(struct file *filp, const char __user *buf, size_t count, loff_t * ppos)
1484 ssize_t i, do_count, blks, transfer;
1486 int undone, retry_eot = 0, scode;
1488 unsigned char cmd[MAX_COMMAND_SIZE];
1489 const char __user *b_point;
1490 struct st_request *SRpnt = NULL;
1491 struct scsi_tape *STp = filp->private_data;
1492 struct st_modedef *STm;
1493 struct st_partstat *STps;
1494 struct st_buffer *STbp;
1495 char *name = tape_name(STp);
1497 if (mutex_lock_interruptible(&STp->lock))
1498 return -ERESTARTSYS;
1500 retval = rw_checks(STp, filp, count);
1501 if (retval || count == 0)
1504 /* Write must be integral number of blocks */
1505 if (STp->block_size != 0 && (count % STp->block_size) != 0) {
1506 printk(KERN_WARNING "%s: Write not multiple of tape block size.\n",
1512 STm = &(STp->modes[STp->current_mode]);
1513 STps = &(STp->ps[STp->partition]);
1515 if (STp->write_prot) {
1521 if (STps->rw == ST_READING) {
1522 retval = flush_buffer(STp, 0);
1525 STps->rw = ST_WRITING;
1526 } else if (STps->rw != ST_WRITING &&
1527 STps->drv_file == 0 && STps->drv_block == 0) {
1528 if ((retval = set_mode_densblk(STp, STm)) < 0)
1530 if (STm->default_compression != ST_DONT_TOUCH &&
1531 !(STp->compression_changed)) {
1532 if (st_compression(STp, (STm->default_compression == ST_YES))) {
1533 printk(KERN_WARNING "%s: Can't set default compression.\n",
1535 if (modes_defined) {
1544 i = write_behind_check(STp);
1547 STps->eof = ST_EOM_OK;
1549 STps->eof = ST_EOM_ERROR;
1552 if (STps->eof == ST_EOM_OK) {
1553 STps->eof = ST_EOD_1; /* allow next write */
1557 else if (STps->eof == ST_EOM_ERROR) {
1562 /* Check the buffer readability in cases where copy_user might catch
1563 the problems after some tape movement. */
1564 if (STp->block_size != 0 &&
1566 (copy_from_user(&i, buf, 1) != 0 ||
1567 copy_from_user(&i, buf + count - 1, 1) != 0)) {
1572 retval = setup_buffering(STp, buf, count, 0);
1578 memset(cmd, 0, MAX_COMMAND_SIZE);
1580 cmd[1] = (STp->block_size != 0);
1582 STps->rw = ST_WRITING;
1585 while (count > 0 && !retry_eot) {
1591 if (STp->block_size == 0)
1594 do_count = STbp->buffer_blocks * STp->block_size -
1596 if (do_count > count)
1600 i = append_to_buffer(b_point, STbp, do_count);
1607 b_point += do_count;
1609 async_write = STp->block_size == 0 && !STbp->do_dio &&
1610 STm->do_async_writes && STps->eof < ST_EOM_OK;
1612 if (STp->block_size != 0 && STm->do_buffer_writes &&
1613 !(STp->try_dio_now && try_wdio) && STps->eof < ST_EOM_OK &&
1614 STbp->buffer_bytes < STbp->buffer_size) {
1616 /* Don't write a buffer that is not full enough. */
1617 if (!async_write && count == 0)
1622 if (STp->block_size == 0)
1623 blks = transfer = do_count;
1626 blks = STbp->buffer_bytes;
1629 blks /= STp->block_size;
1630 transfer = blks * STp->block_size;
1632 cmd[2] = blks >> 16;
1636 SRpnt = st_do_scsi(SRpnt, STp, cmd, transfer, DMA_TO_DEVICE,
1637 STp->device->timeout, MAX_WRITE_RETRIES, !async_write);
1639 retval = STbp->syscall_result;
1642 if (async_write && !STbp->syscall_result) {
1643 STbp->writing = transfer;
1644 STp->dirty = !(STbp->writing ==
1645 STbp->buffer_bytes);
1646 SRpnt = NULL; /* Prevent releasing this request! */
1647 DEB( STp->write_pending = 1; )
1651 if (STbp->syscall_result != 0) {
1652 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
1654 DEBC(printk(ST_DEB_MSG "%s: Error on write:\n", name));
1655 if (cmdstatp->have_sense && (cmdstatp->flags & SENSE_EOM)) {
1656 scode = cmdstatp->sense_hdr.sense_key;
1657 if (cmdstatp->remainder_valid)
1658 undone = (int)cmdstatp->uremainder64;
1659 else if (STp->block_size == 0 &&
1660 scode == VOLUME_OVERFLOW)
1664 if (STp->block_size != 0)
1665 undone *= STp->block_size;
1666 if (undone <= do_count) {
1667 /* Only data from this write is not written */
1671 if (STp->block_size)
1672 blks = (transfer - undone) / STp->block_size;
1673 STps->eof = ST_EOM_OK;
1674 /* Continue in fixed block mode if all written
1675 in this request but still something left to write
1676 (retval left to zero)
1678 if (STp->block_size == 0 ||
1679 undone > 0 || count == 0)
1680 retval = (-ENOSPC); /* EOM within current request */
1681 DEBC(printk(ST_DEB_MSG
1682 "%s: EOM with %d bytes unwritten.\n",
1685 /* EOT within data buffered earlier (possible only
1686 in fixed block mode without direct i/o) */
1687 if (!retry_eot && !cmdstatp->deferred &&
1688 (scode == NO_SENSE || scode == RECOVERED_ERROR)) {
1689 move_buffer_data(STp->buffer, transfer - undone);
1691 if (STps->drv_block >= 0) {
1692 STps->drv_block += (transfer - undone) /
1695 STps->eof = ST_EOM_OK;
1696 DEBC(printk(ST_DEB_MSG
1697 "%s: Retry write of %d bytes at EOM.\n",
1698 name, STp->buffer->buffer_bytes));
1702 /* Either error within data buffered by driver or
1705 blks = do_count = 0;
1706 STps->eof = ST_EOM_ERROR;
1707 STps->drv_block = (-1); /* Too cautious? */
1708 retval = (-EIO); /* EOM for old data */
1709 DEBC(printk(ST_DEB_MSG
1710 "%s: EOM with lost data.\n",
1716 STps->drv_block = (-1); /* Too cautious? */
1717 retval = STbp->syscall_result;
1722 if (STps->drv_block >= 0) {
1723 if (STp->block_size == 0)
1724 STps->drv_block += (do_count > 0);
1726 STps->drv_block += blks;
1729 STbp->buffer_bytes = 0;
1732 if (retval || retry_eot) {
1734 retval = total - count;
1739 if (STps->eof == ST_EOD_1)
1740 STps->eof = ST_EOM_OK;
1741 else if (STps->eof != ST_EOM_OK)
1742 STps->eof = ST_NOEOF;
1743 retval = total - count;
1747 st_release_request(SRpnt);
1748 release_buffering(STp, 0);
1749 mutex_unlock(&STp->lock);
1754 /* Read data from the tape. Returns zero in the normal case, one if the
1755 eof status has changed, and the negative error code in case of a
1756 fatal error. Otherwise updates the buffer and the eof state.
1758 Does release user buffer mapping if it is set.
1760 static long read_tape(struct scsi_tape *STp, long count,
1761 struct st_request ** aSRpnt)
1763 int transfer, blks, bytes;
1764 unsigned char cmd[MAX_COMMAND_SIZE];
1765 struct st_request *SRpnt;
1766 struct st_modedef *STm;
1767 struct st_partstat *STps;
1768 struct st_buffer *STbp;
1770 char *name = tape_name(STp);
1775 STm = &(STp->modes[STp->current_mode]);
1776 STps = &(STp->ps[STp->partition]);
1777 if (STps->eof == ST_FM_HIT)
1781 if (STp->block_size == 0)
1782 blks = bytes = count;
1784 if (!(STp->try_dio_now && try_rdio) && STm->do_read_ahead) {
1785 blks = (STp->buffer)->buffer_blocks;
1786 bytes = blks * STp->block_size;
1789 if (!STbp->do_dio && bytes > (STp->buffer)->buffer_size)
1790 bytes = (STp->buffer)->buffer_size;
1791 blks = bytes / STp->block_size;
1792 bytes = blks * STp->block_size;
1796 memset(cmd, 0, MAX_COMMAND_SIZE);
1798 cmd[1] = (STp->block_size != 0);
1799 if (!cmd[1] && STp->sili)
1801 cmd[2] = blks >> 16;
1806 SRpnt = st_do_scsi(SRpnt, STp, cmd, bytes, DMA_FROM_DEVICE,
1807 STp->device->timeout, MAX_RETRIES, 1);
1808 release_buffering(STp, 1);
1811 return STbp->syscall_result;
1813 STbp->read_pointer = 0;
1816 /* Something to check */
1817 if (STbp->syscall_result) {
1818 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
1821 DEBC(printk(ST_DEB_MSG "%s: Sense: %2x %2x %2x %2x %2x %2x %2x %2x\n",
1823 SRpnt->sense[0], SRpnt->sense[1],
1824 SRpnt->sense[2], SRpnt->sense[3],
1825 SRpnt->sense[4], SRpnt->sense[5],
1826 SRpnt->sense[6], SRpnt->sense[7]));
1827 if (cmdstatp->have_sense) {
1829 if (cmdstatp->sense_hdr.sense_key == BLANK_CHECK)
1830 cmdstatp->flags &= 0xcf; /* No need for EOM in this case */
1832 if (cmdstatp->flags != 0) { /* EOF, EOM, or ILI */
1833 /* Compute the residual count */
1834 if (cmdstatp->remainder_valid)
1835 transfer = (int)cmdstatp->uremainder64;
1838 if (STp->block_size == 0 &&
1839 cmdstatp->sense_hdr.sense_key == MEDIUM_ERROR)
1842 if (cmdstatp->flags & SENSE_ILI) { /* ILI */
1843 if (STp->block_size == 0) {
1844 if (transfer <= 0) {
1847 "%s: Failed to read %d byte block with %d byte transfer.\n",
1848 name, bytes - transfer, bytes);
1849 if (STps->drv_block >= 0)
1850 STps->drv_block += 1;
1851 STbp->buffer_bytes = 0;
1854 STbp->buffer_bytes = bytes - transfer;
1856 st_release_request(SRpnt);
1857 SRpnt = *aSRpnt = NULL;
1858 if (transfer == blks) { /* We did not get anything, error */
1859 printk(KERN_NOTICE "%s: Incorrect block size.\n", name);
1860 if (STps->drv_block >= 0)
1861 STps->drv_block += blks - transfer + 1;
1862 st_int_ioctl(STp, MTBSR, 1);
1865 /* We have some data, deliver it */
1866 STbp->buffer_bytes = (blks - transfer) *
1868 DEBC(printk(ST_DEB_MSG
1869 "%s: ILI but enough data received %ld %d.\n",
1870 name, count, STbp->buffer_bytes));
1871 if (STps->drv_block >= 0)
1872 STps->drv_block += 1;
1873 if (st_int_ioctl(STp, MTBSR, 1))
1876 } else if (cmdstatp->flags & SENSE_FMK) { /* FM overrides EOM */
1877 if (STps->eof != ST_FM_HIT)
1878 STps->eof = ST_FM_HIT;
1880 STps->eof = ST_EOD_2;
1881 if (STp->block_size == 0)
1882 STbp->buffer_bytes = 0;
1884 STbp->buffer_bytes =
1885 bytes - transfer * STp->block_size;
1886 DEBC(printk(ST_DEB_MSG
1887 "%s: EOF detected (%d bytes read).\n",
1888 name, STbp->buffer_bytes));
1889 } else if (cmdstatp->flags & SENSE_EOM) {
1890 if (STps->eof == ST_FM)
1891 STps->eof = ST_EOD_1;
1893 STps->eof = ST_EOM_OK;
1894 if (STp->block_size == 0)
1895 STbp->buffer_bytes = bytes - transfer;
1897 STbp->buffer_bytes =
1898 bytes - transfer * STp->block_size;
1900 DEBC(printk(ST_DEB_MSG "%s: EOM detected (%d bytes read).\n",
1901 name, STbp->buffer_bytes));
1904 /* end of EOF, EOM, ILI test */
1905 else { /* nonzero sense key */
1906 DEBC(printk(ST_DEB_MSG
1907 "%s: Tape error while reading.\n", name));
1908 STps->drv_block = (-1);
1909 if (STps->eof == ST_FM &&
1910 cmdstatp->sense_hdr.sense_key == BLANK_CHECK) {
1911 DEBC(printk(ST_DEB_MSG
1912 "%s: Zero returned for first BLANK CHECK after EOF.\n",
1914 STps->eof = ST_EOD_2; /* First BLANK_CHECK after FM */
1915 } else /* Some other extended sense code */
1919 if (STbp->buffer_bytes < 0) /* Caused by bogus sense data */
1920 STbp->buffer_bytes = 0;
1922 /* End of extended sense test */
1923 else { /* Non-extended sense */
1924 retval = STbp->syscall_result;
1928 /* End of error handling */
1929 else { /* Read successful */
1930 STbp->buffer_bytes = bytes;
1931 if (STp->sili) /* In fixed block mode residual is always zero here */
1932 STbp->buffer_bytes -= STp->buffer->cmdstat.residual;
1935 if (STps->drv_block >= 0) {
1936 if (STp->block_size == 0)
1939 STps->drv_block += STbp->buffer_bytes / STp->block_size;
1947 st_read(struct file *filp, char __user *buf, size_t count, loff_t * ppos)
1951 ssize_t i, transfer;
1952 int special, do_dio = 0;
1953 struct st_request *SRpnt = NULL;
1954 struct scsi_tape *STp = filp->private_data;
1955 struct st_modedef *STm;
1956 struct st_partstat *STps;
1957 struct st_buffer *STbp = STp->buffer;
1958 DEB( char *name = tape_name(STp); )
1960 if (mutex_lock_interruptible(&STp->lock))
1961 return -ERESTARTSYS;
1963 retval = rw_checks(STp, filp, count);
1964 if (retval || count == 0)
1967 STm = &(STp->modes[STp->current_mode]);
1968 if (STp->block_size != 0 && (count % STp->block_size) != 0) {
1969 if (!STm->do_read_ahead) {
1970 retval = (-EINVAL); /* Read must be integral number of blocks */
1973 STp->try_dio_now = 0; /* Direct i/o can't handle split blocks */
1976 STps = &(STp->ps[STp->partition]);
1977 if (STps->rw == ST_WRITING) {
1978 retval = flush_buffer(STp, 0);
1981 STps->rw = ST_READING;
1984 if (debugging && STps->eof != ST_NOEOF)
1985 printk(ST_DEB_MSG "%s: EOF/EOM flag up (%d). Bytes %d\n", name,
1986 STps->eof, STbp->buffer_bytes);
1989 retval = setup_buffering(STp, buf, count, 1);
1992 do_dio = STbp->do_dio;
1994 if (STbp->buffer_bytes == 0 &&
1995 STps->eof >= ST_EOD_1) {
1996 if (STps->eof < ST_EOD) {
2001 retval = (-EIO); /* EOM or Blank Check */
2006 /* Check the buffer writability before any tape movement. Don't alter
2008 if (copy_from_user(&i, buf, 1) != 0 ||
2009 copy_to_user(buf, &i, 1) != 0 ||
2010 copy_from_user(&i, buf + count - 1, 1) != 0 ||
2011 copy_to_user(buf + count - 1, &i, 1) != 0) {
2017 STps->rw = ST_READING;
2020 /* Loop until enough data in buffer or a special condition found */
2021 for (total = 0, special = 0; total < count && !special;) {
2023 /* Get new data if the buffer is empty */
2024 if (STbp->buffer_bytes == 0) {
2025 special = read_tape(STp, count - total, &SRpnt);
2026 if (special < 0) { /* No need to continue read */
2032 /* Move the data from driver buffer to user buffer */
2033 if (STbp->buffer_bytes > 0) {
2035 if (debugging && STps->eof != ST_NOEOF)
2037 "%s: EOF up (%d). Left %d, needed %d.\n", name,
2038 STps->eof, STbp->buffer_bytes,
2039 (int)(count - total));
2041 transfer = STbp->buffer_bytes < count - total ?
2042 STbp->buffer_bytes : count - total;
2044 i = from_buffer(STbp, buf, transfer);
2054 if (STp->block_size == 0)
2055 break; /* Read only one variable length block */
2057 } /* for (total = 0, special = 0;
2058 total < count && !special; ) */
2060 /* Change the eof state if no data from tape or buffer */
2062 if (STps->eof == ST_FM_HIT) {
2064 STps->drv_block = 0;
2065 if (STps->drv_file >= 0)
2067 } else if (STps->eof == ST_EOD_1) {
2068 STps->eof = ST_EOD_2;
2069 STps->drv_block = 0;
2070 if (STps->drv_file >= 0)
2072 } else if (STps->eof == ST_EOD_2)
2074 } else if (STps->eof == ST_FM)
2075 STps->eof = ST_NOEOF;
2079 if (SRpnt != NULL) {
2080 st_release_request(SRpnt);
2084 release_buffering(STp, 1);
2085 STbp->buffer_bytes = 0;
2087 mutex_unlock(&STp->lock);
2095 /* Set the driver options */
2096 static void st_log_options(struct scsi_tape * STp, struct st_modedef * STm, char *name)
2100 "%s: Mode %d options: buffer writes: %d, async writes: %d, read ahead: %d\n",
2101 name, STp->current_mode, STm->do_buffer_writes, STm->do_async_writes,
2102 STm->do_read_ahead);
2104 "%s: can bsr: %d, two FMs: %d, fast mteom: %d, auto lock: %d,\n",
2105 name, STp->can_bsr, STp->two_fm, STp->fast_mteom, STp->do_auto_lock);
2107 "%s: defs for wr: %d, no block limits: %d, partitions: %d, s2 log: %d\n",
2108 name, STm->defaults_for_writes, STp->omit_blklims, STp->can_partitions,
2109 STp->scsi2_logical);
2111 "%s: sysv: %d nowait: %d sili: %d\n", name, STm->sysv, STp->immediate,
2113 printk(KERN_INFO "%s: debugging: %d\n",
2120 static int st_set_options(struct scsi_tape *STp, long options)
2124 struct st_modedef *STm;
2125 char *name = tape_name(STp);
2126 struct cdev *cd0, *cd1;
2128 STm = &(STp->modes[STp->current_mode]);
2129 if (!STm->defined) {
2130 cd0 = STm->cdevs[0]; cd1 = STm->cdevs[1];
2131 memcpy(STm, &(STp->modes[0]), sizeof(struct st_modedef));
2132 STm->cdevs[0] = cd0; STm->cdevs[1] = cd1;
2134 DEBC(printk(ST_DEB_MSG
2135 "%s: Initialized mode %d definition from mode 0\n",
2136 name, STp->current_mode));
2139 code = options & MT_ST_OPTIONS;
2140 if (code == MT_ST_BOOLEANS) {
2141 STm->do_buffer_writes = (options & MT_ST_BUFFER_WRITES) != 0;
2142 STm->do_async_writes = (options & MT_ST_ASYNC_WRITES) != 0;
2143 STm->defaults_for_writes = (options & MT_ST_DEF_WRITES) != 0;
2144 STm->do_read_ahead = (options & MT_ST_READ_AHEAD) != 0;
2145 STp->two_fm = (options & MT_ST_TWO_FM) != 0;
2146 STp->fast_mteom = (options & MT_ST_FAST_MTEOM) != 0;
2147 STp->do_auto_lock = (options & MT_ST_AUTO_LOCK) != 0;
2148 STp->can_bsr = (options & MT_ST_CAN_BSR) != 0;
2149 STp->omit_blklims = (options & MT_ST_NO_BLKLIMS) != 0;
2150 if ((STp->device)->scsi_level >= SCSI_2)
2151 STp->can_partitions = (options & MT_ST_CAN_PARTITIONS) != 0;
2152 STp->scsi2_logical = (options & MT_ST_SCSI2LOGICAL) != 0;
2153 STp->immediate = (options & MT_ST_NOWAIT) != 0;
2154 STm->sysv = (options & MT_ST_SYSV) != 0;
2155 STp->sili = (options & MT_ST_SILI) != 0;
2156 DEB( debugging = (options & MT_ST_DEBUGGING) != 0;
2157 st_log_options(STp, STm, name); )
2158 } else if (code == MT_ST_SETBOOLEANS || code == MT_ST_CLEARBOOLEANS) {
2159 value = (code == MT_ST_SETBOOLEANS);
2160 if ((options & MT_ST_BUFFER_WRITES) != 0)
2161 STm->do_buffer_writes = value;
2162 if ((options & MT_ST_ASYNC_WRITES) != 0)
2163 STm->do_async_writes = value;
2164 if ((options & MT_ST_DEF_WRITES) != 0)
2165 STm->defaults_for_writes = value;
2166 if ((options & MT_ST_READ_AHEAD) != 0)
2167 STm->do_read_ahead = value;
2168 if ((options & MT_ST_TWO_FM) != 0)
2169 STp->two_fm = value;
2170 if ((options & MT_ST_FAST_MTEOM) != 0)
2171 STp->fast_mteom = value;
2172 if ((options & MT_ST_AUTO_LOCK) != 0)
2173 STp->do_auto_lock = value;
2174 if ((options & MT_ST_CAN_BSR) != 0)
2175 STp->can_bsr = value;
2176 if ((options & MT_ST_NO_BLKLIMS) != 0)
2177 STp->omit_blklims = value;
2178 if ((STp->device)->scsi_level >= SCSI_2 &&
2179 (options & MT_ST_CAN_PARTITIONS) != 0)
2180 STp->can_partitions = value;
2181 if ((options & MT_ST_SCSI2LOGICAL) != 0)
2182 STp->scsi2_logical = value;
2183 if ((options & MT_ST_NOWAIT) != 0)
2184 STp->immediate = value;
2185 if ((options & MT_ST_SYSV) != 0)
2187 if ((options & MT_ST_SILI) != 0)
2190 if ((options & MT_ST_DEBUGGING) != 0)
2192 st_log_options(STp, STm, name); )
2193 } else if (code == MT_ST_WRITE_THRESHOLD) {
2194 /* Retained for compatibility */
2195 } else if (code == MT_ST_DEF_BLKSIZE) {
2196 value = (options & ~MT_ST_OPTIONS);
2197 if (value == ~MT_ST_OPTIONS) {
2198 STm->default_blksize = (-1);
2199 DEBC( printk(KERN_INFO "%s: Default block size disabled.\n", name));
2201 STm->default_blksize = value;
2202 DEBC( printk(KERN_INFO "%s: Default block size set to %d bytes.\n",
2203 name, STm->default_blksize));
2204 if (STp->ready == ST_READY) {
2205 STp->blksize_changed = 0;
2206 set_mode_densblk(STp, STm);
2209 } else if (code == MT_ST_TIMEOUTS) {
2210 value = (options & ~MT_ST_OPTIONS);
2211 if ((value & MT_ST_SET_LONG_TIMEOUT) != 0) {
2212 STp->long_timeout = (value & ~MT_ST_SET_LONG_TIMEOUT) * HZ;
2213 DEBC( printk(KERN_INFO "%s: Long timeout set to %d seconds.\n", name,
2214 (value & ~MT_ST_SET_LONG_TIMEOUT)));
2216 STp->device->timeout = value * HZ;
2217 DEBC( printk(KERN_INFO "%s: Normal timeout set to %d seconds.\n",
2220 } else if (code == MT_ST_SET_CLN) {
2221 value = (options & ~MT_ST_OPTIONS) & 0xff;
2223 value < EXTENDED_SENSE_START && value >= SCSI_SENSE_BUFFERSIZE)
2225 STp->cln_mode = value;
2226 STp->cln_sense_mask = (options >> 8) & 0xff;
2227 STp->cln_sense_value = (options >> 16) & 0xff;
2229 "%s: Cleaning request mode %d, mask %02x, value %02x\n",
2230 name, value, STp->cln_sense_mask, STp->cln_sense_value);
2231 } else if (code == MT_ST_DEF_OPTIONS) {
2232 code = (options & ~MT_ST_CLEAR_DEFAULT);
2233 value = (options & MT_ST_CLEAR_DEFAULT);
2234 if (code == MT_ST_DEF_DENSITY) {
2235 if (value == MT_ST_CLEAR_DEFAULT) {
2236 STm->default_density = (-1);
2237 DEBC( printk(KERN_INFO "%s: Density default disabled.\n",
2240 STm->default_density = value & 0xff;
2241 DEBC( printk(KERN_INFO "%s: Density default set to %x\n",
2242 name, STm->default_density));
2243 if (STp->ready == ST_READY) {
2244 STp->density_changed = 0;
2245 set_mode_densblk(STp, STm);
2248 } else if (code == MT_ST_DEF_DRVBUFFER) {
2249 if (value == MT_ST_CLEAR_DEFAULT) {
2250 STp->default_drvbuffer = 0xff;
2251 DEBC( printk(KERN_INFO
2252 "%s: Drive buffer default disabled.\n", name));
2254 STp->default_drvbuffer = value & 7;
2255 DEBC( printk(KERN_INFO
2256 "%s: Drive buffer default set to %x\n",
2257 name, STp->default_drvbuffer));
2258 if (STp->ready == ST_READY)
2259 st_int_ioctl(STp, MTSETDRVBUFFER, STp->default_drvbuffer);
2261 } else if (code == MT_ST_DEF_COMPRESSION) {
2262 if (value == MT_ST_CLEAR_DEFAULT) {
2263 STm->default_compression = ST_DONT_TOUCH;
2264 DEBC( printk(KERN_INFO
2265 "%s: Compression default disabled.\n", name));
2267 if ((value & 0xff00) != 0) {
2268 STp->c_algo = (value & 0xff00) >> 8;
2269 DEBC( printk(KERN_INFO "%s: Compression algorithm set to 0x%x.\n",
2270 name, STp->c_algo));
2272 if ((value & 0xff) != 0xff) {
2273 STm->default_compression = (value & 1 ? ST_YES : ST_NO);
2274 DEBC( printk(KERN_INFO "%s: Compression default set to %x\n",
2275 name, (value & 1)));
2276 if (STp->ready == ST_READY) {
2277 STp->compression_changed = 0;
2278 st_compression(STp, (STm->default_compression == ST_YES));
2289 #define MODE_HEADER_LENGTH 4
2291 /* Mode header and page byte offsets */
2292 #define MH_OFF_DATA_LENGTH 0
2293 #define MH_OFF_MEDIUM_TYPE 1
2294 #define MH_OFF_DEV_SPECIFIC 2
2295 #define MH_OFF_BDESCS_LENGTH 3
2296 #define MP_OFF_PAGE_NBR 0
2297 #define MP_OFF_PAGE_LENGTH 1
2299 /* Mode header and page bit masks */
2300 #define MH_BIT_WP 0x80
2301 #define MP_MSK_PAGE_NBR 0x3f
2303 /* Don't return block descriptors */
2304 #define MODE_SENSE_OMIT_BDESCS 0x08
2306 #define MODE_SELECT_PAGE_FORMAT 0x10
2308 /* Read a mode page into the tape buffer. The block descriptors are included
2309 if incl_block_descs is true. The page control is ored to the page number
2310 parameter, if necessary. */
2311 static int read_mode_page(struct scsi_tape *STp, int page, int omit_block_descs)
2313 unsigned char cmd[MAX_COMMAND_SIZE];
2314 struct st_request *SRpnt = NULL;
2316 memset(cmd, 0, MAX_COMMAND_SIZE);
2317 cmd[0] = MODE_SENSE;
2318 if (omit_block_descs)
2319 cmd[1] = MODE_SENSE_OMIT_BDESCS;
2323 SRpnt = st_do_scsi(SRpnt, STp, cmd, cmd[4], DMA_FROM_DEVICE,
2324 STp->device->timeout, 0, 1);
2326 return (STp->buffer)->syscall_result;
2328 st_release_request(SRpnt);
2330 return (STp->buffer)->syscall_result;
2334 /* Send the mode page in the tape buffer to the drive. Assumes that the mode data
2335 in the buffer is correctly formatted. The long timeout is used if slow is non-zero. */
2336 static int write_mode_page(struct scsi_tape *STp, int page, int slow)
2339 unsigned char cmd[MAX_COMMAND_SIZE];
2340 struct st_request *SRpnt = NULL;
2342 memset(cmd, 0, MAX_COMMAND_SIZE);
2343 cmd[0] = MODE_SELECT;
2344 cmd[1] = MODE_SELECT_PAGE_FORMAT;
2345 pgo = MODE_HEADER_LENGTH + (STp->buffer)->b_data[MH_OFF_BDESCS_LENGTH];
2346 cmd[4] = pgo + (STp->buffer)->b_data[pgo + MP_OFF_PAGE_LENGTH] + 2;
2348 /* Clear reserved fields */
2349 (STp->buffer)->b_data[MH_OFF_DATA_LENGTH] = 0;
2350 (STp->buffer)->b_data[MH_OFF_MEDIUM_TYPE] = 0;
2351 (STp->buffer)->b_data[MH_OFF_DEV_SPECIFIC] &= ~MH_BIT_WP;
2352 (STp->buffer)->b_data[pgo + MP_OFF_PAGE_NBR] &= MP_MSK_PAGE_NBR;
2354 SRpnt = st_do_scsi(SRpnt, STp, cmd, cmd[4], DMA_TO_DEVICE,
2355 (slow ? STp->long_timeout : STp->device->timeout), 0, 1);
2357 return (STp->buffer)->syscall_result;
2359 st_release_request(SRpnt);
2361 return (STp->buffer)->syscall_result;
2365 #define COMPRESSION_PAGE 0x0f
2366 #define COMPRESSION_PAGE_LENGTH 16
2368 #define CP_OFF_DCE_DCC 2
2369 #define CP_OFF_C_ALGO 7
2371 #define DCE_MASK 0x80
2372 #define DCC_MASK 0x40
2373 #define RED_MASK 0x60
2376 /* Control the compression with mode page 15. Algorithm not changed if zero.
2378 The block descriptors are read and written because Sony SDT-7000 does not
2379 work without this (suggestion from Michael Schaefer <Michael.Schaefer@dlr.de>).
2380 Including block descriptors should not cause any harm to other drives. */
2382 static int st_compression(struct scsi_tape * STp, int state)
2385 int mpoffs; /* Offset to mode page start */
2386 unsigned char *b_data = (STp->buffer)->b_data;
2387 DEB( char *name = tape_name(STp); )
2389 if (STp->ready != ST_READY)
2392 /* Read the current page contents */
2393 retval = read_mode_page(STp, COMPRESSION_PAGE, 0);
2395 DEBC(printk(ST_DEB_MSG "%s: Compression mode page not supported.\n",
2400 mpoffs = MODE_HEADER_LENGTH + b_data[MH_OFF_BDESCS_LENGTH];
2401 DEBC(printk(ST_DEB_MSG "%s: Compression state is %d.\n", name,
2402 (b_data[mpoffs + CP_OFF_DCE_DCC] & DCE_MASK ? 1 : 0)));
2404 /* Check if compression can be changed */
2405 if ((b_data[mpoffs + CP_OFF_DCE_DCC] & DCC_MASK) == 0) {
2406 DEBC(printk(ST_DEB_MSG "%s: Compression not supported.\n", name));
2412 b_data[mpoffs + CP_OFF_DCE_DCC] |= DCE_MASK;
2413 if (STp->c_algo != 0)
2414 b_data[mpoffs + CP_OFF_C_ALGO] = STp->c_algo;
2417 b_data[mpoffs + CP_OFF_DCE_DCC] &= ~DCE_MASK;
2418 if (STp->c_algo != 0)
2419 b_data[mpoffs + CP_OFF_C_ALGO] = 0; /* no compression */
2422 retval = write_mode_page(STp, COMPRESSION_PAGE, 0);
2424 DEBC(printk(ST_DEB_MSG "%s: Compression change failed.\n", name));
2427 DEBC(printk(ST_DEB_MSG "%s: Compression state changed to %d.\n",
2430 STp->compression_changed = 1;
2435 /* Process the load and unload commands (does unload if the load code is zero) */
2436 static int do_load_unload(struct scsi_tape *STp, struct file *filp, int load_code)
2438 int retval = (-EIO), timeout;
2439 DEB( char *name = tape_name(STp); )
2440 unsigned char cmd[MAX_COMMAND_SIZE];
2441 struct st_partstat *STps;
2442 struct st_request *SRpnt;
2444 if (STp->ready != ST_READY && !load_code) {
2445 if (STp->ready == ST_NO_TAPE)
2446 return (-ENOMEDIUM);
2451 memset(cmd, 0, MAX_COMMAND_SIZE);
2452 cmd[0] = START_STOP;
2456 * If arg >= 1 && arg <= 6 Enhanced load/unload in HP C1553A
2458 if (load_code >= 1 + MT_ST_HPLOADER_OFFSET
2459 && load_code <= 6 + MT_ST_HPLOADER_OFFSET) {
2460 DEBC(printk(ST_DEB_MSG "%s: Enhanced %sload slot %2d.\n",
2461 name, (cmd[4]) ? "" : "un",
2462 load_code - MT_ST_HPLOADER_OFFSET));
2463 cmd[3] = load_code - MT_ST_HPLOADER_OFFSET; /* MediaID field of C1553A */
2465 if (STp->immediate) {
2466 cmd[1] = 1; /* Don't wait for completion */
2467 timeout = STp->device->timeout;
2470 timeout = STp->long_timeout;
2474 printk(ST_DEB_MSG "%s: Unloading tape.\n", name);
2476 printk(ST_DEB_MSG "%s: Loading tape.\n", name);
2479 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE,
2480 timeout, MAX_RETRIES, 1);
2482 return (STp->buffer)->syscall_result;
2484 retval = (STp->buffer)->syscall_result;
2485 st_release_request(SRpnt);
2487 if (!retval) { /* SCSI command successful */
2490 STp->rew_at_close = 0;
2491 STp->ready = ST_NO_TAPE;
2494 STp->rew_at_close = STp->autorew_dev;
2495 retval = check_tape(STp, filp);
2501 STps = &(STp->ps[STp->partition]);
2502 STps->drv_file = STps->drv_block = (-1);
2509 #define ST_DEB_FORWARD 0
2510 #define ST_DEB_BACKWARD 1
2511 static void deb_space_print(char *name, int direction, char *units, unsigned char *cmd)
2515 sc = cmd[2] & 0x80 ? 0xff000000 : 0;
2516 sc |= (cmd[2] << 16) | (cmd[3] << 8) | cmd[4];
2519 printk(ST_DEB_MSG "%s: Spacing tape %s over %d %s.\n", name,
2520 direction ? "backward" : "forward", sc, units);
2525 /* Internal ioctl function */
2526 static int st_int_ioctl(struct scsi_tape *STp, unsigned int cmd_in, unsigned long arg)
2532 unsigned char cmd[MAX_COMMAND_SIZE];
2533 struct st_request *SRpnt;
2534 struct st_partstat *STps;
2535 int fileno, blkno, at_sm, undone;
2536 int datalen = 0, direction = DMA_NONE;
2537 char *name = tape_name(STp);
2539 WARN_ON(STp->buffer->do_dio != 0);
2540 if (STp->ready != ST_READY) {
2541 if (STp->ready == ST_NO_TAPE)
2542 return (-ENOMEDIUM);
2546 timeout = STp->long_timeout;
2547 STps = &(STp->ps[STp->partition]);
2548 fileno = STps->drv_file;
2549 blkno = STps->drv_block;
2550 at_sm = STps->at_sm;
2552 memset(cmd, 0, MAX_COMMAND_SIZE);
2555 chg_eof = 0; /* Changed from the FSF after this */
2558 cmd[1] = 0x01; /* Space FileMarks */
2559 cmd[2] = (arg >> 16);
2560 cmd[3] = (arg >> 8);
2562 DEBC(deb_space_print(name, ST_DEB_FORWARD, "filemarks", cmd);)
2566 at_sm &= (arg == 0);
2569 chg_eof = 0; /* Changed from the FSF after this */
2572 cmd[1] = 0x01; /* Space FileMarks */
2574 cmd[2] = (ltmp >> 16);
2575 cmd[3] = (ltmp >> 8);
2577 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "filemarks", cmd);)
2580 blkno = (-1); /* We can't know the block number */
2581 at_sm &= (arg == 0);
2585 cmd[1] = 0x00; /* Space Blocks */
2586 cmd[2] = (arg >> 16);
2587 cmd[3] = (arg >> 8);
2589 DEBC(deb_space_print(name, ST_DEB_FORWARD, "blocks", cmd);)
2592 at_sm &= (arg == 0);
2596 cmd[1] = 0x00; /* Space Blocks */
2598 cmd[2] = (ltmp >> 16);
2599 cmd[3] = (ltmp >> 8);
2601 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "blocks", cmd);)
2604 at_sm &= (arg == 0);
2608 cmd[1] = 0x04; /* Space Setmarks */
2609 cmd[2] = (arg >> 16);
2610 cmd[3] = (arg >> 8);
2612 DEBC(deb_space_print(name, ST_DEB_FORWARD, "setmarks", cmd);)
2614 blkno = fileno = (-1);
2620 cmd[1] = 0x04; /* Space Setmarks */
2622 cmd[2] = (ltmp >> 16);
2623 cmd[3] = (ltmp >> 8);
2625 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "setmarks", cmd);)
2627 blkno = fileno = (-1);
2633 if (STp->write_prot)
2635 cmd[0] = WRITE_FILEMARKS;
2636 if (cmd_in == MTWSM)
2638 cmd[2] = (arg >> 16);
2639 cmd[3] = (arg >> 8);
2641 timeout = STp->device->timeout;
2643 if (cmd_in == MTWEOF)
2644 printk(ST_DEB_MSG "%s: Writing %d filemarks.\n", name,
2645 cmd[2] * 65536 + cmd[3] * 256 + cmd[4]);
2647 printk(ST_DEB_MSG "%s: Writing %d setmarks.\n", name,
2648 cmd[2] * 65536 + cmd[3] * 256 + cmd[4]);
2653 at_sm = (cmd_in == MTWSM);
2656 cmd[0] = REZERO_UNIT;
2657 if (STp->immediate) {
2658 cmd[1] = 1; /* Don't wait for completion */
2659 timeout = STp->device->timeout;
2661 DEBC(printk(ST_DEB_MSG "%s: Rewinding tape.\n", name));
2662 fileno = blkno = at_sm = 0;
2665 DEBC(printk(ST_DEB_MSG "%s: No op on tape.\n", name));
2666 return 0; /* Should do something ? */
2669 cmd[0] = START_STOP;
2670 if (STp->immediate) {
2671 cmd[1] = 1; /* Don't wait for completion */
2672 timeout = STp->device->timeout;
2675 DEBC(printk(ST_DEB_MSG "%s: Retensioning tape.\n", name));
2676 fileno = blkno = at_sm = 0;
2679 if (!STp->fast_mteom) {
2680 /* space to the end of tape */
2681 ioctl_result = st_int_ioctl(STp, MTFSF, 0x7fffff);
2682 fileno = STps->drv_file;
2683 if (STps->eof >= ST_EOD_1)
2685 /* The next lines would hide the number of spaced FileMarks
2686 That's why I inserted the previous lines. I had no luck
2687 with detecting EOM with FSF, so we go now to EOM.
2693 DEBC(printk(ST_DEB_MSG "%s: Spacing to end of recorded medium.\n",
2699 if (STp->write_prot)
2702 cmd[1] = (arg ? 1 : 0); /* Long erase with non-zero argument */
2703 if (STp->immediate) {
2704 cmd[1] |= 2; /* Don't wait for completion */
2705 timeout = STp->device->timeout;
2708 timeout = STp->long_timeout * 8;
2710 DEBC(printk(ST_DEB_MSG "%s: Erasing tape.\n", name));
2711 fileno = blkno = at_sm = 0;
2713 case MTSETBLK: /* Set block length */
2714 case MTSETDENSITY: /* Set tape density */
2715 case MTSETDRVBUFFER: /* Set drive buffering */
2716 case SET_DENS_AND_BLK: /* Set density and block size */
2718 if (STp->dirty || (STp->buffer)->buffer_bytes != 0)
2719 return (-EIO); /* Not allowed if data in buffer */
2720 if ((cmd_in == MTSETBLK || cmd_in == SET_DENS_AND_BLK) &&
2721 (arg & MT_ST_BLKSIZE_MASK) != 0 &&
2722 STp->max_block > 0 &&
2723 ((arg & MT_ST_BLKSIZE_MASK) < STp->min_block ||
2724 (arg & MT_ST_BLKSIZE_MASK) > STp->max_block)) {
2725 printk(KERN_WARNING "%s: Illegal block size.\n", name);
2728 cmd[0] = MODE_SELECT;
2729 if ((STp->use_pf & USE_PF))
2730 cmd[1] = MODE_SELECT_PAGE_FORMAT;
2731 cmd[4] = datalen = 12;
2732 direction = DMA_TO_DEVICE;
2734 memset((STp->buffer)->b_data, 0, 12);
2735 if (cmd_in == MTSETDRVBUFFER)
2736 (STp->buffer)->b_data[2] = (arg & 7) << 4;
2738 (STp->buffer)->b_data[2] =
2739 STp->drv_buffer << 4;
2740 (STp->buffer)->b_data[3] = 8; /* block descriptor length */
2741 if (cmd_in == MTSETDENSITY) {
2742 (STp->buffer)->b_data[4] = arg;
2743 STp->density_changed = 1; /* At least we tried ;-) */
2744 } else if (cmd_in == SET_DENS_AND_BLK)
2745 (STp->buffer)->b_data[4] = arg >> 24;
2747 (STp->buffer)->b_data[4] = STp->density;
2748 if (cmd_in == MTSETBLK || cmd_in == SET_DENS_AND_BLK) {
2749 ltmp = arg & MT_ST_BLKSIZE_MASK;
2750 if (cmd_in == MTSETBLK)
2751 STp->blksize_changed = 1; /* At least we tried ;-) */
2753 ltmp = STp->block_size;
2754 (STp->buffer)->b_data[9] = (ltmp >> 16);
2755 (STp->buffer)->b_data[10] = (ltmp >> 8);
2756 (STp->buffer)->b_data[11] = ltmp;
2757 timeout = STp->device->timeout;
2759 if (cmd_in == MTSETBLK || cmd_in == SET_DENS_AND_BLK)
2761 "%s: Setting block size to %d bytes.\n", name,
2762 (STp->buffer)->b_data[9] * 65536 +
2763 (STp->buffer)->b_data[10] * 256 +
2764 (STp->buffer)->b_data[11]);
2765 if (cmd_in == MTSETDENSITY || cmd_in == SET_DENS_AND_BLK)
2767 "%s: Setting density code to %x.\n", name,
2768 (STp->buffer)->b_data[4]);
2769 if (cmd_in == MTSETDRVBUFFER)
2771 "%s: Setting drive buffer code to %d.\n", name,
2772 ((STp->buffer)->b_data[2] >> 4) & 7);
2779 SRpnt = st_do_scsi(NULL, STp, cmd, datalen, direction,
2780 timeout, MAX_RETRIES, 1);
2782 return (STp->buffer)->syscall_result;
2784 ioctl_result = (STp->buffer)->syscall_result;
2786 if (!ioctl_result) { /* SCSI command successful */
2787 st_release_request(SRpnt);
2789 STps->drv_block = blkno;
2790 STps->drv_file = fileno;
2791 STps->at_sm = at_sm;
2793 if (cmd_in == MTBSFM)
2794 ioctl_result = st_int_ioctl(STp, MTFSF, 1);
2795 else if (cmd_in == MTFSFM)
2796 ioctl_result = st_int_ioctl(STp, MTBSF, 1);
2798 if (cmd_in == MTSETBLK || cmd_in == SET_DENS_AND_BLK) {
2799 int old_block_size = STp->block_size;
2800 STp->block_size = arg & MT_ST_BLKSIZE_MASK;
2801 if (STp->block_size != 0) {
2802 if (old_block_size == 0)
2803 normalize_buffer(STp->buffer);
2804 (STp->buffer)->buffer_blocks =
2805 (STp->buffer)->buffer_size / STp->block_size;
2807 (STp->buffer)->buffer_bytes = (STp->buffer)->read_pointer = 0;
2808 if (cmd_in == SET_DENS_AND_BLK)
2809 STp->density = arg >> MT_ST_DENSITY_SHIFT;
2810 } else if (cmd_in == MTSETDRVBUFFER)
2811 STp->drv_buffer = (arg & 7);
2812 else if (cmd_in == MTSETDENSITY)
2815 if (cmd_in == MTEOM)
2817 else if (cmd_in == MTFSF)
2820 STps->eof = ST_NOEOF;
2822 if (cmd_in == MTWEOF)
2824 } else { /* SCSI command was not completely successful. Don't return
2825 from this block without releasing the SCSI command block! */
2826 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat;
2828 if (cmdstatp->flags & SENSE_EOM) {
2829 if (cmd_in != MTBSF && cmd_in != MTBSFM &&
2830 cmd_in != MTBSR && cmd_in != MTBSS)
2831 STps->eof = ST_EOM_OK;
2832 STps->drv_block = 0;
2835 if (cmdstatp->remainder_valid)
2836 undone = (int)cmdstatp->uremainder64;
2840 if (cmd_in == MTWEOF &&
2841 cmdstatp->have_sense &&
2842 (cmdstatp->flags & SENSE_EOM)) {
2843 if (cmdstatp->sense_hdr.sense_key == NO_SENSE ||
2844 cmdstatp->sense_hdr.sense_key == RECOVERED_ERROR) {
2845 ioctl_result = 0; /* EOF(s) written successfully at EOM */
2846 STps->eof = ST_NOEOF;
2847 } else { /* Writing EOF(s) failed */
2851 STps->eof = ST_NOEOF;
2853 STps->drv_file = fileno;
2854 } else if ((cmd_in == MTFSF) || (cmd_in == MTFSFM)) {
2856 STps->drv_file = fileno - undone;
2858 STps->drv_file = fileno;
2859 STps->drv_block = -1;
2860 STps->eof = ST_NOEOF;
2861 } else if ((cmd_in == MTBSF) || (cmd_in == MTBSFM)) {
2862 if (arg > 0 && undone < 0) /* Some drives get this wrong */
2864 if (STps->drv_file >= 0)
2865 STps->drv_file = fileno + undone;
2866 STps->drv_block = 0;
2867 STps->eof = ST_NOEOF;
2868 } else if (cmd_in == MTFSR) {
2869 if (cmdstatp->flags & SENSE_FMK) { /* Hit filemark */
2870 if (STps->drv_file >= 0)
2872 STps->drv_block = 0;
2875 if (blkno >= undone)
2876 STps->drv_block = blkno - undone;
2878 STps->drv_block = (-1);
2879 STps->eof = ST_NOEOF;
2881 } else if (cmd_in == MTBSR) {
2882 if (cmdstatp->flags & SENSE_FMK) { /* Hit filemark */
2884 STps->drv_block = (-1);
2886 if (arg > 0 && undone < 0) /* Some drives get this wrong */
2888 if (STps->drv_block >= 0)
2889 STps->drv_block = blkno + undone;
2891 STps->eof = ST_NOEOF;
2892 } else if (cmd_in == MTEOM) {
2893 STps->drv_file = (-1);
2894 STps->drv_block = (-1);
2896 } else if (cmd_in == MTSETBLK ||
2897 cmd_in == MTSETDENSITY ||
2898 cmd_in == MTSETDRVBUFFER ||
2899 cmd_in == SET_DENS_AND_BLK) {
2900 if (cmdstatp->sense_hdr.sense_key == ILLEGAL_REQUEST &&
2901 !(STp->use_pf & PF_TESTED)) {
2902 /* Try the other possible state of Page Format if not
2904 STp->use_pf = !STp->use_pf | PF_TESTED;
2905 st_release_request(SRpnt);
2907 return st_int_ioctl(STp, cmd_in, arg);
2910 STps->eof = ST_NOEOF;
2912 if (cmdstatp->sense_hdr.sense_key == BLANK_CHECK)
2915 st_release_request(SRpnt);
2919 return ioctl_result;
2923 /* Get the tape position. If bt == 2, arg points into a kernel space mt_loc
2926 static int get_location(struct scsi_tape *STp, unsigned int *block, int *partition,
2930 unsigned char scmd[MAX_COMMAND_SIZE];
2931 struct st_request *SRpnt;
2932 DEB( char *name = tape_name(STp); )
2934 if (STp->ready != ST_READY)
2937 memset(scmd, 0, MAX_COMMAND_SIZE);
2938 if ((STp->device)->scsi_level < SCSI_2) {
2939 scmd[0] = QFA_REQUEST_BLOCK;
2942 scmd[0] = READ_POSITION;
2943 if (!logical && !STp->scsi2_logical)
2946 SRpnt = st_do_scsi(NULL, STp, scmd, 20, DMA_FROM_DEVICE,
2947 STp->device->timeout, MAX_READY_RETRIES, 1);
2949 return (STp->buffer)->syscall_result;
2951 if ((STp->buffer)->syscall_result != 0 ||
2952 (STp->device->scsi_level >= SCSI_2 &&
2953 ((STp->buffer)->b_data[0] & 4) != 0)) {
2954 *block = *partition = 0;
2955 DEBC(printk(ST_DEB_MSG "%s: Can't read tape position.\n", name));
2959 if ((STp->device)->scsi_level < SCSI_2) {
2960 *block = ((STp->buffer)->b_data[0] << 16)
2961 + ((STp->buffer)->b_data[1] << 8)
2962 + (STp->buffer)->b_data[2];
2965 *block = ((STp->buffer)->b_data[4] << 24)
2966 + ((STp->buffer)->b_data[5] << 16)
2967 + ((STp->buffer)->b_data[6] << 8)
2968 + (STp->buffer)->b_data[7];
2969 *partition = (STp->buffer)->b_data[1];
2970 if (((STp->buffer)->b_data[0] & 0x80) &&
2971 (STp->buffer)->b_data[1] == 0) /* BOP of partition 0 */
2972 STp->ps[0].drv_block = STp->ps[0].drv_file = 0;
2974 DEBC(printk(ST_DEB_MSG "%s: Got tape pos. blk %d part %d.\n", name,
2975 *block, *partition));
2977 st_release_request(SRpnt);
2984 /* Set the tape block and partition. Negative partition means that only the
2985 block should be set in vendor specific way. */
2986 static int set_location(struct scsi_tape *STp, unsigned int block, int partition,
2989 struct st_partstat *STps;
2993 unsigned char scmd[MAX_COMMAND_SIZE];
2994 struct st_request *SRpnt;
2995 DEB( char *name = tape_name(STp); )
2997 if (STp->ready != ST_READY)
2999 timeout = STp->long_timeout;
3000 STps = &(STp->ps[STp->partition]);
3002 DEBC(printk(ST_DEB_MSG "%s: Setting block to %d and partition to %d.\n",
3003 name, block, partition));
3004 DEB(if (partition < 0)
3007 /* Update the location at the partition we are leaving */
3008 if ((!STp->can_partitions && partition != 0) ||
3009 partition >= ST_NBR_PARTITIONS)
3011 if (partition != STp->partition) {
3012 if (get_location(STp, &blk, &p, 1))
3013 STps->last_block_valid = 0;
3015 STps->last_block_valid = 1;
3016 STps->last_block_visited = blk;
3017 DEBC(printk(ST_DEB_MSG
3018 "%s: Visited block %d for partition %d saved.\n",
3019 name, blk, STp->partition));
3023 memset(scmd, 0, MAX_COMMAND_SIZE);
3024 if ((STp->device)->scsi_level < SCSI_2) {
3025 scmd[0] = QFA_SEEK_BLOCK;
3026 scmd[2] = (block >> 16);
3027 scmd[3] = (block >> 8);
3032 scmd[3] = (block >> 24);
3033 scmd[4] = (block >> 16);
3034 scmd[5] = (block >> 8);
3036 if (!logical && !STp->scsi2_logical)
3038 if (STp->partition != partition) {
3040 scmd[8] = partition;
3041 DEBC(printk(ST_DEB_MSG
3042 "%s: Trying to change partition from %d to %d\n",
3043 name, STp->partition, partition));
3046 if (STp->immediate) {
3047 scmd[1] |= 1; /* Don't wait for completion */
3048 timeout = STp->device->timeout;
3051 SRpnt = st_do_scsi(NULL, STp, scmd, 0, DMA_NONE,
3052 timeout, MAX_READY_RETRIES, 1);
3054 return (STp->buffer)->syscall_result;
3056 STps->drv_block = STps->drv_file = (-1);
3057 STps->eof = ST_NOEOF;
3058 if ((STp->buffer)->syscall_result != 0) {
3060 if (STp->can_partitions &&
3061 (STp->device)->scsi_level >= SCSI_2 &&
3062 (p = find_partition(STp)) >= 0)
3065 if (STp->can_partitions) {
3066 STp->partition = partition;
3067 STps = &(STp->ps[partition]);
3068 if (!STps->last_block_valid ||
3069 STps->last_block_visited != block) {
3076 STps->drv_block = STps->drv_file = 0;
3080 st_release_request(SRpnt);
3087 /* Find the current partition number for the drive status. Called from open and
3088 returns either partition number of negative error code. */
3089 static int find_partition(struct scsi_tape *STp)
3094 if ((i = get_location(STp, &block, &partition, 1)) < 0)
3096 if (partition >= ST_NBR_PARTITIONS)
3102 /* Change the partition if necessary */
3103 static int switch_partition(struct scsi_tape *STp)
3105 struct st_partstat *STps;
3107 if (STp->partition == STp->new_partition)
3109 STps = &(STp->ps[STp->new_partition]);
3110 if (!STps->last_block_valid)
3111 STps->last_block_visited = 0;
3112 return set_location(STp, STps->last_block_visited, STp->new_partition, 1);
3115 /* Functions for reading and writing the medium partition mode page. */
3117 #define PART_PAGE 0x11
3118 #define PART_PAGE_FIXED_LENGTH 8
3120 #define PP_OFF_MAX_ADD_PARTS 2
3121 #define PP_OFF_NBR_ADD_PARTS 3
3122 #define PP_OFF_FLAGS 4
3123 #define PP_OFF_PART_UNITS 6
3124 #define PP_OFF_RESERVED 7
3126 #define PP_BIT_IDP 0x20
3127 #define PP_MSK_PSUM_MB 0x10
3129 /* Get the number of partitions on the tape. As a side effect reads the
3130 mode page into the tape buffer. */
3131 static int nbr_partitions(struct scsi_tape *STp)
3134 DEB( char *name = tape_name(STp); )
3136 if (STp->ready != ST_READY)
3139 result = read_mode_page(STp, PART_PAGE, 1);
3142 DEBC(printk(ST_DEB_MSG "%s: Can't read medium partition page.\n",
3146 result = (STp->buffer)->b_data[MODE_HEADER_LENGTH +
3147 PP_OFF_NBR_ADD_PARTS] + 1;
3148 DEBC(printk(ST_DEB_MSG "%s: Number of partitions %d.\n", name, result));
3155 /* Partition the tape into two partitions if size > 0 or one partition if
3158 The block descriptors are read and written because Sony SDT-7000 does not
3159 work without this (suggestion from Michael Schaefer <Michael.Schaefer@dlr.de>).
3161 My HP C1533A drive returns only one partition size field. This is used to
3162 set the size of partition 1. There is no size field for the default partition.
3163 Michael Schaefer's Sony SDT-7000 returns two descriptors and the second is
3164 used to set the size of partition 1 (this is what the SCSI-3 standard specifies).
3165 The following algorithm is used to accommodate both drives: if the number of
3166 partition size fields is greater than the maximum number of additional partitions
3167 in the mode page, the second field is used. Otherwise the first field is used.
3169 For Seagate DDS drives the page length must be 8 when no partitions is defined
3170 and 10 when 1 partition is defined (information from Eric Lee Green). This is
3171 is acceptable also to some other old drives and enforced if the first partition
3172 size field is used for the first additional partition size.
3174 static int partition_tape(struct scsi_tape *STp, int size)
3176 char *name = tape_name(STp);
3178 int pgo, psd_cnt, psdo;
3181 result = read_mode_page(STp, PART_PAGE, 0);
3183 DEBC(printk(ST_DEB_MSG "%s: Can't read partition mode page.\n", name));
3186 /* The mode page is in the buffer. Let's modify it and write it. */
3187 bp = (STp->buffer)->b_data;
3188 pgo = MODE_HEADER_LENGTH + bp[MH_OFF_BDESCS_LENGTH];
3189 DEBC(printk(ST_DEB_MSG "%s: Partition page length is %d bytes.\n",
3190 name, bp[pgo + MP_OFF_PAGE_LENGTH] + 2));
3192 psd_cnt = (bp[pgo + MP_OFF_PAGE_LENGTH] + 2 - PART_PAGE_FIXED_LENGTH) / 2;
3193 psdo = pgo + PART_PAGE_FIXED_LENGTH;
3194 if (psd_cnt > bp[pgo + PP_OFF_MAX_ADD_PARTS]) {
3195 bp[psdo] = bp[psdo + 1] = 0xff; /* Rest of the tape */
3198 memset(bp + psdo, 0, bp[pgo + PP_OFF_NBR_ADD_PARTS] * 2);
3200 DEBC(printk("%s: psd_cnt %d, max.parts %d, nbr_parts %d\n", name,
3201 psd_cnt, bp[pgo + PP_OFF_MAX_ADD_PARTS],
3202 bp[pgo + PP_OFF_NBR_ADD_PARTS]));
3205 bp[pgo + PP_OFF_NBR_ADD_PARTS] = 0;
3206 if (psd_cnt <= bp[pgo + PP_OFF_MAX_ADD_PARTS])
3207 bp[pgo + MP_OFF_PAGE_LENGTH] = 6;
3208 DEBC(printk(ST_DEB_MSG "%s: Formatting tape with one partition.\n",
3211 bp[psdo] = (size >> 8) & 0xff;
3212 bp[psdo + 1] = size & 0xff;
3214 if (bp[pgo + MP_OFF_PAGE_LENGTH] < 8)
3215 bp[pgo + MP_OFF_PAGE_LENGTH] = 8;
3216 DEBC(printk(ST_DEB_MSG
3217 "%s: Formatting tape with two partitions (1 = %d MB).\n",
3220 bp[pgo + PP_OFF_PART_UNITS] = 0;
3221 bp[pgo + PP_OFF_RESERVED] = 0;
3222 bp[pgo + PP_OFF_FLAGS] = PP_BIT_IDP | PP_MSK_PSUM_MB;
3224 result = write_mode_page(STp, PART_PAGE, 1);
3226 printk(KERN_INFO "%s: Partitioning of tape failed.\n", name);
3235 /* The ioctl command */
3236 static long st_ioctl(struct file *file, unsigned int cmd_in, unsigned long arg)
3238 int i, cmd_nr, cmd_type, bt;
3241 struct scsi_tape *STp = file->private_data;
3242 struct st_modedef *STm;
3243 struct st_partstat *STps;
3244 char *name = tape_name(STp);
3245 void __user *p = (void __user *)arg;
3247 if (mutex_lock_interruptible(&STp->lock))
3248 return -ERESTARTSYS;
3251 if (debugging && !STp->in_use) {
3252 printk(ST_DEB_MSG "%s: Incorrect device.\n", name);
3257 STm = &(STp->modes[STp->current_mode]);
3258 STps = &(STp->ps[STp->partition]);
3261 * If we are in the middle of error recovery, don't let anyone
3262 * else try and use this device. Also, if error recovery fails, it
3263 * may try and take the device offline, in which case all further
3264 * access to the device is prohibited.
3266 retval = scsi_nonblockable_ioctl(STp->device, cmd_in, p,
3267 file->f_flags & O_NDELAY);
3268 if (!scsi_block_when_processing_errors(STp->device) || retval != -ENODEV)
3272 cmd_type = _IOC_TYPE(cmd_in);
3273 cmd_nr = _IOC_NR(cmd_in);
3275 if (cmd_type == _IOC_TYPE(MTIOCTOP) && cmd_nr == _IOC_NR(MTIOCTOP)) {
3278 if (_IOC_SIZE(cmd_in) != sizeof(mtc)) {
3283 i = copy_from_user(&mtc, p, sizeof(struct mtop));
3289 if (mtc.mt_op == MTSETDRVBUFFER && !capable(CAP_SYS_ADMIN)) {
3291 "%s: MTSETDRVBUFFER only allowed for root.\n", name);
3295 if (!STm->defined &&
3296 (mtc.mt_op != MTSETDRVBUFFER &&
3297 (mtc.mt_count & MT_ST_OPTIONS) == 0)) {
3302 if (!STp->pos_unknown) {
3304 if (STps->eof == ST_FM_HIT) {
3305 if (mtc.mt_op == MTFSF || mtc.mt_op == MTFSFM ||
3306 mtc.mt_op == MTEOM) {
3308 if (STps->drv_file >= 0)
3309 STps->drv_file += 1;
3310 } else if (mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM) {
3312 if (STps->drv_file >= 0)
3313 STps->drv_file += 1;
3317 if (mtc.mt_op == MTSEEK) {
3318 /* Old position must be restored if partition will be
3320 i = !STp->can_partitions ||
3321 (STp->new_partition != STp->partition);
3323 i = mtc.mt_op == MTREW || mtc.mt_op == MTOFFL ||
3324 mtc.mt_op == MTRETEN || mtc.mt_op == MTEOM ||
3325 mtc.mt_op == MTLOCK || mtc.mt_op == MTLOAD ||
3326 mtc.mt_op == MTFSF || mtc.mt_op == MTFSFM ||
3327 mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM ||
3328 mtc.mt_op == MTCOMPRESSION;
3330 i = flush_buffer(STp, i);
3335 if (STps->rw == ST_WRITING &&
3336 (mtc.mt_op == MTREW || mtc.mt_op == MTOFFL ||
3337 mtc.mt_op == MTSEEK ||
3338 mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM)) {
3339 i = st_int_ioctl(STp, MTWEOF, 1);
3344 if (mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM)
3351 * If there was a bus reset, block further access
3352 * to this device. If the user wants to rewind the tape,
3353 * then reset the flag and allow access again.
3355 if (mtc.mt_op != MTREW &&
3356 mtc.mt_op != MTOFFL &&
3357 mtc.mt_op != MTRETEN &&
3358 mtc.mt_op != MTERASE &&
3359 mtc.mt_op != MTSEEK &&
3360 mtc.mt_op != MTEOM) {
3365 /* remove this when the midlevel properly clears was_reset */
3366 STp->device->was_reset = 0;
3369 if (mtc.mt_op != MTNOP && mtc.mt_op != MTSETBLK &&
3370 mtc.mt_op != MTSETDENSITY && mtc.mt_op != MTWSM &&
3371 mtc.mt_op != MTSETDRVBUFFER && mtc.mt_op != MTSETPART)
3372 STps->rw = ST_IDLE; /* Prevent automatic WEOF and fsf */
3374 if (mtc.mt_op == MTOFFL && STp->door_locked != ST_UNLOCKED)
3375 do_door_lock(STp, 0); /* Ignore result! */
3377 if (mtc.mt_op == MTSETDRVBUFFER &&
3378 (mtc.mt_count & MT_ST_OPTIONS) != 0) {
3379 retval = st_set_options(STp, mtc.mt_count);
3383 if (mtc.mt_op == MTSETPART) {
3384 if (!STp->can_partitions ||
3385 mtc.mt_count < 0 || mtc.mt_count >= ST_NBR_PARTITIONS) {
3389 if (mtc.mt_count >= STp->nbr_partitions &&
3390 (STp->nbr_partitions = nbr_partitions(STp)) < 0) {
3394 if (mtc.mt_count >= STp->nbr_partitions) {
3398 STp->new_partition = mtc.mt_count;
3403 if (mtc.mt_op == MTMKPART) {
3404 if (!STp->can_partitions) {
3408 if ((i = st_int_ioctl(STp, MTREW, 0)) < 0 ||
3409 (i = partition_tape(STp, mtc.mt_count)) < 0) {
3413 for (i = 0; i < ST_NBR_PARTITIONS; i++) {
3414 STp->ps[i].rw = ST_IDLE;
3415 STp->ps[i].at_sm = 0;
3416 STp->ps[i].last_block_valid = 0;
3418 STp->partition = STp->new_partition = 0;
3419 STp->nbr_partitions = 1; /* Bad guess ?-) */
3420 STps->drv_block = STps->drv_file = 0;
3425 if (mtc.mt_op == MTSEEK) {
3426 i = set_location(STp, mtc.mt_count, STp->new_partition, 0);
3427 if (!STp->can_partitions)
3428 STp->ps[0].rw = ST_IDLE;
3433 if (mtc.mt_op == MTUNLOAD || mtc.mt_op == MTOFFL) {
3434 retval = do_load_unload(STp, file, 0);
3438 if (mtc.mt_op == MTLOAD) {
3439 retval = do_load_unload(STp, file, max(1, mtc.mt_count));
3443 if (mtc.mt_op == MTLOCK || mtc.mt_op == MTUNLOCK) {
3444 retval = do_door_lock(STp, (mtc.mt_op == MTLOCK));
3448 if (STp->can_partitions && STp->ready == ST_READY &&
3449 (i = switch_partition(STp)) < 0) {
3454 if (mtc.mt_op == MTCOMPRESSION)
3455 retval = st_compression(STp, (mtc.mt_count & 1));
3457 retval = st_int_ioctl(STp, mtc.mt_op, mtc.mt_count);
3460 if (!STm->defined) {
3465 if ((i = flush_buffer(STp, 0)) < 0) {
3469 if (STp->can_partitions &&
3470 (i = switch_partition(STp)) < 0) {
3475 if (cmd_type == _IOC_TYPE(MTIOCGET) && cmd_nr == _IOC_NR(MTIOCGET)) {
3476 struct mtget mt_status;
3478 if (_IOC_SIZE(cmd_in) != sizeof(struct mtget)) {
3483 mt_status.mt_type = STp->tape_type;
3484 mt_status.mt_dsreg =
3485 ((STp->block_size << MT_ST_BLKSIZE_SHIFT) & MT_ST_BLKSIZE_MASK) |
3486 ((STp->density << MT_ST_DENSITY_SHIFT) & MT_ST_DENSITY_MASK);
3487 mt_status.mt_blkno = STps->drv_block;
3488 mt_status.mt_fileno = STps->drv_file;
3489 if (STp->block_size != 0) {
3490 if (STps->rw == ST_WRITING)
3491 mt_status.mt_blkno +=
3492 (STp->buffer)->buffer_bytes / STp->block_size;
3493 else if (STps->rw == ST_READING)
3494 mt_status.mt_blkno -=
3495 ((STp->buffer)->buffer_bytes +
3496 STp->block_size - 1) / STp->block_size;
3499 mt_status.mt_gstat = 0;
3500 if (STp->drv_write_prot)
3501 mt_status.mt_gstat |= GMT_WR_PROT(0xffffffff);
3502 if (mt_status.mt_blkno == 0) {
3503 if (mt_status.mt_fileno == 0)
3504 mt_status.mt_gstat |= GMT_BOT(0xffffffff);
3506 mt_status.mt_gstat |= GMT_EOF(0xffffffff);
3508 mt_status.mt_erreg = (STp->recover_reg << MT_ST_SOFTERR_SHIFT);
3509 mt_status.mt_resid = STp->partition;
3510 if (STps->eof == ST_EOM_OK || STps->eof == ST_EOM_ERROR)
3511 mt_status.mt_gstat |= GMT_EOT(0xffffffff);
3512 else if (STps->eof >= ST_EOM_OK)
3513 mt_status.mt_gstat |= GMT_EOD(0xffffffff);
3514 if (STp->density == 1)
3515 mt_status.mt_gstat |= GMT_D_800(0xffffffff);
3516 else if (STp->density == 2)
3517 mt_status.mt_gstat |= GMT_D_1600(0xffffffff);
3518 else if (STp->density == 3)
3519 mt_status.mt_gstat |= GMT_D_6250(0xffffffff);
3520 if (STp->ready == ST_READY)
3521 mt_status.mt_gstat |= GMT_ONLINE(0xffffffff);
3522 if (STp->ready == ST_NO_TAPE)
3523 mt_status.mt_gstat |= GMT_DR_OPEN(0xffffffff);
3525 mt_status.mt_gstat |= GMT_SM(0xffffffff);
3526 if (STm->do_async_writes ||
3527 (STm->do_buffer_writes && STp->block_size != 0) ||
3528 STp->drv_buffer != 0)
3529 mt_status.mt_gstat |= GMT_IM_REP_EN(0xffffffff);
3530 if (STp->cleaning_req)
3531 mt_status.mt_gstat |= GMT_CLN(0xffffffff);
3533 i = copy_to_user(p, &mt_status, sizeof(struct mtget));
3539 STp->recover_reg = 0; /* Clear after read */
3542 } /* End of MTIOCGET */
3543 if (cmd_type == _IOC_TYPE(MTIOCPOS) && cmd_nr == _IOC_NR(MTIOCPOS)) {
3544 struct mtpos mt_pos;
3545 if (_IOC_SIZE(cmd_in) != sizeof(struct mtpos)) {
3549 if ((i = get_location(STp, &blk, &bt, 0)) < 0) {
3553 mt_pos.mt_blkno = blk;
3554 i = copy_to_user(p, &mt_pos, sizeof(struct mtpos));
3559 mutex_unlock(&STp->lock);
3561 case SCSI_IOCTL_GET_IDLUN:
3562 case SCSI_IOCTL_GET_BUS_NUMBER:
3565 if ((cmd_in == SG_IO ||
3566 cmd_in == SCSI_IOCTL_SEND_COMMAND ||
3567 cmd_in == CDROM_SEND_PACKET) &&
3568 !capable(CAP_SYS_RAWIO))
3571 i = scsi_cmd_ioctl(STp->disk->queue, STp->disk,
3572 file->f_mode, cmd_in, p);
3577 retval = scsi_ioctl(STp->device, cmd_in, p);
3578 if (!retval && cmd_in == SCSI_IOCTL_STOP_UNIT) { /* unload */
3579 STp->rew_at_close = 0;
3580 STp->ready = ST_NO_TAPE;
3585 mutex_unlock(&STp->lock);
3589 #ifdef CONFIG_COMPAT
3590 static long st_compat_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
3592 struct scsi_tape *STp = file->private_data;
3593 struct scsi_device *sdev = STp->device;
3594 int ret = -ENOIOCTLCMD;
3595 if (sdev->host->hostt->compat_ioctl) {
3597 ret = sdev->host->hostt->compat_ioctl(sdev, cmd, (void __user *)arg);
3606 /* Try to allocate a new tape buffer. Calling function must not hold
3608 static struct st_buffer *
3609 new_tape_buffer(int from_initialization, int need_dma, int max_sg)
3613 struct st_buffer *tb;
3615 if (from_initialization)
3616 priority = GFP_ATOMIC;
3618 priority = GFP_KERNEL;
3620 i = sizeof(struct st_buffer) + (max_sg - 1) * sizeof(struct scatterlist) +
3621 max_sg * sizeof(struct st_buf_fragment);
3622 tb = kzalloc(i, priority);
3624 printk(KERN_NOTICE "st: Can't allocate new tape buffer.\n");
3627 tb->frp_segs = tb->orig_frp_segs = 0;
3628 tb->use_sg = max_sg;
3629 tb->frp = (struct st_buf_fragment *)(&(tb->sg[0]) + max_sg);
3632 tb->buffer_size = got;
3633 sg_init_table(tb->sg, max_sg);
3639 /* Try to allocate enough space in the tape buffer */
3640 static int enlarge_buffer(struct st_buffer * STbuffer, int new_size, int need_dma)
3642 int segs, nbr, max_segs, b_size, order, got;
3645 if (new_size <= STbuffer->buffer_size)
3648 if (STbuffer->buffer_size <= PAGE_SIZE)
3649 normalize_buffer(STbuffer); /* Avoid extra segment */
3651 max_segs = STbuffer->use_sg;
3652 nbr = max_segs - STbuffer->frp_segs;
3656 priority = GFP_KERNEL | __GFP_NOWARN;
3658 priority |= GFP_DMA;
3659 for (b_size = PAGE_SIZE, order=0; order <= 6 &&
3660 b_size < new_size - STbuffer->buffer_size;
3661 order++, b_size *= 2)
3664 for (segs = STbuffer->frp_segs, got = STbuffer->buffer_size;
3665 segs < max_segs && got < new_size;) {
3666 STbuffer->frp[segs].page = alloc_pages(priority, order);
3667 if (STbuffer->frp[segs].page == NULL) {
3668 if (new_size - got <= (max_segs - segs) * b_size / 2) {
3669 b_size /= 2; /* Large enough for the rest of the buffers */
3673 DEB(STbuffer->buffer_size = got);
3674 normalize_buffer(STbuffer);
3677 STbuffer->frp[segs].length = b_size;
3678 STbuffer->frp_segs += 1;
3680 STbuffer->buffer_size = got;
3681 if (STbuffer->cleared)
3682 memset(page_address(STbuffer->frp[segs].page), 0, b_size);
3685 STbuffer->b_data = page_address(STbuffer->frp[0].page);
3691 /* Make sure that no data from previous user is in the internal buffer */
3692 static void clear_buffer(struct st_buffer * st_bp)
3696 for (i=0; i < st_bp->frp_segs; i++)
3697 memset(page_address(st_bp->frp[i].page), 0, st_bp->frp[i].length);
3702 /* Release the extra buffer */
3703 static void normalize_buffer(struct st_buffer * STbuffer)
3707 for (i = STbuffer->orig_frp_segs; i < STbuffer->frp_segs; i++) {
3708 order = get_order(STbuffer->frp[i].length);
3709 __free_pages(STbuffer->frp[i].page, order);
3710 STbuffer->buffer_size -= STbuffer->frp[i].length;
3712 STbuffer->frp_segs = STbuffer->orig_frp_segs;
3713 STbuffer->frp_sg_current = 0;
3714 STbuffer->sg_segs = 0;
3718 /* Move data from the user buffer to the tape buffer. Returns zero (success) or
3719 negative error code. */
3720 static int append_to_buffer(const char __user *ubp, struct st_buffer * st_bp, int do_count)
3722 int i, cnt, res, offset;
3724 for (i = 0, offset = st_bp->buffer_bytes;
3725 i < st_bp->frp_segs && offset >= st_bp->frp[i].length; i++)
3726 offset -= st_bp->frp[i].length;
3727 if (i == st_bp->frp_segs) { /* Should never happen */
3728 printk(KERN_WARNING "st: append_to_buffer offset overflow.\n");
3731 for (; i < st_bp->frp_segs && do_count > 0; i++) {
3732 cnt = st_bp->frp[i].length - offset < do_count ?
3733 st_bp->frp[i].length - offset : do_count;
3734 res = copy_from_user(page_address(st_bp->frp[i].page) + offset, ubp, cnt);
3738 st_bp->buffer_bytes += cnt;
3742 if (do_count) /* Should never happen */
3749 /* Move data from the tape buffer to the user buffer. Returns zero (success) or
3750 negative error code. */
3751 static int from_buffer(struct st_buffer * st_bp, char __user *ubp, int do_count)
3753 int i, cnt, res, offset;
3755 for (i = 0, offset = st_bp->read_pointer;
3756 i < st_bp->frp_segs && offset >= st_bp->frp[i].length; i++)
3757 offset -= st_bp->frp[i].length;
3758 if (i == st_bp->frp_segs) { /* Should never happen */
3759 printk(KERN_WARNING "st: from_buffer offset overflow.\n");
3762 for (; i < st_bp->frp_segs && do_count > 0; i++) {
3763 cnt = st_bp->frp[i].length - offset < do_count ?
3764 st_bp->frp[i].length - offset : do_count;
3765 res = copy_to_user(ubp, page_address(st_bp->frp[i].page) + offset, cnt);
3769 st_bp->buffer_bytes -= cnt;
3770 st_bp->read_pointer += cnt;
3774 if (do_count) /* Should never happen */
3781 /* Move data towards start of buffer */
3782 static void move_buffer_data(struct st_buffer * st_bp, int offset)
3784 int src_seg, dst_seg, src_offset = 0, dst_offset;
3790 total=st_bp->buffer_bytes - offset;
3791 for (src_seg=0; src_seg < st_bp->frp_segs; src_seg++) {
3792 src_offset = offset;
3793 if (src_offset < st_bp->frp[src_seg].length)
3795 offset -= st_bp->frp[src_seg].length;
3798 st_bp->buffer_bytes = st_bp->read_pointer = total;
3799 for (dst_seg=dst_offset=0; total > 0; ) {
3800 count = min(st_bp->frp[dst_seg].length - dst_offset,
3801 st_bp->frp[src_seg].length - src_offset);
3802 memmove(page_address(st_bp->frp[dst_seg].page) + dst_offset,
3803 page_address(st_bp->frp[src_seg].page) + src_offset, count);
3804 src_offset += count;
3805 if (src_offset >= st_bp->frp[src_seg].length) {
3809 dst_offset += count;
3810 if (dst_offset >= st_bp->frp[dst_seg].length) {
3819 /* Fill the s/g list up to the length required for this transfer */
3820 static void buf_to_sg(struct st_buffer *STbp, unsigned int length)
3824 struct scatterlist *sg;
3825 struct st_buf_fragment *frp;
3827 if (length == STbp->frp_sg_current)
3828 return; /* work already done */
3830 sg = &(STbp->sg[0]);
3832 for (i=count=0; count < length; i++) {
3833 if (length - count > frp[i].length)
3834 sg_set_page(&sg[i], frp[i].page, frp[i].length, 0);
3836 sg_set_page(&sg[i], frp[i].page, length - count, 0);
3837 count += sg[i].length;
3840 STbp->frp_sg_current = length;
3844 /* Validate the options from command line or module parameters */
3845 static void validate_options(void)
3848 st_fixed_buffer_size = buffer_kbs * ST_KILOBYTE;
3849 if (max_sg_segs >= ST_FIRST_SG)
3850 st_max_sg_segs = max_sg_segs;
3854 /* Set the boot options. Syntax is defined in Documenation/scsi/st.txt.
3856 static int __init st_setup(char *str)
3858 int i, len, ints[5];
3861 stp = get_options(str, ARRAY_SIZE(ints), ints);
3864 for (i = 0; i < ints[0] && i < ARRAY_SIZE(parms); i++)
3866 *parms[i].val = ints[i + 1];
3868 while (stp != NULL) {
3869 for (i = 0; i < ARRAY_SIZE(parms); i++) {
3870 len = strlen(parms[i].name);
3871 if (!strncmp(stp, parms[i].name, len) &&
3872 (*(stp + len) == ':' || *(stp + len) == '=')) {
3875 simple_strtoul(stp + len + 1, NULL, 0);
3877 printk(KERN_WARNING "st: Obsolete parameter %s\n",
3882 if (i >= ARRAY_SIZE(parms))
3883 printk(KERN_WARNING "st: invalid parameter in '%s'\n",
3885 stp = strchr(stp, ',');
3896 __setup("st=", st_setup);
3900 static const struct file_operations st_fops =
3902 .owner = THIS_MODULE,
3905 .unlocked_ioctl = st_ioctl,
3906 #ifdef CONFIG_COMPAT
3907 .compat_ioctl = st_compat_ioctl,
3911 .release = st_release,
3914 static int st_probe(struct device *dev)
3916 struct scsi_device *SDp = to_scsi_device(dev);
3917 struct gendisk *disk = NULL;
3918 struct cdev *cdev = NULL;
3919 struct scsi_tape *tpnt = NULL;
3920 struct st_modedef *STm;
3921 struct st_partstat *STps;
3922 struct st_buffer *buffer;
3923 int i, j, mode, dev_num, error;
3926 if (SDp->type != TYPE_TAPE)
3928 if ((stp = st_incompatible(SDp))) {
3929 sdev_printk(KERN_INFO, SDp, "Found incompatible tape\n");
3930 printk(KERN_INFO "st: The suggested driver is %s.\n", stp);
3934 i = min(SDp->request_queue->max_hw_segments,
3935 SDp->request_queue->max_phys_segments);
3936 if (st_max_sg_segs < i)
3938 buffer = new_tape_buffer(1, (SDp->host)->unchecked_isa_dma, i);
3939 if (buffer == NULL) {
3941 "st: Can't allocate new tape buffer. Device not attached.\n");
3945 disk = alloc_disk(1);
3947 printk(KERN_ERR "st: out of memory. Device not attached.\n");
3948 goto out_buffer_free;
3951 write_lock(&st_dev_arr_lock);
3952 if (st_nr_dev >= st_dev_max) {
3953 struct scsi_tape **tmp_da;
3956 tmp_dev_max = max(st_nr_dev * 2, 8);
3957 if (tmp_dev_max > ST_MAX_TAPES)
3958 tmp_dev_max = ST_MAX_TAPES;
3959 if (tmp_dev_max <= st_nr_dev) {
3960 write_unlock(&st_dev_arr_lock);
3961 printk(KERN_ERR "st: Too many tape devices (max. %d).\n",
3966 tmp_da = kzalloc(tmp_dev_max * sizeof(struct scsi_tape *), GFP_ATOMIC);
3967 if (tmp_da == NULL) {
3968 write_unlock(&st_dev_arr_lock);
3969 printk(KERN_ERR "st: Can't extend device array.\n");
3973 if (scsi_tapes != NULL) {
3974 memcpy(tmp_da, scsi_tapes,
3975 st_dev_max * sizeof(struct scsi_tape *));
3978 scsi_tapes = tmp_da;
3980 st_dev_max = tmp_dev_max;
3983 for (i = 0; i < st_dev_max; i++)
3984 if (scsi_tapes[i] == NULL)
3986 if (i >= st_dev_max)
3987 panic("scsi_devices corrupt (st)");
3989 tpnt = kzalloc(sizeof(struct scsi_tape), GFP_ATOMIC);
3991 write_unlock(&st_dev_arr_lock);
3992 printk(KERN_ERR "st: Can't allocate device descriptor.\n");
3995 kref_init(&tpnt->kref);
3997 sprintf(disk->disk_name, "st%d", i);
3998 disk->private_data = &tpnt->driver;
3999 disk->queue = SDp->request_queue;
4000 tpnt->driver = &st_template;
4001 scsi_tapes[i] = tpnt;
4005 if (SDp->scsi_level <= 2)
4006 tpnt->tape_type = MT_ISSCSI1;
4008 tpnt->tape_type = MT_ISSCSI2;
4010 tpnt->buffer = buffer;
4011 tpnt->buffer->last_SRpnt = NULL;
4016 tpnt->drv_buffer = 1; /* Try buffering if no mode sense */
4017 tpnt->restr_dma = (SDp->host)->unchecked_isa_dma;
4018 tpnt->use_pf = (SDp->scsi_level >= SCSI_2);
4020 tpnt->do_auto_lock = ST_AUTO_LOCK;
4021 tpnt->can_bsr = (SDp->scsi_level > 2 ? 1 : ST_IN_FILE_POS); /* BSR mandatory in SCSI3 */
4022 tpnt->can_partitions = 0;
4023 tpnt->two_fm = ST_TWO_FM;
4024 tpnt->fast_mteom = ST_FAST_MTEOM;
4025 tpnt->scsi2_logical = ST_SCSI2LOGICAL;
4026 tpnt->sili = ST_SILI;
4027 tpnt->immediate = ST_NOWAIT;
4028 tpnt->default_drvbuffer = 0xff; /* No forced buffering */
4029 tpnt->partition = 0;
4030 tpnt->new_partition = 0;
4031 tpnt->nbr_partitions = 0;
4032 tpnt->device->timeout = ST_TIMEOUT;
4033 tpnt->long_timeout = ST_LONG_TIMEOUT;
4034 tpnt->try_dio = try_direct_io && !SDp->host->unchecked_isa_dma;
4036 for (i = 0; i < ST_NBR_MODES; i++) {
4037 STm = &(tpnt->modes[i]);
4039 STm->sysv = ST_SYSV;
4040 STm->defaults_for_writes = 0;
4041 STm->do_async_writes = ST_ASYNC_WRITES;
4042 STm->do_buffer_writes = ST_BUFFER_WRITES;
4043 STm->do_read_ahead = ST_READ_AHEAD;
4044 STm->default_compression = ST_DONT_TOUCH;
4045 STm->default_blksize = (-1); /* No forced size */
4046 STm->default_density = (-1); /* No forced density */
4049 for (i = 0; i < ST_NBR_PARTITIONS; i++) {
4050 STps = &(tpnt->ps[i]);
4052 STps->eof = ST_NOEOF;
4054 STps->last_block_valid = 0;
4055 STps->drv_block = (-1);
4056 STps->drv_file = (-1);
4059 tpnt->current_mode = 0;
4060 tpnt->modes[0].defined = 1;
4062 tpnt->density_changed = tpnt->compression_changed =
4063 tpnt->blksize_changed = 0;
4064 mutex_init(&tpnt->lock);
4067 write_unlock(&st_dev_arr_lock);
4069 for (mode = 0; mode < ST_NBR_MODES; ++mode) {
4070 STm = &(tpnt->modes[mode]);
4071 for (j=0; j < 2; j++) {
4072 cdev = cdev_alloc();
4075 "st%d: out of memory. Device not attached.\n",
4079 cdev->owner = THIS_MODULE;
4080 cdev->ops = &st_fops;
4082 error = cdev_add(cdev,
4083 MKDEV(SCSI_TAPE_MAJOR, TAPE_MINOR(dev_num, mode, j)),
4086 printk(KERN_ERR "st%d: Can't add %s-rewind mode %d\n",
4087 dev_num, j ? "non" : "auto", mode);
4088 printk(KERN_ERR "st%d: Device not attached.\n", dev_num);
4091 STm->cdevs[j] = cdev;
4094 error = do_create_class_files(tpnt, dev_num, mode);
4099 sdev_printk(KERN_NOTICE, SDp,
4100 "Attached scsi tape %s\n", tape_name(tpnt));
4101 sdev_printk(KERN_INFO, SDp, "%s: try direct i/o: %s (alignment %d B)\n",
4102 tape_name(tpnt), tpnt->try_dio ? "yes" : "no",
4103 queue_dma_alignment(SDp->request_queue) + 1);
4108 for (mode=0; mode < ST_NBR_MODES; mode++) {
4109 STm = &(tpnt->modes[mode]);
4110 sysfs_remove_link(&tpnt->device->sdev_gendev.kobj,
4112 for (j=0; j < 2; j++) {
4113 if (STm->cdevs[j]) {
4114 if (cdev == STm->cdevs[j])
4116 device_destroy(st_sysfs_class,
4117 MKDEV(SCSI_TAPE_MAJOR,
4118 TAPE_MINOR(i, mode, j)));
4119 cdev_del(STm->cdevs[j]);
4125 write_lock(&st_dev_arr_lock);
4126 scsi_tapes[dev_num] = NULL;
4128 write_unlock(&st_dev_arr_lock);
4139 static int st_remove(struct device *dev)
4141 struct scsi_device *SDp = to_scsi_device(dev);
4142 struct scsi_tape *tpnt;
4145 write_lock(&st_dev_arr_lock);
4146 for (i = 0; i < st_dev_max; i++) {
4147 tpnt = scsi_tapes[i];
4148 if (tpnt != NULL && tpnt->device == SDp) {
4149 scsi_tapes[i] = NULL;
4151 write_unlock(&st_dev_arr_lock);
4152 sysfs_remove_link(&tpnt->device->sdev_gendev.kobj,
4154 for (mode = 0; mode < ST_NBR_MODES; ++mode) {
4155 for (j=0; j < 2; j++) {
4156 device_destroy(st_sysfs_class,
4157 MKDEV(SCSI_TAPE_MAJOR,
4158 TAPE_MINOR(i, mode, j)));
4159 cdev_del(tpnt->modes[mode].cdevs[j]);
4160 tpnt->modes[mode].cdevs[j] = NULL;
4164 mutex_lock(&st_ref_mutex);
4165 kref_put(&tpnt->kref, scsi_tape_release);
4166 mutex_unlock(&st_ref_mutex);
4171 write_unlock(&st_dev_arr_lock);
4176 * scsi_tape_release - Called to free the Scsi_Tape structure
4177 * @kref: pointer to embedded kref
4179 * st_ref_mutex must be held entering this routine. Because it is
4180 * called on last put, you should always use the scsi_tape_get()
4181 * scsi_tape_put() helpers which manipulate the semaphore directly
4182 * and never do a direct kref_put().
4184 static void scsi_tape_release(struct kref *kref)
4186 struct scsi_tape *tpnt = to_scsi_tape(kref);
4187 struct gendisk *disk = tpnt->disk;
4189 tpnt->device = NULL;
4192 tpnt->buffer->orig_frp_segs = 0;
4193 normalize_buffer(tpnt->buffer);
4194 kfree(tpnt->buffer);
4197 disk->private_data = NULL;
4203 static int __init init_st(void)
4209 printk(KERN_INFO "st: Version %s, fixed bufsize %d, s/g segs %d\n",
4210 verstr, st_fixed_buffer_size, st_max_sg_segs);
4212 st_sysfs_class = class_create(THIS_MODULE, "scsi_tape");
4213 if (IS_ERR(st_sysfs_class)) {
4214 printk(KERN_ERR "Unable create sysfs class for SCSI tapes\n");
4215 return PTR_ERR(st_sysfs_class);
4218 err = register_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0),
4219 ST_MAX_TAPE_ENTRIES, "st");
4221 printk(KERN_ERR "Unable to get major %d for SCSI tapes\n",
4226 err = scsi_register_driver(&st_template.gendrv);
4230 err = do_create_sysfs_files();
4237 scsi_unregister_driver(&st_template.gendrv);
4239 unregister_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0),
4240 ST_MAX_TAPE_ENTRIES);
4242 class_destroy(st_sysfs_class);
4246 static void __exit exit_st(void)
4248 do_remove_sysfs_files();
4249 scsi_unregister_driver(&st_template.gendrv);
4250 unregister_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0),
4251 ST_MAX_TAPE_ENTRIES);
4252 class_destroy(st_sysfs_class);
4254 printk(KERN_INFO "st: Unloaded.\n");
4257 module_init(init_st);
4258 module_exit(exit_st);
4261 /* The sysfs driver interface. Read-only at the moment */
4262 static ssize_t st_try_direct_io_show(struct device_driver *ddp, char *buf)
4264 return snprintf(buf, PAGE_SIZE, "%d\n", try_direct_io);
4266 static DRIVER_ATTR(try_direct_io, S_IRUGO, st_try_direct_io_show, NULL);
4268 static ssize_t st_fixed_buffer_size_show(struct device_driver *ddp, char *buf)
4270 return snprintf(buf, PAGE_SIZE, "%d\n", st_fixed_buffer_size);
4272 static DRIVER_ATTR(fixed_buffer_size, S_IRUGO, st_fixed_buffer_size_show, NULL);
4274 static ssize_t st_max_sg_segs_show(struct device_driver *ddp, char *buf)
4276 return snprintf(buf, PAGE_SIZE, "%d\n", st_max_sg_segs);
4278 static DRIVER_ATTR(max_sg_segs, S_IRUGO, st_max_sg_segs_show, NULL);
4280 static ssize_t st_version_show(struct device_driver *ddd, char *buf)
4282 return snprintf(buf, PAGE_SIZE, "[%s]\n", verstr);
4284 static DRIVER_ATTR(version, S_IRUGO, st_version_show, NULL);
4286 static int do_create_sysfs_files(void)
4288 struct device_driver *sysfs = &st_template.gendrv;
4291 err = driver_create_file(sysfs, &driver_attr_try_direct_io);
4294 err = driver_create_file(sysfs, &driver_attr_fixed_buffer_size);
4296 goto err_try_direct_io;
4297 err = driver_create_file(sysfs, &driver_attr_max_sg_segs);
4299 goto err_attr_fixed_buf;
4300 err = driver_create_file(sysfs, &driver_attr_version);
4302 goto err_attr_max_sg;
4307 driver_remove_file(sysfs, &driver_attr_max_sg_segs);
4309 driver_remove_file(sysfs, &driver_attr_fixed_buffer_size);
4311 driver_remove_file(sysfs, &driver_attr_try_direct_io);
4315 static void do_remove_sysfs_files(void)
4317 struct device_driver *sysfs = &st_template.gendrv;
4319 driver_remove_file(sysfs, &driver_attr_version);
4320 driver_remove_file(sysfs, &driver_attr_max_sg_segs);
4321 driver_remove_file(sysfs, &driver_attr_fixed_buffer_size);
4322 driver_remove_file(sysfs, &driver_attr_try_direct_io);
4326 /* The sysfs simple class interface */
4328 st_defined_show(struct device *dev, struct device_attribute *attr, char *buf)
4330 struct st_modedef *STm = dev_get_drvdata(dev);
4333 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->defined);
4337 DEVICE_ATTR(defined, S_IRUGO, st_defined_show, NULL);
4340 st_defblk_show(struct device *dev, struct device_attribute *attr, char *buf)
4342 struct st_modedef *STm = dev_get_drvdata(dev);
4345 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->default_blksize);
4349 DEVICE_ATTR(default_blksize, S_IRUGO, st_defblk_show, NULL);
4352 st_defdensity_show(struct device *dev, struct device_attribute *attr, char *buf)
4354 struct st_modedef *STm = dev_get_drvdata(dev);
4358 fmt = STm->default_density >= 0 ? "0x%02x\n" : "%d\n";
4359 l = snprintf(buf, PAGE_SIZE, fmt, STm->default_density);
4363 DEVICE_ATTR(default_density, S_IRUGO, st_defdensity_show, NULL);
4366 st_defcompression_show(struct device *dev, struct device_attribute *attr,
4369 struct st_modedef *STm = dev_get_drvdata(dev);
4372 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->default_compression - 1);
4376 DEVICE_ATTR(default_compression, S_IRUGO, st_defcompression_show, NULL);
4379 st_options_show(struct device *dev, struct device_attribute *attr, char *buf)
4381 struct st_modedef *STm = dev_get_drvdata(dev);
4382 struct scsi_tape *STp;
4386 for (i=0; i < st_dev_max; i++) {
4387 for (j=0; j < ST_NBR_MODES; j++)
4388 if (&scsi_tapes[i]->modes[j] == STm)
4390 if (j < ST_NBR_MODES)
4393 if (i == st_dev_max)
4394 return 0; /* should never happen */
4396 STp = scsi_tapes[i];
4398 options = STm->do_buffer_writes ? MT_ST_BUFFER_WRITES : 0;
4399 options |= STm->do_async_writes ? MT_ST_ASYNC_WRITES : 0;
4400 options |= STm->do_read_ahead ? MT_ST_READ_AHEAD : 0;
4401 DEB( options |= debugging ? MT_ST_DEBUGGING : 0 );
4402 options |= STp->two_fm ? MT_ST_TWO_FM : 0;
4403 options |= STp->fast_mteom ? MT_ST_FAST_MTEOM : 0;
4404 options |= STm->defaults_for_writes ? MT_ST_DEF_WRITES : 0;
4405 options |= STp->can_bsr ? MT_ST_CAN_BSR : 0;
4406 options |= STp->omit_blklims ? MT_ST_NO_BLKLIMS : 0;
4407 options |= STp->can_partitions ? MT_ST_CAN_PARTITIONS : 0;
4408 options |= STp->scsi2_logical ? MT_ST_SCSI2LOGICAL : 0;
4409 options |= STm->sysv ? MT_ST_SYSV : 0;
4410 options |= STp->immediate ? MT_ST_NOWAIT : 0;
4411 options |= STp->sili ? MT_ST_SILI : 0;
4413 l = snprintf(buf, PAGE_SIZE, "0x%08x\n", options);
4417 DEVICE_ATTR(options, S_IRUGO, st_options_show, NULL);
4419 static int do_create_class_files(struct scsi_tape *STp, int dev_num, int mode)
4423 struct device *st_class_member;
4425 for (rew=0; rew < 2; rew++) {
4426 /* Make sure that the minor numbers corresponding to the four
4427 first modes always get the same names */
4428 i = mode << (4 - ST_NBR_MODE_BITS);
4429 snprintf(name, 10, "%s%s%s", rew ? "n" : "",
4430 STp->disk->disk_name, st_formats[i]);
4432 device_create(st_sysfs_class, &STp->device->sdev_gendev,
4433 MKDEV(SCSI_TAPE_MAJOR,
4434 TAPE_MINOR(dev_num, mode, rew)),
4435 &STp->modes[mode], "%s", name);
4436 if (IS_ERR(st_class_member)) {
4437 printk(KERN_WARNING "st%d: device_create failed\n",
4439 error = PTR_ERR(st_class_member);
4443 error = device_create_file(st_class_member,
4445 if (error) goto out;
4446 error = device_create_file(st_class_member,
4447 &dev_attr_default_blksize);
4448 if (error) goto out;
4449 error = device_create_file(st_class_member,
4450 &dev_attr_default_density);
4451 if (error) goto out;
4452 error = device_create_file(st_class_member,
4453 &dev_attr_default_compression);
4454 if (error) goto out;
4455 error = device_create_file(st_class_member,
4457 if (error) goto out;
4459 if (mode == 0 && rew == 0) {
4460 error = sysfs_create_link(&STp->device->sdev_gendev.kobj,
4461 &st_class_member->kobj,
4465 "st%d: Can't create sysfs link from SCSI device.\n",
4478 /* The following functions may be useful for a larger audience. */
4479 static int sgl_map_user_pages(struct scatterlist *sgl, const unsigned int max_pages,
4480 unsigned long uaddr, size_t count, int rw)
4482 unsigned long end = (uaddr + count + PAGE_SIZE - 1) >> PAGE_SHIFT;
4483 unsigned long start = uaddr >> PAGE_SHIFT;
4484 const int nr_pages = end - start;
4486 struct page **pages;
4488 /* User attempted Overflow! */
4489 if ((uaddr + count) < uaddr)
4493 if (nr_pages > max_pages)
4500 if ((pages = kmalloc(max_pages * sizeof(*pages), GFP_KERNEL)) == NULL)
4503 /* Try to fault in all of the necessary pages */
4504 down_read(¤t->mm->mmap_sem);
4505 /* rw==READ means read from drive, write into memory area */
4506 res = get_user_pages(
4512 0, /* don't force */
4515 up_read(¤t->mm->mmap_sem);
4517 /* Errors and no page mapped should return here */
4521 for (i=0; i < nr_pages; i++) {
4522 /* FIXME: flush superflous for rw==READ,
4523 * probably wrong function for rw==WRITE
4525 flush_dcache_page(pages[i]);
4528 /* Populate the scatter/gather list */
4529 sg_set_page(&sgl[0], pages[0], 0, uaddr & ~PAGE_MASK);
4531 sgl[0].length = PAGE_SIZE - sgl[0].offset;
4532 count -= sgl[0].length;
4533 for (i=1; i < nr_pages ; i++) {
4534 sg_set_page(&sgl[i], pages[i],
4535 count < PAGE_SIZE ? count : PAGE_SIZE, 0);;
4540 sgl[0].length = count;
4548 for (j=0; j < res; j++)
4549 page_cache_release(pages[j]);
4557 /* And unmap them... */
4558 static int sgl_unmap_user_pages(struct scatterlist *sgl, const unsigned int nr_pages,
4563 for (i=0; i < nr_pages; i++) {
4564 struct page *page = sg_page(&sgl[i]);
4568 /* FIXME: cache flush missing for rw==READ
4569 * FIXME: call the correct reference counting function
4571 page_cache_release(page);