1 /* 2 SCSI Tape Driver for Linux version 1.1 and newer. See the accompanying 3 file Documentation/scsi/st.txt for more information. 4 5 History: 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. 11 12 Copyright 1992 - 2008 Kai Makisara 13 email Kai.Makisara@kolumbus.fi 14 15 Some small formal changes - aeb, 950809 16 17 Last modified: 18-JAN-1998 Richard Gooch <rgooch@atnf.csiro.au> Devfs support 18 */ 19 20 static const char *verstr = "20080504"; 21 22 #include <linux/module.h> 23 24 #include <linux/fs.h> 25 #include <linux/kernel.h> 26 #include <linux/sched.h> 27 #include <linux/mm.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> 42 43 #include <asm/uaccess.h> 44 #include <asm/dma.h> 45 #include <asm/system.h> 46 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> 54 #include <scsi/sg.h> 55 56 57 /* The driver prints some debugging information on the console if DEBUG 58 is defined and non-zero. */ 59 #define DEBUG 0 60 61 #if DEBUG 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 66 #define DEB(a) a 67 #define DEBC(a) if (debugging) { a ; } 68 #else 69 #define DEB(a) 70 #define DEBC(a) 71 #endif 72 73 #define ST_KILOBYTE 1024 74 75 #include "st_options.h" 76 #include "st.h" 77 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; 83 84 static int st_dev_max; 85 static int st_nr_dev; 86 87 static struct class *st_sysfs_class; 88 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); 94 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. 98 */ 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)"); 105 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"); 111 112 #ifndef MODULE 113 static int write_threshold_kbs; /* retained for compatibility */ 114 static struct st_dev_parm { 115 char *name; 116 int *val; 117 } parms[] __initdata = { 118 { 119 "buffer_kbs", &buffer_kbs 120 }, 121 { /* Retained for compatibility with 2.4 */ 122 "write_threshold_kbs", &write_threshold_kbs 123 }, 124 { 125 "max_sg_segs", NULL 126 }, 127 { 128 "try_direct_io", &try_direct_io 129 } 130 }; 131 #endif 132 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" 136 #endif 137 /* Bit reversed order to get same names for same minors with all 138 mode counts */ 139 static const char *st_formats[] = { 140 "", "r", "k", "s", "l", "t", "o", "u", 141 "m", "v", "p", "x", "a", "y", "q", "z"}; 142 143 /* The default definitions have been moved to st_options.h */ 144 145 #define ST_FIXED_BUFFER_SIZE (ST_FIXED_BUFFER_BLOCKS * ST_KILOBYTE) 146 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!" 151 #endif 152 153 static int debugging = DEBUG; 154 155 #define MAX_RETRIES 0 156 #define MAX_WRITE_RETRIES 0 157 #define MAX_READY_RETRIES 0 158 #define NO_TAPE NOT_READY 159 160 #define ST_TIMEOUT (900 * HZ) 161 #define ST_LONG_TIMEOUT (14000 * HZ) 162 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) 167 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) ) 171 172 /* Internal ioctl to set both density (uppermost 8 bits) and blocksize (lower 173 24 bits) */ 174 #define SET_DENS_AND_BLK 0x10001 175 176 static DEFINE_RWLOCK(st_dev_arr_lock); 177 178 static int st_fixed_buffer_size = ST_FIXED_BUFFER_SIZE; 179 static int st_max_sg_segs = ST_MAX_SG; 180 181 static struct scsi_tape **scsi_tapes = NULL; 182 183 static int modes_defined; 184 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); 193 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); 197 198 static int st_probe(struct device *); 199 static int st_remove(struct device *); 200 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); 204 205 static struct scsi_driver st_template = { 206 .owner = THIS_MODULE, 207 .gendrv = { 208 .name = "st", 209 .probe = st_probe, 210 .remove = st_remove, 211 }, 212 }; 213 214 static int st_compression(struct scsi_tape *, int); 215 216 static int find_partition(struct scsi_tape *); 217 static int switch_partition(struct scsi_tape *); 218 219 static int st_int_ioctl(struct scsi_tape *, unsigned int, unsigned long); 220 221 static void scsi_tape_release(struct kref *); 222 223 #define to_scsi_tape(obj) container_of(obj, struct scsi_tape, kref) 224 225 static DEFINE_MUTEX(st_ref_mutex); 226 227 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"} 236 #endif 237 238 static struct scsi_tape *scsi_tape_get(int dev) 239 { 240 struct scsi_tape *STp = NULL; 241 242 mutex_lock(&st_ref_mutex); 243 write_lock(&st_dev_arr_lock); 244 245 if (dev < st_dev_max && scsi_tapes != NULL) 246 STp = scsi_tapes[dev]; 247 if (!STp) goto out; 248 249 kref_get(&STp->kref); 250 251 if (!STp->device) 252 goto out_put; 253 254 if (scsi_device_get(STp->device)) 255 goto out_put; 256 257 goto out; 258 259 out_put: 260 kref_put(&STp->kref, scsi_tape_release); 261 STp = NULL; 262 out: 263 write_unlock(&st_dev_arr_lock); 264 mutex_unlock(&st_ref_mutex); 265 return STp; 266 } 267 268 static void scsi_tape_put(struct scsi_tape *STp) 269 { 270 struct scsi_device *sdev = STp->device; 271 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); 276 } 277 278 struct st_reject_data { 279 char *vendor; 280 char *model; 281 char *rev; 282 char *driver_hint; /* Name of the correct driver, NULL if unknown */ 283 }; 284 285 static struct st_reject_data reject_list[] = { 286 /* {"XXX", "Yy-", "", NULL}, example */ 287 SIGS_FROM_OSST, 288 {NULL, }}; 289 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) 293 { 294 struct st_reject_data *rp; 295 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))) { 300 if (rp->driver_hint) 301 return rp->driver_hint; 302 else 303 return "unknown"; 304 } 305 return NULL; 306 } 307 308 309 static inline char *tape_name(struct scsi_tape *tape) 310 { 311 return tape->disk->disk_name; 312 } 313 314 315 static void st_analyze_sense(struct st_request *SRpnt, struct st_cmdstatus *s) 316 { 317 const u8 *ucp; 318 const u8 *sense = SRpnt->sense; 319 320 s->have_sense = scsi_normalize_sense(SRpnt->sense, 321 SCSI_SENSE_BUFFERSIZE, &s->sense_hdr); 322 s->flags = 0; 323 324 if (s->have_sense) { 325 s->deferred = 0; 326 s->remainder_valid = 327 scsi_get_sense_info_fld(sense, SCSI_SENSE_BUFFERSIZE, &s->uremainder64); 328 switch (sense[0] & 0x7f) { 329 case 0x71: 330 s->deferred = 1; 331 case 0x70: 332 s->fixed_format = 1; 333 s->flags = sense[2] & 0xe0; 334 break; 335 case 0x73: 336 s->deferred = 1; 337 case 0x72: 338 s->fixed_format = 0; 339 ucp = scsi_sense_desc_find(sense, SCSI_SENSE_BUFFERSIZE, 4); 340 s->flags = ucp ? (ucp[3] & 0xe0) : 0; 341 break; 342 } 343 } 344 } 345 346 347 /* Convert the result to success code */ 348 static int st_chk_result(struct scsi_tape *STp, struct st_request * SRpnt) 349 { 350 int result = SRpnt->result; 351 u8 scode; 352 DEB(const char *stp;) 353 char *name = tape_name(STp); 354 struct st_cmdstatus *cmdstatp; 355 356 if (!result) 357 return 0; 358 359 cmdstatp = &STp->buffer->cmdstat; 360 st_analyze_sense(SRpnt, cmdstatp); 361 362 if (cmdstatp->have_sense) 363 scode = STp->buffer->cmdstat.sense_hdr.sense_key; 364 else 365 scode = 0; 366 367 DEB( 368 if (debugging) { 369 printk(ST_DEB_MSG "%s: Error: %x, cmd: %x %x %x %x %x %x\n", 370 name, result, 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); 375 } ) /* end DEB */ 376 if (!debugging) { /* Abnormal conditions for tape */ 377 if (!cmdstatp->have_sense) 378 printk(KERN_WARNING 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 && 383 scode != NO_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) { 390 391 __scsi_print_sense(name, SRpnt->sense, SCSI_SENSE_BUFFERSIZE); 392 } 393 } 394 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); 400 else 401 STp->cleaning_req |= ((SRpnt->sense[STp->cln_mode] & 402 STp->cln_sense_mask) != 0); 403 } 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 */ 407 408 STp->pos_unknown |= STp->device->was_reset; 409 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 415 #endif 416 ) { 417 STp->recover_count++; 418 STp->recover_reg++; 419 420 DEB( 421 if (debugging) { 422 if (SRpnt->cmd[0] == READ_6) 423 stp = "read"; 424 else if (SRpnt->cmd[0] == WRITE_6) 425 stp = "write"; 426 else 427 stp = "ioctl"; 428 printk(ST_DEB_MSG "%s: Recovered %s error (%d).\n", name, stp, 429 STp->recover_count); 430 } ) /* end DEB */ 431 432 if (cmdstatp->flags == 0) 433 return 0; 434 } 435 return (-EIO); 436 } 437 438 439 /* Wakeup from interrupt */ 440 static void st_sleep_done(void *data, char *sense, int result, int resid) 441 { 442 struct st_request *SRpnt = data; 443 struct scsi_tape *STp = SRpnt->stp; 444 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; ) 449 450 if (SRpnt->waiting) 451 complete(SRpnt->waiting); 452 } 453 454 static struct st_request *st_allocate_request(void) 455 { 456 return kzalloc(sizeof(struct st_request), GFP_KERNEL); 457 } 458 459 static void st_release_request(struct st_request *streq) 460 { 461 kfree(streq); 462 } 463 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 466 has finished. */ 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) 470 { 471 struct completion *waiting; 472 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", 476 tape_name(STp)); 477 if (signal_pending(current)) 478 (STp->buffer)->syscall_result = (-EINTR); 479 else 480 (STp->buffer)->syscall_result = (-EBUSY); 481 return NULL; 482 } 483 484 if (SRpnt == NULL) { 485 SRpnt = st_allocate_request(); 486 if (SRpnt == NULL) { 487 DEBC( printk(KERN_ERR "%s: Can't get SCSI request.\n", 488 tape_name(STp)); ); 489 if (signal_pending(current)) 490 (STp->buffer)->syscall_result = (-EINTR); 491 else 492 (STp->buffer)->syscall_result = (-EBUSY); 493 return NULL; 494 } 495 SRpnt->stp = STp; 496 } 497 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. */ 500 if (!do_wait) 501 (STp->buffer)->last_SRpnt = SRpnt; 502 503 waiting = &STp->wait; 504 init_completion(waiting); 505 SRpnt->waiting = waiting; 506 507 if (!STp->buffer->do_dio) 508 buf_to_sg(STp->buffer, bytes); 509 510 memcpy(SRpnt->cmd, cmd, sizeof(SRpnt->cmd)); 511 STp->buffer->cmdstat.have_sense = 0; 512 STp->buffer->syscall_result = 0; 513 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; 520 } 521 else if (do_wait) { 522 wait_for_completion(waiting); 523 SRpnt->waiting = NULL; 524 (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt); 525 } 526 527 return SRpnt; 528 } 529 530 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) 536 { 537 int retval = 0; 538 struct st_buffer *STbuffer; 539 struct st_partstat *STps; 540 struct st_cmdstatus *cmdstatp; 541 struct st_request *SRpnt; 542 543 STbuffer = STp->buffer; 544 if (!STbuffer->writing) 545 return 0; 546 547 DEB( 548 if (STp->write_pending) 549 STp->nbr_waits++; 550 else 551 STp->nbr_finished++; 552 ) /* end DEB */ 553 554 wait_for_completion(&(STp->wait)); 555 SRpnt = STbuffer->last_SRpnt; 556 STbuffer->last_SRpnt = NULL; 557 SRpnt->waiting = NULL; 558 559 (STp->buffer)->syscall_result = st_chk_result(STp, SRpnt); 560 st_release_request(SRpnt); 561 562 STbuffer->buffer_bytes -= STbuffer->writing; 563 STps = &(STp->ps[STp->partition]); 564 if (STps->drv_block >= 0) { 565 if (STp->block_size == 0) 566 STps->drv_block++; 567 else 568 STps->drv_block += STbuffer->writing / STp->block_size; 569 } 570 571 cmdstatp = &STbuffer->cmdstat; 572 if (STbuffer->syscall_result) { 573 retval = -EIO; 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) 581 retval = -ENOSPC; 582 } 583 if (retval == -EIO) 584 STps->drv_block = -1; 585 } 586 STbuffer->writing = 0; 587 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 */ 591 592 return retval; 593 } 594 595 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) 599 { 600 struct st_request *SRpnt; 601 unsigned char cmd[MAX_COMMAND_SIZE]; 602 603 cmd[0] = SPACE; 604 cmd[1] = 0x01; /* Space FileMarks */ 605 if (forward) { 606 cmd[2] = cmd[3] = 0; 607 cmd[4] = 1; 608 } else 609 cmd[2] = cmd[3] = cmd[4] = 0xff; /* -1 filemarks */ 610 cmd[5] = 0; 611 612 DEBC(printk(ST_DEB_MSG "%s: Stepping over filemark %s.\n", 613 tape_name(STp), forward ? "forward" : "backward")); 614 615 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE, 616 STp->device->timeout, MAX_RETRIES, 1); 617 if (!SRpnt) 618 return (STp->buffer)->syscall_result; 619 620 st_release_request(SRpnt); 621 SRpnt = NULL; 622 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"); 626 627 return (STp->buffer)->syscall_result; 628 } 629 630 631 /* Flush the write buffer (never need to write if variable blocksize). */ 632 static int st_flush_write_buffer(struct scsi_tape * STp) 633 { 634 int transfer, blks; 635 int result; 636 unsigned char cmd[MAX_COMMAND_SIZE]; 637 struct st_request *SRpnt; 638 struct st_partstat *STps; 639 640 result = write_behind_check(STp); 641 if (result) 642 return result; 643 644 result = 0; 645 if (STp->dirty == 1) { 646 647 transfer = STp->buffer->buffer_bytes; 648 DEBC(printk(ST_DEB_MSG "%s: Flushing %d bytes.\n", 649 tape_name(STp), transfer)); 650 651 memset(cmd, 0, MAX_COMMAND_SIZE); 652 cmd[0] = WRITE_6; 653 cmd[1] = 1; 654 blks = transfer / STp->block_size; 655 cmd[2] = blks >> 16; 656 cmd[3] = blks >> 8; 657 cmd[4] = blks; 658 659 SRpnt = st_do_scsi(NULL, STp, cmd, transfer, DMA_TO_DEVICE, 660 STp->device->timeout, MAX_WRITE_RETRIES, 1); 661 if (!SRpnt) 662 return (STp->buffer)->syscall_result; 663 664 STps = &(STp->ps[STp->partition]); 665 if ((STp->buffer)->syscall_result != 0) { 666 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat; 667 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 */ 674 STp->dirty = 0; 675 (STp->buffer)->buffer_bytes = 0; 676 if (STps->drv_block >= 0) 677 STps->drv_block += blks; 678 result = (-ENOSPC); 679 } else { 680 printk(KERN_ERR "%s: Error on flush.\n", 681 tape_name(STp)); 682 STps->drv_block = (-1); 683 result = (-EIO); 684 } 685 } else { 686 if (STps->drv_block >= 0) 687 STps->drv_block += blks; 688 STp->dirty = 0; 689 (STp->buffer)->buffer_bytes = 0; 690 } 691 st_release_request(SRpnt); 692 SRpnt = NULL; 693 } 694 return result; 695 } 696 697 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) 701 { 702 int backspace, result; 703 struct st_buffer *STbuffer; 704 struct st_partstat *STps; 705 706 STbuffer = STp->buffer; 707 708 /* 709 * If there was a bus reset, block further access 710 * to this device. 711 */ 712 if (STp->pos_unknown) 713 return (-EIO); 714 715 if (STp->ready != ST_READY) 716 return 0; 717 STps = &(STp->ps[STp->partition]); 718 if (STps->rw == ST_WRITING) /* Writing */ 719 return st_flush_write_buffer(STp); 720 721 if (STp->block_size == 0) 722 return 0; 723 724 backspace = ((STp->buffer)->buffer_bytes + 725 (STp->buffer)->read_pointer) / STp->block_size - 726 ((STp->buffer)->read_pointer + STp->block_size - 1) / 727 STp->block_size; 728 (STp->buffer)->buffer_bytes = 0; 729 (STp->buffer)->read_pointer = 0; 730 result = 0; 731 if (!seek_next) { 732 if (STps->eof == ST_FM_HIT) { 733 result = cross_eof(STp, 0); /* Back over the EOF hit */ 734 if (!result) 735 STps->eof = ST_NOEOF; 736 else { 737 if (STps->drv_file >= 0) 738 STps->drv_file++; 739 STps->drv_block = 0; 740 } 741 } 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) 746 STps->drv_file++; 747 STps->drv_block = 0; 748 STps->eof = ST_NOEOF; 749 } 750 return result; 751 752 } 753 754 /* Set the mode parameters */ 755 static int set_mode_densblk(struct scsi_tape * STp, struct st_modedef * STm) 756 { 757 int set_it = 0; 758 unsigned long arg; 759 char *name = tape_name(STp); 760 761 if (!STp->density_changed && 762 STm->default_density >= 0 && 763 STm->default_density != STp->density) { 764 arg = STm->default_density; 765 set_it = 1; 766 } else 767 arg = STp->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; 773 set_it = 1; 774 } else 775 arg |= STp->block_size; 776 if (set_it && 777 st_int_ioctl(STp, SET_DENS_AND_BLK, arg)) { 778 printk(KERN_WARNING 779 "%s: Can't set default block size to %d bytes and density %x.\n", 780 name, STm->default_blksize, STm->default_density); 781 if (modes_defined) 782 return (-EINVAL); 783 } 784 return 0; 785 } 786 787 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) 790 { 791 int retval, cmd; 792 DEB(char *name = tape_name(STp);) 793 794 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); 799 if (!retval) { 800 STp->door_locked = do_lock ? ST_LOCKED_EXPLICIT : ST_UNLOCKED; 801 } 802 else { 803 STp->door_locked = ST_LOCK_FAILS; 804 } 805 return retval; 806 } 807 808 809 /* Set the internal state after reset */ 810 static void reset_state(struct scsi_tape *STp) 811 { 812 int i; 813 struct st_partstat *STps; 814 815 STp->pos_unknown = 0; 816 for (i = 0; i < ST_NBR_PARTITIONS; i++) { 817 STps = &(STp->ps[i]); 818 STps->rw = ST_IDLE; 819 STps->eof = ST_NOEOF; 820 STps->at_sm = 0; 821 STps->last_block_valid = 0; 822 STps->drv_block = -1; 823 STps->drv_file = -1; 824 } 825 if (STp->can_partitions) { 826 STp->partition = find_partition(STp); 827 if (STp->partition < 0) 828 STp->partition = 0; 829 STp->new_partition = STp->partition; 830 } 831 } 832 833 /* Test if the drive is ready. Returns either one of the codes below or a negative system 834 error code. */ 835 #define CHKRES_READY 0 836 #define CHKRES_NEW_SESSION 1 837 #define CHKRES_NOT_READY 2 838 #define CHKRES_NO_TAPE 3 839 840 #define MAX_ATTENTIONS 10 841 842 static int test_ready(struct scsi_tape *STp, int do_wait) 843 { 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; 849 850 max_wait = do_wait ? ST_BLOCK_SECONDS : 0; 851 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); 857 858 if (!SRpnt) { 859 retval = (STp->buffer)->syscall_result; 860 break; 861 } 862 863 if (cmdstatp->have_sense) { 864 865 scode = cmdstatp->sense_hdr.sense_key; 866 867 if (scode == UNIT_ATTENTION) { /* New media? */ 868 new_session = 1; 869 if (attentions < MAX_ATTENTIONS) { 870 attentions++; 871 continue; 872 } 873 else { 874 retval = (-EIO); 875 break; 876 } 877 } 878 879 if (scode == NOT_READY) { 880 if (waits < max_wait) { 881 if (msleep_interruptible(1000)) { 882 retval = (-EINTR); 883 break; 884 } 885 waits++; 886 continue; 887 } 888 else { 889 if ((STp->device)->scsi_level >= SCSI_2 && 890 cmdstatp->sense_hdr.asc == 0x3a) /* Check ASC */ 891 retval = CHKRES_NO_TAPE; 892 else 893 retval = CHKRES_NOT_READY; 894 break; 895 } 896 } 897 } 898 899 retval = (STp->buffer)->syscall_result; 900 if (!retval) 901 retval = new_session ? CHKRES_NEW_SESSION : CHKRES_READY; 902 break; 903 } 904 905 if (SRpnt != NULL) 906 st_release_request(SRpnt); 907 return retval; 908 } 909 910 911 /* See if the drive is ready and gather information about the tape. Return values: 912 < 0 negative error code from errno.h 913 0 drive ready 914 1 drive not ready (possibly no tape) 915 */ 916 static int check_tape(struct scsi_tape *STp, struct file *filp) 917 { 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); 927 928 STp->ready = ST_READY; 929 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)); 933 new_session = 1; 934 STp->current_mode = mode; 935 } 936 STm = &(STp->modes[STp->current_mode]); 937 938 saved_cleaning = STp->cleaning_req; 939 STp->cleaning_req = 0; 940 941 do_wait = ((filp->f_flags & O_NONBLOCK) == 0); 942 retval = test_ready(STp, do_wait); 943 944 if (retval < 0) 945 goto err_out; 946 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 952 if necessary */ 953 for (i = 0; i < ST_NBR_PARTITIONS; i++) { 954 STps = &(STp->ps[i]); 955 STps->rw = ST_IDLE; 956 STps->eof = ST_NOEOF; 957 STps->at_sm = 0; 958 STps->last_block_valid = 0; 959 STps->drv_block = 0; 960 STps->drv_file = 0; 961 } 962 new_session = 1; 963 } 964 else { 965 STp->cleaning_req |= saved_cleaning; 966 967 if (retval == CHKRES_NOT_READY || retval == CHKRES_NO_TAPE) { 968 if (retval == CHKRES_NO_TAPE) 969 STp->ready = ST_NO_TAPE; 970 else 971 STp->ready = ST_NOT_READY; 972 973 STp->density = 0; /* Clear the erroneous "residue" */ 974 STp->write_prot = 0; 975 STp->block_size = 0; 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; 980 } 981 } 982 983 if (STp->omit_blklims) 984 STp->min_block = STp->max_block = (-1); 985 else { 986 memset((void *) &cmd[0], 0, MAX_COMMAND_SIZE); 987 cmd[0] = READ_BLOCK_LIMITS; 988 989 SRpnt = st_do_scsi(SRpnt, STp, cmd, 6, DMA_FROM_DEVICE, 990 STp->device->timeout, MAX_READY_RETRIES, 1); 991 if (!SRpnt) { 992 retval = (STp->buffer)->syscall_result; 993 goto err_out; 994 } 995 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) 1002 printk(KERN_INFO 1003 "%s: Block limits %d - %d bytes.\n", name, 1004 STp->min_block, STp->max_block); 1005 } else { 1006 STp->min_block = STp->max_block = (-1); 1007 DEBC(printk(ST_DEB_MSG "%s: Can't read block limits.\n", 1008 name)); 1009 } 1010 } 1011 1012 memset((void *) &cmd[0], 0, MAX_COMMAND_SIZE); 1013 cmd[0] = MODE_SENSE; 1014 cmd[4] = 12; 1015 1016 SRpnt = st_do_scsi(SRpnt, STp, cmd, 12, DMA_FROM_DEVICE, 1017 STp->device->timeout, MAX_READY_RETRIES, 1); 1018 if (!SRpnt) { 1019 retval = (STp->buffer)->syscall_result; 1020 goto err_out; 1021 } 1022 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; 1028 } else { 1029 DEBC(printk(ST_DEB_MSG 1030 "%s: Mode sense. Length %d, medium %x, WBS %x, BLL %d\n", 1031 name, 1032 (STp->buffer)->b_data[0], (STp->buffer)->b_data[1], 1033 (STp->buffer)->b_data[2], (STp->buffer)->b_data[3])); 1034 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], 1044 STp->drv_buffer)); 1045 } 1046 STp->drv_write_prot = ((STp->buffer)->b_data[2] & 0x80) != 0; 1047 } 1048 st_release_request(SRpnt); 1049 SRpnt = NULL; 1050 STp->inited = 1; 1051 1052 if (STp->block_size > 0) 1053 (STp->buffer)->buffer_blocks = 1054 (STp->buffer)->buffer_size / STp->block_size; 1055 else 1056 (STp->buffer)->buffer_blocks = 1; 1057 (STp->buffer)->buffer_bytes = (STp->buffer)->read_pointer = 0; 1058 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)); 1063 1064 if (STp->drv_write_prot) { 1065 STp->write_prot = 1; 1066 1067 DEBC(printk(ST_DEB_MSG "%s: Write protected\n", name)); 1068 1069 if (do_wait && 1070 ((st_flags & O_ACCMODE) == O_WRONLY || 1071 (st_flags & O_ACCMODE) == O_RDWR)) { 1072 retval = (-EROFS); 1073 goto err_out; 1074 } 1075 } 1076 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; 1085 goto err_out; 1086 } 1087 STp->new_partition = STp->partition; 1088 STp->nbr_partitions = 1; /* This guess will be updated when necessary */ 1089 } 1090 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) 1096 goto err_out; 1097 1098 if (STp->default_drvbuffer != 0xff) { 1099 if (st_int_ioctl(STp, MTSETDRVBUFFER, STp->default_drvbuffer)) 1100 printk(KERN_WARNING 1101 "%s: Can't set default drive buffering to %d.\n", 1102 name, STp->default_drvbuffer); 1103 } 1104 } 1105 1106 return CHKRES_READY; 1107 1108 err_out: 1109 return retval; 1110 } 1111 1112 1113 /* Open the device. Needs to take the BKL only because of incrementing the SCSI host 1114 module count. */ 1115 static int st_open(struct inode *inode, struct file *filp) 1116 { 1117 int i, retval = (-EIO); 1118 struct scsi_tape *STp; 1119 struct st_partstat *STps; 1120 int dev = TAPE_NR(inode); 1121 char *name; 1122 1123 lock_kernel(); 1124 /* 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. 1128 */ 1129 filp->f_mode &= ~(FMODE_PREAD | FMODE_PWRITE); 1130 1131 if (!(STp = scsi_tape_get(dev))) { 1132 unlock_kernel(); 1133 return -ENXIO; 1134 } 1135 1136 write_lock(&st_dev_arr_lock); 1137 filp->private_data = STp; 1138 name = tape_name(STp); 1139 1140 if (STp->in_use) { 1141 write_unlock(&st_dev_arr_lock); 1142 scsi_tape_put(STp); 1143 unlock_kernel(); 1144 DEB( printk(ST_DEB_MSG "%s: Device already in use.\n", name); ) 1145 return (-EBUSY); 1146 } 1147 1148 STp->in_use = 1; 1149 write_unlock(&st_dev_arr_lock); 1150 STp->rew_at_close = STp->autorew_dev = (iminor(inode) & 0x80) == 0; 1151 1152 if (!scsi_block_when_processing_errors(STp->device)) { 1153 retval = (-ENXIO); 1154 goto err_out; 1155 } 1156 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", 1160 name); 1161 retval = (-EOVERFLOW); 1162 goto err_out; 1163 } 1164 1165 (STp->buffer)->cleared = 0; 1166 (STp->buffer)->writing = 0; 1167 (STp->buffer)->syscall_result = 0; 1168 1169 STp->write_prot = ((filp->f_flags & O_ACCMODE) == O_RDONLY); 1170 1171 STp->dirty = 0; 1172 for (i = 0; i < ST_NBR_PARTITIONS; i++) { 1173 STps = &(STp->ps[i]); 1174 STps->rw = ST_IDLE; 1175 } 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; ) 1180 1181 retval = check_tape(STp, filp); 1182 if (retval < 0) 1183 goto err_out; 1184 if ((filp->f_flags & O_NONBLOCK) == 0 && 1185 retval != CHKRES_READY) { 1186 if (STp->ready == NO_TAPE) 1187 retval = (-ENOMEDIUM); 1188 else 1189 retval = (-EIO); 1190 goto err_out; 1191 } 1192 unlock_kernel(); 1193 return 0; 1194 1195 err_out: 1196 normalize_buffer(STp->buffer); 1197 STp->in_use = 0; 1198 scsi_tape_put(STp); 1199 unlock_kernel(); 1200 return retval; 1201 1202 } 1203 1204 1205 /* Flush the tape buffer before close */ 1206 static int st_flush(struct file *filp, fl_owner_t id) 1207 { 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); 1215 1216 if (file_count(filp) > 1) 1217 return 0; 1218 1219 if (STps->rw == ST_WRITING && !STp->pos_unknown) { 1220 result = st_flush_write_buffer(STp); 1221 if (result != 0 && result != (-ENOSPC)) 1222 goto out; 1223 } 1224 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)); 1229 if (result == 0) 1230 result = result2; 1231 goto out; 1232 } 1233 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)); 1237 1238 if (STps->rw == ST_WRITING && !STp->pos_unknown) { 1239 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat; 1240 1241 DEBC(printk(ST_DEB_MSG "%s: Async write waits %d, finished %d.\n", 1242 name, STp->nbr_waits, STp->nbr_finished); 1243 ) 1244 1245 memset(cmd, 0, MAX_COMMAND_SIZE); 1246 cmd[0] = WRITE_FILEMARKS; 1247 cmd[4] = 1 + STp->two_fm; 1248 1249 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE, 1250 STp->device->timeout, MAX_WRITE_RETRIES, 1); 1251 if (!SRpnt) { 1252 result = (STp->buffer)->syscall_result; 1253 goto out; 1254 } 1255 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); 1264 SRpnt = NULL; 1265 if (STps->drv_file >= 0) 1266 STps->drv_file++; 1267 STps->drv_block = 0; 1268 if (STp->two_fm) 1269 cross_eof(STp, 0); 1270 STps->eof = ST_FM; 1271 } 1272 else { /* Write error */ 1273 st_release_request(SRpnt); 1274 SRpnt = NULL; 1275 printk(KERN_ERR "%s: Error on write filemark.\n", name); 1276 if (result == 0) 1277 result = (-EIO); 1278 } 1279 1280 DEBC(printk(ST_DEB_MSG "%s: Buffer flushed, %d EOF(s) written\n", 1281 name, cmd[4])); 1282 } else if (!STp->rew_at_close) { 1283 STps = &(STp->ps[STp->partition]); 1284 if (!STm->sysv || STps->rw != ST_READING) { 1285 if (STp->can_bsr) 1286 result = flush_buffer(STp, 0); 1287 else if (STps->eof == ST_FM_HIT) { 1288 result = cross_eof(STp, 0); 1289 if (result) { 1290 if (STps->drv_file >= 0) 1291 STps->drv_file++; 1292 STps->drv_block = 0; 1293 STps->eof = ST_FM; 1294 } else 1295 STps->eof = ST_NOEOF; 1296 } 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) 1301 STps->drv_file++; 1302 STps->drv_block = 0; 1303 STps->eof = ST_FM; 1304 } 1305 } 1306 1307 out: 1308 if (STp->rew_at_close) { 1309 result2 = st_int_ioctl(STp, MTREW, 1); 1310 if (result == 0) 1311 result = result2; 1312 } 1313 return result; 1314 } 1315 1316 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) 1320 { 1321 int result = 0; 1322 struct scsi_tape *STp = filp->private_data; 1323 1324 if (STp->door_locked == ST_LOCKED_AUTO) 1325 do_door_lock(STp, 0); 1326 1327 normalize_buffer(STp->buffer); 1328 write_lock(&st_dev_arr_lock); 1329 STp->in_use = 0; 1330 write_unlock(&st_dev_arr_lock); 1331 scsi_tape_put(STp); 1332 1333 return result; 1334 } 1335 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) 1338 { 1339 ssize_t retval = 0; 1340 1341 /* 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. 1346 */ 1347 if (!scsi_block_when_processing_errors(STp->device)) { 1348 retval = (-ENXIO); 1349 goto out; 1350 } 1351 1352 if (STp->ready != ST_READY) { 1353 if (STp->ready == ST_NO_TAPE) 1354 retval = (-ENOMEDIUM); 1355 else 1356 retval = (-EIO); 1357 goto out; 1358 } 1359 1360 if (! STp->modes[STp->current_mode].defined) { 1361 retval = (-ENXIO); 1362 goto out; 1363 } 1364 1365 1366 /* 1367 * If there was a bus reset, block further access 1368 * to this device. 1369 */ 1370 if (STp->pos_unknown) { 1371 retval = (-EIO); 1372 goto out; 1373 } 1374 1375 if (count == 0) 1376 goto out; 1377 1378 DEB( 1379 if (!STp->in_use) { 1380 printk(ST_DEB_MSG "%s: Incorrect device.\n", tape_name(STp)); 1381 retval = (-EIO); 1382 goto out; 1383 } ) /* end DEB */ 1384 1385 if (STp->can_partitions && 1386 (retval = switch_partition(STp)) < 0) 1387 goto out; 1388 1389 if (STp->block_size == 0 && STp->max_block > 0 && 1390 (count < STp->min_block || count > STp->max_block)) { 1391 retval = (-EINVAL); 1392 goto out; 1393 } 1394 1395 if (STp->do_auto_lock && STp->door_locked == ST_UNLOCKED && 1396 !do_door_lock(STp, 1)) 1397 STp->door_locked = ST_LOCKED_AUTO; 1398 1399 out: 1400 return retval; 1401 } 1402 1403 1404 static int setup_buffering(struct scsi_tape *STp, const char __user *buf, 1405 size_t count, int is_read) 1406 { 1407 int i, bufsize, retval = 0; 1408 struct st_buffer *STbp = STp->buffer; 1409 1410 if (is_read) 1411 i = STp->try_dio_now && try_rdio; 1412 else 1413 i = STp->try_dio_now && try_wdio; 1414 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)); 1419 if (i > 0) { 1420 STbp->do_dio = i; 1421 STbp->buffer_bytes = 0; /* can be used as transfer counter */ 1422 } 1423 else 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; 1427 DEB( 1428 if (STbp->do_dio) { 1429 STp->nbr_dio++; 1430 STp->nbr_pages += STbp->do_dio; 1431 } 1432 ) 1433 } else 1434 STbp->do_dio = 0; 1435 DEB( STp->nbr_requests++; ) 1436 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; 1441 else { 1442 bufsize = count; 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) 1446 clear_buffer(STbp); 1447 } 1448 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); 1454 goto out; 1455 } 1456 if (STp->block_size) 1457 STbp->buffer_blocks = bufsize / STp->block_size; 1458 } 1459 1460 out: 1461 return retval; 1462 } 1463 1464 1465 /* Can be called more than once after each setup_buffer() */ 1466 static void release_buffering(struct scsi_tape *STp, int is_read) 1467 { 1468 struct st_buffer *STbp; 1469 1470 STbp = STp->buffer; 1471 if (STbp->do_dio) { 1472 sgl_unmap_user_pages(&(STbp->sg[0]), STbp->do_dio, is_read); 1473 STbp->do_dio = 0; 1474 STbp->sg_segs = 0; 1475 } 1476 } 1477 1478 1479 /* Write command */ 1480 static ssize_t 1481 st_write(struct file *filp, const char __user *buf, size_t count, loff_t * ppos) 1482 { 1483 ssize_t total; 1484 ssize_t i, do_count, blks, transfer; 1485 ssize_t retval; 1486 int undone, retry_eot = 0, scode; 1487 int async_write; 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); 1496 1497 if (mutex_lock_interruptible(&STp->lock)) 1498 return -ERESTARTSYS; 1499 1500 retval = rw_checks(STp, filp, count); 1501 if (retval || count == 0) 1502 goto out; 1503 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", 1507 name); 1508 retval = (-EINVAL); 1509 goto out; 1510 } 1511 1512 STm = &(STp->modes[STp->current_mode]); 1513 STps = &(STp->ps[STp->partition]); 1514 1515 if (STp->write_prot) { 1516 retval = (-EACCES); 1517 goto out; 1518 } 1519 1520 1521 if (STps->rw == ST_READING) { 1522 retval = flush_buffer(STp, 0); 1523 if (retval) 1524 goto out; 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) 1529 goto out; 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", 1534 name); 1535 if (modes_defined) { 1536 retval = (-EINVAL); 1537 goto out; 1538 } 1539 } 1540 } 1541 } 1542 1543 STbp = STp->buffer; 1544 i = write_behind_check(STp); 1545 if (i) { 1546 if (i == -ENOSPC) 1547 STps->eof = ST_EOM_OK; 1548 else 1549 STps->eof = ST_EOM_ERROR; 1550 } 1551 1552 if (STps->eof == ST_EOM_OK) { 1553 STps->eof = ST_EOD_1; /* allow next write */ 1554 retval = (-ENOSPC); 1555 goto out; 1556 } 1557 else if (STps->eof == ST_EOM_ERROR) { 1558 retval = (-EIO); 1559 goto out; 1560 } 1561 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 && 1565 !STbp->do_dio && 1566 (copy_from_user(&i, buf, 1) != 0 || 1567 copy_from_user(&i, buf + count - 1, 1) != 0)) { 1568 retval = (-EFAULT); 1569 goto out; 1570 } 1571 1572 retval = setup_buffering(STp, buf, count, 0); 1573 if (retval) 1574 goto out; 1575 1576 total = count; 1577 1578 memset(cmd, 0, MAX_COMMAND_SIZE); 1579 cmd[0] = WRITE_6; 1580 cmd[1] = (STp->block_size != 0); 1581 1582 STps->rw = ST_WRITING; 1583 1584 b_point = buf; 1585 while (count > 0 && !retry_eot) { 1586 1587 if (STbp->do_dio) { 1588 do_count = count; 1589 } 1590 else { 1591 if (STp->block_size == 0) 1592 do_count = count; 1593 else { 1594 do_count = STbp->buffer_blocks * STp->block_size - 1595 STbp->buffer_bytes; 1596 if (do_count > count) 1597 do_count = count; 1598 } 1599 1600 i = append_to_buffer(b_point, STbp, do_count); 1601 if (i) { 1602 retval = i; 1603 goto out; 1604 } 1605 } 1606 count -= do_count; 1607 b_point += do_count; 1608 1609 async_write = STp->block_size == 0 && !STbp->do_dio && 1610 STm->do_async_writes && STps->eof < ST_EOM_OK; 1611 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) { 1615 STp->dirty = 1; 1616 /* Don't write a buffer that is not full enough. */ 1617 if (!async_write && count == 0) 1618 break; 1619 } 1620 1621 retry_write: 1622 if (STp->block_size == 0) 1623 blks = transfer = do_count; 1624 else { 1625 if (!STbp->do_dio) 1626 blks = STbp->buffer_bytes; 1627 else 1628 blks = do_count; 1629 blks /= STp->block_size; 1630 transfer = blks * STp->block_size; 1631 } 1632 cmd[2] = blks >> 16; 1633 cmd[3] = blks >> 8; 1634 cmd[4] = blks; 1635 1636 SRpnt = st_do_scsi(SRpnt, STp, cmd, transfer, DMA_TO_DEVICE, 1637 STp->device->timeout, MAX_WRITE_RETRIES, !async_write); 1638 if (!SRpnt) { 1639 retval = STbp->syscall_result; 1640 goto out; 1641 } 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; ) 1648 break; 1649 } 1650 1651 if (STbp->syscall_result != 0) { 1652 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat; 1653 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) 1661 undone = transfer; 1662 else 1663 undone = 0; 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 */ 1668 count += undone; 1669 b_point -= undone; 1670 do_count -= undone; 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) 1677 */ 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", 1683 name, (int)count)); 1684 } else { 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); 1690 retry_eot = 1; 1691 if (STps->drv_block >= 0) { 1692 STps->drv_block += (transfer - undone) / 1693 STp->block_size; 1694 } 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)); 1699 goto retry_write; 1700 } 1701 else { 1702 /* Either error within data buffered by driver or 1703 failed retry */ 1704 count -= do_count; 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", 1711 name)); 1712 } 1713 } 1714 } else { 1715 count += do_count; 1716 STps->drv_block = (-1); /* Too cautious? */ 1717 retval = STbp->syscall_result; 1718 } 1719 1720 } 1721 1722 if (STps->drv_block >= 0) { 1723 if (STp->block_size == 0) 1724 STps->drv_block += (do_count > 0); 1725 else 1726 STps->drv_block += blks; 1727 } 1728 1729 STbp->buffer_bytes = 0; 1730 STp->dirty = 0; 1731 1732 if (retval || retry_eot) { 1733 if (count < total) 1734 retval = total - count; 1735 goto out; 1736 } 1737 } 1738 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; 1744 1745 out: 1746 if (SRpnt != NULL) 1747 st_release_request(SRpnt); 1748 release_buffering(STp, 0); 1749 mutex_unlock(&STp->lock); 1750 1751 return retval; 1752 } 1753 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. 1757 1758 Does release user buffer mapping if it is set. 1759 */ 1760 static long read_tape(struct scsi_tape *STp, long count, 1761 struct st_request ** aSRpnt) 1762 { 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; 1769 int retval = 0; 1770 char *name = tape_name(STp); 1771 1772 if (count == 0) 1773 return 0; 1774 1775 STm = &(STp->modes[STp->current_mode]); 1776 STps = &(STp->ps[STp->partition]); 1777 if (STps->eof == ST_FM_HIT) 1778 return 1; 1779 STbp = STp->buffer; 1780 1781 if (STp->block_size == 0) 1782 blks = bytes = count; 1783 else { 1784 if (!(STp->try_dio_now && try_rdio) && STm->do_read_ahead) { 1785 blks = (STp->buffer)->buffer_blocks; 1786 bytes = blks * STp->block_size; 1787 } else { 1788 bytes = count; 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; 1793 } 1794 } 1795 1796 memset(cmd, 0, MAX_COMMAND_SIZE); 1797 cmd[0] = READ_6; 1798 cmd[1] = (STp->block_size != 0); 1799 if (!cmd[1] && STp->sili) 1800 cmd[1] |= 2; 1801 cmd[2] = blks >> 16; 1802 cmd[3] = blks >> 8; 1803 cmd[4] = blks; 1804 1805 SRpnt = *aSRpnt; 1806 SRpnt = st_do_scsi(SRpnt, STp, cmd, bytes, DMA_FROM_DEVICE, 1807 STp->device->timeout, MAX_RETRIES, 1); 1808 release_buffering(STp, 1); 1809 *aSRpnt = SRpnt; 1810 if (!SRpnt) 1811 return STbp->syscall_result; 1812 1813 STbp->read_pointer = 0; 1814 STps->at_sm = 0; 1815 1816 /* Something to check */ 1817 if (STbp->syscall_result) { 1818 struct st_cmdstatus *cmdstatp = &STp->buffer->cmdstat; 1819 1820 retval = 1; 1821 DEBC(printk(ST_DEB_MSG "%s: Sense: %2x %2x %2x %2x %2x %2x %2x %2x\n", 1822 name, 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) { 1828 1829 if (cmdstatp->sense_hdr.sense_key == BLANK_CHECK) 1830 cmdstatp->flags &= 0xcf; /* No need for EOM in this case */ 1831 1832 if (cmdstatp->flags != 0) { /* EOF, EOM, or ILI */ 1833 /* Compute the residual count */ 1834 if (cmdstatp->remainder_valid) 1835 transfer = (int)cmdstatp->uremainder64; 1836 else 1837 transfer = 0; 1838 if (STp->block_size == 0 && 1839 cmdstatp->sense_hdr.sense_key == MEDIUM_ERROR) 1840 transfer = bytes; 1841 1842 if (cmdstatp->flags & SENSE_ILI) { /* ILI */ 1843 if (STp->block_size == 0) { 1844 if (transfer <= 0) { 1845 if (transfer < 0) 1846 printk(KERN_NOTICE 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; 1852 return (-ENOMEM); 1853 } 1854 STbp->buffer_bytes = bytes - transfer; 1855 } else { 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); 1863 return (-EIO); 1864 } 1865 /* We have some data, deliver it */ 1866 STbp->buffer_bytes = (blks - transfer) * 1867 STp->block_size; 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)) 1874 return (-EIO); 1875 } 1876 } else if (cmdstatp->flags & SENSE_FMK) { /* FM overrides EOM */ 1877 if (STps->eof != ST_FM_HIT) 1878 STps->eof = ST_FM_HIT; 1879 else 1880 STps->eof = ST_EOD_2; 1881 if (STp->block_size == 0) 1882 STbp->buffer_bytes = 0; 1883 else 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; 1892 else 1893 STps->eof = ST_EOM_OK; 1894 if (STp->block_size == 0) 1895 STbp->buffer_bytes = bytes - transfer; 1896 else 1897 STbp->buffer_bytes = 1898 bytes - transfer * STp->block_size; 1899 1900 DEBC(printk(ST_DEB_MSG "%s: EOM detected (%d bytes read).\n", 1901 name, STbp->buffer_bytes)); 1902 } 1903 } 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", 1913 name)); 1914 STps->eof = ST_EOD_2; /* First BLANK_CHECK after FM */ 1915 } else /* Some other extended sense code */ 1916 retval = (-EIO); 1917 } 1918 1919 if (STbp->buffer_bytes < 0) /* Caused by bogus sense data */ 1920 STbp->buffer_bytes = 0; 1921 } 1922 /* End of extended sense test */ 1923 else { /* Non-extended sense */ 1924 retval = STbp->syscall_result; 1925 } 1926 1927 } 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; 1933 } 1934 1935 if (STps->drv_block >= 0) { 1936 if (STp->block_size == 0) 1937 STps->drv_block++; 1938 else 1939 STps->drv_block += STbp->buffer_bytes / STp->block_size; 1940 } 1941 return retval; 1942 } 1943 1944 1945 /* Read command */ 1946 static ssize_t 1947 st_read(struct file *filp, char __user *buf, size_t count, loff_t * ppos) 1948 { 1949 ssize_t total; 1950 ssize_t retval = 0; 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); ) 1959 1960 if (mutex_lock_interruptible(&STp->lock)) 1961 return -ERESTARTSYS; 1962 1963 retval = rw_checks(STp, filp, count); 1964 if (retval || count == 0) 1965 goto out; 1966 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 */ 1971 goto out; 1972 } 1973 STp->try_dio_now = 0; /* Direct i/o can't handle split blocks */ 1974 } 1975 1976 STps = &(STp->ps[STp->partition]); 1977 if (STps->rw == ST_WRITING) { 1978 retval = flush_buffer(STp, 0); 1979 if (retval) 1980 goto out; 1981 STps->rw = ST_READING; 1982 } 1983 DEB( 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); 1987 ) /* end DEB */ 1988 1989 retval = setup_buffering(STp, buf, count, 1); 1990 if (retval) 1991 goto out; 1992 do_dio = STbp->do_dio; 1993 1994 if (STbp->buffer_bytes == 0 && 1995 STps->eof >= ST_EOD_1) { 1996 if (STps->eof < ST_EOD) { 1997 STps->eof += 1; 1998 retval = 0; 1999 goto out; 2000 } 2001 retval = (-EIO); /* EOM or Blank Check */ 2002 goto out; 2003 } 2004 2005 if (do_dio) { 2006 /* Check the buffer writability before any tape movement. Don't alter 2007 buffer data. */ 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) { 2012 retval = (-EFAULT); 2013 goto out; 2014 } 2015 } 2016 2017 STps->rw = ST_READING; 2018 2019 2020 /* Loop until enough data in buffer or a special condition found */ 2021 for (total = 0, special = 0; total < count && !special;) { 2022 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 */ 2027 retval = special; 2028 goto out; 2029 } 2030 } 2031 2032 /* Move the data from driver buffer to user buffer */ 2033 if (STbp->buffer_bytes > 0) { 2034 DEB( 2035 if (debugging && STps->eof != ST_NOEOF) 2036 printk(ST_DEB_MSG 2037 "%s: EOF up (%d). Left %d, needed %d.\n", name, 2038 STps->eof, STbp->buffer_bytes, 2039 (int)(count - total)); 2040 ) /* end DEB */ 2041 transfer = STbp->buffer_bytes < count - total ? 2042 STbp->buffer_bytes : count - total; 2043 if (!do_dio) { 2044 i = from_buffer(STbp, buf, transfer); 2045 if (i) { 2046 retval = i; 2047 goto out; 2048 } 2049 } 2050 buf += transfer; 2051 total += transfer; 2052 } 2053 2054 if (STp->block_size == 0) 2055 break; /* Read only one variable length block */ 2056 2057 } /* for (total = 0, special = 0; 2058 total < count && !special; ) */ 2059 2060 /* Change the eof state if no data from tape or buffer */ 2061 if (total == 0) { 2062 if (STps->eof == ST_FM_HIT) { 2063 STps->eof = ST_FM; 2064 STps->drv_block = 0; 2065 if (STps->drv_file >= 0) 2066 STps->drv_file++; 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) 2071 STps->drv_file++; 2072 } else if (STps->eof == ST_EOD_2) 2073 STps->eof = ST_EOD; 2074 } else if (STps->eof == ST_FM) 2075 STps->eof = ST_NOEOF; 2076 retval = total; 2077 2078 out: 2079 if (SRpnt != NULL) { 2080 st_release_request(SRpnt); 2081 SRpnt = NULL; 2082 } 2083 if (do_dio) { 2084 release_buffering(STp, 1); 2085 STbp->buffer_bytes = 0; 2086 } 2087 mutex_unlock(&STp->lock); 2088 2089 return retval; 2090 } 2091 2092 2093 2094 DEB( 2095 /* Set the driver options */ 2096 static void st_log_options(struct scsi_tape * STp, struct st_modedef * STm, char *name) 2097 { 2098 if (debugging) { 2099 printk(KERN_INFO 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); 2103 printk(KERN_INFO 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); 2106 printk(KERN_INFO 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); 2110 printk(KERN_INFO 2111 "%s: sysv: %d nowait: %d sili: %d\n", name, STm->sysv, STp->immediate, 2112 STp->sili); 2113 printk(KERN_INFO "%s: debugging: %d\n", 2114 name, debugging); 2115 } 2116 } 2117 ) 2118 2119 2120 static int st_set_options(struct scsi_tape *STp, long options) 2121 { 2122 int value; 2123 long code; 2124 struct st_modedef *STm; 2125 char *name = tape_name(STp); 2126 struct cdev *cd0, *cd1; 2127 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; 2133 modes_defined = 1; 2134 DEBC(printk(ST_DEB_MSG 2135 "%s: Initialized mode %d definition from mode 0\n", 2136 name, STp->current_mode)); 2137 } 2138 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) 2186 STm->sysv = value; 2187 if ((options & MT_ST_SILI) != 0) 2188 STp->sili = value; 2189 DEB( 2190 if ((options & MT_ST_DEBUGGING) != 0) 2191 debugging = value; 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)); 2200 } else { 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); 2207 } 2208 } 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))); 2215 } else { 2216 STp->device->timeout = value * HZ; 2217 DEBC( printk(KERN_INFO "%s: Normal timeout set to %d seconds.\n", 2218 name, value) ); 2219 } 2220 } else if (code == MT_ST_SET_CLN) { 2221 value = (options & ~MT_ST_OPTIONS) & 0xff; 2222 if (value != 0 && 2223 value < EXTENDED_SENSE_START && value >= SCSI_SENSE_BUFFERSIZE) 2224 return (-EINVAL); 2225 STp->cln_mode = value; 2226 STp->cln_sense_mask = (options >> 8) & 0xff; 2227 STp->cln_sense_value = (options >> 16) & 0xff; 2228 printk(KERN_INFO 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", 2238 name)); 2239 } else { 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); 2246 } 2247 } 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)); 2253 } else { 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); 2260 } 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)); 2266 } else { 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)); 2271 } 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)); 2279 } 2280 } 2281 } 2282 } 2283 } else 2284 return (-EIO); 2285 2286 return 0; 2287 } 2288 2289 #define MODE_HEADER_LENGTH 4 2290 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 2298 2299 /* Mode header and page bit masks */ 2300 #define MH_BIT_WP 0x80 2301 #define MP_MSK_PAGE_NBR 0x3f 2302 2303 /* Don't return block descriptors */ 2304 #define MODE_SENSE_OMIT_BDESCS 0x08 2305 2306 #define MODE_SELECT_PAGE_FORMAT 0x10 2307 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) 2312 { 2313 unsigned char cmd[MAX_COMMAND_SIZE]; 2314 struct st_request *SRpnt = NULL; 2315 2316 memset(cmd, 0, MAX_COMMAND_SIZE); 2317 cmd[0] = MODE_SENSE; 2318 if (omit_block_descs) 2319 cmd[1] = MODE_SENSE_OMIT_BDESCS; 2320 cmd[2] = page; 2321 cmd[4] = 255; 2322 2323 SRpnt = st_do_scsi(SRpnt, STp, cmd, cmd[4], DMA_FROM_DEVICE, 2324 STp->device->timeout, 0, 1); 2325 if (SRpnt == NULL) 2326 return (STp->buffer)->syscall_result; 2327 2328 st_release_request(SRpnt); 2329 2330 return (STp->buffer)->syscall_result; 2331 } 2332 2333 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) 2337 { 2338 int pgo; 2339 unsigned char cmd[MAX_COMMAND_SIZE]; 2340 struct st_request *SRpnt = NULL; 2341 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; 2347 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; 2353 2354 SRpnt = st_do_scsi(SRpnt, STp, cmd, cmd[4], DMA_TO_DEVICE, 2355 (slow ? STp->long_timeout : STp->device->timeout), 0, 1); 2356 if (SRpnt == NULL) 2357 return (STp->buffer)->syscall_result; 2358 2359 st_release_request(SRpnt); 2360 2361 return (STp->buffer)->syscall_result; 2362 } 2363 2364 2365 #define COMPRESSION_PAGE 0x0f 2366 #define COMPRESSION_PAGE_LENGTH 16 2367 2368 #define CP_OFF_DCE_DCC 2 2369 #define CP_OFF_C_ALGO 7 2370 2371 #define DCE_MASK 0x80 2372 #define DCC_MASK 0x40 2373 #define RED_MASK 0x60 2374 2375 2376 /* Control the compression with mode page 15. Algorithm not changed if zero. 2377 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. */ 2381 2382 static int st_compression(struct scsi_tape * STp, int state) 2383 { 2384 int retval; 2385 int mpoffs; /* Offset to mode page start */ 2386 unsigned char *b_data = (STp->buffer)->b_data; 2387 DEB( char *name = tape_name(STp); ) 2388 2389 if (STp->ready != ST_READY) 2390 return (-EIO); 2391 2392 /* Read the current page contents */ 2393 retval = read_mode_page(STp, COMPRESSION_PAGE, 0); 2394 if (retval) { 2395 DEBC(printk(ST_DEB_MSG "%s: Compression mode page not supported.\n", 2396 name)); 2397 return (-EIO); 2398 } 2399 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))); 2403 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)); 2407 return (-EIO); 2408 } 2409 2410 /* Do the change */ 2411 if (state) { 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; 2415 } 2416 else { 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 */ 2420 } 2421 2422 retval = write_mode_page(STp, COMPRESSION_PAGE, 0); 2423 if (retval) { 2424 DEBC(printk(ST_DEB_MSG "%s: Compression change failed.\n", name)); 2425 return (-EIO); 2426 } 2427 DEBC(printk(ST_DEB_MSG "%s: Compression state changed to %d.\n", 2428 name, state)); 2429 2430 STp->compression_changed = 1; 2431 return 0; 2432 } 2433 2434 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) 2437 { 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; 2443 2444 if (STp->ready != ST_READY && !load_code) { 2445 if (STp->ready == ST_NO_TAPE) 2446 return (-ENOMEDIUM); 2447 else 2448 return (-EIO); 2449 } 2450 2451 memset(cmd, 0, MAX_COMMAND_SIZE); 2452 cmd[0] = START_STOP; 2453 if (load_code) 2454 cmd[4] |= 1; 2455 /* 2456 * If arg >= 1 && arg <= 6 Enhanced load/unload in HP C1553A 2457 */ 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 */ 2464 } 2465 if (STp->immediate) { 2466 cmd[1] = 1; /* Don't wait for completion */ 2467 timeout = STp->device->timeout; 2468 } 2469 else 2470 timeout = STp->long_timeout; 2471 2472 DEBC( 2473 if (!load_code) 2474 printk(ST_DEB_MSG "%s: Unloading tape.\n", name); 2475 else 2476 printk(ST_DEB_MSG "%s: Loading tape.\n", name); 2477 ); 2478 2479 SRpnt = st_do_scsi(NULL, STp, cmd, 0, DMA_NONE, 2480 timeout, MAX_RETRIES, 1); 2481 if (!SRpnt) 2482 return (STp->buffer)->syscall_result; 2483 2484 retval = (STp->buffer)->syscall_result; 2485 st_release_request(SRpnt); 2486 2487 if (!retval) { /* SCSI command successful */ 2488 2489 if (!load_code) { 2490 STp->rew_at_close = 0; 2491 STp->ready = ST_NO_TAPE; 2492 } 2493 else { 2494 STp->rew_at_close = STp->autorew_dev; 2495 retval = check_tape(STp, filp); 2496 if (retval > 0) 2497 retval = 0; 2498 } 2499 } 2500 else { 2501 STps = &(STp->ps[STp->partition]); 2502 STps->drv_file = STps->drv_block = (-1); 2503 } 2504 2505 return retval; 2506 } 2507 2508 #if DEBUG 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) 2512 { 2513 s32 sc; 2514 2515 sc = cmd[2] & 0x80 ? 0xff000000 : 0; 2516 sc |= (cmd[2] << 16) | (cmd[3] << 8) | cmd[4]; 2517 if (direction) 2518 sc = -sc; 2519 printk(ST_DEB_MSG "%s: Spacing tape %s over %d %s.\n", name, 2520 direction ? "backward" : "forward", sc, units); 2521 } 2522 #endif 2523 2524 2525 /* Internal ioctl function */ 2526 static int st_int_ioctl(struct scsi_tape *STp, unsigned int cmd_in, unsigned long arg) 2527 { 2528 int timeout; 2529 long ltmp; 2530 int ioctl_result; 2531 int chg_eof = 1; 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); 2538 2539 WARN_ON(STp->buffer->do_dio != 0); 2540 if (STp->ready != ST_READY) { 2541 if (STp->ready == ST_NO_TAPE) 2542 return (-ENOMEDIUM); 2543 else 2544 return (-EIO); 2545 } 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; 2551 2552 memset(cmd, 0, MAX_COMMAND_SIZE); 2553 switch (cmd_in) { 2554 case MTFSFM: 2555 chg_eof = 0; /* Changed from the FSF after this */ 2556 case MTFSF: 2557 cmd[0] = SPACE; 2558 cmd[1] = 0x01; /* Space FileMarks */ 2559 cmd[2] = (arg >> 16); 2560 cmd[3] = (arg >> 8); 2561 cmd[4] = arg; 2562 DEBC(deb_space_print(name, ST_DEB_FORWARD, "filemarks", cmd);) 2563 if (fileno >= 0) 2564 fileno += arg; 2565 blkno = 0; 2566 at_sm &= (arg == 0); 2567 break; 2568 case MTBSFM: 2569 chg_eof = 0; /* Changed from the FSF after this */ 2570 case MTBSF: 2571 cmd[0] = SPACE; 2572 cmd[1] = 0x01; /* Space FileMarks */ 2573 ltmp = (-arg); 2574 cmd[2] = (ltmp >> 16); 2575 cmd[3] = (ltmp >> 8); 2576 cmd[4] = ltmp; 2577 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "filemarks", cmd);) 2578 if (fileno >= 0) 2579 fileno -= arg; 2580 blkno = (-1); /* We can't know the block number */ 2581 at_sm &= (arg == 0); 2582 break; 2583 case MTFSR: 2584 cmd[0] = SPACE; 2585 cmd[1] = 0x00; /* Space Blocks */ 2586 cmd[2] = (arg >> 16); 2587 cmd[3] = (arg >> 8); 2588 cmd[4] = arg; 2589 DEBC(deb_space_print(name, ST_DEB_FORWARD, "blocks", cmd);) 2590 if (blkno >= 0) 2591 blkno += arg; 2592 at_sm &= (arg == 0); 2593 break; 2594 case MTBSR: 2595 cmd[0] = SPACE; 2596 cmd[1] = 0x00; /* Space Blocks */ 2597 ltmp = (-arg); 2598 cmd[2] = (ltmp >> 16); 2599 cmd[3] = (ltmp >> 8); 2600 cmd[4] = ltmp; 2601 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "blocks", cmd);) 2602 if (blkno >= 0) 2603 blkno -= arg; 2604 at_sm &= (arg == 0); 2605 break; 2606 case MTFSS: 2607 cmd[0] = SPACE; 2608 cmd[1] = 0x04; /* Space Setmarks */ 2609 cmd[2] = (arg >> 16); 2610 cmd[3] = (arg >> 8); 2611 cmd[4] = arg; 2612 DEBC(deb_space_print(name, ST_DEB_FORWARD, "setmarks", cmd);) 2613 if (arg != 0) { 2614 blkno = fileno = (-1); 2615 at_sm = 1; 2616 } 2617 break; 2618 case MTBSS: 2619 cmd[0] = SPACE; 2620 cmd[1] = 0x04; /* Space Setmarks */ 2621 ltmp = (-arg); 2622 cmd[2] = (ltmp >> 16); 2623 cmd[3] = (ltmp >> 8); 2624 cmd[4] = ltmp; 2625 DEBC(deb_space_print(name, ST_DEB_BACKWARD, "setmarks", cmd);) 2626 if (arg != 0) { 2627 blkno = fileno = (-1); 2628 at_sm = 1; 2629 } 2630 break; 2631 case MTWEOF: 2632 case MTWSM: 2633 if (STp->write_prot) 2634 return (-EACCES); 2635 cmd[0] = WRITE_FILEMARKS; 2636 if (cmd_in == MTWSM) 2637 cmd[1] = 2; 2638 cmd[2] = (arg >> 16); 2639 cmd[3] = (arg >> 8); 2640 cmd[4] = arg; 2641 timeout = STp->device->timeout; 2642 DEBC( 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]); 2646 else 2647 printk(ST_DEB_MSG "%s: Writing %d setmarks.\n", name, 2648 cmd[2] * 65536 + cmd[3] * 256 + cmd[4]); 2649 ) 2650 if (fileno >= 0) 2651 fileno += arg; 2652 blkno = 0; 2653 at_sm = (cmd_in == MTWSM); 2654 break; 2655 case MTREW: 2656 cmd[0] = REZERO_UNIT; 2657 if (STp->immediate) { 2658 cmd[1] = 1; /* Don't wait for completion */ 2659 timeout = STp->device->timeout; 2660 } 2661 DEBC(printk(ST_DEB_MSG "%s: Rewinding tape.\n", name)); 2662 fileno = blkno = at_sm = 0; 2663 break; 2664 case MTNOP: 2665 DEBC(printk(ST_DEB_MSG "%s: No op on tape.\n", name)); 2666 return 0; /* Should do something ? */ 2667 break; 2668 case MTRETEN: 2669 cmd[0] = START_STOP; 2670 if (STp->immediate) { 2671 cmd[1] = 1; /* Don't wait for completion */ 2672 timeout = STp->device->timeout; 2673 } 2674 cmd[4] = 3; 2675 DEBC(printk(ST_DEB_MSG "%s: Retensioning tape.\n", name)); 2676 fileno = blkno = at_sm = 0; 2677 break; 2678 case MTEOM: 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) 2684 return 0; 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. 2688 Joerg Weule */ 2689 } else 2690 fileno = (-1); 2691 cmd[0] = SPACE; 2692 cmd[1] = 3; 2693 DEBC(printk(ST_DEB_MSG "%s: Spacing to end of recorded medium.\n", 2694 name)); 2695 blkno = -1; 2696 at_sm = 0; 2697 break; 2698 case MTERASE: 2699 if (STp->write_prot) 2700 return (-EACCES); 2701 cmd[0] = ERASE; 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; 2706 } 2707 else 2708 timeout = STp->long_timeout * 8; 2709 2710 DEBC(printk(ST_DEB_MSG "%s: Erasing tape.\n", name)); 2711 fileno = blkno = at_sm = 0; 2712 break; 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 */ 2717 chg_eof = 0; 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); 2726 return (-EINVAL); 2727 } 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; 2733 2734 memset((STp->buffer)->b_data, 0, 12); 2735 if (cmd_in == MTSETDRVBUFFER) 2736 (STp->buffer)->b_data[2] = (arg & 7) << 4; 2737 else 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; 2746 else 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 ;-) */ 2752 } else 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; 2758 DEBC( 2759 if (cmd_in == MTSETBLK || cmd_in == SET_DENS_AND_BLK) 2760 printk(ST_DEB_MSG 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) 2766 printk(ST_DEB_MSG 2767 "%s: Setting density code to %x.\n", name, 2768 (STp->buffer)->b_data[4]); 2769 if (cmd_in == MTSETDRVBUFFER) 2770 printk(ST_DEB_MSG 2771 "%s: Setting drive buffer code to %d.\n", name, 2772 ((STp->buffer)->b_data[2] >> 4) & 7); 2773 ) 2774 break; 2775 default: 2776 return (-ENOSYS); 2777 } 2778 2779 SRpnt = st_do_scsi(NULL, STp, cmd, datalen, direction, 2780 timeout, MAX_RETRIES, 1); 2781 if (!SRpnt) 2782 return (STp->buffer)->syscall_result; 2783 2784 ioctl_result = (STp->buffer)->syscall_result; 2785 2786 if (!ioctl_result) { /* SCSI command successful */ 2787 st_release_request(SRpnt); 2788 SRpnt = NULL; 2789 STps->drv_block = blkno; 2790 STps->drv_file = fileno; 2791 STps->at_sm = at_sm; 2792 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); 2797 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; 2806 } 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) 2813 STp->density = arg; 2814 2815 if (cmd_in == MTEOM) 2816 STps->eof = ST_EOD; 2817 else if (cmd_in == MTFSF) 2818 STps->eof = ST_FM; 2819 else if (chg_eof) 2820 STps->eof = ST_NOEOF; 2821 2822 if (cmd_in == MTWEOF) 2823 STps->rw = ST_IDLE; 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; 2827 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; 2833 } 2834 2835 if (cmdstatp->remainder_valid) 2836 undone = (int)cmdstatp->uremainder64; 2837 else 2838 undone = 0; 2839 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 */ 2848 if (fileno >= 0) 2849 fileno -= undone; 2850 if (undone < arg) 2851 STps->eof = ST_NOEOF; 2852 } 2853 STps->drv_file = fileno; 2854 } else if ((cmd_in == MTFSF) || (cmd_in == MTFSFM)) { 2855 if (fileno >= 0) 2856 STps->drv_file = fileno - undone; 2857 else 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 */ 2863 undone = (-undone); 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) 2871 STps->drv_file++; 2872 STps->drv_block = 0; 2873 STps->eof = ST_FM; 2874 } else { 2875 if (blkno >= undone) 2876 STps->drv_block = blkno - undone; 2877 else 2878 STps->drv_block = (-1); 2879 STps->eof = ST_NOEOF; 2880 } 2881 } else if (cmd_in == MTBSR) { 2882 if (cmdstatp->flags & SENSE_FMK) { /* Hit filemark */ 2883 STps->drv_file--; 2884 STps->drv_block = (-1); 2885 } else { 2886 if (arg > 0 && undone < 0) /* Some drives get this wrong */ 2887 undone = (-undone); 2888 if (STps->drv_block >= 0) 2889 STps->drv_block = blkno + undone; 2890 } 2891 STps->eof = ST_NOEOF; 2892 } else if (cmd_in == MTEOM) { 2893 STps->drv_file = (-1); 2894 STps->drv_block = (-1); 2895 STps->eof = ST_EOD; 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 2903 already tried */ 2904 STp->use_pf = !STp->use_pf | PF_TESTED; 2905 st_release_request(SRpnt); 2906 SRpnt = NULL; 2907 return st_int_ioctl(STp, cmd_in, arg); 2908 } 2909 } else if (chg_eof) 2910 STps->eof = ST_NOEOF; 2911 2912 if (cmdstatp->sense_hdr.sense_key == BLANK_CHECK) 2913 STps->eof = ST_EOD; 2914 2915 st_release_request(SRpnt); 2916 SRpnt = NULL; 2917 } 2918 2919 return ioctl_result; 2920 } 2921 2922 2923 /* Get the tape position. If bt == 2, arg points into a kernel space mt_loc 2924 structure. */ 2925 2926 static int get_location(struct scsi_tape *STp, unsigned int *block, int *partition, 2927 int logical) 2928 { 2929 int result; 2930 unsigned char scmd[MAX_COMMAND_SIZE]; 2931 struct st_request *SRpnt; 2932 DEB( char *name = tape_name(STp); ) 2933 2934 if (STp->ready != ST_READY) 2935 return (-EIO); 2936 2937 memset(scmd, 0, MAX_COMMAND_SIZE); 2938 if ((STp->device)->scsi_level < SCSI_2) { 2939 scmd[0] = QFA_REQUEST_BLOCK; 2940 scmd[4] = 3; 2941 } else { 2942 scmd[0] = READ_POSITION; 2943 if (!logical && !STp->scsi2_logical) 2944 scmd[1] = 1; 2945 } 2946 SRpnt = st_do_scsi(NULL, STp, scmd, 20, DMA_FROM_DEVICE, 2947 STp->device->timeout, MAX_READY_RETRIES, 1); 2948 if (!SRpnt) 2949 return (STp->buffer)->syscall_result; 2950 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)); 2956 result = (-EIO); 2957 } else { 2958 result = 0; 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]; 2963 *partition = 0; 2964 } else { 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; 2973 } 2974 DEBC(printk(ST_DEB_MSG "%s: Got tape pos. blk %d part %d.\n", name, 2975 *block, *partition)); 2976 } 2977 st_release_request(SRpnt); 2978 SRpnt = NULL; 2979 2980 return result; 2981 } 2982 2983 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, 2987 int logical) 2988 { 2989 struct st_partstat *STps; 2990 int result, p; 2991 unsigned int blk; 2992 int timeout; 2993 unsigned char scmd[MAX_COMMAND_SIZE]; 2994 struct st_request *SRpnt; 2995 DEB( char *name = tape_name(STp); ) 2996 2997 if (STp->ready != ST_READY) 2998 return (-EIO); 2999 timeout = STp->long_timeout; 3000 STps = &(STp->ps[STp->partition]); 3001 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) 3005 return (-EIO); ) 3006 3007 /* Update the location at the partition we are leaving */ 3008 if ((!STp->can_partitions && partition != 0) || 3009 partition >= ST_NBR_PARTITIONS) 3010 return (-EINVAL); 3011 if (partition != STp->partition) { 3012 if (get_location(STp, &blk, &p, 1)) 3013 STps->last_block_valid = 0; 3014 else { 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)); 3020 } 3021 } 3022 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); 3028 scmd[4] = block; 3029 scmd[5] = 0; 3030 } else { 3031 scmd[0] = SEEK_10; 3032 scmd[3] = (block >> 24); 3033 scmd[4] = (block >> 16); 3034 scmd[5] = (block >> 8); 3035 scmd[6] = block; 3036 if (!logical && !STp->scsi2_logical) 3037 scmd[1] = 4; 3038 if (STp->partition != partition) { 3039 scmd[1] |= 2; 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)); 3044 } 3045 } 3046 if (STp->immediate) { 3047 scmd[1] |= 1; /* Don't wait for completion */ 3048 timeout = STp->device->timeout; 3049 } 3050 3051 SRpnt = st_do_scsi(NULL, STp, scmd, 0, DMA_NONE, 3052 timeout, MAX_READY_RETRIES, 1); 3053 if (!SRpnt) 3054 return (STp->buffer)->syscall_result; 3055 3056 STps->drv_block = STps->drv_file = (-1); 3057 STps->eof = ST_NOEOF; 3058 if ((STp->buffer)->syscall_result != 0) { 3059 result = (-EIO); 3060 if (STp->can_partitions && 3061 (STp->device)->scsi_level >= SCSI_2 && 3062 (p = find_partition(STp)) >= 0) 3063 STp->partition = p; 3064 } else { 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) { 3070 STps->at_sm = 0; 3071 STps->rw = ST_IDLE; 3072 } 3073 } else 3074 STps->at_sm = 0; 3075 if (block == 0) 3076 STps->drv_block = STps->drv_file = 0; 3077 result = 0; 3078 } 3079 3080 st_release_request(SRpnt); 3081 SRpnt = NULL; 3082 3083 return result; 3084 } 3085 3086 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) 3090 { 3091 int i, partition; 3092 unsigned int block; 3093 3094 if ((i = get_location(STp, &block, &partition, 1)) < 0) 3095 return i; 3096 if (partition >= ST_NBR_PARTITIONS) 3097 return (-EIO); 3098 return partition; 3099 } 3100 3101 3102 /* Change the partition if necessary */ 3103 static int switch_partition(struct scsi_tape *STp) 3104 { 3105 struct st_partstat *STps; 3106 3107 if (STp->partition == STp->new_partition) 3108 return 0; 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); 3113 } 3114 3115 /* Functions for reading and writing the medium partition mode page. */ 3116 3117 #define PART_PAGE 0x11 3118 #define PART_PAGE_FIXED_LENGTH 8 3119 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 3125 3126 #define PP_BIT_IDP 0x20 3127 #define PP_MSK_PSUM_MB 0x10 3128 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) 3132 { 3133 int result; 3134 DEB( char *name = tape_name(STp); ) 3135 3136 if (STp->ready != ST_READY) 3137 return (-EIO); 3138 3139 result = read_mode_page(STp, PART_PAGE, 1); 3140 3141 if (result) { 3142 DEBC(printk(ST_DEB_MSG "%s: Can't read medium partition page.\n", 3143 name)); 3144 result = (-EIO); 3145 } else { 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)); 3149 } 3150 3151 return result; 3152 } 3153 3154 3155 /* Partition the tape into two partitions if size > 0 or one partition if 3156 size == 0. 3157 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>). 3160 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. 3168 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. 3173 */ 3174 static int partition_tape(struct scsi_tape *STp, int size) 3175 { 3176 char *name = tape_name(STp); 3177 int result; 3178 int pgo, psd_cnt, psdo; 3179 unsigned char *bp; 3180 3181 result = read_mode_page(STp, PART_PAGE, 0); 3182 if (result) { 3183 DEBC(printk(ST_DEB_MSG "%s: Can't read partition mode page.\n", name)); 3184 return result; 3185 } 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)); 3191 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 */ 3196 psdo += 2; 3197 } 3198 memset(bp + psdo, 0, bp[pgo + PP_OFF_NBR_ADD_PARTS] * 2); 3199 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])); 3203 3204 if (size <= 0) { 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", 3209 name)); 3210 } else { 3211 bp[psdo] = (size >> 8) & 0xff; 3212 bp[psdo + 1] = size & 0xff; 3213 bp[pgo + 3] = 1; 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", 3218 name, size)); 3219 } 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; 3223 3224 result = write_mode_page(STp, PART_PAGE, 1); 3225 if (result) { 3226 printk(KERN_INFO "%s: Partitioning of tape failed.\n", name); 3227 result = (-EIO); 3228 } 3229 3230 return result; 3231 } 3232 3233 3234 3235 /* The ioctl command */ 3236 static long st_ioctl(struct file *file, unsigned int cmd_in, unsigned long arg) 3237 { 3238 int i, cmd_nr, cmd_type, bt; 3239 int retval = 0; 3240 unsigned int blk; 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; 3246 3247 if (mutex_lock_interruptible(&STp->lock)) 3248 return -ERESTARTSYS; 3249 3250 DEB( 3251 if (debugging && !STp->in_use) { 3252 printk(ST_DEB_MSG "%s: Incorrect device.\n", name); 3253 retval = (-EIO); 3254 goto out; 3255 } ) /* end DEB */ 3256 3257 STm = &(STp->modes[STp->current_mode]); 3258 STps = &(STp->ps[STp->partition]); 3259 3260 /* 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. 3265 */ 3266 retval = scsi_nonblockable_ioctl(STp->device, cmd_in, p, file); 3267 if (!scsi_block_when_processing_errors(STp->device) || retval != -ENODEV) 3268 goto out; 3269 retval = 0; 3270 3271 cmd_type = _IOC_TYPE(cmd_in); 3272 cmd_nr = _IOC_NR(cmd_in); 3273 3274 if (cmd_type == _IOC_TYPE(MTIOCTOP) && cmd_nr == _IOC_NR(MTIOCTOP)) { 3275 struct mtop mtc; 3276 3277 if (_IOC_SIZE(cmd_in) != sizeof(mtc)) { 3278 retval = (-EINVAL); 3279 goto out; 3280 } 3281 3282 i = copy_from_user(&mtc, p, sizeof(struct mtop)); 3283 if (i) { 3284 retval = (-EFAULT); 3285 goto out; 3286 } 3287 3288 if (mtc.mt_op == MTSETDRVBUFFER && !capable(CAP_SYS_ADMIN)) { 3289 printk(KERN_WARNING 3290 "%s: MTSETDRVBUFFER only allowed for root.\n", name); 3291 retval = (-EPERM); 3292 goto out; 3293 } 3294 if (!STm->defined && 3295 (mtc.mt_op != MTSETDRVBUFFER && 3296 (mtc.mt_count & MT_ST_OPTIONS) == 0)) { 3297 retval = (-ENXIO); 3298 goto out; 3299 } 3300 3301 if (!STp->pos_unknown) { 3302 3303 if (STps->eof == ST_FM_HIT) { 3304 if (mtc.mt_op == MTFSF || mtc.mt_op == MTFSFM || 3305 mtc.mt_op == MTEOM) { 3306 mtc.mt_count -= 1; 3307 if (STps->drv_file >= 0) 3308 STps->drv_file += 1; 3309 } else if (mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM) { 3310 mtc.mt_count += 1; 3311 if (STps->drv_file >= 0) 3312 STps->drv_file += 1; 3313 } 3314 } 3315 3316 if (mtc.mt_op == MTSEEK) { 3317 /* Old position must be restored if partition will be 3318 changed */ 3319 i = !STp->can_partitions || 3320 (STp->new_partition != STp->partition); 3321 } else { 3322 i = mtc.mt_op == MTREW || mtc.mt_op == MTOFFL || 3323 mtc.mt_op == MTRETEN || mtc.mt_op == MTEOM || 3324 mtc.mt_op == MTLOCK || mtc.mt_op == MTLOAD || 3325 mtc.mt_op == MTFSF || mtc.mt_op == MTFSFM || 3326 mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM || 3327 mtc.mt_op == MTCOMPRESSION; 3328 } 3329 i = flush_buffer(STp, i); 3330 if (i < 0) { 3331 retval = i; 3332 goto out; 3333 } 3334 if (STps->rw == ST_WRITING && 3335 (mtc.mt_op == MTREW || mtc.mt_op == MTOFFL || 3336 mtc.mt_op == MTSEEK || 3337 mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM)) { 3338 i = st_int_ioctl(STp, MTWEOF, 1); 3339 if (i < 0) { 3340 retval = i; 3341 goto out; 3342 } 3343 if (mtc.mt_op == MTBSF || mtc.mt_op == MTBSFM) 3344 mtc.mt_count++; 3345 STps->rw = ST_IDLE; 3346 } 3347 3348 } else { 3349 /* 3350 * If there was a bus reset, block further access 3351 * to this device. If the user wants to rewind the tape, 3352 * then reset the flag and allow access again. 3353 */ 3354 if (mtc.mt_op != MTREW && 3355 mtc.mt_op != MTOFFL && 3356 mtc.mt_op != MTRETEN && 3357 mtc.mt_op != MTERASE && 3358 mtc.mt_op != MTSEEK && 3359 mtc.mt_op != MTEOM) { 3360 retval = (-EIO); 3361 goto out; 3362 } 3363 reset_state(STp); 3364 /* remove this when the midlevel properly clears was_reset */ 3365 STp->device->was_reset = 0; 3366 } 3367 3368 if (mtc.mt_op != MTNOP && mtc.mt_op != MTSETBLK && 3369 mtc.mt_op != MTSETDENSITY && mtc.mt_op != MTWSM && 3370 mtc.mt_op != MTSETDRVBUFFER && mtc.mt_op != MTSETPART) 3371 STps->rw = ST_IDLE; /* Prevent automatic WEOF and fsf */ 3372 3373 if (mtc.mt_op == MTOFFL && STp->door_locked != ST_UNLOCKED) 3374 do_door_lock(STp, 0); /* Ignore result! */ 3375 3376 if (mtc.mt_op == MTSETDRVBUFFER && 3377 (mtc.mt_count & MT_ST_OPTIONS) != 0) { 3378 retval = st_set_options(STp, mtc.mt_count); 3379 goto out; 3380 } 3381 3382 if (mtc.mt_op == MTSETPART) { 3383 if (!STp->can_partitions || 3384 mtc.mt_count < 0 || mtc.mt_count >= ST_NBR_PARTITIONS) { 3385 retval = (-EINVAL); 3386 goto out; 3387 } 3388 if (mtc.mt_count >= STp->nbr_partitions && 3389 (STp->nbr_partitions = nbr_partitions(STp)) < 0) { 3390 retval = (-EIO); 3391 goto out; 3392 } 3393 if (mtc.mt_count >= STp->nbr_partitions) { 3394 retval = (-EINVAL); 3395 goto out; 3396 } 3397 STp->new_partition = mtc.mt_count; 3398 retval = 0; 3399 goto out; 3400 } 3401 3402 if (mtc.mt_op == MTMKPART) { 3403 if (!STp->can_partitions) { 3404 retval = (-EINVAL); 3405 goto out; 3406 } 3407 if ((i = st_int_ioctl(STp, MTREW, 0)) < 0 || 3408 (i = partition_tape(STp, mtc.mt_count)) < 0) { 3409 retval = i; 3410 goto out; 3411 } 3412 for (i = 0; i < ST_NBR_PARTITIONS; i++) { 3413 STp->ps[i].rw = ST_IDLE; 3414 STp->ps[i].at_sm = 0; 3415 STp->ps[i].last_block_valid = 0; 3416 } 3417 STp->partition = STp->new_partition = 0; 3418 STp->nbr_partitions = 1; /* Bad guess ?-) */ 3419 STps->drv_block = STps->drv_file = 0; 3420 retval = 0; 3421 goto out; 3422 } 3423 3424 if (mtc.mt_op == MTSEEK) { 3425 i = set_location(STp, mtc.mt_count, STp->new_partition, 0); 3426 if (!STp->can_partitions) 3427 STp->ps[0].rw = ST_IDLE; 3428 retval = i; 3429 goto out; 3430 } 3431 3432 if (mtc.mt_op == MTUNLOAD || mtc.mt_op == MTOFFL) { 3433 retval = do_load_unload(STp, file, 0); 3434 goto out; 3435 } 3436 3437 if (mtc.mt_op == MTLOAD) { 3438 retval = do_load_unload(STp, file, max(1, mtc.mt_count)); 3439 goto out; 3440 } 3441 3442 if (mtc.mt_op == MTLOCK || mtc.mt_op == MTUNLOCK) { 3443 retval = do_door_lock(STp, (mtc.mt_op == MTLOCK)); 3444 goto out; 3445 } 3446 3447 if (STp->can_partitions && STp->ready == ST_READY && 3448 (i = switch_partition(STp)) < 0) { 3449 retval = i; 3450 goto out; 3451 } 3452 3453 if (mtc.mt_op == MTCOMPRESSION) 3454 retval = st_compression(STp, (mtc.mt_count & 1)); 3455 else 3456 retval = st_int_ioctl(STp, mtc.mt_op, mtc.mt_count); 3457 goto out; 3458 } 3459 if (!STm->defined) { 3460 retval = (-ENXIO); 3461 goto out; 3462 } 3463 3464 if ((i = flush_buffer(STp, 0)) < 0) { 3465 retval = i; 3466 goto out; 3467 } 3468 if (STp->can_partitions && 3469 (i = switch_partition(STp)) < 0) { 3470 retval = i; 3471 goto out; 3472 } 3473 3474 if (cmd_type == _IOC_TYPE(MTIOCGET) && cmd_nr == _IOC_NR(MTIOCGET)) { 3475 struct mtget mt_status; 3476 3477 if (_IOC_SIZE(cmd_in) != sizeof(struct mtget)) { 3478 retval = (-EINVAL); 3479 goto out; 3480 } 3481 3482 mt_status.mt_type = STp->tape_type; 3483 mt_status.mt_dsreg = 3484 ((STp->block_size << MT_ST_BLKSIZE_SHIFT) & MT_ST_BLKSIZE_MASK) | 3485 ((STp->density << MT_ST_DENSITY_SHIFT) & MT_ST_DENSITY_MASK); 3486 mt_status.mt_blkno = STps->drv_block; 3487 mt_status.mt_fileno = STps->drv_file; 3488 if (STp->block_size != 0) { 3489 if (STps->rw == ST_WRITING) 3490 mt_status.mt_blkno += 3491 (STp->buffer)->buffer_bytes / STp->block_size; 3492 else if (STps->rw == ST_READING) 3493 mt_status.mt_blkno -= 3494 ((STp->buffer)->buffer_bytes + 3495 STp->block_size - 1) / STp->block_size; 3496 } 3497 3498 mt_status.mt_gstat = 0; 3499 if (STp->drv_write_prot) 3500 mt_status.mt_gstat |= GMT_WR_PROT(0xffffffff); 3501 if (mt_status.mt_blkno == 0) { 3502 if (mt_status.mt_fileno == 0) 3503 mt_status.mt_gstat |= GMT_BOT(0xffffffff); 3504 else 3505 mt_status.mt_gstat |= GMT_EOF(0xffffffff); 3506 } 3507 mt_status.mt_erreg = (STp->recover_reg << MT_ST_SOFTERR_SHIFT); 3508 mt_status.mt_resid = STp->partition; 3509 if (STps->eof == ST_EOM_OK || STps->eof == ST_EOM_ERROR) 3510 mt_status.mt_gstat |= GMT_EOT(0xffffffff); 3511 else if (STps->eof >= ST_EOM_OK) 3512 mt_status.mt_gstat |= GMT_EOD(0xffffffff); 3513 if (STp->density == 1) 3514 mt_status.mt_gstat |= GMT_D_800(0xffffffff); 3515 else if (STp->density == 2) 3516 mt_status.mt_gstat |= GMT_D_1600(0xffffffff); 3517 else if (STp->density == 3) 3518 mt_status.mt_gstat |= GMT_D_6250(0xffffffff); 3519 if (STp->ready == ST_READY) 3520 mt_status.mt_gstat |= GMT_ONLINE(0xffffffff); 3521 if (STp->ready == ST_NO_TAPE) 3522 mt_status.mt_gstat |= GMT_DR_OPEN(0xffffffff); 3523 if (STps->at_sm) 3524 mt_status.mt_gstat |= GMT_SM(0xffffffff); 3525 if (STm->do_async_writes || 3526 (STm->do_buffer_writes && STp->block_size != 0) || 3527 STp->drv_buffer != 0) 3528 mt_status.mt_gstat |= GMT_IM_REP_EN(0xffffffff); 3529 if (STp->cleaning_req) 3530 mt_status.mt_gstat |= GMT_CLN(0xffffffff); 3531 3532 i = copy_to_user(p, &mt_status, sizeof(struct mtget)); 3533 if (i) { 3534 retval = (-EFAULT); 3535 goto out; 3536 } 3537 3538 STp->recover_reg = 0; /* Clear after read */ 3539 retval = 0; 3540 goto out; 3541 } /* End of MTIOCGET */ 3542 if (cmd_type == _IOC_TYPE(MTIOCPOS) && cmd_nr == _IOC_NR(MTIOCPOS)) { 3543 struct mtpos mt_pos; 3544 if (_IOC_SIZE(cmd_in) != sizeof(struct mtpos)) { 3545 retval = (-EINVAL); 3546 goto out; 3547 } 3548 if ((i = get_location(STp, &blk, &bt, 0)) < 0) { 3549 retval = i; 3550 goto out; 3551 } 3552 mt_pos.mt_blkno = blk; 3553 i = copy_to_user(p, &mt_pos, sizeof(struct mtpos)); 3554 if (i) 3555 retval = (-EFAULT); 3556 goto out; 3557 } 3558 mutex_unlock(&STp->lock); 3559 switch (cmd_in) { 3560 case SCSI_IOCTL_GET_IDLUN: 3561 case SCSI_IOCTL_GET_BUS_NUMBER: 3562 break; 3563 default: 3564 if ((cmd_in == SG_IO || 3565 cmd_in == SCSI_IOCTL_SEND_COMMAND || 3566 cmd_in == CDROM_SEND_PACKET) && 3567 !capable(CAP_SYS_RAWIO)) 3568 i = -EPERM; 3569 else 3570 i = scsi_cmd_ioctl(file, STp->disk->queue, 3571 STp->disk, cmd_in, p); 3572 if (i != -ENOTTY) 3573 return i; 3574 break; 3575 } 3576 retval = scsi_ioctl(STp->device, cmd_in, p); 3577 if (!retval && cmd_in == SCSI_IOCTL_STOP_UNIT) { /* unload */ 3578 STp->rew_at_close = 0; 3579 STp->ready = ST_NO_TAPE; 3580 } 3581 return retval; 3582 3583 out: 3584 mutex_unlock(&STp->lock); 3585 return retval; 3586 } 3587 3588 #ifdef CONFIG_COMPAT 3589 static long st_compat_ioctl(struct file *file, unsigned int cmd, unsigned long arg) 3590 { 3591 struct scsi_tape *STp = file->private_data; 3592 struct scsi_device *sdev = STp->device; 3593 int ret = -ENOIOCTLCMD; 3594 if (sdev->host->hostt->compat_ioctl) { 3595 3596 ret = sdev->host->hostt->compat_ioctl(sdev, cmd, (void __user *)arg); 3597 3598 } 3599 return ret; 3600 } 3601 #endif 3602 3603 3604 3605 /* Try to allocate a new tape buffer. Calling function must not hold 3606 dev_arr_lock. */ 3607 static struct st_buffer * 3608 new_tape_buffer(int from_initialization, int need_dma, int max_sg) 3609 { 3610 int i, got = 0; 3611 gfp_t priority; 3612 struct st_buffer *tb; 3613 3614 if (from_initialization) 3615 priority = GFP_ATOMIC; 3616 else 3617 priority = GFP_KERNEL; 3618 3619 i = sizeof(struct st_buffer) + (max_sg - 1) * sizeof(struct scatterlist) + 3620 max_sg * sizeof(struct st_buf_fragment); 3621 tb = kzalloc(i, priority); 3622 if (!tb) { 3623 printk(KERN_NOTICE "st: Can't allocate new tape buffer.\n"); 3624 return NULL; 3625 } 3626 tb->frp_segs = tb->orig_frp_segs = 0; 3627 tb->use_sg = max_sg; 3628 tb->frp = (struct st_buf_fragment *)(&(tb->sg[0]) + max_sg); 3629 3630 tb->dma = need_dma; 3631 tb->buffer_size = got; 3632 sg_init_table(tb->sg, max_sg); 3633 3634 return tb; 3635 } 3636 3637 3638 /* Try to allocate enough space in the tape buffer */ 3639 static int enlarge_buffer(struct st_buffer * STbuffer, int new_size, int need_dma) 3640 { 3641 int segs, nbr, max_segs, b_size, order, got; 3642 gfp_t priority; 3643 3644 if (new_size <= STbuffer->buffer_size) 3645 return 1; 3646 3647 if (STbuffer->buffer_size <= PAGE_SIZE) 3648 normalize_buffer(STbuffer); /* Avoid extra segment */ 3649 3650 max_segs = STbuffer->use_sg; 3651 nbr = max_segs - STbuffer->frp_segs; 3652 if (nbr <= 0) 3653 return 0; 3654 3655 priority = GFP_KERNEL | __GFP_NOWARN; 3656 if (need_dma) 3657 priority |= GFP_DMA; 3658 for (b_size = PAGE_SIZE, order=0; order <= 6 && 3659 b_size < new_size - STbuffer->buffer_size; 3660 order++, b_size *= 2) 3661 ; /* empty */ 3662 3663 for (segs = STbuffer->frp_segs, got = STbuffer->buffer_size; 3664 segs < max_segs && got < new_size;) { 3665 STbuffer->frp[segs].page = alloc_pages(priority, order); 3666 if (STbuffer->frp[segs].page == NULL) { 3667 if (new_size - got <= (max_segs - segs) * b_size / 2) { 3668 b_size /= 2; /* Large enough for the rest of the buffers */ 3669 order--; 3670 continue; 3671 } 3672 DEB(STbuffer->buffer_size = got); 3673 normalize_buffer(STbuffer); 3674 return 0; 3675 } 3676 STbuffer->frp[segs].length = b_size; 3677 STbuffer->frp_segs += 1; 3678 got += b_size; 3679 STbuffer->buffer_size = got; 3680 if (STbuffer->cleared) 3681 memset(page_address(STbuffer->frp[segs].page), 0, b_size); 3682 segs++; 3683 } 3684 STbuffer->b_data = page_address(STbuffer->frp[0].page); 3685 3686 return 1; 3687 } 3688 3689 3690 /* Make sure that no data from previous user is in the internal buffer */ 3691 static void clear_buffer(struct st_buffer * st_bp) 3692 { 3693 int i; 3694 3695 for (i=0; i < st_bp->frp_segs; i++) 3696 memset(page_address(st_bp->frp[i].page), 0, st_bp->frp[i].length); 3697 st_bp->cleared = 1; 3698 } 3699 3700 3701 /* Release the extra buffer */ 3702 static void normalize_buffer(struct st_buffer * STbuffer) 3703 { 3704 int i, order; 3705 3706 for (i = STbuffer->orig_frp_segs; i < STbuffer->frp_segs; i++) { 3707 order = get_order(STbuffer->frp[i].length); 3708 __free_pages(STbuffer->frp[i].page, order); 3709 STbuffer->buffer_size -= STbuffer->frp[i].length; 3710 } 3711 STbuffer->frp_segs = STbuffer->orig_frp_segs; 3712 STbuffer->frp_sg_current = 0; 3713 STbuffer->sg_segs = 0; 3714 } 3715 3716 3717 /* Move data from the user buffer to the tape buffer. Returns zero (success) or 3718 negative error code. */ 3719 static int append_to_buffer(const char __user *ubp, struct st_buffer * st_bp, int do_count) 3720 { 3721 int i, cnt, res, offset; 3722 3723 for (i = 0, offset = st_bp->buffer_bytes; 3724 i < st_bp->frp_segs && offset >= st_bp->frp[i].length; i++) 3725 offset -= st_bp->frp[i].length; 3726 if (i == st_bp->frp_segs) { /* Should never happen */ 3727 printk(KERN_WARNING "st: append_to_buffer offset overflow.\n"); 3728 return (-EIO); 3729 } 3730 for (; i < st_bp->frp_segs && do_count > 0; i++) { 3731 cnt = st_bp->frp[i].length - offset < do_count ? 3732 st_bp->frp[i].length - offset : do_count; 3733 res = copy_from_user(page_address(st_bp->frp[i].page) + offset, ubp, cnt); 3734 if (res) 3735 return (-EFAULT); 3736 do_count -= cnt; 3737 st_bp->buffer_bytes += cnt; 3738 ubp += cnt; 3739 offset = 0; 3740 } 3741 if (do_count) /* Should never happen */ 3742 return (-EIO); 3743 3744 return 0; 3745 } 3746 3747 3748 /* Move data from the tape buffer to the user buffer. Returns zero (success) or 3749 negative error code. */ 3750 static int from_buffer(struct st_buffer * st_bp, char __user *ubp, int do_count) 3751 { 3752 int i, cnt, res, offset; 3753 3754 for (i = 0, offset = st_bp->read_pointer; 3755 i < st_bp->frp_segs && offset >= st_bp->frp[i].length; i++) 3756 offset -= st_bp->frp[i].length; 3757 if (i == st_bp->frp_segs) { /* Should never happen */ 3758 printk(KERN_WARNING "st: from_buffer offset overflow.\n"); 3759 return (-EIO); 3760 } 3761 for (; i < st_bp->frp_segs && do_count > 0; i++) { 3762 cnt = st_bp->frp[i].length - offset < do_count ? 3763 st_bp->frp[i].length - offset : do_count; 3764 res = copy_to_user(ubp, page_address(st_bp->frp[i].page) + offset, cnt); 3765 if (res) 3766 return (-EFAULT); 3767 do_count -= cnt; 3768 st_bp->buffer_bytes -= cnt; 3769 st_bp->read_pointer += cnt; 3770 ubp += cnt; 3771 offset = 0; 3772 } 3773 if (do_count) /* Should never happen */ 3774 return (-EIO); 3775 3776 return 0; 3777 } 3778 3779 3780 /* Move data towards start of buffer */ 3781 static void move_buffer_data(struct st_buffer * st_bp, int offset) 3782 { 3783 int src_seg, dst_seg, src_offset = 0, dst_offset; 3784 int count, total; 3785 3786 if (offset == 0) 3787 return; 3788 3789 total=st_bp->buffer_bytes - offset; 3790 for (src_seg=0; src_seg < st_bp->frp_segs; src_seg++) { 3791 src_offset = offset; 3792 if (src_offset < st_bp->frp[src_seg].length) 3793 break; 3794 offset -= st_bp->frp[src_seg].length; 3795 } 3796 3797 st_bp->buffer_bytes = st_bp->read_pointer = total; 3798 for (dst_seg=dst_offset=0; total > 0; ) { 3799 count = min(st_bp->frp[dst_seg].length - dst_offset, 3800 st_bp->frp[src_seg].length - src_offset); 3801 memmove(page_address(st_bp->frp[dst_seg].page) + dst_offset, 3802 page_address(st_bp->frp[src_seg].page) + src_offset, count); 3803 src_offset += count; 3804 if (src_offset >= st_bp->frp[src_seg].length) { 3805 src_seg++; 3806 src_offset = 0; 3807 } 3808 dst_offset += count; 3809 if (dst_offset >= st_bp->frp[dst_seg].length) { 3810 dst_seg++; 3811 dst_offset = 0; 3812 } 3813 total -= count; 3814 } 3815 } 3816 3817 3818 /* Fill the s/g list up to the length required for this transfer */ 3819 static void buf_to_sg(struct st_buffer *STbp, unsigned int length) 3820 { 3821 int i; 3822 unsigned int count; 3823 struct scatterlist *sg; 3824 struct st_buf_fragment *frp; 3825 3826 if (length == STbp->frp_sg_current) 3827 return; /* work already done */ 3828 3829 sg = &(STbp->sg[0]); 3830 frp = STbp->frp; 3831 for (i=count=0; count < length; i++) { 3832 if (length - count > frp[i].length) 3833 sg_set_page(&sg[i], frp[i].page, frp[i].length, 0); 3834 else 3835 sg_set_page(&sg[i], frp[i].page, length - count, 0); 3836 count += sg[i].length; 3837 } 3838 STbp->sg_segs = i; 3839 STbp->frp_sg_current = length; 3840 } 3841 3842 3843 /* Validate the options from command line or module parameters */ 3844 static void validate_options(void) 3845 { 3846 if (buffer_kbs > 0) 3847 st_fixed_buffer_size = buffer_kbs * ST_KILOBYTE; 3848 if (max_sg_segs >= ST_FIRST_SG) 3849 st_max_sg_segs = max_sg_segs; 3850 } 3851 3852 #ifndef MODULE 3853 /* Set the boot options. Syntax is defined in Documenation/scsi/st.txt. 3854 */ 3855 static int __init st_setup(char *str) 3856 { 3857 int i, len, ints[5]; 3858 char *stp; 3859 3860 stp = get_options(str, ARRAY_SIZE(ints), ints); 3861 3862 if (ints[0] > 0) { 3863 for (i = 0; i < ints[0] && i < ARRAY_SIZE(parms); i++) 3864 if (parms[i].val) 3865 *parms[i].val = ints[i + 1]; 3866 } else { 3867 while (stp != NULL) { 3868 for (i = 0; i < ARRAY_SIZE(parms); i++) { 3869 len = strlen(parms[i].name); 3870 if (!strncmp(stp, parms[i].name, len) && 3871 (*(stp + len) == ':' || *(stp + len) == '=')) { 3872 if (parms[i].val) 3873 *parms[i].val = 3874 simple_strtoul(stp + len + 1, NULL, 0); 3875 else 3876 printk(KERN_WARNING "st: Obsolete parameter %s\n", 3877 parms[i].name); 3878 break; 3879 } 3880 } 3881 if (i >= ARRAY_SIZE(parms)) 3882 printk(KERN_WARNING "st: invalid parameter in '%s'\n", 3883 stp); 3884 stp = strchr(stp, ','); 3885 if (stp) 3886 stp++; 3887 } 3888 } 3889 3890 validate_options(); 3891 3892 return 1; 3893 } 3894 3895 __setup("st=", st_setup); 3896 3897 #endif 3898 3899 static const struct file_operations st_fops = 3900 { 3901 .owner = THIS_MODULE, 3902 .read = st_read, 3903 .write = st_write, 3904 .unlocked_ioctl = st_ioctl, 3905 #ifdef CONFIG_COMPAT 3906 .compat_ioctl = st_compat_ioctl, 3907 #endif 3908 .open = st_open, 3909 .flush = st_flush, 3910 .release = st_release, 3911 }; 3912 3913 static int st_probe(struct device *dev) 3914 { 3915 struct scsi_device *SDp = to_scsi_device(dev); 3916 struct gendisk *disk = NULL; 3917 struct cdev *cdev = NULL; 3918 struct scsi_tape *tpnt = NULL; 3919 struct st_modedef *STm; 3920 struct st_partstat *STps; 3921 struct st_buffer *buffer; 3922 int i, j, mode, dev_num, error; 3923 char *stp; 3924 3925 if (SDp->type != TYPE_TAPE) 3926 return -ENODEV; 3927 if ((stp = st_incompatible(SDp))) { 3928 sdev_printk(KERN_INFO, SDp, "Found incompatible tape\n"); 3929 printk(KERN_INFO "st: The suggested driver is %s.\n", stp); 3930 return -ENODEV; 3931 } 3932 3933 i = min(SDp->request_queue->max_hw_segments, 3934 SDp->request_queue->max_phys_segments); 3935 if (st_max_sg_segs < i) 3936 i = st_max_sg_segs; 3937 buffer = new_tape_buffer(1, (SDp->host)->unchecked_isa_dma, i); 3938 if (buffer == NULL) { 3939 printk(KERN_ERR 3940 "st: Can't allocate new tape buffer. Device not attached.\n"); 3941 goto out; 3942 } 3943 3944 disk = alloc_disk(1); 3945 if (!disk) { 3946 printk(KERN_ERR "st: out of memory. Device not attached.\n"); 3947 goto out_buffer_free; 3948 } 3949 3950 write_lock(&st_dev_arr_lock); 3951 if (st_nr_dev >= st_dev_max) { 3952 struct scsi_tape **tmp_da; 3953 int tmp_dev_max; 3954 3955 tmp_dev_max = max(st_nr_dev * 2, 8); 3956 if (tmp_dev_max > ST_MAX_TAPES) 3957 tmp_dev_max = ST_MAX_TAPES; 3958 if (tmp_dev_max <= st_nr_dev) { 3959 write_unlock(&st_dev_arr_lock); 3960 printk(KERN_ERR "st: Too many tape devices (max. %d).\n", 3961 ST_MAX_TAPES); 3962 goto out_put_disk; 3963 } 3964 3965 tmp_da = kzalloc(tmp_dev_max * sizeof(struct scsi_tape *), GFP_ATOMIC); 3966 if (tmp_da == NULL) { 3967 write_unlock(&st_dev_arr_lock); 3968 printk(KERN_ERR "st: Can't extend device array.\n"); 3969 goto out_put_disk; 3970 } 3971 3972 if (scsi_tapes != NULL) { 3973 memcpy(tmp_da, scsi_tapes, 3974 st_dev_max * sizeof(struct scsi_tape *)); 3975 kfree(scsi_tapes); 3976 } 3977 scsi_tapes = tmp_da; 3978 3979 st_dev_max = tmp_dev_max; 3980 } 3981 3982 for (i = 0; i < st_dev_max; i++) 3983 if (scsi_tapes[i] == NULL) 3984 break; 3985 if (i >= st_dev_max) 3986 panic("scsi_devices corrupt (st)"); 3987 3988 tpnt = kzalloc(sizeof(struct scsi_tape), GFP_ATOMIC); 3989 if (tpnt == NULL) { 3990 write_unlock(&st_dev_arr_lock); 3991 printk(KERN_ERR "st: Can't allocate device descriptor.\n"); 3992 goto out_put_disk; 3993 } 3994 kref_init(&tpnt->kref); 3995 tpnt->disk = disk; 3996 sprintf(disk->disk_name, "st%d", i); 3997 disk->private_data = &tpnt->driver; 3998 disk->queue = SDp->request_queue; 3999 tpnt->driver = &st_template; 4000 scsi_tapes[i] = tpnt; 4001 dev_num = i; 4002 4003 tpnt->device = SDp; 4004 if (SDp->scsi_level <= 2) 4005 tpnt->tape_type = MT_ISSCSI1; 4006 else 4007 tpnt->tape_type = MT_ISSCSI2; 4008 4009 tpnt->buffer = buffer; 4010 tpnt->buffer->last_SRpnt = NULL; 4011 4012 tpnt->inited = 0; 4013 tpnt->dirty = 0; 4014 tpnt->in_use = 0; 4015 tpnt->drv_buffer = 1; /* Try buffering if no mode sense */ 4016 tpnt->restr_dma = (SDp->host)->unchecked_isa_dma; 4017 tpnt->use_pf = (SDp->scsi_level >= SCSI_2); 4018 tpnt->density = 0; 4019 tpnt->do_auto_lock = ST_AUTO_LOCK; 4020 tpnt->can_bsr = (SDp->scsi_level > 2 ? 1 : ST_IN_FILE_POS); /* BSR mandatory in SCSI3 */ 4021 tpnt->can_partitions = 0; 4022 tpnt->two_fm = ST_TWO_FM; 4023 tpnt->fast_mteom = ST_FAST_MTEOM; 4024 tpnt->scsi2_logical = ST_SCSI2LOGICAL; 4025 tpnt->sili = ST_SILI; 4026 tpnt->immediate = ST_NOWAIT; 4027 tpnt->default_drvbuffer = 0xff; /* No forced buffering */ 4028 tpnt->partition = 0; 4029 tpnt->new_partition = 0; 4030 tpnt->nbr_partitions = 0; 4031 tpnt->device->timeout = ST_TIMEOUT; 4032 tpnt->long_timeout = ST_LONG_TIMEOUT; 4033 tpnt->try_dio = try_direct_io && !SDp->host->unchecked_isa_dma; 4034 4035 for (i = 0; i < ST_NBR_MODES; i++) { 4036 STm = &(tpnt->modes[i]); 4037 STm->defined = 0; 4038 STm->sysv = ST_SYSV; 4039 STm->defaults_for_writes = 0; 4040 STm->do_async_writes = ST_ASYNC_WRITES; 4041 STm->do_buffer_writes = ST_BUFFER_WRITES; 4042 STm->do_read_ahead = ST_READ_AHEAD; 4043 STm->default_compression = ST_DONT_TOUCH; 4044 STm->default_blksize = (-1); /* No forced size */ 4045 STm->default_density = (-1); /* No forced density */ 4046 } 4047 4048 for (i = 0; i < ST_NBR_PARTITIONS; i++) { 4049 STps = &(tpnt->ps[i]); 4050 STps->rw = ST_IDLE; 4051 STps->eof = ST_NOEOF; 4052 STps->at_sm = 0; 4053 STps->last_block_valid = 0; 4054 STps->drv_block = (-1); 4055 STps->drv_file = (-1); 4056 } 4057 4058 tpnt->current_mode = 0; 4059 tpnt->modes[0].defined = 1; 4060 4061 tpnt->density_changed = tpnt->compression_changed = 4062 tpnt->blksize_changed = 0; 4063 mutex_init(&tpnt->lock); 4064 4065 st_nr_dev++; 4066 write_unlock(&st_dev_arr_lock); 4067 4068 for (mode = 0; mode < ST_NBR_MODES; ++mode) { 4069 STm = &(tpnt->modes[mode]); 4070 for (j=0; j < 2; j++) { 4071 cdev = cdev_alloc(); 4072 if (!cdev) { 4073 printk(KERN_ERR 4074 "st%d: out of memory. Device not attached.\n", 4075 dev_num); 4076 goto out_free_tape; 4077 } 4078 cdev->owner = THIS_MODULE; 4079 cdev->ops = &st_fops; 4080 4081 error = cdev_add(cdev, 4082 MKDEV(SCSI_TAPE_MAJOR, TAPE_MINOR(dev_num, mode, j)), 4083 1); 4084 if (error) { 4085 printk(KERN_ERR "st%d: Can't add %s-rewind mode %d\n", 4086 dev_num, j ? "non" : "auto", mode); 4087 printk(KERN_ERR "st%d: Device not attached.\n", dev_num); 4088 goto out_free_tape; 4089 } 4090 STm->cdevs[j] = cdev; 4091 4092 } 4093 error = do_create_class_files(tpnt, dev_num, mode); 4094 if (error) 4095 goto out_free_tape; 4096 } 4097 4098 sdev_printk(KERN_NOTICE, SDp, 4099 "Attached scsi tape %s\n", tape_name(tpnt)); 4100 sdev_printk(KERN_INFO, SDp, "%s: try direct i/o: %s (alignment %d B)\n", 4101 tape_name(tpnt), tpnt->try_dio ? "yes" : "no", 4102 queue_dma_alignment(SDp->request_queue) + 1); 4103 4104 return 0; 4105 4106 out_free_tape: 4107 for (mode=0; mode < ST_NBR_MODES; mode++) { 4108 STm = &(tpnt->modes[mode]); 4109 sysfs_remove_link(&tpnt->device->sdev_gendev.kobj, 4110 "tape"); 4111 for (j=0; j < 2; j++) { 4112 if (STm->cdevs[j]) { 4113 if (cdev == STm->cdevs[j]) 4114 cdev = NULL; 4115 device_destroy(st_sysfs_class, 4116 MKDEV(SCSI_TAPE_MAJOR, 4117 TAPE_MINOR(i, mode, j))); 4118 cdev_del(STm->cdevs[j]); 4119 } 4120 } 4121 } 4122 if (cdev) 4123 cdev_del(cdev); 4124 write_lock(&st_dev_arr_lock); 4125 scsi_tapes[dev_num] = NULL; 4126 st_nr_dev--; 4127 write_unlock(&st_dev_arr_lock); 4128 out_put_disk: 4129 put_disk(disk); 4130 kfree(tpnt); 4131 out_buffer_free: 4132 kfree(buffer); 4133 out: 4134 return -ENODEV; 4135 }; 4136 4137 4138 static int st_remove(struct device *dev) 4139 { 4140 struct scsi_device *SDp = to_scsi_device(dev); 4141 struct scsi_tape *tpnt; 4142 int i, j, mode; 4143 4144 write_lock(&st_dev_arr_lock); 4145 for (i = 0; i < st_dev_max; i++) { 4146 tpnt = scsi_tapes[i]; 4147 if (tpnt != NULL && tpnt->device == SDp) { 4148 scsi_tapes[i] = NULL; 4149 st_nr_dev--; 4150 write_unlock(&st_dev_arr_lock); 4151 sysfs_remove_link(&tpnt->device->sdev_gendev.kobj, 4152 "tape"); 4153 for (mode = 0; mode < ST_NBR_MODES; ++mode) { 4154 for (j=0; j < 2; j++) { 4155 device_destroy(st_sysfs_class, 4156 MKDEV(SCSI_TAPE_MAJOR, 4157 TAPE_MINOR(i, mode, j))); 4158 cdev_del(tpnt->modes[mode].cdevs[j]); 4159 tpnt->modes[mode].cdevs[j] = NULL; 4160 } 4161 } 4162 4163 mutex_lock(&st_ref_mutex); 4164 kref_put(&tpnt->kref, scsi_tape_release); 4165 mutex_unlock(&st_ref_mutex); 4166 return 0; 4167 } 4168 } 4169 4170 write_unlock(&st_dev_arr_lock); 4171 return 0; 4172 } 4173 4174 /** 4175 * scsi_tape_release - Called to free the Scsi_Tape structure 4176 * @kref: pointer to embedded kref 4177 * 4178 * st_ref_mutex must be held entering this routine. Because it is 4179 * called on last put, you should always use the scsi_tape_get() 4180 * scsi_tape_put() helpers which manipulate the semaphore directly 4181 * and never do a direct kref_put(). 4182 **/ 4183 static void scsi_tape_release(struct kref *kref) 4184 { 4185 struct scsi_tape *tpnt = to_scsi_tape(kref); 4186 struct gendisk *disk = tpnt->disk; 4187 4188 tpnt->device = NULL; 4189 4190 if (tpnt->buffer) { 4191 tpnt->buffer->orig_frp_segs = 0; 4192 normalize_buffer(tpnt->buffer); 4193 kfree(tpnt->buffer); 4194 } 4195 4196 disk->private_data = NULL; 4197 put_disk(disk); 4198 kfree(tpnt); 4199 return; 4200 } 4201 4202 static int __init init_st(void) 4203 { 4204 int err; 4205 4206 validate_options(); 4207 4208 printk(KERN_INFO "st: Version %s, fixed bufsize %d, s/g segs %d\n", 4209 verstr, st_fixed_buffer_size, st_max_sg_segs); 4210 4211 st_sysfs_class = class_create(THIS_MODULE, "scsi_tape"); 4212 if (IS_ERR(st_sysfs_class)) { 4213 printk(KERN_ERR "Unable create sysfs class for SCSI tapes\n"); 4214 return PTR_ERR(st_sysfs_class); 4215 } 4216 4217 err = register_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0), 4218 ST_MAX_TAPE_ENTRIES, "st"); 4219 if (err) { 4220 printk(KERN_ERR "Unable to get major %d for SCSI tapes\n", 4221 SCSI_TAPE_MAJOR); 4222 goto err_class; 4223 } 4224 4225 err = scsi_register_driver(&st_template.gendrv); 4226 if (err) 4227 goto err_chrdev; 4228 4229 err = do_create_sysfs_files(); 4230 if (err) 4231 goto err_scsidrv; 4232 4233 return 0; 4234 4235 err_scsidrv: 4236 scsi_unregister_driver(&st_template.gendrv); 4237 err_chrdev: 4238 unregister_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0), 4239 ST_MAX_TAPE_ENTRIES); 4240 err_class: 4241 class_destroy(st_sysfs_class); 4242 return err; 4243 } 4244 4245 static void __exit exit_st(void) 4246 { 4247 do_remove_sysfs_files(); 4248 scsi_unregister_driver(&st_template.gendrv); 4249 unregister_chrdev_region(MKDEV(SCSI_TAPE_MAJOR, 0), 4250 ST_MAX_TAPE_ENTRIES); 4251 class_destroy(st_sysfs_class); 4252 kfree(scsi_tapes); 4253 printk(KERN_INFO "st: Unloaded.\n"); 4254 } 4255 4256 module_init(init_st); 4257 module_exit(exit_st); 4258 4259 4260 /* The sysfs driver interface. Read-only at the moment */ 4261 static ssize_t st_try_direct_io_show(struct device_driver *ddp, char *buf) 4262 { 4263 return snprintf(buf, PAGE_SIZE, "%d\n", try_direct_io); 4264 } 4265 static DRIVER_ATTR(try_direct_io, S_IRUGO, st_try_direct_io_show, NULL); 4266 4267 static ssize_t st_fixed_buffer_size_show(struct device_driver *ddp, char *buf) 4268 { 4269 return snprintf(buf, PAGE_SIZE, "%d\n", st_fixed_buffer_size); 4270 } 4271 static DRIVER_ATTR(fixed_buffer_size, S_IRUGO, st_fixed_buffer_size_show, NULL); 4272 4273 static ssize_t st_max_sg_segs_show(struct device_driver *ddp, char *buf) 4274 { 4275 return snprintf(buf, PAGE_SIZE, "%d\n", st_max_sg_segs); 4276 } 4277 static DRIVER_ATTR(max_sg_segs, S_IRUGO, st_max_sg_segs_show, NULL); 4278 4279 static ssize_t st_version_show(struct device_driver *ddd, char *buf) 4280 { 4281 return snprintf(buf, PAGE_SIZE, "[%s]\n", verstr); 4282 } 4283 static DRIVER_ATTR(version, S_IRUGO, st_version_show, NULL); 4284 4285 static int do_create_sysfs_files(void) 4286 { 4287 struct device_driver *sysfs = &st_template.gendrv; 4288 int err; 4289 4290 err = driver_create_file(sysfs, &driver_attr_try_direct_io); 4291 if (err) 4292 return err; 4293 err = driver_create_file(sysfs, &driver_attr_fixed_buffer_size); 4294 if (err) 4295 goto err_try_direct_io; 4296 err = driver_create_file(sysfs, &driver_attr_max_sg_segs); 4297 if (err) 4298 goto err_attr_fixed_buf; 4299 err = driver_create_file(sysfs, &driver_attr_version); 4300 if (err) 4301 goto err_attr_max_sg; 4302 4303 return 0; 4304 4305 err_attr_max_sg: 4306 driver_remove_file(sysfs, &driver_attr_max_sg_segs); 4307 err_attr_fixed_buf: 4308 driver_remove_file(sysfs, &driver_attr_fixed_buffer_size); 4309 err_try_direct_io: 4310 driver_remove_file(sysfs, &driver_attr_try_direct_io); 4311 return err; 4312 } 4313 4314 static void do_remove_sysfs_files(void) 4315 { 4316 struct device_driver *sysfs = &st_template.gendrv; 4317 4318 driver_remove_file(sysfs, &driver_attr_version); 4319 driver_remove_file(sysfs, &driver_attr_max_sg_segs); 4320 driver_remove_file(sysfs, &driver_attr_fixed_buffer_size); 4321 driver_remove_file(sysfs, &driver_attr_try_direct_io); 4322 } 4323 4324 4325 /* The sysfs simple class interface */ 4326 static ssize_t 4327 st_defined_show(struct device *dev, struct device_attribute *attr, char *buf) 4328 { 4329 struct st_modedef *STm = dev_get_drvdata(dev); 4330 ssize_t l = 0; 4331 4332 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->defined); 4333 return l; 4334 } 4335 4336 DEVICE_ATTR(defined, S_IRUGO, st_defined_show, NULL); 4337 4338 static ssize_t 4339 st_defblk_show(struct device *dev, struct device_attribute *attr, char *buf) 4340 { 4341 struct st_modedef *STm = dev_get_drvdata(dev); 4342 ssize_t l = 0; 4343 4344 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->default_blksize); 4345 return l; 4346 } 4347 4348 DEVICE_ATTR(default_blksize, S_IRUGO, st_defblk_show, NULL); 4349 4350 static ssize_t 4351 st_defdensity_show(struct device *dev, struct device_attribute *attr, char *buf) 4352 { 4353 struct st_modedef *STm = dev_get_drvdata(dev); 4354 ssize_t l = 0; 4355 char *fmt; 4356 4357 fmt = STm->default_density >= 0 ? "0x%02x\n" : "%d\n"; 4358 l = snprintf(buf, PAGE_SIZE, fmt, STm->default_density); 4359 return l; 4360 } 4361 4362 DEVICE_ATTR(default_density, S_IRUGO, st_defdensity_show, NULL); 4363 4364 static ssize_t 4365 st_defcompression_show(struct device *dev, struct device_attribute *attr, 4366 char *buf) 4367 { 4368 struct st_modedef *STm = dev_get_drvdata(dev); 4369 ssize_t l = 0; 4370 4371 l = snprintf(buf, PAGE_SIZE, "%d\n", STm->default_compression - 1); 4372 return l; 4373 } 4374 4375 DEVICE_ATTR(default_compression, S_IRUGO, st_defcompression_show, NULL); 4376 4377 static ssize_t 4378 st_options_show(struct device *dev, struct device_attribute *attr, char *buf) 4379 { 4380 struct st_modedef *STm = dev_get_drvdata(dev); 4381 struct scsi_tape *STp; 4382 int i, j, options; 4383 ssize_t l = 0; 4384 4385 for (i=0; i < st_dev_max; i++) { 4386 for (j=0; j < ST_NBR_MODES; j++) 4387 if (&scsi_tapes[i]->modes[j] == STm) 4388 break; 4389 if (j < ST_NBR_MODES) 4390 break; 4391 } 4392 if (i == st_dev_max) 4393 return 0; /* should never happen */ 4394 4395 STp = scsi_tapes[i]; 4396 4397 options = STm->do_buffer_writes ? MT_ST_BUFFER_WRITES : 0; 4398 options |= STm->do_async_writes ? MT_ST_ASYNC_WRITES : 0; 4399 options |= STm->do_read_ahead ? MT_ST_READ_AHEAD : 0; 4400 DEB( options |= debugging ? MT_ST_DEBUGGING : 0 ); 4401 options |= STp->two_fm ? MT_ST_TWO_FM : 0; 4402 options |= STp->fast_mteom ? MT_ST_FAST_MTEOM : 0; 4403 options |= STm->defaults_for_writes ? MT_ST_DEF_WRITES : 0; 4404 options |= STp->can_bsr ? MT_ST_CAN_BSR : 0; 4405 options |= STp->omit_blklims ? MT_ST_NO_BLKLIMS : 0; 4406 options |= STp->can_partitions ? MT_ST_CAN_PARTITIONS : 0; 4407 options |= STp->scsi2_logical ? MT_ST_SCSI2LOGICAL : 0; 4408 options |= STm->sysv ? MT_ST_SYSV : 0; 4409 options |= STp->immediate ? MT_ST_NOWAIT : 0; 4410 options |= STp->sili ? MT_ST_SILI : 0; 4411 4412 l = snprintf(buf, PAGE_SIZE, "0x%08x\n", options); 4413 return l; 4414 } 4415 4416 DEVICE_ATTR(options, S_IRUGO, st_options_show, NULL); 4417 4418 static int do_create_class_files(struct scsi_tape *STp, int dev_num, int mode) 4419 { 4420 int i, rew, error; 4421 char name[10]; 4422 struct device *st_class_member; 4423 4424 for (rew=0; rew < 2; rew++) { 4425 /* Make sure that the minor numbers corresponding to the four 4426 first modes always get the same names */ 4427 i = mode << (4 - ST_NBR_MODE_BITS); 4428 snprintf(name, 10, "%s%s%s", rew ? "n" : "", 4429 STp->disk->disk_name, st_formats[i]); 4430 st_class_member = 4431 device_create_drvdata(st_sysfs_class, 4432 &STp->device->sdev_gendev, 4433 MKDEV(SCSI_TAPE_MAJOR, 4434 TAPE_MINOR(dev_num, 4435 mode, rew)), 4436 &STp->modes[mode], 4437 "%s", name); 4438 if (IS_ERR(st_class_member)) { 4439 printk(KERN_WARNING "st%d: device_create failed\n", 4440 dev_num); 4441 error = PTR_ERR(st_class_member); 4442 goto out; 4443 } 4444 4445 error = device_create_file(st_class_member, 4446 &dev_attr_defined); 4447 if (error) goto out; 4448 error = device_create_file(st_class_member, 4449 &dev_attr_default_blksize); 4450 if (error) goto out; 4451 error = device_create_file(st_class_member, 4452 &dev_attr_default_density); 4453 if (error) goto out; 4454 error = device_create_file(st_class_member, 4455 &dev_attr_default_compression); 4456 if (error) goto out; 4457 error = device_create_file(st_class_member, 4458 &dev_attr_options); 4459 if (error) goto out; 4460 4461 if (mode == 0 && rew == 0) { 4462 error = sysfs_create_link(&STp->device->sdev_gendev.kobj, 4463 &st_class_member->kobj, 4464 "tape"); 4465 if (error) { 4466 printk(KERN_ERR 4467 "st%d: Can't create sysfs link from SCSI device.\n", 4468 dev_num); 4469 goto out; 4470 } 4471 } 4472 } 4473 4474 return 0; 4475 4476 out: 4477 return error; 4478 } 4479 4480 /* The following functions may be useful for a larger audience. */ 4481 static int sgl_map_user_pages(struct scatterlist *sgl, const unsigned int max_pages, 4482 unsigned long uaddr, size_t count, int rw) 4483 { 4484 unsigned long end = (uaddr + count + PAGE_SIZE - 1) >> PAGE_SHIFT; 4485 unsigned long start = uaddr >> PAGE_SHIFT; 4486 const int nr_pages = end - start; 4487 int res, i, j; 4488 struct page **pages; 4489 4490 /* User attempted Overflow! */ 4491 if ((uaddr + count) < uaddr) 4492 return -EINVAL; 4493 4494 /* Too big */ 4495 if (nr_pages > max_pages) 4496 return -ENOMEM; 4497 4498 /* Hmm? */ 4499 if (count == 0) 4500 return 0; 4501 4502 if ((pages = kmalloc(max_pages * sizeof(*pages), GFP_KERNEL)) == NULL) 4503 return -ENOMEM; 4504 4505 /* Try to fault in all of the necessary pages */ 4506 down_read(¤t->mm->mmap_sem); 4507 /* rw==READ means read from drive, write into memory area */ 4508 res = get_user_pages( 4509 current, 4510 current->mm, 4511 uaddr, 4512 nr_pages, 4513 rw == READ, 4514 0, /* don't force */ 4515 pages, 4516 NULL); 4517 up_read(¤t->mm->mmap_sem); 4518 4519 /* Errors and no page mapped should return here */ 4520 if (res < nr_pages) 4521 goto out_unmap; 4522 4523 for (i=0; i < nr_pages; i++) { 4524 /* FIXME: flush superflous for rw==READ, 4525 * probably wrong function for rw==WRITE 4526 */ 4527 flush_dcache_page(pages[i]); 4528 } 4529 4530 /* Populate the scatter/gather list */ 4531 sg_set_page(&sgl[0], pages[0], 0, uaddr & ~PAGE_MASK); 4532 if (nr_pages > 1) { 4533 sgl[0].length = PAGE_SIZE - sgl[0].offset; 4534 count -= sgl[0].length; 4535 for (i=1; i < nr_pages ; i++) { 4536 sg_set_page(&sgl[i], pages[i], 4537 count < PAGE_SIZE ? count : PAGE_SIZE, 0);; 4538 count -= PAGE_SIZE; 4539 } 4540 } 4541 else { 4542 sgl[0].length = count; 4543 } 4544 4545 kfree(pages); 4546 return nr_pages; 4547 4548 out_unmap: 4549 if (res > 0) { 4550 for (j=0; j < res; j++) 4551 page_cache_release(pages[j]); 4552 res = 0; 4553 } 4554 kfree(pages); 4555 return res; 4556 } 4557 4558 4559 /* And unmap them... */ 4560 static int sgl_unmap_user_pages(struct scatterlist *sgl, const unsigned int nr_pages, 4561 int dirtied) 4562 { 4563 int i; 4564 4565 for (i=0; i < nr_pages; i++) { 4566 struct page *page = sg_page(&sgl[i]); 4567 4568 if (dirtied) 4569 SetPageDirty(page); 4570 /* FIXME: cache flush missing for rw==READ 4571 * FIXME: call the correct reference counting function 4572 */ 4573 page_cache_release(page); 4574 } 4575 4576 return 0; 4577 } 4578