1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 22 /* 23 * Copyright 2005 Sun Microsystems, Inc. All rights reserved. 24 * Use is subject to license terms. 25 */ 26 27 #pragma ident "%Z%%M% %I% %E% SMI" 28 29 /* 30 * SCSI SCSA-compliant and not-so-DDI-compliant Tape Driver 31 */ 32 33 #if defined(lint) && !defined(DEBUG) 34 #define DEBUG 1 35 #endif 36 37 #include <sys/modctl.h> 38 #include <sys/scsi/scsi.h> 39 #include <sys/mtio.h> 40 #include <sys/scsi/targets/stdef.h> 41 #include <sys/file.h> 42 #include <sys/stat.h> 43 #include <sys/kstat.h> 44 #include <sys/ddidmareq.h> 45 #include <sys/ddi.h> 46 #include <sys/sunddi.h> 47 48 #define IOSP KSTAT_IO_PTR(un->un_stats) 49 /* 50 * stats maintained only for reads/writes as commands 51 * like rewind etc skew the wait/busy times 52 */ 53 #define IS_RW(bp) ((bp)->b_bcount > 0) 54 #define ST_DO_KSTATS(bp, kstat_function) \ 55 if ((bp != un->un_sbufp) && un->un_stats && IS_RW(bp)) { \ 56 kstat_function(IOSP); \ 57 } 58 59 #define ST_DO_ERRSTATS(un, x) \ 60 if (un->un_errstats) { \ 61 struct st_errstats *stp; \ 62 stp = (struct st_errstats *)un->un_errstats->ks_data; \ 63 stp->x.value.ul++; \ 64 } 65 66 #define FILL_SCSI1_LUN(devp, pkt) \ 67 if ((devp)->sd_inq->inq_ansi == 0x1) { \ 68 int _lun; \ 69 _lun = ddi_prop_get_int(DDI_DEV_T_ANY, (devp)->sd_dev, \ 70 DDI_PROP_DONTPASS, SCSI_ADDR_PROP_LUN, 0); \ 71 if (_lun > 0) { \ 72 ((union scsi_cdb *)(pkt)->pkt_cdbp)->scc_lun = \ 73 _lun; \ 74 } \ 75 } 76 77 /* 78 * get an available contig mem header, cp. 79 * when big_enough is true, we will return NULL, if no big enough 80 * contig mem is found. 81 * when big_enough is false, we will try to find cp containing big 82 * enough contig mem. if not found, we will ruturn the last cp available. 83 * 84 * used by st_get_contig_mem() 85 */ 86 #define ST_GET_CONTIG_MEM_HEAD(un, cp, len, big_enough) { \ 87 struct contig_mem *tmp_cp = NULL; \ 88 for ((cp) = (un)->un_contig_mem; \ 89 (cp) != NULL; \ 90 tmp_cp = (cp), (cp) = (cp)->cm_next) { \ 91 if (((cp)->cm_len >= (len)) || \ 92 (!(big_enough) && ((cp)->cm_next == NULL))) { \ 93 if (tmp_cp == NULL) { \ 94 (un)->un_contig_mem = (cp)->cm_next; \ 95 } else { \ 96 tmp_cp->cm_next = (cp)->cm_next; \ 97 } \ 98 (cp)->cm_next = NULL; \ 99 (un)->un_contig_mem_available_num--; \ 100 break; \ 101 } \ 102 } \ 103 } 104 105 #define ST_NUM_MEMBERS(array) (sizeof (array) / sizeof (array[0])) 106 107 /* 108 * Global External Data Definitions 109 */ 110 extern struct scsi_key_strings scsi_cmds[]; 111 112 /* 113 * Local Static Data 114 */ 115 static void *st_state; 116 static char *st_label = "st"; 117 118 #if defined(__i386) || defined(__amd64) 119 /* 120 * We need to use below DMA attr to alloc physically contiguous 121 * memory to do I/O in big block size 122 */ 123 static ddi_dma_attr_t st_contig_mem_dma_attr = { 124 DMA_ATTR_V0, /* version number */ 125 0x0, /* lowest usable address */ 126 0xFFFFFFFFull, /* high DMA address range */ 127 0xFFFFFFFFull, /* DMA counter register */ 128 1, /* DMA address alignment */ 129 1, /* DMA burstsizes */ 130 1, /* min effective DMA size */ 131 0xFFFFFFFFull, /* max DMA xfer size */ 132 0xFFFFFFFFull, /* segment boundary */ 133 1, /* s/g list length */ 134 1, /* granularity of device */ 135 0 /* DMA transfer flags */ 136 }; 137 138 static ddi_device_acc_attr_t st_acc_attr = { 139 DDI_DEVICE_ATTR_V0, 140 DDI_NEVERSWAP_ACC, 141 DDI_STRICTORDER_ACC 142 }; 143 144 /* set limitation for the number of contig_mem */ 145 static int st_max_contig_mem_num = ST_MAX_CONTIG_MEM_NUM; 146 #endif 147 148 /* 149 * Tunable parameters 150 * 151 * DISCLAIMER 152 * ---------- 153 * These parameters are intended for use only in system testing; if you use 154 * them in production systems, you do so at your own risk. Altering any 155 * variable not listed below may cause unpredictable system behavior. 156 * 157 * st_check_media_time 158 * 159 * Three second state check 160 * 161 * st_allow_large_xfer 162 * 163 * Gated with ST_NO_RECSIZE_LIMIT 164 * 165 * 0 - Transfers larger than 64KB will not be allowed 166 * regardless of the setting of ST_NO_RECSIZE_LIMIT 167 * 1 - Transfers larger than 64KB will be allowed 168 * if ST_NO_RECSIZE_LIMIT is TRUE for the drive 169 * 170 * st_report_soft_errors_on_close 171 * 172 * Gated with ST_SOFT_ERROR_REPORTING 173 * 174 * 0 - Errors will not be reported on close regardless 175 * of the setting of ST_SOFT_ERROR_REPORTING 176 * 177 * 1 - Errors will be reported on close if 178 * ST_SOFT_ERROR_REPORTING is TRUE for the drive 179 */ 180 static int st_selection_retry_count = ST_SEL_RETRY_COUNT; 181 static int st_retry_count = ST_RETRY_COUNT; 182 183 static int st_io_time = ST_IO_TIME; 184 static int st_long_timeout_x = ST_LONG_TIMEOUT_X; 185 186 static int st_space_time = ST_SPACE_TIME; 187 static int st_long_space_time_x = ST_LONG_SPACE_TIME_X; 188 189 static int st_error_level = SCSI_ERR_RETRYABLE; 190 static int st_check_media_time = 3000000; /* 3 Second State Check */ 191 192 static int st_max_throttle = ST_MAX_THROTTLE; 193 194 static clock_t st_wait_cmds_complete = ST_WAIT_CMDS_COMPLETE; 195 196 static int st_allow_large_xfer = 1; 197 static int st_report_soft_errors_on_close = 1; 198 199 /* 200 * End of tunable parameters list 201 */ 202 203 204 205 /* 206 * Asynchronous I/O and persistent errors, refer to PSARC/1995/228 207 * 208 * Asynchronous I/O's main offering is that it is a non-blocking way to do 209 * reads and writes. The driver will queue up all the requests it gets and 210 * have them ready to transport to the HBA. Unfortunately, we cannot always 211 * just ship the I/O requests to the HBA, as there errors and exceptions 212 * that may happen when we don't want the HBA to continue. Therein comes 213 * the flush-on-errors capability. If the HBA supports it, then st will 214 * send in st_max_throttle I/O requests at the same time. 215 * 216 * Persistent errors : This was also reasonably simple. In the interrupt 217 * routines, if there was an error or exception (FM, LEOT, media error, 218 * transport error), the persistent error bits are set and shuts everything 219 * down, but setting the throttle to zero. If we hit and exception in the 220 * HBA, and flush-on-errors were set, we wait for all outstanding I/O's to 221 * come back (with CMD_ABORTED), then flush all bp's in the wait queue with 222 * the appropriate error, and this will preserve order. Of course, depending 223 * on the exception we have to show a zero read or write before we show 224 * errors back to the application. 225 */ 226 227 extern const int st_ndrivetypes; /* defined in st_conf.c */ 228 extern const struct st_drivetype st_drivetypes[]; 229 230 #ifdef STDEBUG 231 static int st_soft_error_report_debug = 0; 232 static int st_debug = 0; 233 #endif 234 235 #define ST_MT02_NAME "Emulex MT02 QIC-11/24 " 236 237 static const struct driver_minor_data { 238 char *name; 239 int minor; 240 } st_minor_data[] = { 241 /* 242 * The top 4 entries are for the default densities, 243 * don't alter their position. 244 */ 245 {"", 0}, 246 {"n", MT_NOREWIND}, 247 {"b", MT_BSD}, 248 {"bn", MT_NOREWIND | MT_BSD}, 249 {"l", MT_DENSITY1}, 250 {"m", MT_DENSITY2}, 251 {"h", MT_DENSITY3}, 252 {"c", MT_DENSITY4}, 253 {"u", MT_DENSITY4}, 254 {"ln", MT_DENSITY1 | MT_NOREWIND}, 255 {"mn", MT_DENSITY2 | MT_NOREWIND}, 256 {"hn", MT_DENSITY3 | MT_NOREWIND}, 257 {"cn", MT_DENSITY4 | MT_NOREWIND}, 258 {"un", MT_DENSITY4 | MT_NOREWIND}, 259 {"lb", MT_DENSITY1 | MT_BSD}, 260 {"mb", MT_DENSITY2 | MT_BSD}, 261 {"hb", MT_DENSITY3 | MT_BSD}, 262 {"cb", MT_DENSITY4 | MT_BSD}, 263 {"ub", MT_DENSITY4 | MT_BSD}, 264 {"lbn", MT_DENSITY1 | MT_NOREWIND | MT_BSD}, 265 {"mbn", MT_DENSITY2 | MT_NOREWIND | MT_BSD}, 266 {"hbn", MT_DENSITY3 | MT_NOREWIND | MT_BSD}, 267 {"cbn", MT_DENSITY4 | MT_NOREWIND | MT_BSD}, 268 {"ubn", MT_DENSITY4 | MT_NOREWIND | MT_BSD} 269 }; 270 271 /* strings used in many debug and warning messages */ 272 static const char wr_str[] = "write"; 273 static const char rd_str[] = "read"; 274 static const char wrg_str[] = "writing"; 275 static const char rdg_str[] = "reading"; 276 277 /* default density offsets in the table above */ 278 #define DEF_BLANK 0 279 #define DEF_NOREWIND 1 280 #define DEF_BSD 2 281 #define DEF_BSD_NR 3 282 283 /* Sense Key, ASC/ASCQ for which tape ejection is needed */ 284 285 static struct tape_failure_code { 286 uchar_t key; 287 uchar_t add_code; 288 uchar_t qual_code; 289 } st_tape_failure_code[] = { 290 { KEY_HARDWARE_ERROR, 0x15, 0x01}, 291 { KEY_HARDWARE_ERROR, 0x44, 0x00}, 292 { KEY_HARDWARE_ERROR, 0x53, 0x00}, 293 { KEY_HARDWARE_ERROR, 0x53, 0x01}, 294 { KEY_NOT_READY, 0x53, 0x00}, 295 { 0xff} 296 }; 297 298 /* clean bit position and mask */ 299 300 static struct cln_bit_position { 301 ushort_t cln_bit_byte; 302 uchar_t cln_bit_mask; 303 } st_cln_bit_position[] = { 304 { 21, 0x08}, 305 { 70, 0xc0}, 306 { 18, 0x81} /* 80 bit indicates in bit mode, 1 bit clean light is on */ 307 }; 308 309 /* 310 * architecture dependent allocation restrictions. For x86, we'll set 311 * dma_attr_addr_hi to st_max_phys_addr and dma_attr_sgllen to 312 * st_sgl_size during _init(). 313 */ 314 #if defined(__sparc) 315 static ddi_dma_attr_t st_alloc_attr = { 316 DMA_ATTR_V0, /* version number */ 317 0x0, /* lowest usable address */ 318 0xFFFFFFFFull, /* high DMA address range */ 319 0xFFFFFFFFull, /* DMA counter register */ 320 1, /* DMA address alignment */ 321 1, /* DMA burstsizes */ 322 1, /* min effective DMA size */ 323 0xFFFFFFFFull, /* max DMA xfer size */ 324 0xFFFFFFFFull, /* segment boundary */ 325 1, /* s/g list length */ 326 512, /* granularity of device */ 327 0 /* DMA transfer flags */ 328 }; 329 #elif defined(__x86) 330 static ddi_dma_attr_t st_alloc_attr = { 331 DMA_ATTR_V0, /* version number */ 332 0x0, /* lowest usable address */ 333 0x0, /* high DMA address range [set in _init()] */ 334 0xFFFFull, /* DMA counter register */ 335 512, /* DMA address alignment */ 336 1, /* DMA burstsizes */ 337 1, /* min effective DMA size */ 338 0xFFFFFFFFull, /* max DMA xfer size */ 339 0xFFFFFFFFull, /* segment boundary */ 340 0, /* s/g list length */ 341 512, /* granularity of device [set in _init()] */ 342 0 /* DMA transfer flags */ 343 }; 344 uint64_t st_max_phys_addr = 0xFFFFFFFFull; 345 int st_sgl_size = 0xF; 346 347 #endif 348 349 /* 350 * Configuration Data: 351 * 352 * Device driver ops vector 353 */ 354 static int st_aread(dev_t dev, struct aio_req *aio, cred_t *cred_p); 355 static int st_awrite(dev_t dev, struct aio_req *aio, cred_t *cred_p); 356 static int st_read(dev_t dev, struct uio *uio_p, cred_t *cred_p); 357 static int st_write(dev_t dev, struct uio *uio_p, cred_t *cred_p); 358 static int st_open(dev_t *devp, int flag, int otyp, cred_t *cred_p); 359 static int st_close(dev_t dev, int flag, int otyp, cred_t *cred_p); 360 static int st_strategy(struct buf *bp); 361 static int st_ioctl(dev_t dev, int cmd, intptr_t arg, int flag, 362 cred_t *cred_p, int *rval_p); 363 extern int nulldev(), nodev(); 364 365 static struct cb_ops st_cb_ops = { 366 st_open, /* open */ 367 st_close, /* close */ 368 st_strategy, /* strategy */ 369 nodev, /* print */ 370 nodev, /* dump */ 371 st_read, /* read */ 372 st_write, /* write */ 373 st_ioctl, /* ioctl */ 374 nodev, /* devmap */ 375 nodev, /* mmap */ 376 nodev, /* segmap */ 377 nochpoll, /* poll */ 378 ddi_prop_op, /* cb_prop_op */ 379 0, /* streamtab */ 380 D_64BIT | D_MP | D_NEW | D_HOTPLUG, /* Driver compatibility flag */ 381 CB_REV, /* cb_rev */ 382 st_aread, /* async I/O read entry point */ 383 st_awrite /* async I/O write entry point */ 384 385 }; 386 387 static int stinfo(dev_info_t *dip, ddi_info_cmd_t infocmd, void *arg, 388 void **result); 389 static int st_probe(dev_info_t *dev); 390 static int st_attach(dev_info_t *dev, ddi_attach_cmd_t cmd); 391 static int st_detach(dev_info_t *dev, ddi_detach_cmd_t cmd); 392 393 static struct dev_ops st_ops = { 394 DEVO_REV, /* devo_rev, */ 395 0, /* refcnt */ 396 stinfo, /* info */ 397 nulldev, /* identify */ 398 st_probe, /* probe */ 399 st_attach, /* attach */ 400 st_detach, /* detach */ 401 nodev, /* reset */ 402 &st_cb_ops, /* driver operations */ 403 (struct bus_ops *)0, /* bus operations */ 404 nulldev /* power */ 405 }; 406 407 /* 408 * Local Function Declarations 409 */ 410 static void st_clean_print(dev_info_t *dev, char *label, uint_t level, 411 char *title, char *data, int len); 412 static int st_doattach(struct scsi_device *devp, int (*canwait)()); 413 static void st_known_tape_type(struct scsi_tape *un); 414 static int st_get_conf_from_st_dot_conf(struct scsi_tape *, char *, 415 struct st_drivetype *); 416 static int st_get_conf_from_st_conf_dot_c(struct scsi_tape *, char *, 417 struct st_drivetype *); 418 static int st_get_default_conf(struct scsi_tape *, char *, 419 struct st_drivetype *); 420 static int st_rw(dev_t dev, struct uio *uio, int flag); 421 static int st_arw(dev_t dev, struct aio_req *aio, int flag); 422 static int st_find_eom(dev_t dev); 423 static int st_check_density_or_wfm(dev_t dev, int wfm, int mode, int stepflag); 424 static int st_ioctl_cmd(dev_t dev, struct uscsi_cmd *, 425 enum uio_seg, enum uio_seg, enum uio_seg); 426 static int st_mtioctop(struct scsi_tape *un, intptr_t arg, int flag); 427 static void st_start(struct scsi_tape *un); 428 static int st_handle_start_busy(struct scsi_tape *un, struct buf *bp, 429 clock_t timeout_interval); 430 static int st_handle_intr_busy(struct scsi_tape *un, struct buf *bp, 431 clock_t timeout_interval); 432 static int st_handle_intr_retry_lcmd(struct scsi_tape *un, struct buf *bp); 433 static void st_done_and_mutex_exit(struct scsi_tape *un, struct buf *bp); 434 static void st_init(struct scsi_tape *un); 435 static void st_make_cmd(struct scsi_tape *un, struct buf *bp, 436 int (*func)(caddr_t)); 437 static void st_make_uscsi_cmd(struct scsi_tape *, struct uscsi_cmd *, 438 struct buf *bp, int (*func)(caddr_t)); 439 static void st_intr(struct scsi_pkt *pkt); 440 static void st_set_state(struct scsi_tape *un); 441 static void st_test_append(struct buf *bp); 442 static int st_runout(caddr_t); 443 static int st_cmd(dev_t dev, int com, int count, int wait); 444 static int st_set_compression(struct scsi_tape *un); 445 static int st_write_fm(dev_t dev, int wfm); 446 static int st_determine_generic(dev_t dev); 447 static int st_determine_density(dev_t dev, int rw); 448 static int st_get_density(dev_t dev); 449 static int st_set_density(dev_t dev); 450 static int st_loadtape(dev_t dev); 451 static int st_modesense(struct scsi_tape *un); 452 static int st_modeselect(struct scsi_tape *un); 453 static int st_handle_incomplete(struct scsi_tape *un, struct buf *bp); 454 static int st_wrongtapetype(struct scsi_tape *un); 455 static int st_check_error(struct scsi_tape *un, struct scsi_pkt *pkt); 456 static int st_handle_sense(struct scsi_tape *un, struct buf *bp); 457 static int st_handle_autosense(struct scsi_tape *un, struct buf *bp); 458 static int st_decode_sense(struct scsi_tape *un, struct buf *bp, int amt, 459 struct scsi_status *); 460 static int st_report_soft_errors(dev_t dev, int flag); 461 static void st_delayed_cv_broadcast(void *arg); 462 static int st_check_media(dev_t dev, enum mtio_state state); 463 static int st_media_watch_cb(caddr_t arg, struct scsi_watch_result *resultp); 464 static void st_intr_restart(void *arg); 465 static void st_start_restart(void *arg); 466 static int st_gen_mode_sense(struct scsi_tape *un, int page, 467 struct seq_mode *page_data, int page_size); 468 static int st_change_block_size(dev_t dev, uint32_t nblksz); 469 static int st_gen_mode_select(struct scsi_tape *un, struct seq_mode *page_data, 470 int page_size); 471 static int st_tape_init(dev_t dev); 472 static void st_flush(struct scsi_tape *un); 473 static void st_set_pe_errno(struct scsi_tape *un); 474 static void st_hba_unflush(struct scsi_tape *un); 475 static void st_turn_pe_on(struct scsi_tape *un); 476 static void st_turn_pe_off(struct scsi_tape *un); 477 static void st_set_pe_flag(struct scsi_tape *un); 478 static void st_clear_pe(struct scsi_tape *un); 479 static void st_wait_for_io(struct scsi_tape *un); 480 static int st_set_devconfig_page(struct scsi_tape *un, int compression_on); 481 static int st_set_datacomp_page(struct scsi_tape *un, int compression_on); 482 static int st_tape_reservation_init(dev_t dev); 483 static int st_reserve_release(dev_t dev, int command); 484 static int st_take_ownership(dev_t dev); 485 static int st_check_asc_ascq(struct scsi_tape *un); 486 static int st_check_clean_bit(dev_t dev); 487 static int st_check_alert_clean_bit(dev_t dev); 488 static int st_check_sequential_clean_bit(dev_t dev); 489 static int st_check_sense_clean_bit(dev_t dev); 490 static int st_clear_unit_attentions(dev_t dev_instance, int max_trys); 491 static void st_calculate_timeouts(struct scsi_tape *un); 492 493 #if defined(__i386) || defined(__amd64) 494 /* 495 * routines for I/O in big block size 496 */ 497 static void st_release_contig_mem(struct scsi_tape *un, struct contig_mem *cp); 498 static struct contig_mem *st_get_contig_mem(struct scsi_tape *un, size_t len, 499 int alloc_flags); 500 static int st_bigblk_xfer_done(struct buf *bp); 501 static struct buf *st_get_bigblk_bp(struct buf *bp); 502 #endif 503 504 /* 505 * error statistics create/update functions 506 */ 507 static int st_create_errstats(struct scsi_tape *, int); 508 static void st_uscsi_minphys(struct buf *bp); 509 static int st_validate_tapemarks(struct scsi_tape *un, int fileno, daddr_t bn); 510 511 #ifdef STDEBUG 512 static void st_debug_cmds(struct scsi_tape *un, int com, int count, int wait); 513 static char *st_dev_name(dev_t dev); 514 #endif /* STDEBUG */ 515 516 #if !defined(lint) 517 _NOTE(SCHEME_PROTECTS_DATA("unique per pkt", scsi_pkt buf uio scsi_cdb)) 518 _NOTE(SCHEME_PROTECTS_DATA("unique per pkt", scsi_extended_sense scsi_status)) 519 _NOTE(SCHEME_PROTECTS_DATA("stable data", scsi_device)) 520 _NOTE(DATA_READABLE_WITHOUT_LOCK(st_drivetype scsi_address)) 521 #endif 522 523 /* 524 * autoconfiguration routines. 525 */ 526 char _depends_on[] = "misc/scsi"; 527 528 static struct modldrv modldrv = { 529 &mod_driverops, /* Type of module. This one is a driver */ 530 "SCSI tape Driver %I%", /* Name of the module. */ 531 &st_ops /* driver ops */ 532 }; 533 534 static struct modlinkage modlinkage = { 535 MODREV_1, &modldrv, NULL 536 }; 537 538 /* 539 * Notes on Post Reset Behavior in the tape driver: 540 * 541 * When the tape drive is opened, the driver attempts to make sure that 542 * the tape head is positioned exactly where it was left when it was last 543 * closed provided the medium is not changed. If the tape drive is 544 * opened in O_NDELAY mode, the repositioning (if necessary for any loss 545 * of position due to reset) will happen when the first tape operation or 546 * I/O occurs. The repositioning (if required) may not be possible under 547 * certain situations such as when the device firmware not able to report 548 * the medium change in the REQUEST SENSE data because of a reset or a 549 * misbehaving bus not allowing the reposition to happen. In such 550 * extraordinary situations, where the driver fails to position the head 551 * at its original position, it will fail the open the first time, to 552 * save the applications from overwriting the data. All further attempts 553 * to open the tape device will result in the driver attempting to load 554 * the tape at BOT (beginning of tape). Also a warning message to 555 * indicate that further attempts to open the tape device may result in 556 * the tape being loaded at BOT will be printed on the console. If the 557 * tape device is opened in O_NDELAY mode, failure to restore the 558 * original tape head position, will result in the failure of the first 559 * tape operation or I/O, Further, the driver will invalidate its 560 * internal tape position which will necessitate the applications to 561 * validate the position by using either a tape positioning ioctl (such 562 * as MTREW) or closing and reopening the tape device. 563 * 564 */ 565 566 int 567 _init(void) 568 { 569 int e; 570 571 if (((e = ddi_soft_state_init(&st_state, 572 sizeof (struct scsi_tape), ST_MAXUNIT)) != 0)) { 573 return (e); 574 } 575 576 if ((e = mod_install(&modlinkage)) != 0) { 577 ddi_soft_state_fini(&st_state); 578 } 579 580 #if defined(__x86) 581 /* set the max physical address for iob allocs on x86 */ 582 st_alloc_attr.dma_attr_addr_hi = st_max_phys_addr; 583 584 /* 585 * set the sgllen for iob allocs on x86. If this is set less than 586 * the number of pages the buffer will take (taking into account 587 * alignment), it would force the allocator to try and allocate 588 * contiguous pages. 589 */ 590 st_alloc_attr.dma_attr_sgllen = st_sgl_size; 591 #endif 592 593 return (e); 594 } 595 596 int 597 _fini(void) 598 { 599 int e; 600 601 if ((e = mod_remove(&modlinkage)) != 0) { 602 return (e); 603 } 604 605 ddi_soft_state_fini(&st_state); 606 607 return (e); 608 } 609 610 int 611 _info(struct modinfo *modinfop) 612 { 613 return (mod_info(&modlinkage, modinfop)); 614 } 615 616 617 static int 618 st_probe(dev_info_t *devi) 619 { 620 int instance; 621 struct scsi_device *devp; 622 int rval; 623 624 #if !defined(__sparc) 625 char *tape_prop; 626 int tape_prop_len; 627 #endif 628 629 /* If self identifying device */ 630 if (ddi_dev_is_sid(devi) == DDI_SUCCESS) { 631 return (DDI_PROBE_DONTCARE); 632 } 633 634 #if !defined(__sparc) 635 /* 636 * Since some x86 HBAs have devnodes that look like SCSI as 637 * far as we can tell but aren't really SCSI (DADK, like mlx) 638 * we check for the presence of the "tape" property. 639 */ 640 if (ddi_prop_op(DDI_DEV_T_NONE, devi, PROP_LEN_AND_VAL_ALLOC, 641 DDI_PROP_CANSLEEP, "tape", 642 (caddr_t)&tape_prop, &tape_prop_len) != DDI_PROP_SUCCESS) { 643 return (DDI_PROBE_FAILURE); 644 } 645 if (strncmp(tape_prop, "sctp", tape_prop_len) != 0) { 646 kmem_free(tape_prop, tape_prop_len); 647 return (DDI_PROBE_FAILURE); 648 } 649 kmem_free(tape_prop, tape_prop_len); 650 #endif 651 652 devp = ddi_get_driver_private(devi); 653 instance = ddi_get_instance(devi); 654 655 if (ddi_get_soft_state(st_state, instance) != NULL) { 656 return (DDI_PROBE_PARTIAL); 657 } 658 659 660 /* 661 * Turn around and call probe routine to see whether 662 * we actually have a tape at this SCSI nexus. 663 */ 664 if (scsi_probe(devp, NULL_FUNC) == SCSIPROBE_EXISTS) { 665 666 /* 667 * In checking the whole inq_dtype byte we are looking at both 668 * the Peripheral Qualifier and the Peripheral Device Type. 669 * For this driver we are only interested in sequential devices 670 * that are connected or capable if connecting to this logical 671 * unit. 672 */ 673 if (devp->sd_inq->inq_dtype == 674 (DTYPE_SEQUENTIAL | DPQ_POSSIBLE)) { 675 ST_DEBUG6(devi, st_label, SCSI_DEBUG, 676 "probe exists\n"); 677 rval = DDI_PROBE_SUCCESS; 678 } else { 679 rval = DDI_PROBE_FAILURE; 680 } 681 } else { 682 ST_DEBUG6(devi, st_label, SCSI_DEBUG, 683 "probe failure: nothing there\n"); 684 rval = DDI_PROBE_FAILURE; 685 } 686 scsi_unprobe(devp); 687 return (rval); 688 } 689 690 static int 691 st_attach(dev_info_t *devi, ddi_attach_cmd_t cmd) 692 { 693 int instance; 694 int wide; 695 int dev_instance; 696 int ret_status; 697 struct scsi_device *devp; 698 int node_ix; 699 struct scsi_tape *un; 700 701 devp = ddi_get_driver_private(devi); 702 instance = ddi_get_instance(devi); 703 704 switch (cmd) { 705 case DDI_ATTACH: 706 if (st_doattach(devp, SLEEP_FUNC) == DDI_FAILURE) { 707 return (DDI_FAILURE); 708 } 709 break; 710 case DDI_RESUME: 711 /* 712 * Suspend/Resume 713 * 714 * When the driver suspended, there might be 715 * outstanding cmds and therefore we need to 716 * reset the suspended flag and resume the scsi 717 * watch thread and restart commands and timeouts 718 */ 719 720 if (!(un = ddi_get_soft_state(st_state, instance))) { 721 return (DDI_FAILURE); 722 } 723 dev_instance = ((un->un_dev == 0) ? MTMINOR(instance) : 724 un->un_dev); 725 726 mutex_enter(ST_MUTEX); 727 728 un->un_throttle = un->un_max_throttle; 729 un->un_tids_at_suspend = 0; 730 un->un_pwr_mgmt = ST_PWR_NORMAL; 731 732 if (un->un_swr_token) { 733 scsi_watch_resume(un->un_swr_token); 734 } 735 736 /* 737 * Restart timeouts 738 */ 739 if ((un->un_tids_at_suspend & ST_DELAY_TID) != 0) { 740 mutex_exit(ST_MUTEX); 741 un->un_delay_tid = 742 timeout(st_delayed_cv_broadcast, un, 743 drv_usectohz((clock_t) 744 MEDIA_ACCESS_DELAY)); 745 mutex_enter(ST_MUTEX); 746 } 747 748 if (un->un_tids_at_suspend & ST_HIB_TID) { 749 mutex_exit(ST_MUTEX); 750 un->un_hib_tid = timeout(st_intr_restart, un, 751 ST_STATUS_BUSY_TIMEOUT); 752 mutex_enter(ST_MUTEX); 753 } 754 755 ret_status = st_clear_unit_attentions(dev_instance, 5); 756 757 /* 758 * now check if we need to restore the tape position 759 */ 760 if ((un->un_suspend_fileno > 0) || 761 (un->un_suspend_blkno > 0)) { 762 if (ret_status != 0) { 763 /* 764 * tape didn't get good TUR 765 * just print out error messages 766 */ 767 scsi_log(ST_DEVINFO, st_label, CE_WARN, 768 "st_attach-RESUME: tape failure " 769 " tape position will be lost"); 770 } else { 771 /* this prints errors */ 772 (void) st_validate_tapemarks(un, 773 un->un_suspend_fileno, 774 un->un_suspend_blkno); 775 } 776 /* 777 * there are no retries, if there is an error 778 * we don't know if the tape has changed 779 */ 780 un->un_suspend_fileno = 0; 781 un->un_suspend_blkno = 0; 782 } 783 784 /* now we are ready to start up any queued I/Os */ 785 if (un->un_ncmds || un->un_quef) { 786 st_start(un); 787 } 788 789 cv_broadcast(&un->un_suspend_cv); 790 mutex_exit(ST_MUTEX); 791 return (DDI_SUCCESS); 792 793 default: 794 return (DDI_FAILURE); 795 } 796 797 un = ddi_get_soft_state(st_state, instance); 798 799 ST_DEBUG(devi, st_label, SCSI_DEBUG, 800 "st_attach: instance=%x\n", instance); 801 802 /* 803 * find the drive type for this target 804 */ 805 st_known_tape_type(un); 806 807 for (node_ix = 0; node_ix < ST_NUM_MEMBERS(st_minor_data); node_ix++) { 808 int minor; 809 char *name; 810 811 name = st_minor_data[node_ix].name; 812 minor = st_minor_data[node_ix].minor; 813 814 /* 815 * For default devices set the density to the 816 * preferred default density for this device. 817 */ 818 if (node_ix <= DEF_BSD_NR) { 819 minor |= un->un_dp->default_density; 820 } 821 minor |= MTMINOR(instance); 822 823 if (ddi_create_minor_node(devi, name, S_IFCHR, minor, 824 DDI_NT_TAPE, NULL) == DDI_SUCCESS) { 825 continue; 826 } 827 828 ddi_remove_minor_node(devi, NULL); 829 if (un) { 830 cv_destroy(&un->un_clscv); 831 cv_destroy(&un->un_sbuf_cv); 832 cv_destroy(&un->un_queue_cv); 833 cv_destroy(&un->un_state_cv); 834 cv_destroy(&un->un_suspend_cv); 835 cv_destroy(&un->un_tape_busy_cv); 836 837 if (un->un_sbufp) { 838 freerbuf(un->un_sbufp); 839 } 840 if (un->un_uscsi_rqs_buf) { 841 kmem_free(un->un_uscsi_rqs_buf, SENSE_LENGTH); 842 } 843 if (un->un_mspl) { 844 i_ddi_mem_free((caddr_t)un->un_mspl, 0); 845 } 846 scsi_destroy_pkt(un->un_rqs); 847 scsi_free_consistent_buf(un->un_rqs_bp); 848 ddi_soft_state_free(st_state, instance); 849 devp->sd_private = NULL; 850 devp->sd_sense = NULL; 851 852 } 853 ddi_prop_remove_all(devi); 854 return (DDI_FAILURE); 855 } 856 857 /* 858 * Add a zero-length attribute to tell the world we support 859 * kernel ioctls (for layered drivers) 860 */ 861 (void) ddi_prop_create(DDI_DEV_T_NONE, devi, DDI_PROP_CANSLEEP, 862 DDI_KERNEL_IOCTL, NULL, 0); 863 864 ddi_report_dev((dev_info_t *)devi); 865 866 /* 867 * If it's a SCSI-2 tape drive which supports wide, 868 * tell the host adapter to use wide. 869 */ 870 wide = ((devp->sd_inq->inq_rdf == RDF_SCSI2) && 871 (devp->sd_inq->inq_wbus16 || devp->sd_inq->inq_wbus32)) ? 872 1 : 0; 873 874 if (scsi_ifsetcap(ROUTE, "wide-xfer", wide, 1) == 1) { 875 ST_DEBUG(devi, st_label, SCSI_DEBUG, 876 "Wide Transfer %s\n", wide ? "enabled" : "disabled"); 877 } 878 879 /* 880 * enable autorequest sense; keep the rq packet around in case 881 * the autorequest sense fails because of a busy condition 882 * do a getcap first in case the capability is not variable 883 */ 884 if (scsi_ifgetcap(ROUTE, "auto-rqsense", 1) == 1) { 885 un->un_arq_enabled = 1; 886 } else { 887 un->un_arq_enabled = 888 ((scsi_ifsetcap(ROUTE, "auto-rqsense", 1, 1) == 1) ? 1 : 0); 889 } 890 891 892 ST_DEBUG(devi, st_label, SCSI_DEBUG, "auto request sense %s\n", 893 (un->un_arq_enabled ? "enabled" : "disabled")); 894 895 un->un_untagged_qing = 896 (scsi_ifgetcap(ROUTE, "untagged-qing", 0) == 1); 897 898 /* 899 * XXX - This is just for 2.6. to tell users that write buffering 900 * has gone away. 901 */ 902 if (un->un_arq_enabled && un->un_untagged_qing) { 903 if (ddi_getprop(DDI_DEV_T_ANY, devi, DDI_PROP_DONTPASS, 904 "tape-driver-buffering", 0) != 0) { 905 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 906 "Write Data Buffering has been depricated. Your " 907 "applications should continue to work normally.\n" 908 " But, they should ported to use Asynchronous " 909 " I/O\n" 910 " For more information, read about " 911 " tape-driver-buffering " 912 "property in the st(7d) man page\n"); 913 } 914 } 915 916 un->un_max_throttle = un->un_throttle = un->un_last_throttle = 1; 917 un->un_flush_on_errors = 0; 918 un->un_mkr_pkt = (struct scsi_pkt *)NULL; 919 920 ST_DEBUG(devi, st_label, SCSI_DEBUG, 921 "throttle=%x, max_throttle = %x\n", 922 un->un_throttle, un->un_max_throttle); 923 924 /* initialize persistent errors to nil */ 925 un->un_persistence = 0; 926 un->un_persist_errors = 0; 927 928 /* 929 * Get dma-max from HBA driver. If it is not defined, use 64k 930 */ 931 un->un_maxdma = scsi_ifgetcap(&devp->sd_address, "dma-max", 1); 932 if (un->un_maxdma == -1) { 933 un->un_maxdma = (64 * 1024); 934 } 935 936 un->un_maxbsize = MAXBSIZE_UNKNOWN; 937 938 un->un_mediastate = MTIO_NONE; 939 un->un_HeadClean = TAPE_ALERT_SUPPORT_UNKNOWN; 940 941 /* 942 * initialize kstats 943 */ 944 un->un_stats = kstat_create("st", instance, NULL, "tape", 945 KSTAT_TYPE_IO, 1, KSTAT_FLAG_PERSISTENT); 946 if (un->un_stats) { 947 un->un_stats->ks_lock = ST_MUTEX; 948 kstat_install(un->un_stats); 949 } 950 (void) st_create_errstats(un, instance); 951 952 return (DDI_SUCCESS); 953 } 954 955 /* 956 * st_detach: 957 * 958 * we allow a detach if and only if: 959 * - no tape is currently inserted 960 * - tape position is at BOT or unknown 961 * (if it is not at BOT then a no rewind 962 * device was opened and we have to preserve state) 963 * - it must be in a closed state : no timeouts or scsi_watch requests 964 * will exist if it is closed, so we don't need to check for 965 * them here. 966 */ 967 /*ARGSUSED*/ 968 static int 969 st_detach(dev_info_t *devi, ddi_detach_cmd_t cmd) 970 { 971 int instance; 972 int dev_instance; 973 struct scsi_device *devp; 974 struct scsi_tape *un; 975 clock_t wait_cmds_complete; 976 977 instance = ddi_get_instance(devi); 978 979 if (!(un = ddi_get_soft_state(st_state, instance))) { 980 return (DDI_FAILURE); 981 } 982 983 switch (cmd) { 984 985 case DDI_DETACH: 986 /* 987 * Undo what we did in st_attach & st_doattach, 988 * freeing resources and removing things we installed. 989 * The system framework guarantees we are not active 990 * with this devinfo node in any other entry points at 991 * this time. 992 */ 993 994 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 995 "st_detach: instance=%x, un=%p\n", instance, 996 (void *)un); 997 998 if (((un->un_dp->options & ST_UNLOADABLE) == 0) || 999 (un->un_ncmds != 0) || (un->un_quef != NULL) || 1000 (un->un_state != ST_STATE_CLOSED)) { 1001 /* 1002 * we cannot unload some targets because the 1003 * inquiry returns junk unless immediately 1004 * after a reset 1005 */ 1006 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 1007 "cannot unload instance %x\n", instance); 1008 return (DDI_FAILURE); 1009 } 1010 1011 /* 1012 * if the tape has been removed then we may unload; 1013 * do a test unit ready and if it returns NOT READY 1014 * then we assume that it is safe to unload. 1015 * as a side effect, fileno may be set to -1 if the 1016 * the test unit ready fails; 1017 * also un_state may be set to non-closed, so reset it 1018 */ 1019 if ((un->un_dev) && /* Been opened since attach */ 1020 ((un->un_fileno > 0) || /* Known position not rewound */ 1021 (un->un_blkno != 0))) { /* Or within first file */ 1022 mutex_enter(ST_MUTEX); 1023 /* 1024 * Send Test Unit Ready in the hopes that if 1025 * the drive is not in the state we think it is. 1026 * And the state will be changed so it can be detached. 1027 * If the command fails to reach the device and 1028 * the drive was not rewound or unloaded we want 1029 * to fail the detach till a user command fails 1030 * where after the detach will succead. 1031 */ 1032 (void) st_cmd(un->un_dev, SCMD_TEST_UNIT_READY, 1033 0, SYNC_CMD); 1034 /* 1035 * After TUR un_state may be set to non-closed, 1036 * so reset it back. 1037 */ 1038 un->un_state = ST_STATE_CLOSED; 1039 mutex_exit(ST_MUTEX); 1040 } 1041 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 1042 "un_status=%x, fileno=%x, blkno=%lx\n", 1043 un->un_status, un->un_fileno, un->un_blkno); 1044 1045 /* 1046 * check again: 1047 * if we are not at BOT then it is not safe to unload 1048 */ 1049 if ((un->un_dev) && /* Been opened since attach */ 1050 ((un->un_fileno > 0) || /* Known position not rewound */ 1051 (un->un_blkno != 0))) { /* Or within first file */ 1052 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 1053 "cannot detach: fileno=%x, blkno=%lx\n", 1054 un->un_fileno, un->un_blkno); 1055 return (DDI_FAILURE); 1056 } 1057 1058 /* 1059 * Just To make sure that we have released the 1060 * tape unit . 1061 */ 1062 if (un->un_dev && (un->un_rsvd_status & ST_RESERVE) && 1063 !DEVI_IS_DEVICE_REMOVED(devi)) { 1064 mutex_enter(ST_MUTEX); 1065 (void) st_cmd(un->un_dev, SCMD_RELEASE, 0, SYNC_CMD); 1066 mutex_exit(ST_MUTEX); 1067 } 1068 1069 /* 1070 * now remove other data structures allocated in st_doattach() 1071 */ 1072 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 1073 "destroying/freeing\n"); 1074 cv_destroy(&un->un_clscv); 1075 cv_destroy(&un->un_sbuf_cv); 1076 cv_destroy(&un->un_queue_cv); 1077 cv_destroy(&un->un_suspend_cv); 1078 cv_destroy(&un->un_tape_busy_cv); 1079 1080 if (un->un_hib_tid) { 1081 (void) untimeout(un->un_hib_tid); 1082 un->un_hib_tid = 0; 1083 } 1084 1085 if (un->un_delay_tid) { 1086 (void) untimeout(un->un_delay_tid); 1087 un->un_delay_tid = 0; 1088 } 1089 cv_destroy(&un->un_state_cv); 1090 1091 #if defined(__i386) || defined(__amd64) 1092 if (un->un_contig_mem_hdl != NULL) { 1093 ddi_dma_free_handle(&un->un_contig_mem_hdl); 1094 } 1095 #endif 1096 if (un->un_sbufp) { 1097 freerbuf(un->un_sbufp); 1098 } 1099 if (un->un_uscsi_rqs_buf) { 1100 kmem_free(un->un_uscsi_rqs_buf, SENSE_LENGTH); 1101 } 1102 if (un->un_mspl) { 1103 i_ddi_mem_free((caddr_t)un->un_mspl, 0); 1104 } 1105 if (un->un_rqs) { 1106 scsi_destroy_pkt(un->un_rqs); 1107 scsi_free_consistent_buf(un->un_rqs_bp); 1108 } 1109 if (un->un_mkr_pkt) { 1110 scsi_destroy_pkt(un->un_mkr_pkt); 1111 } 1112 if (un->un_arq_enabled) { 1113 (void) scsi_ifsetcap(ROUTE, "auto-rqsense", 0, 1); 1114 } 1115 if (un->un_dp_size) { 1116 kmem_free(un->un_dp, un->un_dp_size); 1117 } 1118 if (un->un_stats) { 1119 kstat_delete(un->un_stats); 1120 un->un_stats = (kstat_t *)0; 1121 } 1122 if (un->un_errstats) { 1123 kstat_delete(un->un_errstats); 1124 un->un_errstats = (kstat_t *)0; 1125 } 1126 devp = ST_SCSI_DEVP; 1127 ddi_soft_state_free(st_state, instance); 1128 devp->sd_private = NULL; 1129 devp->sd_sense = NULL; 1130 scsi_unprobe(devp); 1131 ddi_prop_remove_all(devi); 1132 ddi_remove_minor_node(devi, NULL); 1133 ST_DEBUG(0, st_label, SCSI_DEBUG, "st_detach done\n"); 1134 return (DDI_SUCCESS); 1135 1136 case DDI_SUSPEND: 1137 1138 /* 1139 * Suspend/Resume 1140 * 1141 * To process DDI_SUSPEND, we must do the following: 1142 * 1143 * - check ddi_removing_power to see if power will be turned 1144 * off. if so, return DDI_FAILURE 1145 * - check if we are already suspended, 1146 * if so, return DDI_FAILURE 1147 * - check if device state is CLOSED, 1148 * if not, return DDI_FAILURE. 1149 * - wait until outstanding operations complete 1150 * - save tape state 1151 * - block new operations 1152 * - cancel pending timeouts 1153 * 1154 */ 1155 1156 if (ddi_removing_power(devi)) 1157 return (DDI_FAILURE); 1158 1159 mutex_enter(ST_MUTEX); 1160 1161 /* 1162 * Shouldn't already be suspended, if so return failure 1163 */ 1164 if (un->un_pwr_mgmt == ST_PWR_SUSPENDED) { 1165 mutex_exit(ST_MUTEX); 1166 return (DDI_FAILURE); 1167 } 1168 if (un->un_state != ST_STATE_CLOSED) { 1169 mutex_exit(ST_MUTEX); 1170 return (DDI_FAILURE); 1171 } 1172 1173 /* 1174 * Wait for all outstanding I/O's to complete 1175 * 1176 * we wait on both ncmds and the wait queue for times 1177 * when we are flushing after persistent errors are 1178 * flagged, which is when ncmds can be 0, and the 1179 * queue can still have I/O's. This way we preserve 1180 * order of biodone's. 1181 */ 1182 wait_cmds_complete = ddi_get_lbolt(); 1183 wait_cmds_complete += 1184 st_wait_cmds_complete * drv_usectohz(1000000); 1185 while (un->un_ncmds || un->un_quef || 1186 (un->un_state == ST_STATE_RESOURCE_WAIT)) { 1187 1188 if (cv_timedwait(&un->un_tape_busy_cv, ST_MUTEX, 1189 wait_cmds_complete) == -1) { 1190 /* 1191 * Time expired then cancel the command 1192 */ 1193 mutex_exit(ST_MUTEX); 1194 if (scsi_reset(ROUTE, RESET_TARGET) == 0) { 1195 mutex_enter(ST_MUTEX); 1196 if (un->un_last_throttle) { 1197 un->un_throttle = 1198 un->un_last_throttle; 1199 } 1200 mutex_exit(ST_MUTEX); 1201 return (DDI_FAILURE); 1202 } else { 1203 mutex_enter(ST_MUTEX); 1204 break; 1205 } 1206 } 1207 } 1208 1209 /* 1210 * DDI_SUSPEND says that the system "may" power down, we 1211 * remember the file and block number before rewinding. 1212 * we also need to save state before issuing 1213 * any WRITE_FILE_MARK command. 1214 */ 1215 if (un->un_fileno < 0) { 1216 un->un_suspend_fileno = 0; 1217 un->un_suspend_blkno = 0; 1218 } else { 1219 un->un_suspend_fileno = un->un_fileno; 1220 un->un_suspend_blkno = un->un_blkno; 1221 } 1222 dev_instance = ((un->un_dev == 0) ? MTMINOR(instance) : 1223 un->un_dev); 1224 1225 /* 1226 * Issue a zero write file fmk command to tell the drive to 1227 * flush any buffered tape marks 1228 */ 1229 (void) st_cmd(dev_instance, SCMD_WRITE_FILE_MARK, 0, SYNC_CMD); 1230 1231 /* 1232 * Because not all tape drives correctly implement buffer 1233 * flushing with the zero write file fmk command, issue a 1234 * synchronous rewind command to force data flushing. 1235 * st_validate_tapemarks() will do a rewind during DDI_RESUME 1236 * anyway. 1237 */ 1238 (void) st_cmd(dev_instance, SCMD_REWIND, 0, SYNC_CMD); 1239 1240 /* stop any new operations */ 1241 un->un_pwr_mgmt = ST_PWR_SUSPENDED; 1242 un->un_throttle = 0; 1243 1244 /* 1245 * cancel any outstanding timeouts 1246 */ 1247 if (un->un_delay_tid) { 1248 timeout_id_t temp_id = un->un_delay_tid; 1249 un->un_delay_tid = 0; 1250 un->un_tids_at_suspend |= ST_DELAY_TID; 1251 mutex_exit(ST_MUTEX); 1252 (void) untimeout(temp_id); 1253 mutex_enter(ST_MUTEX); 1254 } 1255 1256 if (un->un_hib_tid) { 1257 timeout_id_t temp_id = un->un_hib_tid; 1258 un->un_hib_tid = 0; 1259 un->un_tids_at_suspend |= ST_HIB_TID; 1260 mutex_exit(ST_MUTEX); 1261 (void) untimeout(temp_id); 1262 mutex_enter(ST_MUTEX); 1263 } 1264 1265 /* 1266 * Suspend the scsi_watch_thread 1267 */ 1268 if (un->un_swr_token) { 1269 opaque_t temp_token = un->un_swr_token; 1270 mutex_exit(ST_MUTEX); 1271 scsi_watch_suspend(temp_token); 1272 } else { 1273 mutex_exit(ST_MUTEX); 1274 } 1275 1276 return (DDI_SUCCESS); 1277 1278 default: 1279 ST_DEBUG(0, st_label, SCSI_DEBUG, "st_detach failed\n"); 1280 return (DDI_FAILURE); 1281 } 1282 } 1283 1284 1285 /* ARGSUSED */ 1286 static int 1287 stinfo(dev_info_t *dip, ddi_info_cmd_t infocmd, void *arg, void **result) 1288 { 1289 dev_t dev; 1290 struct scsi_tape *un; 1291 int instance, error; 1292 switch (infocmd) { 1293 case DDI_INFO_DEVT2DEVINFO: 1294 dev = (dev_t)arg; 1295 instance = MTUNIT(dev); 1296 if ((un = ddi_get_soft_state(st_state, instance)) == NULL) 1297 return (DDI_FAILURE); 1298 *result = (void *) ST_DEVINFO; 1299 error = DDI_SUCCESS; 1300 break; 1301 case DDI_INFO_DEVT2INSTANCE: 1302 dev = (dev_t)arg; 1303 instance = MTUNIT(dev); 1304 *result = (void *)(uintptr_t)instance; 1305 error = DDI_SUCCESS; 1306 break; 1307 default: 1308 error = DDI_FAILURE; 1309 } 1310 return (error); 1311 } 1312 1313 static int 1314 st_doattach(struct scsi_device *devp, int (*canwait)()) 1315 { 1316 struct scsi_pkt *rqpkt = NULL; 1317 struct scsi_tape *un = NULL; 1318 int km_flags = (canwait != NULL_FUNC) ? KM_SLEEP : KM_NOSLEEP; 1319 int instance; 1320 struct buf *bp; 1321 size_t rlen; 1322 1323 /* 1324 * Call the routine scsi_probe to do some of the dirty work. 1325 * If the INQUIRY command succeeds, the field sd_inq in the 1326 * device structure will be filled in. 1327 */ 1328 ST_DEBUG(devp->sd_dev, st_label, SCSI_DEBUG, 1329 "st_doattach(): probing\n"); 1330 1331 if (scsi_probe(devp, canwait) == SCSIPROBE_EXISTS) { 1332 1333 /* 1334 * In checking the whole inq_dtype byte we are looking at both 1335 * the Peripheral Qualifier and the Peripheral Device Type. 1336 * For this driver we are only interested in sequential devices 1337 * that are connected or capable if connecting to this logical 1338 * unit. 1339 */ 1340 if (devp->sd_inq->inq_dtype == 1341 (DTYPE_SEQUENTIAL | DPQ_POSSIBLE)) { 1342 ST_DEBUG(devp->sd_dev, st_label, SCSI_DEBUG, 1343 "probe exists\n"); 1344 } else { 1345 /* Something there but not a tape device */ 1346 scsi_unprobe(devp); 1347 return (DDI_FAILURE); 1348 } 1349 } else { 1350 /* Nothing there */ 1351 ST_DEBUG(devp->sd_dev, st_label, SCSI_DEBUG, 1352 "probe failure: nothing there\n"); 1353 scsi_unprobe(devp); 1354 return (DDI_FAILURE); 1355 } 1356 1357 bp = scsi_alloc_consistent_buf(&devp->sd_address, (struct buf *)NULL, 1358 SENSE_LENGTH, B_READ, canwait, NULL); 1359 if (!bp) { 1360 goto error; 1361 } 1362 rqpkt = scsi_init_pkt(&devp->sd_address, 1363 (struct scsi_pkt *)NULL, bp, CDB_GROUP0, 1, 0, 1364 PKT_CONSISTENT, canwait, NULL); 1365 if (!rqpkt) { 1366 goto error; 1367 } 1368 devp->sd_sense = (struct scsi_extended_sense *)bp->b_un.b_addr; 1369 ASSERT(geterror(bp) == NULL); 1370 1371 (void) scsi_setup_cdb((union scsi_cdb *)rqpkt->pkt_cdbp, 1372 SCMD_REQUEST_SENSE, 0, SENSE_LENGTH, 0); 1373 FILL_SCSI1_LUN(devp, rqpkt); 1374 1375 /* 1376 * The actual unit is present. 1377 * Now is the time to fill in the rest of our info.. 1378 */ 1379 instance = ddi_get_instance(devp->sd_dev); 1380 1381 if (ddi_soft_state_zalloc(st_state, instance) != DDI_SUCCESS) { 1382 goto error; 1383 } 1384 un = ddi_get_soft_state(st_state, instance); 1385 1386 un->un_sbufp = getrbuf(km_flags); 1387 1388 un->un_uscsi_rqs_buf = kmem_alloc(SENSE_LENGTH, KM_SLEEP); 1389 1390 /* 1391 * use i_ddi_mem_alloc() for now until we have an interface to allocate 1392 * memory for DMA which doesn't require a DMA handle. ddi_iopb_alloc() 1393 * is obsolete and we want more flexibility in controlling the DMA 1394 * address constraints. 1395 */ 1396 (void) i_ddi_mem_alloc(devp->sd_dev, &st_alloc_attr, 1397 sizeof (struct seq_mode), ((km_flags == KM_SLEEP) ? 1 : 0), 0, 1398 NULL, (caddr_t *)&un->un_mspl, &rlen, NULL); 1399 1400 if (!un->un_sbufp || !un->un_mspl) { 1401 if (un->un_mspl) { 1402 i_ddi_mem_free((caddr_t)un->un_mspl, 0); 1403 } 1404 ST_DEBUG6(devp->sd_dev, st_label, SCSI_DEBUG, 1405 "probe partial failure: no space\n"); 1406 goto error; 1407 } 1408 1409 bzero(un->un_mspl, sizeof (struct seq_mode)); 1410 1411 cv_init(&un->un_sbuf_cv, NULL, CV_DRIVER, NULL); 1412 cv_init(&un->un_queue_cv, NULL, CV_DRIVER, NULL); 1413 cv_init(&un->un_clscv, NULL, CV_DRIVER, NULL); 1414 cv_init(&un->un_state_cv, NULL, CV_DRIVER, NULL); 1415 #if defined(__i386) || defined(__amd64) 1416 cv_init(&un->un_contig_mem_cv, NULL, CV_DRIVER, NULL); 1417 #endif 1418 1419 /* Initialize power managemnet condition variable */ 1420 cv_init(&un->un_suspend_cv, NULL, CV_DRIVER, NULL); 1421 cv_init(&un->un_tape_busy_cv, NULL, CV_DRIVER, NULL); 1422 1423 rqpkt->pkt_flags |= (FLAG_SENSING | FLAG_HEAD | FLAG_NODISCON); 1424 1425 un->un_fileno = -1; 1426 rqpkt->pkt_time = st_io_time; 1427 rqpkt->pkt_comp = st_intr; 1428 un->un_rqs = rqpkt; 1429 un->un_sd = devp; 1430 un->un_rqs_bp = bp; 1431 un->un_swr_token = (opaque_t)NULL; 1432 un->un_comp_page = ST_DEV_DATACOMP_PAGE | ST_DEV_CONFIG_PAGE; 1433 1434 un->un_suspend_fileno = 0; 1435 un->un_suspend_blkno = 0; 1436 1437 #if defined(__i386) || defined(__amd64) 1438 if (ddi_dma_alloc_handle(ST_DEVINFO, &st_contig_mem_dma_attr, 1439 DDI_DMA_SLEEP, NULL, &un->un_contig_mem_hdl) != DDI_SUCCESS) { 1440 ST_DEBUG6(devp->sd_dev, st_label, SCSI_DEBUG, 1441 "allocation of contiguous memory dma handle failed!"); 1442 un->un_contig_mem_hdl = NULL; 1443 goto error; 1444 } 1445 #endif 1446 1447 /* 1448 * Since this driver manages devices with "remote" hardware, 1449 * i.e. the devices themselves have no "reg" properties, 1450 * the SUSPEND/RESUME commands in detach/attach will not be 1451 * called by the power management framework unless we request 1452 * it by creating a "pm-hardware-state" property and setting it 1453 * to value "needs-suspend-resume". 1454 */ 1455 if (ddi_prop_update_string(DDI_DEV_T_NONE, devp->sd_dev, 1456 "pm-hardware-state", "needs-suspend-resume") != 1457 DDI_PROP_SUCCESS) { 1458 1459 ST_DEBUG(devp->sd_dev, st_label, SCSI_DEBUG, 1460 "ddi_prop_update(\"pm-hardware-state\") failed\n"); 1461 goto error; 1462 } 1463 1464 if (ddi_prop_create(DDI_DEV_T_NONE, devp->sd_dev, DDI_PROP_CANSLEEP, 1465 "no-involuntary-power-cycles", NULL, 0) != DDI_PROP_SUCCESS) { 1466 1467 ST_DEBUG(devp->sd_dev, st_label, SCSI_DEBUG, 1468 "ddi_prop_create(\"no-involuntary-power-cycles\") " 1469 "failed\n"); 1470 goto error; 1471 } 1472 1473 ST_DEBUG6(devp->sd_dev, st_label, SCSI_DEBUG, "probe success\n"); 1474 return (DDI_SUCCESS); 1475 1476 error: 1477 devp->sd_sense = NULL; 1478 1479 ddi_remove_minor_node(devp->sd_dev, NULL); 1480 if (un) { 1481 if (un->un_mspl) { 1482 i_ddi_mem_free((caddr_t)un->un_mspl, 0); 1483 } 1484 if (un->un_sbufp) { 1485 freerbuf(un->un_sbufp); 1486 } 1487 if (un->un_uscsi_rqs_buf) { 1488 kmem_free(un->un_uscsi_rqs_buf, SENSE_LENGTH); 1489 } 1490 #if defined(__i386) || defined(__amd64) 1491 if (un->un_contig_mem_hdl != NULL) { 1492 ddi_dma_free_handle(&un->un_contig_mem_hdl); 1493 } 1494 #endif 1495 ddi_soft_state_free(st_state, instance); 1496 devp->sd_private = NULL; 1497 } 1498 1499 if (rqpkt) { 1500 scsi_destroy_pkt(rqpkt); 1501 } 1502 1503 if (bp) { 1504 scsi_free_consistent_buf(bp); 1505 } 1506 1507 if (devp->sd_inq) { 1508 scsi_unprobe(devp); 1509 } 1510 return (DDI_FAILURE); 1511 } 1512 1513 typedef int 1514 (*cfg_functp)(struct scsi_tape *, char *vidpid, struct st_drivetype *); 1515 1516 static cfg_functp config_functs[] = { 1517 st_get_conf_from_st_dot_conf, 1518 st_get_conf_from_st_conf_dot_c, 1519 st_get_default_conf 1520 }; 1521 1522 1523 /* 1524 * determine tape type, using tape-config-list or built-in table or 1525 * use a generic tape config entry 1526 */ 1527 static void 1528 st_known_tape_type(struct scsi_tape *un) 1529 { 1530 struct st_drivetype *dp; 1531 cfg_functp *config_funct; 1532 1533 /* 1534 * XXX: Emulex MT-02 (and emulators) predates SCSI-1 and has 1535 * no vid & pid inquiry data. So, we provide one. 1536 */ 1537 if (ST_INQUIRY->inq_len == 0 || 1538 (bcmp("\0\0\0\0\0\0\0\0", ST_INQUIRY->inq_vid, 8) == 0)) { 1539 (void) strcpy((char *)ST_INQUIRY->inq_vid, ST_MT02_NAME); 1540 } 1541 1542 un->un_dp_size = sizeof (struct st_drivetype); 1543 dp = kmem_zalloc((size_t)un->un_dp_size, KM_SLEEP); 1544 un->un_dp = dp; 1545 1546 /* 1547 * Loop through the configuration methods till one works. 1548 */ 1549 for (config_funct = &config_functs[0]; ; config_funct++) { 1550 if ((*config_funct)(un, ST_INQUIRY->inq_vid, dp)) { 1551 break; 1552 } 1553 } 1554 1555 /* 1556 * If we didn't just make up this configuration and 1557 * all the density codes are the same.. 1558 * Set Auto Density over ride. 1559 */ 1560 if (*config_funct != st_get_default_conf) { 1561 /* 1562 * If this device is one that is configured and all 1563 * densities are the same, This saves doing gets and set 1564 * that yield nothing. 1565 */ 1566 if ((dp->densities[0]) == (dp->densities[1]) && 1567 (dp->densities[0]) == (dp->densities[2]) && 1568 (dp->densities[0]) == (dp->densities[3])) { 1569 1570 dp->options |= ST_AUTODEN_OVERRIDE; 1571 } 1572 } 1573 1574 1575 /* 1576 * Store tape drive characteristics. 1577 */ 1578 un->un_status = 0; 1579 un->un_attached = 1; 1580 un->un_init_options = dp->options; 1581 1582 /* setup operation time-outs based on options */ 1583 st_calculate_timeouts(un); 1584 1585 /* make sure if we are supposed to be variable, make it variable */ 1586 if (dp->options & ST_VARIABLE) { 1587 dp->bsize = 0; 1588 } 1589 1590 scsi_log(ST_DEVINFO, st_label, CE_NOTE, "?<%s>\n", dp->name); 1591 } 1592 1593 1594 typedef struct { 1595 int mask; 1596 int bottom; 1597 int top; 1598 char *name; 1599 } conf_limit; 1600 1601 static const conf_limit conf_limits[] = { 1602 1603 -1, 1, 2, "conf version", 1604 -1, MT_ISTS, ST_LAST_TYPE, "drive type", 1605 -1, 0, 0xffffff, "block size", 1606 ST_VALID_OPTS, 0, ST_VALID_OPTS, "options", 1607 -1, 0, 4, "number of densities", 1608 -1, 0, UINT8_MAX, "density code", 1609 -1, 0, 3, "default density", 1610 -1, 0, UINT16_MAX, "non motion timeout", 1611 -1, 0, UINT16_MAX, "I/O timeout", 1612 -1, 0, UINT16_MAX, "space timeout", 1613 -1, 0, UINT16_MAX, "load timeout", 1614 -1, 0, UINT16_MAX, "unload timeout", 1615 -1, 0, UINT16_MAX, "erase timeout", 1616 0, 0, 0, NULL 1617 }; 1618 1619 static int 1620 st_validate_conf_data(struct scsi_tape *un, int *list, int list_len, 1621 const char *conf_name) 1622 { 1623 int dens; 1624 int ndens; 1625 int value; 1626 int type; 1627 int count; 1628 const conf_limit *limit = &conf_limits[0]; 1629 1630 ST_DEBUG3(ST_DEVINFO, st_label, CE_NOTE, 1631 "Checking %d entrys total with %d densities\n", list_len, list[4]); 1632 1633 count = list_len; 1634 type = *list; 1635 for (; count && limit->name; count--, list++, limit++) { 1636 1637 value = *list; 1638 if (value & ~limit->mask) { 1639 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1640 "%s %s value invalid bits set: 0x%X\n", 1641 conf_name, limit->name, value & ~limit->mask); 1642 *list &= limit->mask; 1643 } else if (value < limit->bottom) { 1644 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1645 "%s %s value too low: value = %d limit %d\n", 1646 conf_name, limit->name, value, limit->bottom); 1647 } else if (value > limit->top) { 1648 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1649 "%s %s value too high: value = %d limit %d\n", 1650 conf_name, limit->name, value, limit->top); 1651 } else { 1652 ST_DEBUG3(ST_DEVINFO, st_label, CE_CONT, 1653 "%s %s value = 0x%X\n", 1654 conf_name, limit->name, value); 1655 } 1656 1657 /* If not the number of densities continue */ 1658 if (limit != &conf_limits[4]) { 1659 continue; 1660 } 1661 1662 /* If number of densities is not in range can't use config */ 1663 if (value < limit->bottom || value > limit->top) { 1664 return (-1); 1665 } 1666 1667 ndens = min(value, NDENSITIES); 1668 if ((type == 1) && (list_len - ndens) != 6) { 1669 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1670 "%s conf version 1 with %d densities has %d items" 1671 " should have %d", 1672 conf_name, ndens, list_len, 6 + ndens); 1673 } else if ((type == 2) && (list_len - ndens) != 13) { 1674 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1675 "%s conf version 2 with %d densities has %d items" 1676 " should have %d", 1677 conf_name, ndens, list_len, 13 + ndens); 1678 } 1679 1680 limit++; 1681 for (dens = 0; dens < ndens && count; dens++) { 1682 count--; 1683 list++; 1684 value = *list; 1685 if (value < limit->bottom) { 1686 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1687 "%s density[%d] value too low: value =" 1688 " 0x%X limit 0x%X\n", 1689 conf_name, dens, value, limit->bottom); 1690 } else if (value > limit->top) { 1691 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 1692 "%s density[%d] value too high: value =" 1693 " 0x%X limit 0x%X\n", 1694 conf_name, dens, value, limit->top); 1695 } else { 1696 ST_DEBUG3(ST_DEVINFO, st_label, CE_CONT, 1697 "%s density[%d] value = 0x%X\n", 1698 conf_name, dens, value); 1699 } 1700 } 1701 } 1702 1703 return (0); 1704 } 1705 1706 static int 1707 st_get_conf_from_st_dot_conf(struct scsi_tape *un, char *vidpid, 1708 struct st_drivetype *dp) 1709 { 1710 caddr_t config_list = NULL; 1711 caddr_t data_list = NULL; 1712 int *data_ptr; 1713 caddr_t vidptr, prettyptr, datanameptr; 1714 size_t vidlen, prettylen, datanamelen, tripletlen = 0; 1715 int config_list_len, data_list_len, len, i; 1716 int version; 1717 int found = 0; 1718 1719 1720 /* 1721 * Determine type of tape controller. Type is determined by 1722 * checking the vendor ids of the earlier inquiry command and 1723 * comparing those with vids in tape-config-list defined in st.conf 1724 */ 1725 if (ddi_getlongprop(DDI_DEV_T_ANY, ST_DEVINFO, DDI_PROP_DONTPASS, 1726 "tape-config-list", (caddr_t)&config_list, &config_list_len) 1727 != DDI_PROP_SUCCESS) { 1728 return (found); 1729 } 1730 1731 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 1732 "st_get_conf_from_st_dot_conf(): st.conf has tape-config-list\n"); 1733 1734 /* 1735 * Compare vids in each triplet - if it matches, get value for 1736 * data_name and contruct a st_drivetype struct 1737 * tripletlen is not set yet! 1738 */ 1739 for (len = config_list_len, vidptr = config_list; 1740 len > 0; 1741 vidptr += tripletlen, len -= tripletlen) { 1742 1743 vidlen = strlen(vidptr); 1744 prettyptr = vidptr + vidlen + 1; 1745 prettylen = strlen(prettyptr); 1746 datanameptr = prettyptr + prettylen + 1; 1747 datanamelen = strlen(datanameptr); 1748 tripletlen = vidlen + prettylen + datanamelen + 3; 1749 1750 if (vidlen == 0) { 1751 continue; 1752 } 1753 1754 /* 1755 * If inquiry vid dosen't match this triplets vid, 1756 * try the next. 1757 */ 1758 if (strncasecmp(vidpid, vidptr, vidlen)) { 1759 continue; 1760 } 1761 1762 /* 1763 * if prettylen is zero then use the vid string 1764 */ 1765 if (prettylen == 0) { 1766 prettyptr = vidptr; 1767 prettylen = vidlen; 1768 } 1769 1770 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 1771 "vid = %s, pretty=%s, dataname = %s\n", 1772 vidptr, prettyptr, datanameptr); 1773 1774 /* 1775 * get the data list 1776 */ 1777 if (ddi_getlongprop(DDI_DEV_T_ANY, ST_DEVINFO, 0, 1778 datanameptr, (caddr_t)&data_list, 1779 &data_list_len) != DDI_PROP_SUCCESS) { 1780 /* 1781 * Error in getting property value 1782 * print warning! 1783 */ 1784 scsi_log(ST_DEVINFO, st_label, CE_WARN, 1785 "data property (%s) has no value\n", 1786 datanameptr); 1787 continue; 1788 } 1789 1790 /* 1791 * now initialize the st_drivetype struct 1792 */ 1793 (void) strncpy(dp->name, prettyptr, ST_NAMESIZE - 1); 1794 dp->length = (int)min(vidlen, (VIDPIDLEN - 1)); 1795 (void) strncpy(dp->vid, vidptr, dp->length); 1796 data_ptr = (int *)data_list; 1797 /* 1798 * check if data is enough for version, type, 1799 * bsize, options, # of densities, density1, 1800 * density2, ..., default_density 1801 */ 1802 if ((data_list_len < 5 * sizeof (int)) || 1803 (data_list_len < 6 * sizeof (int) + 1804 *(data_ptr + 4) * sizeof (int))) { 1805 /* 1806 * print warning and skip to next triplet. 1807 */ 1808 scsi_log(ST_DEVINFO, st_label, CE_WARN, 1809 "data property (%s) incomplete\n", 1810 datanameptr); 1811 kmem_free(data_list, data_list_len); 1812 continue; 1813 } 1814 1815 if (st_validate_conf_data(un, data_ptr, 1816 data_list_len / sizeof (int), datanameptr)) { 1817 kmem_free(data_list, data_list_len); 1818 scsi_log(ST_DEVINFO, st_label, CE_WARN, 1819 "data property (%s) rejected\n", 1820 datanameptr); 1821 continue; 1822 } 1823 1824 /* 1825 * check version 1826 */ 1827 version = *data_ptr++; 1828 if (version != 1 && version != 2) { 1829 /* print warning but accept it */ 1830 scsi_log(ST_DEVINFO, st_label, CE_WARN, 1831 "Version # for data property (%s) " 1832 "not set to 1 or 2\n", datanameptr); 1833 } 1834 1835 dp->type = *data_ptr++; 1836 dp->bsize = *data_ptr++; 1837 dp->options = *data_ptr++; 1838 dp->options |= ST_DYNAMIC; 1839 len = *data_ptr++; 1840 for (i = 0; i < NDENSITIES; i++) { 1841 if (i < len) { 1842 dp->densities[i] = *data_ptr++; 1843 } 1844 } 1845 dp->default_density = *data_ptr << 3; 1846 if (version == 2 && 1847 data_list_len >= (13 + len) * sizeof (int)) { 1848 data_ptr++; 1849 dp->non_motion_timeout = *data_ptr++; 1850 dp->io_timeout = *data_ptr++; 1851 dp->rewind_timeout = *data_ptr++; 1852 dp->space_timeout = *data_ptr++; 1853 dp->load_timeout = *data_ptr++; 1854 dp->unload_timeout = *data_ptr++; 1855 dp->erase_timeout = *data_ptr++; 1856 } 1857 kmem_free(data_list, data_list_len); 1858 found = 1; 1859 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 1860 "found in st.conf: vid = %s, pretty=%s\n", 1861 dp->vid, dp->name); 1862 break; 1863 } 1864 1865 /* 1866 * free up the memory allocated by ddi_getlongprop 1867 */ 1868 if (config_list) { 1869 kmem_free(config_list, config_list_len); 1870 } 1871 return (found); 1872 } 1873 1874 static int 1875 st_get_conf_from_st_conf_dot_c(struct scsi_tape *un, char *vidpid, 1876 struct st_drivetype *dp) 1877 { 1878 int i; 1879 1880 /* 1881 * Determine type of tape controller. Type is determined by 1882 * checking the result of the earlier inquiry command and 1883 * comparing vendor ids with strings in a table declared in st_conf.c. 1884 */ 1885 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 1886 "st_get_conf_from_st_conf_dot_c(): looking at st_drivetypes\n"); 1887 1888 for (i = 0; i < st_ndrivetypes; i++) { 1889 if (st_drivetypes[i].length == 0) { 1890 continue; 1891 } 1892 if (strncasecmp(vidpid, st_drivetypes[i].vid, 1893 st_drivetypes[i].length)) { 1894 continue; 1895 } 1896 bcopy(&st_drivetypes[i], dp, sizeof (st_drivetypes[i])); 1897 return (1); 1898 } 1899 return (0); 1900 } 1901 1902 static int 1903 st_get_default_conf(struct scsi_tape *un, char *vidpid, struct st_drivetype *dp) 1904 { 1905 int i; 1906 1907 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 1908 "st_get_default_conf(): making drivetype from INQ cmd\n"); 1909 1910 1911 /* 1912 * Make up a name 1913 */ 1914 bcopy("Vendor '", dp->name, 8); 1915 bcopy(vidpid, &dp->name[8], VIDLEN); 1916 bcopy("' Product '", &dp->name[16], 11); 1917 bcopy(&vidpid[8], &dp->name[27], PIDLEN); 1918 dp->name[ST_NAMESIZE - 2] = '\''; 1919 dp->name[ST_NAMESIZE - 1] = '\0'; 1920 dp->length = min(strlen(ST_INQUIRY->inq_vid), (VIDPIDLEN - 1)); 1921 (void) strncpy(dp->vid, ST_INQUIRY->inq_vid, dp->length); 1922 /* 1923 * 'clean' vendor and product strings of non-printing chars 1924 */ 1925 for (i = 0; i < ST_NAMESIZE - 2; i++) { 1926 if (dp->name[i] < ' ' || dp->name[i] > '~') { 1927 dp->name[i] = '.'; 1928 } 1929 } 1930 dp->type = ST_TYPE_INVALID; 1931 dp->options |= (ST_DYNAMIC | ST_UNLOADABLE | ST_MODE_SEL_COMP); 1932 1933 return (1); /* Can Not Fail */ 1934 } 1935 1936 /* 1937 * Regular Unix Entry points 1938 */ 1939 1940 1941 1942 /* ARGSUSED */ 1943 static int 1944 st_open(dev_t *dev_p, int flag, int otyp, cred_t *cred_p) 1945 { 1946 dev_t dev = *dev_p; 1947 int rval = 0; 1948 1949 GET_SOFT_STATE(dev); 1950 1951 /* 1952 * validate that we are addressing a sensible unit 1953 */ 1954 mutex_enter(ST_MUTEX); 1955 1956 #ifdef STDEBUG 1957 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 1958 "st_open(node = %s dev = 0x%lx, flag = %d, otyp = %d)\n", 1959 st_dev_name(dev), *dev_p, flag, otyp); 1960 #endif 1961 1962 /* 1963 * All device accesss go thru st_strategy() where we check 1964 * suspend status 1965 */ 1966 1967 if (!un->un_attached) { 1968 st_known_tape_type(un); 1969 if (!un->un_attached) { 1970 rval = ENXIO; 1971 goto exit; 1972 } 1973 1974 } 1975 1976 /* 1977 * Check for the case of the tape in the middle of closing. 1978 * This isn't simply a check of the current state, because 1979 * we could be in state of sensing with the previous state 1980 * that of closing. 1981 * 1982 * And don't allow multiple opens. 1983 */ 1984 if (!(flag & (FNDELAY | FNONBLOCK)) && IS_CLOSING(un)) { 1985 un->un_laststate = un->un_state; 1986 un->un_state = ST_STATE_CLOSE_PENDING_OPEN; 1987 while (IS_CLOSING(un) || 1988 un->un_state == ST_STATE_CLOSE_PENDING_OPEN) { 1989 if (cv_wait_sig(&un->un_clscv, ST_MUTEX) == 0) { 1990 rval = EINTR; 1991 un->un_state = un->un_laststate; 1992 goto exit; 1993 } 1994 } 1995 } else if (un->un_state != ST_STATE_CLOSED) { 1996 rval = EBUSY; 1997 goto busy; 1998 } 1999 2000 /* 2001 * record current dev 2002 */ 2003 un->un_dev = dev; 2004 un->un_oflags = flag; /* save for use in st_tape_init() */ 2005 un->un_errno = 0; /* no errors yet */ 2006 un->un_restore_pos = 0; 2007 un->un_rqs_state = 0; 2008 2009 /* 2010 * If we are opening O_NDELAY, or O_NONBLOCK, we don't check for 2011 * anything, leave internal states alone, if fileno >= 0 2012 */ 2013 if (flag & (FNDELAY | FNONBLOCK)) { 2014 if (un->un_fileno < 0 || (un->un_fileno == 0 && 2015 un->un_blkno == 0)) { 2016 un->un_state = ST_STATE_OFFLINE; 2017 } else { 2018 /* 2019 * set un_read_only/write-protect status. 2020 * 2021 * If the tape is not bot we can assume 2022 * that mspl->wp_status is set properly. 2023 * else 2024 * we need to do a mode sense/Tur once 2025 * again to get the actual tape status.(since 2026 * user might have replaced the tape) 2027 * Hence make the st state OFFLINE so that 2028 * we re-intialize the tape once again. 2029 */ 2030 if (un->un_fileno > 0 || 2031 (un->un_fileno == 0 && un->un_blkno != 0)) { 2032 un->un_read_only = 2033 (un->un_oflags & FWRITE) ? 0 : 1; 2034 un->un_state = ST_STATE_OPEN_PENDING_IO; 2035 } else { 2036 un->un_state = ST_STATE_OFFLINE; 2037 } 2038 } 2039 rval = 0; 2040 } else { 2041 /* 2042 * If reserve/release is supported on this drive. 2043 * then call st_tape_reservation_init(). 2044 */ 2045 un->un_state = ST_STATE_OPENING; 2046 2047 if (ST_RESERVE_SUPPORTED(un)) { 2048 rval = st_tape_reservation_init(dev); 2049 if (rval) { 2050 goto exit; 2051 } 2052 } 2053 rval = st_tape_init(dev); 2054 if (rval) { 2055 /* 2056 * Release the tape unit, if no preserve reserve 2057 */ 2058 if ((ST_RESERVE_SUPPORTED(un)) && 2059 !(un->un_rsvd_status & ST_PRESERVE_RESERVE)) { 2060 (void) st_reserve_release(dev, ST_RELEASE); 2061 } 2062 } else { 2063 un->un_state = ST_STATE_OPEN_PENDING_IO; 2064 } 2065 } 2066 2067 exit: 2068 /* 2069 * we don't want any uninvited guests scrogging our data when we're 2070 * busy with something, so for successful opens or failed opens 2071 * (except for EBUSY), reset these counters and state appropriately. 2072 */ 2073 if (rval != EBUSY) { 2074 if (rval) { 2075 un->un_state = ST_STATE_CLOSED; 2076 } 2077 un->un_err_resid = 0; 2078 un->un_retry_ct = 0; 2079 un->un_tran_retry_ct = 0; 2080 } 2081 busy: 2082 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2083 "st_open: return val = %x, state = %d\n", rval, un->un_state); 2084 mutex_exit(ST_MUTEX); 2085 return (rval); 2086 2087 } 2088 2089 #define ST_LOST_RESERVE_BETWEEN_OPENS \ 2090 (ST_RESERVE | ST_LOST_RESERVE | ST_PRESERVE_RESERVE) 2091 2092 int 2093 st_tape_reservation_init(dev_t dev) 2094 { 2095 int rval = 0; 2096 2097 GET_SOFT_STATE(dev); 2098 2099 ASSERT(mutex_owned(ST_MUTEX)); 2100 2101 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2102 "st_tape_reservation_init(dev = 0x%lx)\n", dev); 2103 2104 /* 2105 * Issue a Throw-Away reserve command to clear the 2106 * check condition. 2107 * If the current behaviour of reserve/release is to 2108 * hold reservation across opens , and if a Bus reset 2109 * has been issued between opens then this command 2110 * would set the ST_LOST_RESERVE flags in rsvd_status. 2111 * In this case return an EACCES so that user knows that 2112 * reservation has been lost in between opens. 2113 * If this error is not returned and we continue with 2114 * successful open , then user may think position of the 2115 * tape is still the same but inreality we would rewind the 2116 * tape and continue from BOT. 2117 */ 2118 rval = st_reserve_release(dev, ST_RESERVE); 2119 2120 if (rval) { 2121 if ((un->un_rsvd_status & ST_LOST_RESERVE_BETWEEN_OPENS) == 2122 ST_LOST_RESERVE_BETWEEN_OPENS) { 2123 un->un_rsvd_status &= 2124 ~(ST_LOST_RESERVE | ST_RESERVE); 2125 un->un_errno = EACCES; 2126 return (EACCES); 2127 } 2128 rval = st_reserve_release(dev, ST_RESERVE); 2129 } 2130 if (rval == 0) 2131 un->un_rsvd_status |= ST_INIT_RESERVE; 2132 2133 return (rval); 2134 } 2135 2136 static int 2137 st_tape_init(dev_t dev) 2138 { 2139 int err; 2140 int rval = 0; 2141 2142 GET_SOFT_STATE(dev); 2143 2144 ASSERT(mutex_owned(ST_MUTEX)); 2145 2146 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2147 "st_tape_init(dev = 0x%lx, oflags = %d)\n", dev, un->un_oflags); 2148 2149 /* 2150 * Clean up after any errors left by 'last' close. 2151 * This also handles the case of the initial open. 2152 */ 2153 if (un->un_state != ST_STATE_INITIALIZING) { 2154 un->un_laststate = un->un_state; 2155 un->un_state = ST_STATE_OPENING; 2156 } 2157 2158 un->un_kbytes_xferred = 0; 2159 2160 /* 2161 * do a throw away TUR to clear check condition 2162 */ 2163 err = st_cmd(dev, SCMD_TEST_UNIT_READY, 0, SYNC_CMD); 2164 2165 /* 2166 * If test unit ready fails because the drive is reserved 2167 * by another host fail the open for no access. 2168 */ 2169 if (err) { 2170 if (un->un_rsvd_status & ST_RESERVATION_CONFLICT) { 2171 un->un_state = ST_STATE_CLOSED; 2172 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 2173 "st_tape_init: RESERVATION CONFLICT\n"); 2174 rval = EACCES; 2175 goto exit; 2176 } 2177 } 2178 2179 /* 2180 * See whether this is a generic device that we haven't figured 2181 * anything out about yet. 2182 */ 2183 if (un->un_dp->type == ST_TYPE_INVALID) { 2184 if (st_determine_generic(dev)) { 2185 un->un_state = ST_STATE_CLOSED; 2186 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2187 "st_open: EIO invalid type\n"); 2188 rval = EIO; 2189 goto exit; 2190 } 2191 /* 2192 * If this is a Unknown Type drive, 2193 * Use the READ BLOCK LIMITS to determine if 2194 * allow large xfer is approprate if not globally 2195 * disabled with st_allow_large_xfer. 2196 */ 2197 un->un_allow_large_xfer = (uchar_t)st_allow_large_xfer; 2198 } else { 2199 2200 /* 2201 * If we allow_large_xfer (ie >64k) and have not yet found out 2202 * the max block size supported by the drive, 2203 * find it by issueing a READ_BLKLIM command. 2204 * if READ_BLKLIM cmd fails, assume drive doesn't 2205 * allow_large_xfer and min/max block sizes as 1 byte and 63k. 2206 */ 2207 un->un_allow_large_xfer = st_allow_large_xfer && 2208 (un->un_dp->options & ST_NO_RECSIZE_LIMIT); 2209 } 2210 /* 2211 * if maxbsize is unknown, set the maximum block size. 2212 */ 2213 if (un->un_maxbsize == MAXBSIZE_UNKNOWN) { 2214 2215 /* 2216 * Get the Block limits of the tape drive. 2217 * if un->un_allow_large_xfer = 0 , then make sure 2218 * that maxbsize is <= ST_MAXRECSIZE_FIXED. 2219 */ 2220 un->un_rbl = kmem_zalloc(RBLSIZE, KM_SLEEP); 2221 2222 err = st_cmd(dev, SCMD_READ_BLKLIM, RBLSIZE, SYNC_CMD); 2223 if (err) { 2224 /* Retry */ 2225 err = st_cmd(dev, SCMD_READ_BLKLIM, RBLSIZE, SYNC_CMD); 2226 } 2227 if (!err) { 2228 2229 /* 2230 * if cmd successful, use limit returned 2231 */ 2232 un->un_maxbsize = (un->un_rbl->max_hi << 16) + 2233 (un->un_rbl->max_mid << 8) + 2234 un->un_rbl->max_lo; 2235 un->un_minbsize = (un->un_rbl->min_hi << 8) + 2236 un->un_rbl->min_lo; 2237 un->un_data_mod = 1 << un->un_rbl->granularity; 2238 if ((un->un_maxbsize == 0) || 2239 (un->un_allow_large_xfer == 0 && 2240 un->un_maxbsize > ST_MAXRECSIZE_FIXED)) { 2241 un->un_maxbsize = ST_MAXRECSIZE_FIXED; 2242 2243 } else if (un->un_dp->type == ST_TYPE_DEFAULT) { 2244 /* 2245 * Drive is not one that is configured, But the 2246 * READ BLOCK LIMITS tells us it can do large 2247 * xfers. 2248 */ 2249 if (un->un_maxbsize > ST_MAXRECSIZE_FIXED) { 2250 un->un_dp->options |= 2251 ST_NO_RECSIZE_LIMIT; 2252 } 2253 /* 2254 * If max and mimimum block limits are the 2255 * same this is a fixed block size device. 2256 */ 2257 if (un->un_maxbsize == un->un_minbsize) { 2258 un->un_dp->options &= ~ST_VARIABLE; 2259 } 2260 } 2261 2262 if (un->un_minbsize == 0) { 2263 un->un_minbsize = 1; 2264 } 2265 2266 } else { /* error on read block limits */ 2267 2268 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 2269 "!st_tape_init: Error on READ BLOCK LIMITS," 2270 " errno = %d un_rsvd_status = 0x%X\n", 2271 err, un->un_rsvd_status); 2272 2273 /* 2274 * since read block limits cmd failed, 2275 * do not allow large xfers. 2276 * use old values in st_minphys 2277 */ 2278 if (un->un_rsvd_status & ST_RESERVATION_CONFLICT) { 2279 rval = EACCES; 2280 } else { 2281 un->un_allow_large_xfer = 0; 2282 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 2283 "!Disabling large transfers\n"); 2284 2285 /* 2286 * we guess maxbsize and minbsize 2287 */ 2288 if (un->un_bsize) { 2289 un->un_maxbsize = un->un_minbsize = 2290 un->un_bsize; 2291 } else { 2292 un->un_maxbsize = ST_MAXRECSIZE_FIXED; 2293 un->un_minbsize = 1; 2294 } 2295 /* 2296 * Data Mod must be set, 2297 * Even if read block limits fails. 2298 * Prevents Divide By Zero in st_rw(). 2299 */ 2300 un->un_data_mod = 1; 2301 } 2302 } 2303 if (un->un_rbl) { 2304 kmem_free(un->un_rbl, RBLSIZE); 2305 un->un_rbl = NULL; 2306 } 2307 2308 if (rval) { 2309 goto exit; 2310 } 2311 } 2312 2313 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 2314 "maxdma = %d, maxbsize = %d, minbsize = %d, %s large xfer\n", 2315 un->un_maxdma, un->un_maxbsize, un->un_minbsize, 2316 (un->un_allow_large_xfer ? "ALLOW": "DON'T ALLOW")); 2317 2318 err = st_cmd(dev, SCMD_TEST_UNIT_READY, 0, SYNC_CMD); 2319 2320 if (err != 0) { 2321 if (err == EINTR) { 2322 un->un_laststate = un->un_state; 2323 un->un_state = ST_STATE_CLOSED; 2324 rval = EINTR; 2325 goto exit; 2326 } 2327 /* 2328 * Make sure the tape is ready 2329 */ 2330 un->un_fileno = -1; 2331 if (un->un_status != KEY_UNIT_ATTENTION) { 2332 /* 2333 * allow open no media. Subsequent MTIOCSTATE 2334 * with media present will complete the open 2335 * logic. 2336 */ 2337 un->un_laststate = un->un_state; 2338 if (un->un_oflags & (FNONBLOCK|FNDELAY)) { 2339 un->un_mediastate = MTIO_EJECTED; 2340 un->un_state = ST_STATE_OFFLINE; 2341 rval = 0; 2342 goto exit; 2343 } else { 2344 un->un_state = ST_STATE_CLOSED; 2345 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2346 "st_open EIO no media, not opened O_NONBLOCK|O_EXCL\n"); 2347 rval = EIO; 2348 goto exit; 2349 } 2350 } 2351 } 2352 2353 /* 2354 * On each open, initialize block size from drivetype struct, 2355 * as it could have been changed by MTSRSZ ioctl. 2356 * Now, ST_VARIABLE simply means drive is capable of variable 2357 * mode. All drives are assumed to support fixed records. 2358 * Hence, un_bsize tells what mode the drive is in. 2359 * un_bsize = 0 - variable record length 2360 * = x - fixed record length is x 2361 */ 2362 un->un_bsize = un->un_dp->bsize; 2363 2364 if (un->un_restore_pos) { 2365 if (st_validate_tapemarks(un, un->un_save_fileno, 2366 un->un_save_blkno) != 0) { 2367 un->un_restore_pos = 0; 2368 un->un_laststate = un->un_state; 2369 un->un_state = ST_STATE_CLOSED; 2370 rval = EIO; 2371 goto exit; 2372 } 2373 un->un_restore_pos = 0; 2374 } 2375 2376 if ((un->un_fileno < 0) && st_loadtape(dev)) { 2377 un->un_laststate = un->un_state; 2378 un->un_state = ST_STATE_CLOSED; 2379 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2380 "st_open : EIO can't open tape\n"); 2381 rval = EIO; 2382 goto exit; 2383 } 2384 2385 /* 2386 * do a mode sense to pick up state of current write-protect, 2387 */ 2388 (void) st_modesense(un); 2389 2390 /* 2391 * If we are opening the tape for writing, check 2392 * to make sure that the tape can be written. 2393 */ 2394 if (un->un_oflags & FWRITE) { 2395 err = 0; 2396 if (un->un_mspl->wp) { 2397 un->un_status = KEY_WRITE_PROTECT; 2398 un->un_laststate = un->un_state; 2399 un->un_state = ST_STATE_CLOSED; 2400 rval = EACCES; 2401 goto exit; 2402 } else { 2403 un->un_read_only = 0; 2404 } 2405 } else { 2406 un->un_read_only = 1; 2407 } 2408 2409 /* 2410 * If we're opening the tape write-only, we need to 2411 * write 2 filemarks on the HP 1/2 inch drive, to 2412 * create a null file. 2413 */ 2414 if ((un->un_oflags == FWRITE) && (un->un_dp->options & ST_REEL)) { 2415 un->un_fmneeded = 2; 2416 } else if (un->un_oflags == FWRITE) { 2417 un->un_fmneeded = 1; 2418 } else { 2419 un->un_fmneeded = 0; 2420 } 2421 2422 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 2423 "fmneeded = %x\n", un->un_fmneeded); 2424 2425 /* 2426 * Make sure the density can be selected correctly. 2427 */ 2428 if (st_determine_density(dev, B_WRITE)) { 2429 un->un_status = KEY_ILLEGAL_REQUEST; 2430 un->un_laststate = un->un_state; 2431 un->un_state = ST_STATE_CLOSED; 2432 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 2433 "st_open: EIO can't determine density\n"); 2434 rval = EIO; 2435 goto exit; 2436 } 2437 2438 /* 2439 * Destroy the knowledge that we have 'determined' 2440 * density so that a later read at BOT comes along 2441 * does the right density determination. 2442 */ 2443 2444 un->un_density_known = 0; 2445 2446 2447 /* 2448 * Okay, the tape is loaded and either at BOT or somewhere past. 2449 * Mark the state such that any I/O or tape space operations 2450 * will get/set the right density, etc.. 2451 */ 2452 un->un_laststate = un->un_state; 2453 un->un_lastop = ST_OP_NIL; 2454 un->un_mediastate = MTIO_INSERTED; 2455 cv_broadcast(&un->un_state_cv); 2456 2457 /* 2458 * Set test append flag if writing. 2459 * First write must check that tape is positioned correctly. 2460 */ 2461 un->un_test_append = (un->un_oflags & FWRITE); 2462 2463 exit: 2464 un->un_err_resid = 0; 2465 un->un_last_resid = 0; 2466 un->un_last_count = 0; 2467 2468 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 2469 "st_tape_init: return val = %x\n", rval); 2470 return (rval); 2471 2472 } 2473 2474 2475 2476 /* ARGSUSED */ 2477 static int 2478 st_close(dev_t dev, int flag, int otyp, cred_t *cred_p) 2479 { 2480 int err = 0; 2481 int norew, count, last_state; 2482 #if defined(__i386) || defined(__amd64) 2483 struct contig_mem *cp, *cp_temp; 2484 #endif 2485 2486 GET_SOFT_STATE(dev); 2487 2488 /* 2489 * wait till all cmds in the pipeline have been completed 2490 */ 2491 mutex_enter(ST_MUTEX); 2492 2493 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2494 "st_close(dev = 0x%lx, flag = %d, otyp = %d)\n", dev, flag, otyp); 2495 2496 st_wait_for_io(un); 2497 2498 /* turn off persistent errors on close, as we want close to succeed */ 2499 TURN_PE_OFF(un); 2500 2501 /* 2502 * set state to indicate that we are in process of closing 2503 */ 2504 last_state = un->un_laststate = un->un_state; 2505 un->un_state = ST_STATE_CLOSING; 2506 2507 /* 2508 * BSD behavior: 2509 * a close always causes a silent span to the next file if we've hit 2510 * an EOF (but not yet read across it). 2511 */ 2512 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 2513 "st_close1: fileno=%x, blkno=%lx, un_eof=%x\n", un->un_fileno, 2514 un->un_blkno, un->un_eof); 2515 2516 2517 if (BSD_BEHAVIOR && (un->un_eof == ST_EOF)) { 2518 if (un->un_fileno >= 0) { 2519 un->un_fileno++; 2520 un->un_blkno = 0; 2521 } 2522 un->un_eof = ST_NO_EOF; 2523 } 2524 2525 /* 2526 * rewinding? 2527 */ 2528 norew = (getminor(dev) & MT_NOREWIND); 2529 2530 /* 2531 * SVR4 behavior for skipping to next file: 2532 * 2533 * If we have not seen a filemark, space to the next file 2534 * 2535 * If we have already seen the filemark we are physically in the next 2536 * file and we only increment the filenumber 2537 */ 2538 2539 if (norew && SVR4_BEHAVIOR && (flag & FREAD) && (un->un_blkno != 0) && 2540 (un->un_lastop != ST_OP_WRITE)) { 2541 switch (un->un_eof) { 2542 case ST_NO_EOF: 2543 /* 2544 * if we were reading and did not read the complete file 2545 * skip to the next file, leaving the tape correctly 2546 * positioned to read the first record of the next file 2547 * Check first for REEL if we are at EOT by trying to 2548 * read a block 2549 */ 2550 if ((un->un_dp->options & ST_REEL) && 2551 (!(un->un_dp->options & ST_READ_IGNORE_EOFS)) && 2552 (un->un_blkno == 0)) { 2553 if (st_cmd(dev, SCMD_SPACE, Blk(1), SYNC_CMD)) { 2554 ST_DEBUG2(ST_DEVINFO, st_label, 2555 SCSI_DEBUG, 2556 "st_close : EIO can't space\n"); 2557 err = EIO; 2558 break; 2559 } 2560 if (un->un_eof >= ST_EOF_PENDING) { 2561 un->un_eof = ST_EOT_PENDING; 2562 un->un_fileno += 1; 2563 un->un_blkno = 0; 2564 break; 2565 } 2566 } 2567 if (st_cmd(dev, SCMD_SPACE, Fmk(1), SYNC_CMD)) { 2568 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2569 "st_close: EIO can't space #2\n"); 2570 err = EIO; 2571 } else { 2572 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 2573 "st_close2: fileno=%x,blkno=%lx," 2574 "un_eof=%x\n", 2575 un->un_fileno, un->un_blkno, un->un_eof); 2576 un->un_eof = ST_NO_EOF; 2577 } 2578 break; 2579 2580 case ST_EOF_PENDING: 2581 case ST_EOF: 2582 un->un_fileno += 1; 2583 un->un_blkno = 0; 2584 un->un_eof = ST_NO_EOF; 2585 break; 2586 2587 case ST_EOT: 2588 case ST_EOT_PENDING: 2589 /* nothing to do */ 2590 break; 2591 } 2592 } 2593 2594 2595 /* 2596 * For performance reasons (HP 88780), the driver should 2597 * postpone writing the second tape mark until just before a file 2598 * positioning ioctl is issued (e.g., rewind). This means that 2599 * the user must not manually rewind the tape because the tape will 2600 * be missing the second tape mark which marks EOM. 2601 * However, this small performance improvement is not worth the risk. 2602 */ 2603 2604 /* 2605 * We need to back up over the filemark we inadvertently popped 2606 * over doing a read in between the two filemarks that constitute 2607 * logical eot for 1/2" tapes. Note that ST_EOT_PENDING is only 2608 * set while reading. 2609 * 2610 * If we happen to be at physical eot (ST_EOM) (writing case), 2611 * the writing of filemark(s) will clear the ST_EOM state, which 2612 * we don't want, so we save this state and restore it later. 2613 */ 2614 2615 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 2616 "flag=%x, fmneeded=%x, lastop=%x, eof=%x\n", 2617 flag, un->un_fmneeded, un->un_lastop, un->un_eof); 2618 2619 if (un->un_eof == ST_EOT_PENDING) { 2620 if (norew) { 2621 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), SYNC_CMD)) { 2622 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2623 "st_close: EIO can't space #3\n"); 2624 err = EIO; 2625 } else { 2626 un->un_blkno = 0; 2627 un->un_eof = ST_EOT; 2628 } 2629 } else { 2630 un->un_eof = ST_NO_EOF; 2631 } 2632 2633 /* 2634 * Do we need to write a file mark? 2635 * 2636 * only write filemarks if there are fmks to be written and 2637 * - open for write (possibly read/write) 2638 * - the last operation was a write 2639 * or: 2640 * - opened for wronly 2641 * - no data was written 2642 */ 2643 } else if ((un->un_fileno >= 0) && (un->un_fmneeded > 0) && 2644 (((flag & FWRITE) && (un->un_lastop == ST_OP_WRITE)) || 2645 ((flag & FWRITE) && (un->un_lastop == ST_OP_WEOF)) || 2646 ((flag == FWRITE) && (un->un_lastop == ST_OP_NIL)))) { 2647 2648 /* save ST_EOM state */ 2649 int was_at_eom = (un->un_eof == ST_EOM) ? 1 : 0; 2650 2651 /* 2652 * Note that we will write a filemark if we had opened 2653 * the tape write only and no data was written, thus 2654 * creating a null file. 2655 * 2656 * If the user already wrote one, we only have to write 1 more. 2657 * If they wrote two, we don't have to write any. 2658 */ 2659 2660 count = un->un_fmneeded; 2661 if (count > 0) { 2662 if (st_cmd(dev, SCMD_WRITE_FILE_MARK, 2663 count, SYNC_CMD)) { 2664 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2665 "st_close : EIO can't wfm\n"); 2666 err = EIO; 2667 } 2668 if ((un->un_dp->options & ST_REEL) && norew) { 2669 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), 2670 SYNC_CMD)) { 2671 ST_DEBUG2(ST_DEVINFO, st_label, 2672 SCSI_DEBUG, 2673 "st_close : EIO space fmk(-1)\n"); 2674 err = EIO; 2675 } 2676 un->un_eof = ST_NO_EOF; 2677 /* fix up block number */ 2678 un->un_blkno = 0; 2679 } 2680 } 2681 2682 /* 2683 * If we aren't going to be rewinding, and we were at 2684 * physical eot, restore the state that indicates we 2685 * are at physical eot. Once you have reached physical 2686 * eot, and you close the tape, the only thing you can 2687 * do on the next open is to rewind. Access to trailer 2688 * records is only allowed without closing the device. 2689 */ 2690 if (norew == 0 && was_at_eom) 2691 un->un_eof = ST_EOM; 2692 } 2693 2694 /* 2695 * report soft errors if enabled and available, if we never accessed 2696 * the drive, don't get errors. This will prevent some DAT error 2697 * messages upon LOG SENSE. 2698 */ 2699 if (st_report_soft_errors_on_close && 2700 (un->un_dp->options & ST_SOFT_ERROR_REPORTING) && 2701 (last_state != ST_STATE_OFFLINE)) { 2702 /* 2703 * Make sure we have reserve the tape unit. 2704 * This is the case when we do a O_NDELAY open and 2705 * then do a close without any I/O. 2706 */ 2707 if (!(un->un_rsvd_status & ST_INIT_RESERVE) && 2708 ST_RESERVE_SUPPORTED(un)) { 2709 if ((err = st_tape_reservation_init(dev))) { 2710 goto error; 2711 } 2712 } 2713 (void) st_report_soft_errors(dev, flag); 2714 } 2715 2716 2717 /* 2718 * Do we need to rewind? Can we rewind? 2719 */ 2720 if (norew == 0 && un->un_fileno >= 0 && err == 0) { 2721 /* 2722 * We'd like to rewind with the 2723 * 'immediate' bit set, but this 2724 * causes problems on some drives 2725 * where subsequent opens get a 2726 * 'NOT READY' error condition 2727 * back while the tape is rewinding, 2728 * which is impossible to distinguish 2729 * from the condition of 'no tape loaded'. 2730 * 2731 * Also, for some targets, if you disconnect 2732 * with the 'immediate' bit set, you don't 2733 * actually return right away, i.e., the 2734 * target ignores your request for immediate 2735 * return. 2736 * 2737 * Instead, we'll fire off an async rewind 2738 * command. We'll mark the device as closed, 2739 * and any subsequent open will stall on 2740 * the first TEST_UNIT_READY until the rewind 2741 * completes. 2742 * 2743 */ 2744 if (!(un->un_rsvd_status & ST_INIT_RESERVE) && 2745 ST_RESERVE_SUPPORTED(un)) { 2746 if ((err = st_tape_reservation_init(dev))) { 2747 goto error; 2748 } 2749 } 2750 if (ST_RESERVE_SUPPORTED(un)) { 2751 (void) st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD); 2752 } else { 2753 (void) st_cmd(dev, SCMD_REWIND, 0, ASYNC_CMD); 2754 } 2755 } 2756 2757 /* 2758 * eject tape if necessary 2759 */ 2760 if (un->un_eject_tape_on_failure) { 2761 un->un_eject_tape_on_failure = 0; 2762 if (st_cmd(dev, SCMD_LOAD, 0, SYNC_CMD)) { 2763 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2764 "st_close : can't unload tape\n"); 2765 } else { 2766 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 2767 "st_close : tape unloaded \n"); 2768 un->un_eof = ST_NO_EOF; 2769 un->un_mediastate = MTIO_EJECTED; 2770 } 2771 } 2772 /* 2773 * Release the tape unit, if default reserve/release 2774 * behaviour. 2775 */ 2776 if (ST_RESERVE_SUPPORTED(un) && 2777 !(un->un_rsvd_status & ST_PRESERVE_RESERVE) && 2778 (un->un_rsvd_status & ST_INIT_RESERVE)) { 2779 (void) st_reserve_release(dev, ST_RELEASE); 2780 } 2781 2782 error: 2783 /* 2784 * clear up state 2785 */ 2786 un->un_laststate = un->un_state; 2787 un->un_state = ST_STATE_CLOSED; 2788 un->un_lastop = ST_OP_NIL; 2789 un->un_throttle = 1; /* assume one request at time, for now */ 2790 un->un_retry_ct = 0; 2791 un->un_tran_retry_ct = 0; 2792 un->un_errno = 0; 2793 un->un_swr_token = (opaque_t)NULL; 2794 un->un_rsvd_status &= ~(ST_INIT_RESERVE); 2795 2796 /* Restore the options to the init time settings */ 2797 if (un->un_init_options & ST_READ_IGNORE_ILI) { 2798 un->un_dp->options |= ST_READ_IGNORE_ILI; 2799 } else { 2800 un->un_dp->options &= ~ST_READ_IGNORE_ILI; 2801 } 2802 2803 if (un->un_init_options & ST_READ_IGNORE_EOFS) { 2804 un->un_dp->options |= ST_READ_IGNORE_EOFS; 2805 } else { 2806 un->un_dp->options &= ~ST_READ_IGNORE_EOFS; 2807 } 2808 2809 if (un->un_init_options & ST_SHORT_FILEMARKS) { 2810 un->un_dp->options |= ST_SHORT_FILEMARKS; 2811 } else { 2812 un->un_dp->options &= ~ST_SHORT_FILEMARKS; 2813 } 2814 2815 ASSERT(mutex_owned(ST_MUTEX)); 2816 2817 /* 2818 * Signal anyone awaiting a close operation to complete. 2819 */ 2820 cv_signal(&un->un_clscv); 2821 2822 /* 2823 * any kind of error on closing causes all state to be tossed 2824 */ 2825 if (err && un->un_status != KEY_ILLEGAL_REQUEST) { 2826 un->un_density_known = 0; 2827 /* 2828 * note that st_intr has already set un_fileno to -1 2829 */ 2830 } 2831 2832 #if defined(__i386) || defined(__amd64) 2833 /* 2834 * free any contiguous mem alloc'ed for big block I/O 2835 */ 2836 cp = un->un_contig_mem; 2837 while (cp) { 2838 if (cp->cm_addr) { 2839 ddi_dma_mem_free(&cp->cm_acc_hdl); 2840 } 2841 cp_temp = cp; 2842 cp = cp->cm_next; 2843 kmem_free(cp_temp, 2844 sizeof (struct contig_mem) + biosize()); 2845 } 2846 un->un_contig_mem_total_num = 0; 2847 un->un_contig_mem_available_num = 0; 2848 un->un_contig_mem = NULL; 2849 un->un_max_contig_mem_len = 0; 2850 #endif 2851 2852 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 2853 "st_close3: return val = %x, fileno=%x, blkno=%lx, un_eof=%x\n", 2854 err, un->un_fileno, un->un_blkno, un->un_eof); 2855 2856 mutex_exit(ST_MUTEX); 2857 return (err); 2858 } 2859 2860 /* 2861 * These routines perform raw i/o operations. 2862 */ 2863 2864 /* ARGSUSED2 */ 2865 static int 2866 st_aread(dev_t dev, struct aio_req *aio, cred_t *cred_p) 2867 { 2868 return (st_arw(dev, aio, B_READ)); 2869 } 2870 2871 2872 /* ARGSUSED2 */ 2873 static int 2874 st_awrite(dev_t dev, struct aio_req *aio, cred_t *cred_p) 2875 { 2876 return (st_arw(dev, aio, B_WRITE)); 2877 } 2878 2879 2880 2881 /* ARGSUSED */ 2882 static int 2883 st_read(dev_t dev, struct uio *uiop, cred_t *cred_p) 2884 { 2885 return (st_rw(dev, uiop, B_READ)); 2886 } 2887 2888 /* ARGSUSED */ 2889 static int 2890 st_write(dev_t dev, struct uio *uiop, cred_t *cred_p) 2891 { 2892 return (st_rw(dev, uiop, B_WRITE)); 2893 } 2894 2895 /* 2896 * Due to historical reasons, old limits are: For variable-length devices: 2897 * if greater than 64KB - 1 (ST_MAXRECSIZE_VARIABLE), block into 64 KB - 2 2898 * ST_MAXRECSIZE_VARIABLE_LIMIT) requests; otherwise, 2899 * (let it through unmodified. For fixed-length record devices: 2900 * 63K (ST_MAXRECSIZE_FIXED) is max (default minphys). 2901 * 2902 * The new limits used are un_maxdma (retrieved using scsi_ifgetcap() 2903 * from the HBA) and un_maxbsize (retrieved by sending SCMD_READ_BLKLIM 2904 * command to the drive). 2905 * 2906 */ 2907 static void 2908 st_minphys(struct buf *bp) 2909 { 2910 struct scsi_tape *un; 2911 2912 #if !defined(lint) 2913 _NOTE(SCHEME_PROTECTS_DATA("stable data", scsi_tape::un_sd)); 2914 #endif 2915 2916 un = ddi_get_soft_state(st_state, MTUNIT(bp->b_edev)); 2917 2918 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2919 "st_minphys(bp = 0x%p): b_bcount = 0x%lx\n", (void *)bp, 2920 bp->b_bcount); 2921 2922 if (un->un_allow_large_xfer) { 2923 2924 /* 2925 * check un_maxbsize for variable length devices only 2926 */ 2927 if (un->un_bsize == 0 && bp->b_bcount > un->un_maxbsize) { 2928 bp->b_bcount = un->un_maxbsize; 2929 } 2930 /* 2931 * can't go more that HBA maxdma limit in either fixed-length 2932 * or variable-length tape drives. 2933 */ 2934 if (bp->b_bcount > un->un_maxdma) { 2935 bp->b_bcount = un->un_maxdma; 2936 } 2937 } else { 2938 2939 /* 2940 * use old fixed limits 2941 */ 2942 if (un->un_bsize == 0) { 2943 if (bp->b_bcount > ST_MAXRECSIZE_VARIABLE) { 2944 bp->b_bcount = ST_MAXRECSIZE_VARIABLE_LIMIT; 2945 } 2946 } else { 2947 if (bp->b_bcount > ST_MAXRECSIZE_FIXED) { 2948 bp->b_bcount = ST_MAXRECSIZE_FIXED; 2949 } 2950 } 2951 } 2952 2953 #if !defined(lint) 2954 _NOTE(DATA_READABLE_WITHOUT_LOCK(scsi_tape::un_sbufp)); 2955 #endif /* lint */ 2956 /* 2957 * For regular raw I/O and Fixed Block length devices, make sure 2958 * the adjusted block count is a whole multiple of the device 2959 * block size. 2960 */ 2961 if (bp != un->un_sbufp && un->un_bsize) { 2962 bp->b_bcount -= (bp->b_bcount % un->un_bsize); 2963 } 2964 } 2965 2966 /*ARGSUSED*/ 2967 static void 2968 st_uscsi_minphys(struct buf *bp) 2969 { 2970 /* 2971 * do not break up because the CDB count would then be 2972 * incorrect and create spurious data underrun errors. 2973 */ 2974 } 2975 2976 static int 2977 st_rw(dev_t dev, struct uio *uio, int flag) 2978 { 2979 int rval = 0; 2980 long len; 2981 2982 GET_SOFT_STATE(dev); 2983 2984 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 2985 "st_rw(dev = 0x%lx, flag = %s)\n", dev, 2986 (flag == B_READ ? rd_str: wr_str)); 2987 2988 /* get local copy of transfer length */ 2989 len = uio->uio_iov->iov_len; 2990 2991 mutex_enter(ST_MUTEX); 2992 2993 /* 2994 * If in fixed block size mode and requested read or write 2995 * is not an even multiple of that block size. 2996 */ 2997 if ((un->un_bsize != 0) && (len % un->un_bsize != 0)) { 2998 scsi_log(ST_DEVINFO, st_label, CE_WARN, 2999 "%s: not modulo %d block size\n", 3000 (flag == B_WRITE) ? wr_str : rd_str, un->un_bsize); 3001 rval = EINVAL; 3002 } 3003 3004 /* If device has set granularity in the READ_BLKLIM we honor it. */ 3005 if ((un->un_data_mod != 0) && (len % un->un_data_mod != 0)) { 3006 scsi_log(ST_DEVINFO, st_label, CE_WARN, 3007 "%s: not modulo %d device granularity\n", 3008 (flag == B_WRITE) ? wr_str : rd_str, un->un_data_mod); 3009 rval = EINVAL; 3010 } 3011 3012 if (rval != 0) { 3013 un->un_errno = rval; 3014 mutex_exit(ST_MUTEX); 3015 return (rval); 3016 } 3017 3018 un->un_silent_skip = 0; 3019 mutex_exit(ST_MUTEX); 3020 3021 len = uio->uio_resid; 3022 3023 rval = physio(st_strategy, (struct buf *)NULL, 3024 dev, flag, st_minphys, uio); 3025 /* 3026 * if we have hit logical EOT during this xfer and there is not a 3027 * full residue, then set un_eof back to ST_EOM to make sure that 3028 * the user will see at least one zero write 3029 * after this short write 3030 */ 3031 mutex_enter(ST_MUTEX); 3032 if (un->un_eof > ST_NO_EOF) { 3033 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3034 "un_eof=%d resid=%lx\n", un->un_eof, uio->uio_resid); 3035 } 3036 if (un->un_eof >= ST_EOM && (flag == B_WRITE)) { 3037 if ((uio->uio_resid != len) && (uio->uio_resid != 0)) { 3038 un->un_eof = ST_EOM; 3039 } else if (uio->uio_resid == len) { 3040 un->un_eof = ST_NO_EOF; 3041 } 3042 } 3043 3044 if (un->un_silent_skip && uio->uio_resid != len) { 3045 un->un_eof = ST_EOF; 3046 un->un_blkno = un->un_save_blkno; 3047 un->un_fileno--; 3048 } 3049 3050 un->un_errno = rval; 3051 3052 mutex_exit(ST_MUTEX); 3053 3054 return (rval); 3055 } 3056 3057 static int 3058 st_arw(dev_t dev, struct aio_req *aio, int flag) 3059 { 3060 struct uio *uio = aio->aio_uio; 3061 int rval = 0; 3062 long len; 3063 3064 GET_SOFT_STATE(dev); 3065 3066 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3067 "st_rw(dev = 0x%lx, flag = %s)\n", dev, 3068 (flag == B_READ ? rd_str: wr_str)); 3069 3070 /* get local copy of transfer length */ 3071 len = uio->uio_iov->iov_len; 3072 3073 mutex_enter(ST_MUTEX); 3074 3075 /* 3076 * If in fixed block size mode and requested read or write 3077 * is not an even multiple of that block size. 3078 */ 3079 if ((un->un_bsize != 0) && (len % un->un_bsize != 0)) { 3080 scsi_log(ST_DEVINFO, st_label, CE_WARN, 3081 "%s: not modulo %d block size\n", 3082 (flag == B_WRITE) ? wr_str : rd_str, un->un_bsize); 3083 rval = EINVAL; 3084 } 3085 3086 /* If device has set granularity in the READ_BLKLIM we honor it. */ 3087 if ((un->un_data_mod != 0) && (len % un->un_data_mod != 0)) { 3088 scsi_log(ST_DEVINFO, st_label, CE_WARN, 3089 "%s: not modulo %d device granularity\n", 3090 (flag == B_WRITE) ? wr_str : rd_str, un->un_data_mod); 3091 rval = EINVAL; 3092 } 3093 3094 if (rval != 0) { 3095 un->un_errno = rval; 3096 mutex_exit(ST_MUTEX); 3097 return (rval); 3098 } 3099 3100 mutex_exit(ST_MUTEX); 3101 3102 len = uio->uio_resid; 3103 3104 rval = aphysio(st_strategy, anocancel, dev, flag, st_minphys, aio); 3105 3106 /* 3107 * if we have hit logical EOT during this xfer and there is not a 3108 * full residue, then set un_eof back to ST_EOM to make sure that 3109 * the user will see at least one zero write 3110 * after this short write 3111 * 3112 * we keep this here just in case the application is not using 3113 * persistent errors 3114 */ 3115 mutex_enter(ST_MUTEX); 3116 if (un->un_eof > ST_NO_EOF) { 3117 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3118 "un_eof=%d resid=%lx\n", un->un_eof, uio->uio_resid); 3119 } 3120 if (un->un_eof >= ST_EOM && (flag == B_WRITE)) { 3121 if ((uio->uio_resid != len) && (uio->uio_resid != 0)) { 3122 un->un_eof = ST_EOM; 3123 } else if (uio->uio_resid == len && !IS_PE_FLAG_SET(un)) { 3124 un->un_eof = ST_NO_EOF; 3125 } 3126 } 3127 un->un_errno = rval; 3128 mutex_exit(ST_MUTEX); 3129 3130 return (rval); 3131 } 3132 3133 3134 3135 static int 3136 st_strategy(struct buf *bp) 3137 { 3138 struct scsi_tape *un; 3139 dev_t dev = bp->b_edev; 3140 3141 /* 3142 * validate arguments 3143 */ 3144 if ((un = ddi_get_soft_state(st_state, MTUNIT(bp->b_edev))) == NULL) { 3145 bp->b_resid = bp->b_bcount; 3146 mutex_enter(ST_MUTEX); 3147 st_bioerror(bp, ENXIO); 3148 mutex_exit(ST_MUTEX); 3149 goto error; 3150 } 3151 3152 mutex_enter(ST_MUTEX); 3153 3154 while (un->un_pwr_mgmt == ST_PWR_SUSPENDED) { 3155 cv_wait(&un->un_suspend_cv, ST_MUTEX); 3156 } 3157 3158 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3159 "st_strategy(): bcount=0x%lx, fileno=%d, blkno=%lx, eof=%d\n", 3160 bp->b_bcount, un->un_fileno, un->un_blkno, un->un_eof); 3161 3162 /* 3163 * If persistent errors have been flagged, just nix this one. We wait 3164 * for any outstanding I/O's below, so we will be in order. 3165 */ 3166 if (IS_PE_FLAG_SET(un)) 3167 goto exit; 3168 3169 if (bp != un->un_sbufp) { 3170 char reading = bp->b_flags & B_READ; 3171 int wasopening = 0; 3172 3173 /* 3174 * If we haven't done/checked reservation on the tape unit 3175 * do it now. 3176 */ 3177 if (!(un->un_rsvd_status & ST_INIT_RESERVE)) { 3178 if (ST_RESERVE_SUPPORTED(un)) { 3179 if (st_tape_reservation_init(dev)) { 3180 st_bioerror(bp, un->un_errno); 3181 goto exit; 3182 } 3183 } else if (un->un_state == ST_STATE_OPEN_PENDING_IO) { 3184 /* 3185 * Enter here to restore position for possible 3186 * resets when the device was closed and opened 3187 * in O_NDELAY mode subsequently 3188 */ 3189 un->un_state = ST_STATE_INITIALIZING; 3190 (void) st_cmd(dev, SCMD_TEST_UNIT_READY, 3191 0, SYNC_CMD); 3192 un->un_state = ST_STATE_OPEN_PENDING_IO; 3193 } 3194 un->un_rsvd_status |= ST_INIT_RESERVE; 3195 } 3196 3197 /* 3198 * If we are offline, we have to initialize everything first. 3199 * This is to handle either when opened with O_NDELAY, or 3200 * we just got a new tape in the drive, after an offline. 3201 * We don't observe O_NDELAY past the open, 3202 * as it will not make sense for tapes. 3203 */ 3204 if (un->un_state == ST_STATE_OFFLINE || un->un_restore_pos) { 3205 /* reset state to avoid recursion */ 3206 un->un_state = ST_STATE_INITIALIZING; 3207 if (st_tape_init(dev)) { 3208 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3209 "stioctl : OFFLINE init failure "); 3210 un->un_state = ST_STATE_OFFLINE; 3211 un->un_fileno = -1; 3212 goto b_done_err; 3213 } 3214 un->un_state = ST_STATE_OPEN_PENDING_IO; 3215 } 3216 /* 3217 * Check for legal operations 3218 */ 3219 if (un->un_fileno < 0) { 3220 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3221 "strategy with un->un_fileno < 0\n"); 3222 goto b_done_err; 3223 } 3224 3225 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3226 "st_strategy(): regular io\n"); 3227 3228 /* 3229 * Process this first. If we were reading, and we're pending 3230 * logical eot, that means we've bumped one file mark too far. 3231 */ 3232 3233 /* 3234 * Recursion warning: st_cmd will route back through here. 3235 */ 3236 if (un->un_eof == ST_EOT_PENDING) { 3237 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), SYNC_CMD)) { 3238 un->un_fileno = -1; 3239 un->un_density_known = 0; 3240 goto b_done_err; 3241 } 3242 un->un_blkno = 0; /* fix up block number.. */ 3243 un->un_eof = ST_EOT; 3244 } 3245 3246 /* 3247 * If we are in the process of opening, we may have to 3248 * determine/set the correct density. We also may have 3249 * to do a test_append (if QIC) to see whether we are 3250 * in a position to append to the end of the tape. 3251 * 3252 * If we're already at logical eot, we transition 3253 * to ST_NO_EOF. If we're at physical eot, we punt 3254 * to the switch statement below to handle. 3255 */ 3256 if ((un->un_state == ST_STATE_OPEN_PENDING_IO) || 3257 (un->un_test_append && (un->un_dp->options & ST_QIC))) { 3258 3259 if (un->un_state == ST_STATE_OPEN_PENDING_IO) { 3260 if (st_determine_density(dev, (int)reading)) { 3261 goto b_done_err; 3262 } 3263 } 3264 3265 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3266 "pending_io@fileno %d rw %d qic %d eof %d\n", 3267 un->un_fileno, (int)reading, 3268 (un->un_dp->options & ST_QIC) ? 1 : 0, 3269 un->un_eof); 3270 3271 if (!reading && un->un_eof != ST_EOM) { 3272 if (un->un_eof == ST_EOT) { 3273 un->un_eof = ST_NO_EOF; 3274 } else if (un->un_fileno > 0 && 3275 (un->un_dp->options & ST_QIC)) { 3276 /* 3277 * st_test_append() will do it all 3278 */ 3279 st_test_append(bp); 3280 goto done; 3281 } 3282 } 3283 if (un->un_state == ST_STATE_OPEN_PENDING_IO) { 3284 wasopening = 1; 3285 } 3286 un->un_laststate = un->un_state; 3287 un->un_state = ST_STATE_OPEN; 3288 } 3289 3290 3291 /* 3292 * Process rest of END OF FILE and END OF TAPE conditions 3293 */ 3294 3295 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3296 "un_eof=%x, wasopening=%x\n", 3297 un->un_eof, wasopening); 3298 3299 switch (un->un_eof) { 3300 case ST_EOM: 3301 /* 3302 * This allows writes to proceed past physical 3303 * eot. We'll *really* be in trouble if the 3304 * user continues blindly writing data too 3305 * much past this point (unwind the tape). 3306 * Physical eot really means 'early warning 3307 * eot' in this context. 3308 * 3309 * Every other write from now on will succeed 3310 * (if sufficient tape left). 3311 * This write will return with resid == count 3312 * but the next one should be successful 3313 * 3314 * Note that we only transition to logical EOT 3315 * if the last state wasn't the OPENING state. 3316 * We explicitly prohibit running up to physical 3317 * eot, closing the device, and then re-opening 3318 * to proceed. Trailer records may only be gotten 3319 * at by keeping the tape open after hitting eot. 3320 * 3321 * Also note that ST_EOM cannot be set by reading- 3322 * this can only be set during writing. Reading 3323 * up to the end of the tape gets a blank check 3324 * or a double-filemark indication (ST_EOT_PENDING), 3325 * and we prohibit reading after that point. 3326 * 3327 */ 3328 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "EOM\n"); 3329 if (wasopening == 0) { 3330 /* 3331 * this allows st_rw() to reset it back to 3332 * ST_EOM to make sure that the application 3333 * will see a zero write 3334 */ 3335 un->un_eof = ST_WRITE_AFTER_EOM; 3336 } 3337 un->un_status = SUN_KEY_EOT; 3338 goto b_done; 3339 3340 case ST_WRITE_AFTER_EOM: 3341 case ST_EOT: 3342 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "EOT\n"); 3343 un->un_status = SUN_KEY_EOT; 3344 if (SVR4_BEHAVIOR && reading) { 3345 goto b_done_err; 3346 } 3347 3348 if (reading) { 3349 goto b_done; 3350 } 3351 un->un_eof = ST_NO_EOF; 3352 break; 3353 3354 case ST_EOF_PENDING: 3355 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3356 "EOF PENDING\n"); 3357 un->un_status = SUN_KEY_EOF; 3358 if (SVR4_BEHAVIOR) { 3359 un->un_eof = ST_EOF; 3360 goto b_done; 3361 } 3362 /* FALLTHROUGH */ 3363 case ST_EOF: 3364 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "EOF\n"); 3365 un->un_status = SUN_KEY_EOF; 3366 if (SVR4_BEHAVIOR) { 3367 goto b_done_err; 3368 } 3369 3370 if (BSD_BEHAVIOR) { 3371 un->un_eof = ST_NO_EOF; 3372 un->un_fileno += 1; 3373 un->un_blkno = 0; 3374 } 3375 3376 if (reading) { 3377 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3378 "now file %d (read)\n", 3379 un->un_fileno); 3380 goto b_done; 3381 } 3382 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3383 "now file %d (write)\n", un->un_fileno); 3384 break; 3385 default: 3386 un->un_status = 0; 3387 break; 3388 } 3389 } 3390 3391 bp->b_flags &= ~(B_DONE); 3392 st_bioerror(bp, 0); 3393 bp->av_forw = NULL; 3394 bp->b_resid = 0; 3395 SET_BP_PKT(bp, 0); 3396 3397 3398 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3399 "st_strategy: cmd=0x%p count=%ld resid=%ld flags=0x%x" 3400 " pkt=0x%p\n", 3401 (void *)bp->b_forw, bp->b_bcount, 3402 bp->b_resid, bp->b_flags, (void *)BP_PKT(bp)); 3403 3404 #if defined(__i386) || defined(__amd64) 3405 /* 3406 * We will replace bp with a new bp that can do big blk xfer 3407 * if the requested xfer size is bigger than ST_BIGBLK_XFER 3408 * 3409 * Also, we need to make sure that we're handling real I/O 3410 * by checking group 0/1 SCSI I/O commands, if needed 3411 */ 3412 if (bp->b_bcount > ST_BIGBLK_XFER && 3413 (bp != un->un_sbufp || 3414 (uchar_t)(uintptr_t)bp->b_forw == SCMD_READ || 3415 (uchar_t)(uintptr_t)bp->b_forw == SCMD_READ_G1 || 3416 (uchar_t)(uintptr_t)bp->b_forw == SCMD_WRITE || 3417 (uchar_t)(uintptr_t)bp->b_forw == SCMD_WRITE_G1)) { 3418 mutex_exit(ST_MUTEX); 3419 bp = st_get_bigblk_bp(bp); 3420 mutex_enter(ST_MUTEX); 3421 } 3422 #endif 3423 3424 /* put on wait queue */ 3425 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3426 "st_strategy: un->un_quef = 0x%p, bp = 0x%p\n", 3427 (void *)un->un_quef, (void *)bp); 3428 3429 if (un->un_quef) { 3430 un->un_quel->b_actf = bp; 3431 } else { 3432 un->un_quef = bp; 3433 } 3434 un->un_quel = bp; 3435 3436 ST_DO_KSTATS(bp, kstat_waitq_enter); 3437 3438 st_start(un); 3439 3440 done: 3441 mutex_exit(ST_MUTEX); 3442 return (0); 3443 3444 3445 error: 3446 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3447 "st_strategy: error exit\n"); 3448 3449 biodone(bp); 3450 return (0); 3451 3452 b_done_err: 3453 st_bioerror(bp, EIO); 3454 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3455 "st_strategy : EIO b_done_err\n"); 3456 3457 b_done: 3458 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3459 "st_strategy: b_done\n"); 3460 3461 exit: 3462 /* 3463 * make sure no commands are outstanding or waiting before closing, 3464 * so we can guarantee order 3465 */ 3466 st_wait_for_io(un); 3467 un->un_err_resid = bp->b_resid = bp->b_bcount; 3468 3469 /* override errno here, if persistent errors were flagged */ 3470 if (IS_PE_FLAG_SET(un)) 3471 bioerror(bp, un->un_errno); 3472 3473 mutex_exit(ST_MUTEX); 3474 3475 biodone(bp); 3476 ASSERT(mutex_owned(ST_MUTEX) == 0); 3477 return (0); 3478 } 3479 3480 3481 3482 /* 3483 * this routine spaces forward over filemarks 3484 */ 3485 static int 3486 st_space_fmks(dev_t dev, int count) 3487 { 3488 int rval = 0; 3489 3490 GET_SOFT_STATE(dev); 3491 3492 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3493 "st_space_fmks(dev = 0x%lx, count = %d)\n", dev, count); 3494 3495 ASSERT(mutex_owned(ST_MUTEX)); 3496 3497 /* 3498 * the risk with doing only one space operation is that we 3499 * may accidentily jump in old data 3500 * the exabyte 8500 reading 8200 tapes cannot use KNOWS_EOD 3501 * because the 8200 does not append a marker; in order not to 3502 * sacrifice the fast file skip, we do a slow skip if the low 3503 * density device has been opened 3504 */ 3505 3506 if ((un->un_dp->options & ST_KNOWS_EOD) && 3507 !((un->un_dp->type == ST_TYPE_EXB8500 && MT_DENSITY(dev) == 0))) { 3508 if (st_cmd(dev, SCMD_SPACE, Fmk(count), SYNC_CMD)) { 3509 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3510 "space_fmks : EIO can't do space cmd #1\n"); 3511 rval = EIO; 3512 } 3513 } else { 3514 while (count > 0) { 3515 if (st_cmd(dev, SCMD_SPACE, Fmk(1), SYNC_CMD)) { 3516 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3517 "space_fmks : EIO can't do space cmd #2\n"); 3518 rval = EIO; 3519 break; 3520 } 3521 count -= 1; 3522 /* 3523 * read a block to see if we have reached 3524 * end of medium (double filemark for reel or 3525 * medium error for others) 3526 */ 3527 if (count > 0) { 3528 if (st_cmd(dev, SCMD_SPACE, Blk(1), 3529 SYNC_CMD)) { 3530 ST_DEBUG2(ST_DEVINFO, st_label, 3531 SCSI_DEBUG, 3532 "space_fmks : EIO can't do " 3533 "space cmd #3\n"); 3534 rval = EIO; 3535 break; 3536 } 3537 if ((un->un_eof >= ST_EOF_PENDING) && 3538 (un->un_dp->options & ST_REEL)) { 3539 un->un_status = SUN_KEY_EOT; 3540 ST_DEBUG2(ST_DEVINFO, st_label, 3541 SCSI_DEBUG, 3542 "space_fmks : EIO ST_REEL\n"); 3543 rval = EIO; 3544 break; 3545 } else if (IN_EOF(un)) { 3546 un->un_eof = ST_NO_EOF; 3547 un->un_fileno++; 3548 un->un_blkno = 0; 3549 count--; 3550 } else if (un->un_eof > ST_EOF) { 3551 ST_DEBUG2(ST_DEVINFO, st_label, 3552 SCSI_DEBUG, 3553 "space_fmks, EIO > ST_EOF\n"); 3554 rval = EIO; 3555 break; 3556 } 3557 3558 } 3559 } 3560 un->un_err_resid = count; 3561 un->un_err_fileno = un->un_fileno; 3562 un->un_err_blkno = un->un_blkno; 3563 } 3564 ASSERT(mutex_owned(ST_MUTEX)); 3565 return (rval); 3566 } 3567 3568 /* 3569 * this routine spaces to EOM 3570 * 3571 * it keeps track of the current filenumber and returns the filenumber after 3572 * the last successful space operation, we keep the number high because as 3573 * tapes are getting larger, the possibility of more and more files exist, 3574 * 0x100000 (1 Meg of files) probably will never have to be changed any time 3575 * soon 3576 */ 3577 #define MAX_SKIP 0x100000 /* somewhat arbitrary */ 3578 3579 static int 3580 st_find_eom(dev_t dev) 3581 { 3582 int count, savefile; 3583 struct scsi_tape *un; 3584 int instance; 3585 3586 instance = MTUNIT(dev); 3587 if ((un = ddi_get_soft_state(st_state, instance)) == NULL) 3588 return (-1); 3589 3590 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3591 "st_find_eom(dev = 0x%lx): fileno = %d\n", dev, un->un_fileno); 3592 3593 ASSERT(mutex_owned(ST_MUTEX)); 3594 3595 savefile = un->un_fileno; 3596 3597 /* 3598 * see if the drive is smart enough to do the skips in 3599 * one operation; 1/2" use two filemarks 3600 * the exabyte 8500 reading 8200 tapes cannot use KNOWS_EOD 3601 * because the 8200 does not append a marker; in order not to 3602 * sacrifice the fast file skip, we do a slow skip if the low 3603 * density device has been opened 3604 */ 3605 if ((un->un_dp->options & ST_KNOWS_EOD) && 3606 !((un->un_dp->type == ST_TYPE_EXB8500 && MT_DENSITY(dev) == 0))) { 3607 count = MAX_SKIP; 3608 } else { 3609 count = 1; 3610 } 3611 3612 while (st_cmd(dev, SCMD_SPACE, Fmk(count), SYNC_CMD) == 0) { 3613 3614 savefile = un->un_fileno; 3615 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3616 "count=%x, eof=%x, status=%x\n", count, un->un_eof, 3617 un->un_status); 3618 3619 /* 3620 * If we're not EOM smart, space a record 3621 * to see whether we're now in the slot between 3622 * the two sequential filemarks that logical 3623 * EOM consists of (REEL) or hit nowhere land 3624 * (8mm). 3625 */ 3626 if (count == 1) { 3627 /* 3628 * no fast skipping, check a record 3629 */ 3630 if (st_cmd(dev, SCMD_SPACE, Blk((1)), SYNC_CMD)) 3631 break; 3632 else if ((un->un_eof >= ST_EOF_PENDING) && 3633 (un->un_dp->options & ST_REEL)) { 3634 un->un_status = KEY_BLANK_CHECK; 3635 un->un_fileno++; 3636 un->un_blkno = 0; 3637 break; 3638 } else if (IN_EOF(un)) { 3639 un->un_eof = ST_NO_EOF; 3640 un->un_fileno++; 3641 un->un_blkno = 0; 3642 } else if (un->un_eof > ST_EOF) { 3643 break; 3644 } 3645 } else { 3646 if (un->un_eof > ST_EOF) { 3647 break; 3648 } 3649 } 3650 } 3651 3652 if (un->un_dp->options & ST_KNOWS_EOD) { 3653 savefile = un->un_fileno; 3654 } 3655 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 3656 "st_find_eom: %x\n", savefile); 3657 ASSERT(mutex_owned(ST_MUTEX)); 3658 return (savefile); 3659 } 3660 3661 3662 /* 3663 * this routine is frequently used in ioctls below; 3664 * it determines whether we know the density and if not will 3665 * determine it 3666 * if we have written the tape before, one or more filemarks are written 3667 * 3668 * depending on the stepflag, the head is repositioned to where it was before 3669 * the filemarks were written in order not to confuse step counts 3670 */ 3671 #define STEPBACK 0 3672 #define NO_STEPBACK 1 3673 3674 static int 3675 st_check_density_or_wfm(dev_t dev, int wfm, int mode, int stepflag) 3676 { 3677 3678 GET_SOFT_STATE(dev); 3679 3680 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3681 "st_check_density_or_wfm(dev= 0x%lx, wfm= %d, mode= %d, stpflg= %d)\n", 3682 dev, wfm, mode, stepflag); 3683 3684 ASSERT(mutex_owned(ST_MUTEX)); 3685 3686 /* 3687 * If we don't yet know the density of the tape we have inserted, 3688 * we have to either unconditionally set it (if we're 'writing'), 3689 * or we have to determine it. As side effects, check for any 3690 * write-protect errors, and for the need to put out any file-marks 3691 * before positioning a tape. 3692 * 3693 * If we are going to be spacing forward, and we haven't determined 3694 * the tape density yet, we have to do so now... 3695 */ 3696 if (un->un_state == ST_STATE_OPEN_PENDING_IO) { 3697 if (st_determine_density(dev, mode)) { 3698 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3699 "check_density_or_wfm : EIO can't determine " 3700 "density\n"); 3701 un->un_errno = EIO; 3702 return (EIO); 3703 } 3704 /* 3705 * Presumably we are at BOT. If we attempt to write, it will 3706 * either work okay, or bomb. We don't do a st_test_append 3707 * unless we're past BOT. 3708 */ 3709 un->un_laststate = un->un_state; 3710 un->un_state = ST_STATE_OPEN; 3711 3712 } else if (un->un_fileno >= 0 && un->un_fmneeded > 0 && 3713 ((un->un_lastop == ST_OP_WEOF && wfm) || 3714 (un->un_lastop == ST_OP_WRITE && wfm))) { 3715 3716 daddr_t blkno = un->un_blkno; 3717 int fileno = un->un_fileno; 3718 3719 /* 3720 * We need to write one or two filemarks. 3721 * In the case of the HP, we need to 3722 * position the head between the two 3723 * marks. 3724 */ 3725 if ((un->un_fmneeded > 0) || (un->un_lastop == ST_OP_WEOF)) { 3726 wfm = un->un_fmneeded; 3727 un->un_fmneeded = 0; 3728 } 3729 3730 if (st_write_fm(dev, wfm)) { 3731 un->un_fileno = -1; 3732 un->un_density_known = 0; 3733 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3734 "check_density_or_wfm : EIO can't write fm\n"); 3735 un->un_errno = EIO; 3736 return (EIO); 3737 } 3738 3739 if (stepflag == STEPBACK) { 3740 if (st_cmd(dev, SCMD_SPACE, Fmk((-wfm)), SYNC_CMD)) { 3741 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3742 "check_density_or_wfm : EIO can't space " 3743 "(-wfm)\n"); 3744 un->un_errno = EIO; 3745 return (EIO); 3746 } 3747 un->un_blkno = blkno; 3748 un->un_fileno = fileno; 3749 } 3750 } 3751 3752 /* 3753 * Whatever we do at this point clears the state of the eof flag. 3754 */ 3755 3756 un->un_eof = ST_NO_EOF; 3757 3758 /* 3759 * If writing, let's check that we're positioned correctly 3760 * at the end of tape before issuing the next write. 3761 */ 3762 if (!un->un_read_only) { 3763 un->un_test_append = 1; 3764 } 3765 3766 ASSERT(mutex_owned(ST_MUTEX)); 3767 return (0); 3768 } 3769 3770 3771 /* 3772 * Wait for all outstaning I/O's to complete 3773 * 3774 * we wait on both ncmds and the wait queue for times when we are flushing 3775 * after persistent errors are flagged, which is when ncmds can be 0, and the 3776 * queue can still have I/O's. This way we preserve order of biodone's. 3777 */ 3778 static void 3779 st_wait_for_io(struct scsi_tape *un) 3780 { 3781 ASSERT(mutex_owned(ST_MUTEX)); 3782 while (un->un_ncmds || un->un_quef) { 3783 cv_wait(&un->un_queue_cv, ST_MUTEX); 3784 } 3785 } 3786 3787 /* 3788 * This routine implements the ioctl calls. It is called 3789 * from the device switch at normal priority. 3790 */ 3791 /*ARGSUSED*/ 3792 static int 3793 st_ioctl(dev_t dev, int cmd, intptr_t arg, int flag, cred_t *cred_p, 3794 int *rval_p) 3795 { 3796 int tmp, rval = 0; 3797 3798 GET_SOFT_STATE(dev); 3799 3800 mutex_enter(ST_MUTEX); 3801 3802 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 3803 "st_ioctl(): fileno=%x, blkno=%lx, un_eof=%x, state = %d, " 3804 "pe_flag = %d\n", 3805 un->un_fileno, un->un_blkno, un->un_eof, un->un_state, 3806 IS_PE_FLAG_SET(un)); 3807 3808 /* 3809 * We don't want to block on these, so let them through 3810 * and we don't care about setting driver states here. 3811 */ 3812 if ((cmd == MTIOCGETDRIVETYPE) || 3813 (cmd == MTIOCGUARANTEEDORDER) || 3814 (cmd == MTIOCPERSISTENTSTATUS)) { 3815 goto check_commands; 3816 } 3817 3818 /* 3819 * wait for all outstanding commands to complete, or be dequeued. 3820 * And because ioctl's are synchronous commands, any return value 3821 * after this, will be in order 3822 */ 3823 st_wait_for_io(un); 3824 3825 /* 3826 * allow only a through clear errors and persistent status, and 3827 * status 3828 */ 3829 if (IS_PE_FLAG_SET(un)) { 3830 if ((cmd == MTIOCLRERR) || 3831 (cmd == MTIOCPERSISTENT) || 3832 (cmd == MTIOCGET) || 3833 (cmd == USCSIGETRQS)) { 3834 goto check_commands; 3835 } else { 3836 rval = un->un_errno; 3837 goto exit; 3838 } 3839 } 3840 3841 un->un_throttle = 1; /* > 1 will never happen here */ 3842 un->un_errno = 0; /* start clean from here */ 3843 3844 /* 3845 * first and foremost, handle any ST_EOT_PENDING cases. 3846 * That is, if a logical eot is pending notice, notice it. 3847 */ 3848 if (un->un_eof == ST_EOT_PENDING) { 3849 int resid = un->un_err_resid; 3850 uchar_t status = un->un_status; 3851 uchar_t lastop = un->un_lastop; 3852 3853 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), SYNC_CMD)) { 3854 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 3855 "stioctl : EIO can't space fmk(-1)\n"); 3856 rval = EIO; 3857 goto exit; 3858 } 3859 un->un_lastop = lastop; /* restore last operation */ 3860 if (status == SUN_KEY_EOF) { 3861 un->un_status = SUN_KEY_EOT; 3862 } else { 3863 un->un_status = status; 3864 } 3865 un->un_err_resid = resid; 3866 un->un_err_blkno = un->un_blkno = 0; /* fix up block number */ 3867 un->un_eof = ST_EOT; /* now we're at logical eot */ 3868 } 3869 3870 /* 3871 * now, handle the rest of the situations 3872 */ 3873 check_commands: 3874 switch (cmd) { 3875 case MTIOCGET: 3876 { 3877 #ifdef _MULTI_DATAMODEL 3878 /* 3879 * For use when a 32 bit app makes a call into a 3880 * 64 bit ioctl 3881 */ 3882 struct mtget32 mtg_local32; 3883 struct mtget32 *mtget_32 = &mtg_local32; 3884 #endif /* _MULTI_DATAMODEL */ 3885 3886 /* Get tape status */ 3887 struct mtget mtg_local; 3888 struct mtget *mtget = &mtg_local; 3889 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 3890 "st_ioctl: MTIOCGET\n"); 3891 3892 bzero(mtget, sizeof (struct mtget)); 3893 mtget->mt_erreg = un->un_status; 3894 mtget->mt_resid = un->un_err_resid; 3895 mtget->mt_dsreg = un->un_retry_ct; 3896 mtget->mt_fileno = un->un_err_fileno; 3897 mtget->mt_blkno = un->un_err_blkno; 3898 mtget->mt_type = un->un_dp->type; 3899 mtget->mt_flags = MTF_SCSI | MTF_ASF; 3900 if (un->un_dp->options & ST_REEL) { 3901 mtget->mt_flags |= MTF_REEL; 3902 mtget->mt_bf = 20; 3903 } else { /* 1/4" cartridges */ 3904 switch (mtget->mt_type) { 3905 /* Emulex cartridge tape */ 3906 case MT_ISMT02: 3907 mtget->mt_bf = 40; 3908 break; 3909 default: 3910 mtget->mt_bf = 126; 3911 break; 3912 } 3913 } 3914 3915 /* 3916 * If large transfers are allowed and drive options 3917 * has no record size limit set. Calculate blocking 3918 * factor from the lesser of maxbsize and maxdma. 3919 */ 3920 if ((un->un_allow_large_xfer) && 3921 (un->un_dp->options & ST_NO_RECSIZE_LIMIT)) { 3922 mtget->mt_bf = min(un->un_maxbsize, 3923 un->un_maxdma) / SECSIZE; 3924 } 3925 3926 rval = st_check_clean_bit(dev); 3927 if (rval == -1) { 3928 rval = EIO; 3929 goto exit; 3930 } else { 3931 mtget->mt_flags |= (ushort_t)rval; 3932 rval = 0; 3933 } 3934 3935 un->un_status = 0; /* Reset status */ 3936 un->un_err_resid = 0; 3937 tmp = sizeof (struct mtget); 3938 3939 #ifdef _MULTI_DATAMODEL 3940 3941 switch (ddi_model_convert_from(flag & FMODELS)) { 3942 case DDI_MODEL_ILP32: 3943 /* 3944 * Convert 64 bit back to 32 bit before doing 3945 * copyout. This is what the ILP32 app expects. 3946 */ 3947 mtget_32->mt_erreg = mtget->mt_erreg; 3948 mtget_32->mt_resid = mtget->mt_resid; 3949 mtget_32->mt_dsreg = mtget->mt_dsreg; 3950 mtget_32->mt_fileno = (daddr32_t)mtget->mt_fileno; 3951 mtget_32->mt_blkno = (daddr32_t)mtget->mt_blkno; 3952 mtget_32->mt_type = mtget->mt_type; 3953 mtget_32->mt_flags = mtget->mt_flags; 3954 mtget_32->mt_bf = mtget->mt_bf; 3955 3956 if (ddi_copyout(mtget_32, (void *)arg, 3957 sizeof (struct mtget32), flag)) { 3958 rval = EFAULT; 3959 } 3960 break; 3961 3962 case DDI_MODEL_NONE: 3963 if (ddi_copyout(mtget, (void *)arg, tmp, flag)) { 3964 rval = EFAULT; 3965 } 3966 break; 3967 } 3968 #else /* ! _MULTI_DATAMODE */ 3969 if (ddi_copyout(mtget, (void *)arg, tmp, flag)) { 3970 rval = EFAULT; 3971 } 3972 #endif /* _MULTI_DATAMODE */ 3973 3974 break; 3975 } 3976 case MTIOCSTATE: 3977 { 3978 /* 3979 * return when media presence matches state 3980 */ 3981 enum mtio_state state; 3982 3983 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 3984 "st_ioctl: MTIOCSTATE\n"); 3985 3986 if (ddi_copyin((void *)arg, &state, sizeof (int), flag)) 3987 rval = EFAULT; 3988 3989 mutex_exit(ST_MUTEX); 3990 3991 rval = st_check_media(dev, state); 3992 3993 mutex_enter(ST_MUTEX); 3994 3995 if (rval != 0) { 3996 break; 3997 } 3998 3999 if (ddi_copyout(&un->un_mediastate, (void *)arg, 4000 sizeof (int), flag)) 4001 rval = EFAULT; 4002 break; 4003 4004 } 4005 4006 case MTIOCGETDRIVETYPE: 4007 { 4008 #ifdef _MULTI_DATAMODEL 4009 /* 4010 * For use when a 32 bit app makes a call into a 4011 * 64 bit ioctl 4012 */ 4013 struct mtdrivetype_request32 mtdtrq32; 4014 #endif /* _MULTI_DATAMODEL */ 4015 4016 /* 4017 * return mtdrivetype 4018 */ 4019 struct mtdrivetype_request mtdtrq; 4020 struct mtdrivetype mtdrtyp; 4021 struct mtdrivetype *mtdt = &mtdrtyp; 4022 struct st_drivetype *stdt = un->un_dp; 4023 4024 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4025 "st_ioctl: MTIOCGETDRIVETYPE\n"); 4026 4027 #ifdef _MULTI_DATAMODEL 4028 switch (ddi_model_convert_from(flag & FMODELS)) { 4029 case DDI_MODEL_ILP32: 4030 { 4031 if (ddi_copyin((void *)arg, &mtdtrq32, 4032 sizeof (struct mtdrivetype_request32), flag)) { 4033 rval = EFAULT; 4034 break; 4035 } 4036 mtdtrq.size = mtdtrq32.size; 4037 mtdtrq.mtdtp = 4038 (struct mtdrivetype *)(uintptr_t)mtdtrq32.mtdtp; 4039 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4040 "st_ioctl: size 0x%x\n", mtdtrq.size); 4041 break; 4042 } 4043 case DDI_MODEL_NONE: 4044 if (ddi_copyin((void *)arg, &mtdtrq, 4045 sizeof (struct mtdrivetype_request), flag)) { 4046 rval = EFAULT; 4047 break; 4048 } 4049 break; 4050 } 4051 4052 #else /* ! _MULTI_DATAMODEL */ 4053 if (ddi_copyin((void *)arg, &mtdtrq, 4054 sizeof (struct mtdrivetype_request), flag)) { 4055 rval = EFAULT; 4056 break; 4057 } 4058 #endif /* _MULTI_DATAMODEL */ 4059 4060 /* 4061 * if requested size is < 0 then return 4062 * error. 4063 */ 4064 if (mtdtrq.size < 0) { 4065 rval = EINVAL; 4066 break; 4067 } 4068 bzero(mtdt, sizeof (struct mtdrivetype)); 4069 (void) strncpy(mtdt->name, stdt->name, ST_NAMESIZE); 4070 (void) strncpy(mtdt->vid, stdt->vid, VIDPIDLEN - 1); 4071 mtdt->type = stdt->type; 4072 mtdt->bsize = stdt->bsize; 4073 mtdt->options = stdt->options; 4074 mtdt->max_rretries = stdt->max_rretries; 4075 mtdt->max_wretries = stdt->max_wretries; 4076 for (tmp = 0; tmp < NDENSITIES; tmp++) 4077 mtdt->densities[tmp] = stdt->densities[tmp]; 4078 mtdt->default_density = stdt->default_density; 4079 /* 4080 * Speed hasn't been used since the hayday of reel tape. 4081 * For all drives not setting the option ST_KNOWS_MEDIA 4082 * the speed member renamed to mediatype are zeros. 4083 * Those drives that have ST_KNOWS_MEDIA set use the 4084 * new mediatype member which is used to figure the 4085 * type of media loaded. 4086 * 4087 * So as to not break applications speed in the 4088 * mtdrivetype structure is not renamed. 4089 */ 4090 for (tmp = 0; tmp < NDENSITIES; tmp++) { 4091 mtdt->speeds[tmp] = stdt->mediatype[tmp]; 4092 } 4093 mtdt->non_motion_timeout = stdt->non_motion_timeout; 4094 mtdt->io_timeout = stdt->io_timeout; 4095 mtdt->rewind_timeout = stdt->rewind_timeout; 4096 mtdt->space_timeout = stdt->space_timeout; 4097 mtdt->load_timeout = stdt->load_timeout; 4098 mtdt->unload_timeout = stdt->unload_timeout; 4099 mtdt->erase_timeout = stdt->erase_timeout; 4100 4101 /* 4102 * Limit the maximum length of the result to 4103 * sizeof (struct mtdrivetype). 4104 */ 4105 tmp = sizeof (struct mtdrivetype); 4106 if (mtdtrq.size < tmp) 4107 tmp = mtdtrq.size; 4108 if (ddi_copyout(mtdt, mtdtrq.mtdtp, tmp, flag)) { 4109 rval = EFAULT; 4110 } 4111 break; 4112 } 4113 case MTIOCPERSISTENT: 4114 { 4115 int persistence = 0; 4116 4117 if (ddi_copyin((void *)arg, &persistence, 4118 sizeof (int), flag)) { 4119 rval = EFAULT; 4120 break; 4121 } 4122 4123 /* non zero sets it, only 0 turns it off */ 4124 un->un_persistence = (uchar_t)persistence ? 1 : 0; 4125 4126 if (un->un_persistence) 4127 TURN_PE_ON(un); 4128 else 4129 TURN_PE_OFF(un); 4130 4131 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4132 "st_ioctl: MTIOCPERSISTENT : persistence = %d\n", 4133 un->un_persistence); 4134 4135 break; 4136 } 4137 case MTIOCPERSISTENTSTATUS: 4138 { 4139 int persistence = (int)un->un_persistence; 4140 4141 if (ddi_copyout(&persistence, (void *)arg, 4142 sizeof (int), flag)) { 4143 rval = EFAULT; 4144 } 4145 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4146 "st_ioctl: MTIOCPERSISTENTSTATUS:persistece = %d\n", 4147 un->un_persistence); 4148 4149 break; 4150 } 4151 4152 4153 case MTIOCLRERR: 4154 { 4155 /* clear persistent errors */ 4156 4157 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4158 "st_ioctl: MTIOCLRERR\n"); 4159 4160 CLEAR_PE(un); 4161 4162 break; 4163 } 4164 4165 case MTIOCGUARANTEEDORDER: 4166 { 4167 /* 4168 * this is just a holder to make a valid ioctl and 4169 * it won't be in any earlier release 4170 */ 4171 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4172 "st_ioctl: MTIOCGUARANTEEDORDER\n"); 4173 4174 break; 4175 } 4176 4177 case MTIOCRESERVE: 4178 { 4179 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 4180 "st_ioctl: MTIOCRESERVE\n"); 4181 4182 /* 4183 * Check if Reserve/Release is supported. 4184 */ 4185 if (!(ST_RESERVE_SUPPORTED(un))) { 4186 rval = ENOTTY; 4187 break; 4188 } 4189 4190 rval = st_reserve_release(dev, ST_RESERVE); 4191 4192 if (rval == 0) { 4193 un->un_rsvd_status |= ST_PRESERVE_RESERVE; 4194 } 4195 break; 4196 } 4197 4198 case MTIOCRELEASE: 4199 { 4200 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 4201 "st_ioctl: MTIOCRELEASE\n"); 4202 4203 /* 4204 * Check if Reserve/Release is supported. 4205 */ 4206 if (!(ST_RESERVE_SUPPORTED(un))) { 4207 rval = ENOTTY; 4208 break; 4209 } 4210 4211 un->un_rsvd_status &= ~ST_PRESERVE_RESERVE; 4212 4213 break; 4214 } 4215 4216 case MTIOCFORCERESERVE: 4217 { 4218 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 4219 "st_ioctl: MTIOCFORCERESERVE\n"); 4220 4221 /* 4222 * Check if Reserve/Release is supported. 4223 */ 4224 if (!(ST_RESERVE_SUPPORTED(un))) { 4225 rval = ENOTTY; 4226 break; 4227 } 4228 /* 4229 * allow only super user to run this. 4230 */ 4231 if (drv_priv(cred_p) != 0) { 4232 rval = EPERM; 4233 break; 4234 } 4235 /* 4236 * Throw away reserve, 4237 * not using test-unit-ready 4238 * since reserve can succeed without tape being 4239 * present in the drive. 4240 */ 4241 (void) st_reserve_release(dev, ST_RESERVE); 4242 4243 rval = st_take_ownership(dev); 4244 4245 break; 4246 } 4247 case USCSIGETRQS: 4248 { 4249 #ifdef _MULTI_DATAMODEL 4250 /* 4251 * For use when a 32 bit app makes a call into a 4252 * 64 bit ioctl 4253 */ 4254 struct uscsi_rqs32 urqs_32; 4255 struct uscsi_rqs32 *urqs_32_ptr = &urqs_32; 4256 #endif /* _MULTI_DATAMODEL */ 4257 struct uscsi_rqs urqs; 4258 struct uscsi_rqs *urqs_ptr = &urqs; 4259 ushort_t len; 4260 #ifdef _MULTI_DATAMODEL 4261 switch (ddi_model_convert_from(flag & FMODELS)) { 4262 case DDI_MODEL_ILP32: 4263 { 4264 if (ddi_copyin((void *)arg, urqs_32_ptr, 4265 sizeof (struct uscsi_rqs32), flag)) { 4266 rval = EFAULT; 4267 break; 4268 } 4269 urqs_ptr->rqs_buflen = urqs_32_ptr->rqs_buflen; 4270 urqs_ptr->rqs_bufaddr = 4271 (caddr_t)(uintptr_t)urqs_32_ptr->rqs_bufaddr; 4272 break; 4273 } 4274 case DDI_MODEL_NONE: 4275 if (ddi_copyin((void *)arg, urqs_ptr, 4276 sizeof (struct uscsi_rqs), flag)) { 4277 rval = EFAULT; 4278 break; 4279 } 4280 } 4281 #else /* ! _MULTI_DATAMODEL */ 4282 if (ddi_copyin((void *)arg, urqs_ptr, sizeof (urqs), flag)) { 4283 rval = EFAULT; 4284 break; 4285 } 4286 #endif /* _MULTI_DATAMODEL */ 4287 4288 urqs_ptr->rqs_flags = (int)un->un_rqs_state & 4289 (ST_RQS_OVR | ST_RQS_VALID); 4290 if (urqs_ptr->rqs_buflen <= SENSE_LENGTH) { 4291 len = urqs_ptr->rqs_buflen; 4292 urqs_ptr->rqs_resid = 0; 4293 } else { 4294 len = SENSE_LENGTH; 4295 urqs_ptr->rqs_resid = urqs_ptr->rqs_buflen 4296 - SENSE_LENGTH; 4297 } 4298 if (!(un->un_rqs_state & ST_RQS_VALID)) { 4299 urqs_ptr->rqs_resid = urqs_ptr->rqs_buflen; 4300 } 4301 un->un_rqs_state |= ST_RQS_READ; 4302 un->un_rqs_state &= ~(ST_RQS_OVR); 4303 4304 #ifdef _MULTI_DATAMODEL 4305 switch (ddi_model_convert_from(flag & FMODELS)) { 4306 case DDI_MODEL_ILP32: 4307 urqs_32_ptr->rqs_flags = urqs_ptr->rqs_flags; 4308 urqs_32_ptr->rqs_resid = urqs_ptr->rqs_resid; 4309 if (ddi_copyout(&urqs_32, (void *)arg, 4310 sizeof (urqs_32), flag)) { 4311 rval = EFAULT; 4312 } 4313 break; 4314 case DDI_MODEL_NONE: 4315 if (ddi_copyout(&urqs, (void *)arg, sizeof (urqs), 4316 flag)) { 4317 rval = EFAULT; 4318 } 4319 break; 4320 } 4321 4322 if (un->un_rqs_state & ST_RQS_VALID) { 4323 if (ddi_copyout(un->un_uscsi_rqs_buf, 4324 urqs_ptr->rqs_bufaddr, len, flag)) { 4325 rval = EFAULT; 4326 } 4327 } 4328 #else /* ! _MULTI_DATAMODEL */ 4329 if (ddi_copyout(&urqs, (void *)arg, sizeof (urqs), flag)) { 4330 rval = EFAULT; 4331 } 4332 if (un->un_rqs_state & ST_RQS_VALID) { 4333 if (ddi_copyout(un->un_uscsi_rqs_buf, 4334 urqs_ptr->rqs_bufaddr, len, flag)) { 4335 rval = EFAULT; 4336 } 4337 } 4338 #endif /* _MULTI_DATAMODEL */ 4339 break; 4340 } 4341 4342 case USCSICMD: 4343 { 4344 cred_t *cr; 4345 #ifdef _MULTI_DATAMODEL 4346 /* 4347 * For use when a 32 bit app makes a call into a 4348 * 64 bit ioctl 4349 */ 4350 struct uscsi_cmd32 ucmd_32; 4351 struct uscsi_cmd32 *ucmd_32_ptr = &ucmd_32; 4352 #endif /* _MULTI_DATAMODEL */ 4353 4354 /* 4355 * Run a generic USCSI command 4356 */ 4357 struct uscsi_cmd ucmd; 4358 struct uscsi_cmd *ucmd_ptr = &ucmd; 4359 enum uio_seg uioseg; 4360 4361 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4362 "st_ioctl: USCSICMD\n"); 4363 4364 cr = ddi_get_cred(); 4365 if ((drv_priv(cred_p) != 0) && (drv_priv(cr) != 0)) { 4366 rval = EPERM; 4367 break; 4368 } 4369 4370 #ifdef _MULTI_DATAMODEL 4371 switch (ddi_model_convert_from(flag & FMODELS)) { 4372 case DDI_MODEL_ILP32: 4373 { 4374 if (ddi_copyin((void *)arg, ucmd_32_ptr, 4375 sizeof (struct uscsi_cmd32), flag)) { 4376 rval = EFAULT; 4377 break; 4378 } 4379 uscsi_cmd32touscsi_cmd(ucmd_32_ptr, ucmd_ptr); 4380 break; 4381 } 4382 case DDI_MODEL_NONE: 4383 if (ddi_copyin((void *)arg, ucmd_ptr, sizeof (ucmd), 4384 flag)) { 4385 rval = EFAULT; 4386 break; 4387 } 4388 } 4389 4390 #else /* ! _MULTI_DATAMODEL */ 4391 if (ddi_copyin((void *)arg, ucmd_ptr, sizeof (ucmd), flag)) { 4392 rval = EFAULT; 4393 break; 4394 } 4395 #endif /* _MULTI_DATAMODEL */ 4396 4397 4398 /* 4399 * If we haven't done/checked reservation on the 4400 * tape unit do it now. 4401 */ 4402 if (ST_RESERVE_SUPPORTED(un) && 4403 !(un->un_rsvd_status & ST_INIT_RESERVE)) { 4404 if (rval = st_tape_reservation_init(dev)) 4405 goto exit; 4406 } 4407 4408 /* 4409 * although st_ioctl_cmd() never makes use of these 4410 * now, we are just being safe and consistent 4411 */ 4412 ucmd.uscsi_flags &= ~(USCSI_NOINTR | USCSI_NOPARITY | 4413 USCSI_OTAG | USCSI_HTAG | USCSI_HEAD); 4414 4415 4416 uioseg = (flag & FKIOCTL) ? 4417 UIO_SYSSPACE : UIO_USERSPACE; 4418 4419 rval = st_ioctl_cmd(dev, &ucmd, uioseg, uioseg, uioseg); 4420 4421 4422 #ifdef _MULTI_DATAMODEL 4423 switch (ddi_model_convert_from(flag & FMODELS)) { 4424 case DDI_MODEL_ILP32: 4425 /* 4426 * Convert 64 bit back to 32 bit before doing 4427 * copyout. This is what the ILP32 app expects. 4428 */ 4429 uscsi_cmdtouscsi_cmd32(ucmd_ptr, ucmd_32_ptr); 4430 4431 if (ddi_copyout(&ucmd_32, (void *)arg, 4432 sizeof (ucmd_32), flag)) { 4433 if (rval != 0) 4434 rval = EFAULT; 4435 } 4436 break; 4437 4438 case DDI_MODEL_NONE: 4439 if (ddi_copyout(&ucmd, (void *)arg, 4440 sizeof (ucmd), flag)) { 4441 if (rval != 0) 4442 rval = EFAULT; 4443 } 4444 break; 4445 } 4446 #else /* ! _MULTI_DATAMODEL */ 4447 if (ddi_copyout(&ucmd, (void *)arg, sizeof (ucmd), flag)) { 4448 if (rval != 0) 4449 rval = EFAULT; 4450 } 4451 #endif /* _MULTI_DATAMODEL */ 4452 4453 break; 4454 } 4455 4456 case MTIOCTOP: 4457 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4458 "st_ioctl: MTIOCTOP\n"); 4459 rval = st_mtioctop(un, arg, flag); 4460 break; 4461 4462 case MTIOCREADIGNOREILI: 4463 { 4464 int set_ili; 4465 4466 if (ddi_copyin((void *)arg, &set_ili, 4467 sizeof (set_ili), flag)) { 4468 rval = EFAULT; 4469 break; 4470 } 4471 4472 if (un->un_bsize) { 4473 rval = ENOTTY; 4474 break; 4475 } 4476 4477 switch (set_ili) { 4478 case 0: 4479 un->un_dp->options &= ~ST_READ_IGNORE_ILI; 4480 break; 4481 4482 case 1: 4483 un->un_dp->options |= ST_READ_IGNORE_ILI; 4484 break; 4485 4486 default: 4487 rval = EINVAL; 4488 break; 4489 } 4490 break; 4491 } 4492 4493 case MTIOCREADIGNOREEOFS: 4494 { 4495 int ignore_eof; 4496 4497 if (ddi_copyin((void *)arg, &ignore_eof, 4498 sizeof (ignore_eof), flag)) { 4499 rval = EFAULT; 4500 break; 4501 } 4502 4503 if (!(un->un_dp->options & ST_REEL)) { 4504 rval = ENOTTY; 4505 break; 4506 } 4507 4508 switch (ignore_eof) { 4509 case 0: 4510 un->un_dp->options &= ~ST_READ_IGNORE_EOFS; 4511 break; 4512 4513 case 1: 4514 un->un_dp->options |= ST_READ_IGNORE_EOFS; 4515 break; 4516 4517 default: 4518 rval = EINVAL; 4519 break; 4520 } 4521 break; 4522 } 4523 4524 case MTIOCSHORTFMK: 4525 { 4526 int short_fmk; 4527 4528 if (ddi_copyin((void *)arg, &short_fmk, 4529 sizeof (short_fmk), flag)) { 4530 rval = EFAULT; 4531 break; 4532 } 4533 4534 switch (un->un_dp->type) { 4535 case ST_TYPE_EXB8500: 4536 case ST_TYPE_EXABYTE: 4537 if (!short_fmk) { 4538 un->un_dp->options &= 4539 ~ST_SHORT_FILEMARKS; 4540 } else if (short_fmk == 1) { 4541 un->un_dp->options |= 4542 ST_SHORT_FILEMARKS; 4543 } else { 4544 rval = EINVAL; 4545 } 4546 break; 4547 4548 default: 4549 rval = ENOTTY; 4550 break; 4551 } 4552 break; 4553 } 4554 4555 default: 4556 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4557 "st_ioctl: unknown ioctl\n"); 4558 rval = ENOTTY; 4559 } 4560 4561 exit: 4562 if (!IS_PE_FLAG_SET(un)) 4563 un->un_errno = rval; 4564 4565 mutex_exit(ST_MUTEX); 4566 4567 return (rval); 4568 } 4569 4570 4571 /* 4572 * do some MTIOCTOP tape operations 4573 */ 4574 static int 4575 st_mtioctop(struct scsi_tape *un, intptr_t arg, int flag) 4576 { 4577 struct mtop *mtop, local; 4578 int savefile, tmp, rval = 0; 4579 dev_t dev = un->un_dev; 4580 #ifdef _MULTI_DATAMODEL 4581 /* 4582 * For use when a 32 bit app makes a call into a 4583 * 64 bit ioctl 4584 */ 4585 struct mtop32 mtop_32_for_64; 4586 #endif /* _MULTI_DATAMODEL */ 4587 4588 4589 ASSERT(mutex_owned(ST_MUTEX)); 4590 4591 mtop = &local; 4592 #ifdef _MULTI_DATAMODEL 4593 switch (ddi_model_convert_from(flag & FMODELS)) { 4594 case DDI_MODEL_ILP32: 4595 { 4596 if (ddi_copyin((void *)arg, &mtop_32_for_64, 4597 sizeof (struct mtop32), flag)) { 4598 return (EFAULT); 4599 } 4600 mtop->mt_op = mtop_32_for_64.mt_op; 4601 mtop->mt_count = (daddr_t)mtop_32_for_64.mt_count; 4602 break; 4603 } 4604 case DDI_MODEL_NONE: 4605 if (ddi_copyin((void *)arg, mtop, 4606 sizeof (struct mtop), flag)) { 4607 return (EFAULT); 4608 } 4609 break; 4610 } 4611 4612 #else /* ! _MULTI_DATAMODEL */ 4613 if (ddi_copyin((void *)arg, mtop, sizeof (struct mtop), flag)) { 4614 return (EFAULT); 4615 } 4616 #endif /* _MULTI_DATAMODEL */ 4617 4618 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 4619 "st_mtioctop(): mt_op=%x\n", mtop->mt_op); 4620 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 4621 "fileno=%x, blkno=%lx, un_eof=%x\n", un->un_fileno, un->un_blkno, 4622 un->un_eof); 4623 4624 rval = 0; 4625 un->un_status = 0; 4626 4627 /* 4628 * If we haven't done/checked reservation on the tape unit 4629 * do it now. 4630 */ 4631 if (ST_RESERVE_SUPPORTED(un) && 4632 !(un->un_rsvd_status & ST_INIT_RESERVE)) { 4633 if (rval = st_tape_reservation_init(dev)) 4634 return (rval); 4635 } 4636 /* 4637 * if we are going to mess with a tape, we have to make sure we have 4638 * one and are not offline (i.e. no tape is initialized). We let 4639 * commands pass here that don't actually touch the tape, except for 4640 * loading and initialization (rewinding). 4641 */ 4642 if (un->un_state == ST_STATE_OFFLINE) { 4643 switch (mtop->mt_op) { 4644 case MTLOAD: 4645 case MTNOP: 4646 /* 4647 * We don't want strategy calling st_tape_init here, 4648 * so, change state 4649 */ 4650 un->un_state = ST_STATE_INITIALIZING; 4651 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4652 "st_mtioctop : OFFLINE state = %d\n", 4653 un->un_state); 4654 break; 4655 default: 4656 /* 4657 * reinitialize by normal means 4658 */ 4659 if (st_tape_init(dev)) { 4660 un->un_state = ST_STATE_INITIALIZING; 4661 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4662 "st_mtioctop : OFFLINE init failure "); 4663 un->un_state = ST_STATE_OFFLINE; 4664 un->un_fileno = -1; 4665 return (EIO); 4666 } 4667 un->un_state = ST_STATE_OPEN_PENDING_IO; 4668 break; 4669 } 4670 } 4671 4672 /* 4673 * If the file position is invalid, allow only those 4674 * commands that properly position the tape and fail 4675 * the rest with EIO 4676 */ 4677 if (un->un_fileno < 0) { 4678 switch (mtop->mt_op) { 4679 case MTWEOF: 4680 case MTRETEN: 4681 case MTERASE: 4682 case MTEOM: 4683 case MTFSF: 4684 case MTFSR: 4685 case MTBSF: 4686 case MTNBSF: 4687 case MTBSR: 4688 case MTSRSZ: 4689 case MTGRSZ: 4690 return (EIO); 4691 /* NOTREACHED */ 4692 case MTREW: 4693 case MTLOAD: 4694 case MTOFFL: 4695 case MTNOP: 4696 break; 4697 4698 default: 4699 return (ENOTTY); 4700 /* NOTREACHED */ 4701 } 4702 } 4703 4704 switch (mtop->mt_op) { 4705 case MTERASE: 4706 /* 4707 * MTERASE rewinds the tape, erase it completely, and returns 4708 * to the beginning of the tape 4709 */ 4710 if (un->un_dp->options & ST_REEL) 4711 un->un_fmneeded = 2; 4712 4713 if (un->un_mspl->wp || un->un_read_only) { 4714 un->un_status = KEY_WRITE_PROTECT; 4715 un->un_err_resid = mtop->mt_count; 4716 un->un_err_fileno = un->un_fileno; 4717 un->un_err_blkno = un->un_blkno; 4718 return (EACCES); 4719 } 4720 if (st_check_density_or_wfm(dev, 1, B_WRITE, NO_STEPBACK) || 4721 st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD) || 4722 st_cmd(dev, SCMD_ERASE, 0, SYNC_CMD)) { 4723 un->un_fileno = -1; 4724 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4725 "st_mtioctop : EIO space or erase or check den)\n"); 4726 rval = EIO; 4727 } else { 4728 /* QIC and helical scan rewind after erase */ 4729 if (un->un_dp->options & ST_REEL) { 4730 (void) st_cmd(dev, SCMD_REWIND, 0, ASYNC_CMD); 4731 } 4732 } 4733 break; 4734 4735 case MTWEOF: 4736 /* 4737 * write an end-of-file record 4738 */ 4739 if (un->un_mspl->wp || un->un_read_only) { 4740 un->un_status = KEY_WRITE_PROTECT; 4741 un->un_err_resid = mtop->mt_count; 4742 un->un_err_fileno = un->un_fileno; 4743 un->un_err_blkno = un->un_blkno; 4744 return (EACCES); 4745 } 4746 4747 /* 4748 * zero count means just flush buffers 4749 * negative count is not permitted 4750 */ 4751 if (mtop->mt_count < 0) 4752 return (EINVAL); 4753 4754 if (!un->un_read_only) { 4755 un->un_test_append = 1; 4756 } 4757 4758 if (un->un_state == ST_STATE_OPEN_PENDING_IO) { 4759 if (st_determine_density(dev, B_WRITE)) { 4760 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4761 "st_mtioctop : EIO : MTWEOF can't determine" 4762 "density"); 4763 return (EIO); 4764 } 4765 } 4766 4767 if (st_write_fm(dev, (int)mtop->mt_count)) { 4768 /* 4769 * Failure due to something other than illegal 4770 * request results in loss of state (st_intr). 4771 */ 4772 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4773 "st_mtioctop : EIO : MTWEOF can't write file mark"); 4774 rval = EIO; 4775 } 4776 break; 4777 4778 case MTRETEN: 4779 /* 4780 * retension the tape 4781 */ 4782 if (st_check_density_or_wfm(dev, 1, 0, NO_STEPBACK) || 4783 st_cmd(dev, SCMD_LOAD, 3, SYNC_CMD)) { 4784 un->un_fileno = -1; 4785 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4786 "st_mtioctop : EIO : MTRETEN "); 4787 rval = EIO; 4788 } 4789 break; 4790 4791 case MTREW: 4792 /* 4793 * rewind the tape 4794 */ 4795 if (st_check_density_or_wfm(dev, 1, 0, NO_STEPBACK)) { 4796 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4797 "st_mtioctop : EIO:MTREW check density/wfm failed"); 4798 return (EIO); 4799 } 4800 if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD)) { 4801 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4802 "st_mtioctop : EIO : MTREW "); 4803 rval = EIO; 4804 } 4805 break; 4806 4807 case MTOFFL: 4808 /* 4809 * rewinds, and, if appropriate, takes the device offline by 4810 * unloading the tape 4811 */ 4812 if (st_check_density_or_wfm(dev, 1, 0, NO_STEPBACK)) { 4813 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4814 "st_mtioctop :EIO:MTOFFL check density/wfm failed"); 4815 return (EIO); 4816 } 4817 (void) st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD); 4818 if (st_cmd(dev, SCMD_LOAD, 0, SYNC_CMD)) { 4819 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4820 "st_mtioctop : EIO : MTOFFL"); 4821 return (EIO); 4822 } 4823 un->un_eof = ST_NO_EOF; 4824 un->un_laststate = un->un_state; 4825 un->un_state = ST_STATE_OFFLINE; 4826 un->un_mediastate = MTIO_EJECTED; 4827 break; 4828 4829 case MTLOAD: 4830 /* 4831 * This is to load a tape into the drive 4832 * Note that if the tape is not loaded, the device will have 4833 * to be opened via O_NDELAY or O_NONBLOCK. 4834 */ 4835 /* 4836 * Let's try and clean things up, if we are not 4837 * initializing, and then send in the load command, no 4838 * matter what. 4839 * 4840 * we try the load twice because some drives fail the first 4841 * load after a media change by the user. 4842 */ 4843 4844 if (un->un_state > ST_STATE_INITIALIZING) 4845 (void) st_check_density_or_wfm(dev, 1, 0, NO_STEPBACK); 4846 4847 if (st_cmd(dev, SCMD_LOAD, 1, SYNC_CMD) && 4848 st_cmd(dev, SCMD_LOAD, 1, SYNC_CMD)) { 4849 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4850 "st_mtioctop : EIO : MTLOAD\n"); 4851 rval = EIO; 4852 4853 /* 4854 * If load tape fails, who knows what happened... 4855 */ 4856 un->un_fileno = -1; 4857 rval = EIO; 4858 break; 4859 } 4860 4861 /* 4862 * reset all counters appropriately using rewind, as if LOAD 4863 * succeeds, we are at BOT 4864 */ 4865 un->un_state = ST_STATE_INITIALIZING; 4866 4867 if (st_tape_init(dev)) { 4868 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4869 "st_mtioctop : EIO : MTLOAD calls st_tape_init\n"); 4870 rval = EIO; 4871 un->un_state = ST_STATE_OFFLINE; 4872 } 4873 4874 break; 4875 4876 case MTNOP: 4877 un->un_status = 0; /* Reset status */ 4878 un->un_err_resid = 0; 4879 break; 4880 4881 case MTEOM: 4882 /* 4883 * positions the tape at a location just after the last file 4884 * written on the tape. For cartridge and 8 mm, this after 4885 * the last file mark; for reel, this is inbetween the two 4886 * last 2 file marks 4887 */ 4888 if ((un->un_eof >= ST_EOT) || 4889 (un->un_lastop == ST_OP_WRITE) || 4890 (un->un_lastop == ST_OP_WEOF)) { 4891 /* 4892 * If the command wants to move to logical end 4893 * of media, and we're already there, we're done. 4894 * If we were at logical eot, we reset the state 4895 * to be *not* at logical eot. 4896 * 4897 * If we're at physical or logical eot, we prohibit 4898 * forward space operations (unconditionally). 4899 * 4900 * Also if the last operation was a write of any 4901 * kind the tape is at EOD. 4902 */ 4903 return (0); 4904 } 4905 /* 4906 * physical tape position may not be what we've been 4907 * telling the user; adjust the request accordingly 4908 */ 4909 if (IN_EOF(un)) { 4910 un->un_fileno++; 4911 un->un_blkno = 0; 4912 } 4913 4914 if (st_check_density_or_wfm(dev, 1, B_READ, NO_STEPBACK)) { 4915 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4916 "st_mtioctop : EIO:MTEOM check density/wfm failed"); 4917 return (EIO); 4918 } 4919 4920 /* 4921 * st_find_eom() returns the last fileno we knew about; 4922 */ 4923 savefile = st_find_eom(dev); 4924 4925 if ((un->un_status != KEY_BLANK_CHECK) && 4926 (un->un_status != SUN_KEY_EOT)) { 4927 un->un_fileno = -1; 4928 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4929 "st_mtioctop : EIO : MTEOM status check failed"); 4930 rval = EIO; 4931 } else { 4932 /* 4933 * For 1/2" reel tapes assume logical EOT marked 4934 * by two file marks or we don't care that we may 4935 * be extending the last file on the tape. 4936 */ 4937 if (un->un_dp->options & ST_REEL) { 4938 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), 4939 SYNC_CMD)) { 4940 un->un_fileno = -1; 4941 ST_DEBUG2(ST_DEVINFO, st_label, 4942 SCSI_DEBUG, 4943 "st_mtioctop : EIO : MTEOM space " 4944 "cmd failed"); 4945 rval = EIO; 4946 break; 4947 } 4948 /* 4949 * Fix up the block number. 4950 */ 4951 un->un_blkno = 0; 4952 un->un_err_blkno = 0; 4953 } 4954 un->un_err_resid = 0; 4955 un->un_fileno = savefile; 4956 un->un_eof = ST_EOT; 4957 } 4958 un->un_status = 0; 4959 break; 4960 4961 case MTFSF: 4962 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 4963 "fsf: count=%lx, eof=%x\n", mtop->mt_count, 4964 un->un_eof); 4965 /* 4966 * forward space over filemark 4967 * 4968 * For ASF we allow a count of 0 on fsf which means 4969 * we just want to go to beginning of current file. 4970 * Equivalent to "nbsf(0)" or "bsf(1) + fsf". 4971 * Allow stepping over double fmk with reel 4972 */ 4973 if ((un->un_eof >= ST_EOT) && (mtop->mt_count > 0) && 4974 ((un->un_dp->options & ST_REEL) == 0)) { 4975 /* we're at EOM */ 4976 un->un_err_resid = mtop->mt_count; 4977 un->un_status = KEY_BLANK_CHECK; 4978 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 4979 "st_mtioctop : EIO : MTFSF at EOM"); 4980 return (EIO); 4981 } 4982 4983 /* 4984 * physical tape position may not be what we've been 4985 * telling the user; adjust the request accordingly 4986 */ 4987 if (IN_EOF(un)) { 4988 un->un_fileno++; 4989 un->un_blkno = 0; 4990 /* 4991 * For positive direction case, we're now covered. 4992 * For zero or negative direction, we're covered 4993 * (almost) 4994 */ 4995 mtop->mt_count--; 4996 } 4997 4998 if (st_check_density_or_wfm(dev, 1, B_READ, STEPBACK)) { 4999 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5000 "st_mtioctop : EIO : MTFSF density/wfm failed"); 5001 return (EIO); 5002 } 5003 5004 5005 /* 5006 * Forward space file marks. 5007 * We leave ourselves at block zero 5008 * of the target file number. 5009 */ 5010 if (mtop->mt_count < 0) { 5011 mtop->mt_count = -mtop->mt_count; 5012 mtop->mt_op = MTNBSF; 5013 goto bspace; 5014 } 5015 fspace: 5016 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5017 "fspace: count=%lx, eof=%x\n", mtop->mt_count, 5018 un->un_eof); 5019 if ((tmp = mtop->mt_count) == 0) { 5020 if (un->un_blkno == 0) { 5021 un->un_err_resid = 0; 5022 un->un_err_fileno = un->un_fileno; 5023 un->un_err_blkno = un->un_blkno; 5024 break; 5025 } else if (un->un_fileno == 0) { 5026 rval = st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD); 5027 } else if (un->un_dp->options & ST_BSF) { 5028 rval = (st_cmd(dev, SCMD_SPACE, Fmk((-1)), 5029 SYNC_CMD) || 5030 st_cmd(dev, SCMD_SPACE, Fmk(1), SYNC_CMD)); 5031 } else { 5032 tmp = un->un_fileno; 5033 rval = (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD) || 5034 st_cmd(dev, SCMD_SPACE, (int)Fmk(tmp), 5035 SYNC_CMD)); 5036 } 5037 if (rval != 0) { 5038 un->un_fileno = -1; 5039 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5040 "st_mtioctop : EIO : fspace fileno = -1"); 5041 5042 rval = EIO; 5043 } 5044 } else { 5045 rval = st_space_fmks(dev, tmp); 5046 } 5047 5048 if (mtop->mt_op == MTBSF && rval != EIO) { 5049 /* 5050 * we came here with a count < 0; we now need 5051 * to skip back to end up before the filemark 5052 */ 5053 mtop->mt_count = 1; 5054 goto bspace; 5055 } 5056 break; 5057 5058 5059 case MTFSR: 5060 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5061 "fsr: count=%lx, eof=%x\n", mtop->mt_count, 5062 un->un_eof); 5063 /* 5064 * forward space to inter-record gap 5065 * 5066 */ 5067 if ((un->un_eof >= ST_EOT) && (mtop->mt_count > 0)) { 5068 /* we're at EOM */ 5069 un->un_err_resid = mtop->mt_count; 5070 un->un_status = KEY_BLANK_CHECK; 5071 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5072 "st_mtioctop : EIO : MTFSR un_eof > ST_EOT"); 5073 return (EIO); 5074 } 5075 5076 if (mtop->mt_count == 0) { 5077 un->un_err_fileno = un->un_fileno; 5078 un->un_err_blkno = un->un_blkno; 5079 un->un_err_resid = 0; 5080 if (IN_EOF(un) && SVR4_BEHAVIOR) { 5081 un->un_status = SUN_KEY_EOF; 5082 } 5083 return (0); 5084 } 5085 5086 /* 5087 * physical tape position may not be what we've been 5088 * telling the user; adjust the position accordingly 5089 */ 5090 if (IN_EOF(un)) { 5091 daddr_t blkno = un->un_blkno; 5092 int fileno = un->un_fileno; 5093 uchar_t lastop = un->un_lastop; 5094 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), SYNC_CMD) 5095 == -1) { 5096 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5097 "st_mtioctop : EIO :MTFSR count && IN_EOF"); 5098 return (EIO); 5099 } 5100 5101 un->un_blkno = blkno; 5102 un->un_fileno = fileno; 5103 un->un_lastop = lastop; 5104 } 5105 5106 if (st_check_density_or_wfm(dev, 1, B_READ, STEPBACK)) { 5107 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5108 "st_mtioctop : EIO : MTFSR st_check_den"); 5109 return (EIO); 5110 } 5111 5112 space_records: 5113 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5114 "space_records: count=%lx, eof=%x\n", mtop->mt_count, 5115 un->un_eof); 5116 tmp = un->un_blkno + mtop->mt_count; 5117 if (tmp == un->un_blkno) { 5118 un->un_err_resid = 0; 5119 un->un_err_fileno = un->un_fileno; 5120 un->un_err_blkno = un->un_blkno; 5121 break; 5122 } else if (un->un_blkno < tmp || 5123 (un->un_dp->options & ST_BSR)) { 5124 /* 5125 * If we're spacing forward, or the device can 5126 * backspace records, we can just use the SPACE 5127 * command. 5128 */ 5129 tmp = tmp - un->un_blkno; 5130 if (st_cmd(dev, SCMD_SPACE, Blk(tmp), SYNC_CMD)) { 5131 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5132 "st_mtioctop :EIO:space_records can't spc"); 5133 rval = EIO; 5134 } else if (un->un_eof >= ST_EOF_PENDING) { 5135 /* 5136 * check if we hit BOT/EOT 5137 */ 5138 if (tmp < 0 && un->un_eof == ST_EOM) { 5139 un->un_status = SUN_KEY_BOT; 5140 un->un_eof = ST_NO_EOF; 5141 } else if (tmp < 0 && un->un_eof == 5142 ST_EOF_PENDING) { 5143 int residue = un->un_err_resid; 5144 /* 5145 * we skipped over a filemark 5146 * and need to go forward again 5147 */ 5148 if (st_cmd(dev, SCMD_SPACE, Fmk(1), 5149 SYNC_CMD)) { 5150 ST_DEBUG2(ST_DEVINFO, 5151 st_label, SCSI_DEBUG, 5152 "st_mtioctop : EIO : " 5153 "space_records can't " 5154 "space #2"); 5155 rval = EIO; 5156 } 5157 un->un_err_resid = residue; 5158 } 5159 if (rval == 0) { 5160 ST_DEBUG2(ST_DEVINFO, st_label, 5161 SCSI_DEBUG, 5162 "st_mtioctop : EIO : space_rec rval" 5163 " == 0"); 5164 rval = EIO; 5165 } 5166 } 5167 } else { 5168 /* 5169 * else we rewind, space forward across filemarks to 5170 * the desired file, and then space records to the 5171 * desired block. 5172 */ 5173 5174 int t = un->un_fileno; /* save current file */ 5175 5176 if (tmp < 0) { 5177 /* 5178 * Wups - we're backing up over a filemark 5179 */ 5180 if (un->un_blkno != 0 && 5181 (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD) || 5182 st_cmd(dev, SCMD_SPACE, Fmk(t), SYNC_CMD))) 5183 un->un_fileno = -1; 5184 un->un_err_resid = -tmp; 5185 if (un->un_fileno == 0 && un->un_blkno == 0) { 5186 un->un_status = SUN_KEY_BOT; 5187 un->un_eof = ST_NO_EOF; 5188 } else if (un->un_fileno > 0) { 5189 un->un_status = SUN_KEY_EOF; 5190 un->un_eof = ST_NO_EOF; 5191 } 5192 un->un_err_fileno = un->un_fileno; 5193 un->un_err_blkno = un->un_blkno; 5194 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5195 "st_mtioctop :EIO:space_records : tmp < 0"); 5196 rval = EIO; 5197 } else if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD) || 5198 st_cmd(dev, SCMD_SPACE, Fmk(t), SYNC_CMD) || 5199 st_cmd(dev, SCMD_SPACE, Blk(tmp), 5200 SYNC_CMD)) { 5201 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5202 "st_mtioctop : EIO :space_records : rewind " 5203 "and space failed"); 5204 un->un_fileno = -1; 5205 rval = EIO; 5206 } 5207 } 5208 break; 5209 5210 5211 case MTBSF: 5212 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5213 "bsf: count=%lx, eof=%x\n", mtop->mt_count, 5214 un->un_eof); 5215 /* 5216 * backward space of file filemark (1/2" and 8mm) 5217 * tape position will end on the beginning of tape side 5218 * of the desired file mark 5219 */ 5220 if ((un->un_dp->options & ST_BSF) == 0) { 5221 return (ENOTTY); 5222 } 5223 5224 /* 5225 * If a negative count (which implies a forward space op) 5226 * is specified, and we're at logical or physical eot, 5227 * bounce the request. 5228 */ 5229 5230 if (un->un_eof >= ST_EOT && mtop->mt_count < 0) { 5231 un->un_err_resid = mtop->mt_count; 5232 un->un_status = SUN_KEY_EOT; 5233 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5234 "st_ioctl : EIO : MTBSF : un_eof > ST_EOF"); 5235 return (EIO); 5236 } 5237 /* 5238 * physical tape position may not be what we've been 5239 * telling the user; adjust the request accordingly 5240 */ 5241 if (IN_EOF(un)) { 5242 un->un_fileno++; 5243 un->un_blkno = 0; 5244 mtop->mt_count++; 5245 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5246 "bsf in eof: count=%ld, op=%x\n", 5247 mtop->mt_count, mtop->mt_op); 5248 5249 } 5250 5251 if (st_check_density_or_wfm(dev, 1, 0, STEPBACK)) { 5252 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5253 "st_ioctl : EIO : MTBSF : check den wfm"); 5254 return (EIO); 5255 } 5256 5257 if (mtop->mt_count <= 0) { 5258 /* 5259 * for a negative count, we need to step forward 5260 * first and then step back again 5261 */ 5262 mtop->mt_count = -mtop->mt_count+1; 5263 goto fspace; 5264 } 5265 5266 bspace: 5267 { 5268 int skip_cnt, end_at_eof; 5269 5270 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5271 "bspace: count=%lx, eof=%x\n", mtop->mt_count, 5272 un->un_eof); 5273 /* 5274 * Backspace files (MTNBSF): 5275 * 5276 * For tapes that can backspace, backspace 5277 * count+1 filemarks and then run forward over 5278 * a filemark 5279 * 5280 * For tapes that can't backspace, 5281 * calculate desired filenumber 5282 * (un->un_fileno - count), rewind, 5283 * and then space forward this amount 5284 * 5285 * Backspace filemarks (MTBSF) 5286 * 5287 * For tapes that can backspace, backspace count 5288 * filemarks 5289 * 5290 * For tapes that can't backspace, calculate 5291 * desired filenumber (un->un_fileno - count), 5292 * add 1, rewind, space forward this amount, 5293 * and mark state as ST_EOF_PENDING appropriately. 5294 */ 5295 5296 if (mtop->mt_op == MTBSF) { 5297 end_at_eof = 1; 5298 } else { 5299 end_at_eof = 0; 5300 } 5301 5302 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5303 "bspace: mt_op=%x, count=%lx, fileno=%x, blkno=%lx\n", 5304 mtop->mt_op, mtop->mt_count, un->un_fileno, un->un_blkno); 5305 5306 /* 5307 * Handle the simple case of BOT 5308 * playing a role in these cmds. 5309 * We do this by calculating the 5310 * ending file number. If the ending 5311 * file is < BOT, rewind and set an 5312 * error and mark resid appropriately. 5313 * If we're backspacing a file (not a 5314 * filemark) and the target file is 5315 * the first file on the tape, just 5316 * rewind. 5317 */ 5318 5319 tmp = un->un_fileno - mtop->mt_count; 5320 if ((end_at_eof && tmp < 0) || (end_at_eof == 0 && tmp <= 0)) { 5321 if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD)) { 5322 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5323 "st_ioctl : EIO : bspace : end_at_eof && " 5324 "tmp < 0"); 5325 rval = EIO; 5326 } 5327 if (tmp < 0) { 5328 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5329 "st_ioctl : EIO : bspace : tmp < 0"); 5330 rval = EIO; 5331 un->un_err_resid = -tmp; 5332 un->un_status = SUN_KEY_BOT; 5333 } 5334 break; 5335 } 5336 5337 if (un->un_dp->options & ST_BSF) { 5338 skip_cnt = 1 - end_at_eof; 5339 /* 5340 * If we are going to end up at the beginning 5341 * of the file, we have to space one extra file 5342 * first, and then space forward later. 5343 */ 5344 tmp = -(mtop->mt_count + skip_cnt); 5345 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5346 "skip_cnt=%x, tmp=%x\n", skip_cnt, tmp); 5347 if (st_cmd(dev, SCMD_SPACE, Fmk(tmp), SYNC_CMD)) { 5348 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5349 "st_ioctl : EIO : bspace : can't space " 5350 "tmp"); 5351 rval = EIO; 5352 } 5353 } else { 5354 if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD)) { 5355 rval = EIO; 5356 } else { 5357 skip_cnt = tmp + end_at_eof; 5358 } 5359 } 5360 5361 /* 5362 * If we have to space forward, do so... 5363 */ 5364 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5365 "space forward skip_cnt=%x, rval=%x\n", skip_cnt, rval); 5366 if (rval == 0 && skip_cnt) { 5367 if (st_cmd(dev, SCMD_SPACE, Fmk(skip_cnt), SYNC_CMD)) { 5368 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5369 "st_ioctl : EIO : bspace : can't space " 5370 "skip_cnt"); 5371 rval = EIO; 5372 } else if (end_at_eof) { 5373 /* 5374 * If we had to space forward, and we're 5375 * not a tape that can backspace, mark state 5376 * as if we'd just seen a filemark during a 5377 * a read. 5378 */ 5379 if ((un->un_dp->options & ST_BSF) == 0) { 5380 un->un_eof = ST_EOF_PENDING; 5381 un->un_fileno -= 1; 5382 un->un_blkno = INF; 5383 } 5384 } 5385 } 5386 5387 if (rval != 0) { 5388 un->un_fileno = -1; 5389 } 5390 break; 5391 } 5392 5393 case MTNBSF: 5394 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5395 "nbsf: count=%lx, eof=%x\n", mtop->mt_count, 5396 un->un_eof); 5397 /* 5398 * backward space file to beginning of file 5399 * 5400 * If a negative count (which implies a forward space op) 5401 * is specified, and we're at logical or physical eot, 5402 * bounce the request. 5403 */ 5404 5405 if (un->un_eof >= ST_EOT && mtop->mt_count < 0) { 5406 un->un_err_resid = mtop->mt_count; 5407 un->un_status = SUN_KEY_EOT; 5408 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5409 "st_ioctl : EIO : > EOT and count < 0"); 5410 return (EIO); 5411 } 5412 /* 5413 * physical tape position may not be what we've been 5414 * telling the user; adjust the request accordingly 5415 */ 5416 if (IN_EOF(un)) { 5417 un->un_fileno++; 5418 un->un_blkno = 0; 5419 mtop->mt_count++; 5420 } 5421 5422 if (st_check_density_or_wfm(dev, 1, 0, STEPBACK)) { 5423 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5424 "st_ioctl : EIO : MTNBSF check den and wfm"); 5425 return (EIO); 5426 } 5427 5428 mtnbsf: 5429 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5430 "mtnbsf: count=%lx, eof=%x\n", mtop->mt_count, 5431 un->un_eof); 5432 if (mtop->mt_count <= 0) { 5433 mtop->mt_op = MTFSF; 5434 mtop->mt_count = -mtop->mt_count; 5435 goto fspace; 5436 } 5437 goto bspace; 5438 5439 case MTBSR: 5440 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5441 "bsr: count=%lx, eof=%x\n", mtop->mt_count, 5442 un->un_eof); 5443 /* 5444 * backward space into inter-record gap 5445 * 5446 * If a negative count (which implies a forward space op) 5447 * is specified, and we're at logical or physical eot, 5448 * bounce the request. 5449 */ 5450 if (un->un_eof >= ST_EOT && mtop->mt_count < 0) { 5451 un->un_err_resid = mtop->mt_count; 5452 un->un_status = SUN_KEY_EOT; 5453 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5454 "st_ioctl : EIO : MTBSR > EOT"); 5455 return (EIO); 5456 } 5457 5458 if (mtop->mt_count == 0) { 5459 un->un_err_fileno = un->un_fileno; 5460 un->un_err_blkno = un->un_blkno; 5461 un->un_err_resid = 0; 5462 if (IN_EOF(un) && SVR4_BEHAVIOR) { 5463 un->un_status = SUN_KEY_EOF; 5464 } 5465 return (0); 5466 } 5467 5468 /* 5469 * physical tape position may not be what we've been 5470 * telling the user; adjust the position accordingly. 5471 * bsr can not skip filemarks and continue to skip records 5472 * therefore if we are logically before the filemark but 5473 * physically at the EOT side of the filemark, we need to step 5474 * back; this allows fsr N where N > number of blocks in file 5475 * followed by bsr 1 to position at the beginning of last block 5476 */ 5477 if (IN_EOF(un)) { 5478 int blkno = un->un_blkno; 5479 int fileno = un->un_fileno; 5480 uchar_t lastop = un->un_lastop; 5481 if (st_cmd(dev, SCMD_SPACE, Fmk((-1)), SYNC_CMD) 5482 == -1) { 5483 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5484 "st_write_fm : EIO : MTBSR can't space"); 5485 return (EIO); 5486 } 5487 5488 un->un_blkno = blkno; 5489 un->un_fileno = fileno; 5490 un->un_lastop = lastop; 5491 } 5492 5493 un->un_eof = ST_NO_EOF; 5494 5495 if (st_check_density_or_wfm(dev, 1, 0, STEPBACK)) { 5496 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5497 "st_ioctl : EIO : MTBSR : can't set density or " 5498 "wfm"); 5499 return (EIO); 5500 } 5501 5502 mtop->mt_count = -mtop->mt_count; 5503 goto space_records; 5504 5505 case MTSRSZ: 5506 5507 /* 5508 * Set record-size to that sent by user 5509 * Check to see if there is reason that the requested 5510 * block size should not be set. 5511 */ 5512 5513 /* If requesting variable block size is it ok? */ 5514 if ((mtop->mt_count == 0) && 5515 ((un->un_dp->options & ST_VARIABLE) == 0)) { 5516 return (ENOTTY); 5517 } 5518 5519 /* 5520 * If requested block size is not variable "0", 5521 * is it less then minimum. 5522 */ 5523 if ((mtop->mt_count != 0) && 5524 (mtop->mt_count < un->un_minbsize)) { 5525 return (EINVAL); 5526 } 5527 5528 /* Is the requested block size more then maximum */ 5529 if ((mtop->mt_count > min(un->un_maxbsize, un->un_maxdma)) && 5530 (un->un_maxbsize != 0)) { 5531 return (EINVAL); 5532 } 5533 5534 /* Is requested block size a modulus the device likes */ 5535 if ((mtop->mt_count % un->un_data_mod) != 0) { 5536 return (EINVAL); 5537 } 5538 5539 if (st_change_block_size(dev, (uint32_t)mtop->mt_count) != 0) { 5540 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5541 "st_ioctl : MTSRSZ : EIO : cant set block size"); 5542 return (EIO); 5543 } 5544 5545 return (0); 5546 5547 case MTGRSZ: 5548 { 5549 #ifdef _MULTI_DATAMODEL 5550 /* 5551 * For use when a 32 bit app makes a call into a 5552 * 64 bit ioctl 5553 */ 5554 struct mtop32 mtop_32_for_64; 5555 #endif /* _MULTI_DATAMODEL */ 5556 5557 5558 /* 5559 * Get record-size to the user 5560 */ 5561 mtop->mt_count = un->un_bsize; 5562 5563 #ifdef _MULTI_DATAMODEL 5564 switch (ddi_model_convert_from(flag & FMODELS)) { 5565 case DDI_MODEL_ILP32: 5566 /* 5567 * Convert 64 bit back to 32 bit before doing 5568 * copyout. This is what the ILP32 app expects. 5569 */ 5570 mtop_32_for_64.mt_op = mtop->mt_op; 5571 mtop_32_for_64.mt_count = mtop->mt_count; 5572 5573 if (ddi_copyout(&mtop_32_for_64, (void *)arg, 5574 sizeof (struct mtop32), flag)) { 5575 return (EFAULT); 5576 } 5577 break; 5578 5579 case DDI_MODEL_NONE: 5580 if (ddi_copyout(mtop, (void *)arg, 5581 sizeof (struct mtop), flag)) { 5582 return (EFAULT); 5583 } 5584 break; 5585 } 5586 #else /* ! _MULTI_DATAMODE */ 5587 if (ddi_copyout(mtop, (void *)arg, sizeof (struct mtop), flag)) 5588 return (EFAULT); 5589 5590 #endif /* _MULTI_DATAMODE */ 5591 5592 return (0); 5593 } 5594 default: 5595 rval = ENOTTY; 5596 } 5597 5598 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5599 "st_ioctl: fileno=%x, blkno=%lx, un_eof=%x\n", un->un_fileno, 5600 un->un_blkno, un->un_eof); 5601 5602 if (un->un_fileno < 0) { 5603 un->un_density_known = 0; 5604 } 5605 5606 ASSERT(mutex_owned(ST_MUTEX)); 5607 return (rval); 5608 } 5609 5610 5611 /* 5612 * Run a command for uscsi ioctl. 5613 * cdbspace is address space of cdb. 5614 * dataspace is address space of the uscsi data buffer. 5615 */ 5616 static int 5617 st_ioctl_cmd(dev_t dev, struct uscsi_cmd *ucmd, 5618 enum uio_seg cdbspace, enum uio_seg dataspace, 5619 enum uio_seg rqbufspace) 5620 { 5621 struct buf *bp; 5622 struct uscsi_cmd *kcmd; 5623 caddr_t kcdb; 5624 int flag; 5625 int err; 5626 int rqlen; 5627 int offline_state = 0; 5628 char *krqbuf = NULL; 5629 5630 GET_SOFT_STATE(dev); 5631 5632 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 5633 "st_ioctl_cmd(dev = 0x%lx)\n", dev); 5634 5635 ASSERT(mutex_owned(ST_MUTEX)); 5636 5637 /* 5638 * We really don't know what commands are coming in here and 5639 * we don't want to limit the commands coming in. 5640 * 5641 * If st_tape_init() gets called from st_strategy(), then we 5642 * will hang the process waiting for un->un_sbuf_busy to be cleared, 5643 * which it never will, as we set it below. To prevent 5644 * st_tape_init() from getting called, we have to set state to other 5645 * than ST_STATE_OFFLINE, so we choose ST_STATE_INITIALIZING, which 5646 * achieves this purpose already 5647 * 5648 * We use offline_state to preserve the OFFLINE state, if it exists, 5649 * so other entry points to the driver might have the chance to call 5650 * st_tape_init(). 5651 */ 5652 if (un->un_state == ST_STATE_OFFLINE) { 5653 un->un_laststate = ST_STATE_OFFLINE; 5654 un->un_state = ST_STATE_INITIALIZING; 5655 offline_state = 1; 5656 } 5657 /* 5658 * Is this a request to reset the bus? 5659 * If so, we need go no further. 5660 */ 5661 if (ucmd->uscsi_flags & (USCSI_RESET|USCSI_RESET_ALL)) { 5662 flag = ((ucmd->uscsi_flags & USCSI_RESET_ALL)) ? 5663 RESET_ALL : RESET_TARGET; 5664 5665 mutex_exit(ST_MUTEX); 5666 err = (scsi_reset(ROUTE, flag)) ? 0 : EIO; 5667 mutex_enter(ST_MUTEX); 5668 5669 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 5670 "reset %s %s\n", 5671 (flag == RESET_ALL) ? "all" : "target", 5672 (err == 0) ? "ok" : "failed"); 5673 /* 5674 * If scsi reset successful, don't write any filemarks. 5675 */ 5676 if (err == 0) { 5677 un->un_fmneeded = 0; 5678 } else { 5679 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5680 "st_ioctl_cmd : EIO : scsi_reset failed"); 5681 } 5682 goto exit; 5683 } 5684 5685 /* 5686 * First do some sanity checks for USCSI commands. 5687 */ 5688 if (ucmd->uscsi_cdblen <= 0) { 5689 return (EINVAL); 5690 } 5691 5692 /* 5693 * In order to not worry about where the uscsi structure 5694 * or cdb it points to came from, we kmem_alloc copies 5695 * of them here. This will allow reference to the data 5696 * they contain long after this process has gone to 5697 * sleep and its kernel stack has been unmapped, etc. 5698 */ 5699 5700 kcdb = kmem_alloc((size_t)ucmd->uscsi_cdblen, KM_SLEEP); 5701 if (cdbspace == UIO_SYSSPACE) { 5702 bcopy(ucmd->uscsi_cdb, kcdb, ucmd->uscsi_cdblen); 5703 } else { 5704 if (ddi_copyin(ucmd->uscsi_cdb, kcdb, 5705 (size_t)ucmd->uscsi_cdblen, 0)) { 5706 kmem_free(kcdb, (size_t)ucmd->uscsi_cdblen); 5707 err = EFAULT; 5708 goto exit; 5709 } 5710 } 5711 5712 kcmd = kmem_alloc(sizeof (struct uscsi_cmd), KM_SLEEP); 5713 bcopy(ucmd, kcmd, sizeof (struct uscsi_cmd)); 5714 kcmd->uscsi_cdb = kcdb; 5715 5716 flag = (kcmd->uscsi_flags & USCSI_READ) ? B_READ : B_WRITE; 5717 5718 #ifdef STDEBUG 5719 if (st_debug > 6) { 5720 st_clean_print(ST_DEVINFO, st_label, SCSI_DEBUG, 5721 "uscsi cdb", kcdb, kcmd->uscsi_cdblen); 5722 if (kcmd->uscsi_buflen) { 5723 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5724 "uscsi %s of %ld bytes %s %s space\n", 5725 (flag == B_READ) ? rd_str : wr_str, 5726 kcmd->uscsi_buflen, 5727 (flag == B_READ) ? "to" : "from", 5728 (dataspace == UIO_SYSSPACE) ? "system" : "user"); 5729 } 5730 } 5731 #endif /* ST_DEBUG */ 5732 5733 /* 5734 * Initialize Request Sense buffering, if requested. 5735 * For user processes, allocate a kernel copy of the sense buffer 5736 */ 5737 if ((kcmd->uscsi_flags & USCSI_RQENABLE) && 5738 kcmd->uscsi_rqlen && kcmd->uscsi_rqbuf) { 5739 if (rqbufspace == UIO_USERSPACE) { 5740 krqbuf = kmem_alloc(SENSE_LENGTH, KM_SLEEP); 5741 } 5742 kcmd->uscsi_rqlen = SENSE_LENGTH; 5743 kcmd->uscsi_rqresid = SENSE_LENGTH; 5744 } else { 5745 kcmd->uscsi_rqlen = 0; 5746 kcmd->uscsi_rqresid = 0; 5747 } 5748 5749 /* 5750 * Get buffer resources... 5751 */ 5752 while (un->un_sbuf_busy) 5753 cv_wait(&un->un_sbuf_cv, ST_MUTEX); 5754 un->un_sbuf_busy = 1; 5755 5756 un->un_srqbufp = krqbuf; 5757 bp = un->un_sbufp; 5758 bzero(bp, sizeof (buf_t)); 5759 5760 /* 5761 * Force asynchronous mode, if necessary. 5762 */ 5763 if (ucmd->uscsi_flags & USCSI_ASYNC) { 5764 mutex_exit(ST_MUTEX); 5765 if (scsi_ifgetcap(ROUTE, "synchronous", 1) == 1) { 5766 if (scsi_ifsetcap(ROUTE, "synchronous", 0, 1) == 1) { 5767 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 5768 "forced async ok\n"); 5769 } else { 5770 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 5771 "forced async failed\n"); 5772 err = EINVAL; 5773 mutex_enter(ST_MUTEX); 5774 goto done; 5775 } 5776 } 5777 mutex_enter(ST_MUTEX); 5778 } 5779 5780 /* 5781 * Re-enable synchronous mode, if requested 5782 */ 5783 if (ucmd->uscsi_flags & USCSI_SYNC) { 5784 mutex_exit(ST_MUTEX); 5785 if (scsi_ifgetcap(ROUTE, "synchronous", 1) == 0) { 5786 int i = scsi_ifsetcap(ROUTE, "synchronous", 1, 1); 5787 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 5788 "re-enabled sync %s\n", 5789 (i == 1) ? "ok" : "failed"); 5790 } 5791 mutex_enter(ST_MUTEX); 5792 } 5793 5794 if (kcmd->uscsi_buflen) { 5795 /* 5796 * We're going to do actual I/O. 5797 * Set things up for physio. 5798 */ 5799 struct iovec aiov; 5800 struct uio auio; 5801 struct uio *uio = &auio; 5802 5803 bzero(&auio, sizeof (struct uio)); 5804 bzero(&aiov, sizeof (struct iovec)); 5805 aiov.iov_base = kcmd->uscsi_bufaddr; 5806 aiov.iov_len = kcmd->uscsi_buflen; 5807 5808 uio->uio_iov = &aiov; 5809 uio->uio_iovcnt = 1; 5810 uio->uio_resid = aiov.iov_len; 5811 uio->uio_segflg = dataspace; 5812 5813 /* 5814 * Let physio do the rest... 5815 */ 5816 bp->b_forw = (struct buf *)(uintptr_t)kcdb[0]; 5817 bp->b_back = (struct buf *)kcmd; 5818 5819 mutex_exit(ST_MUTEX); 5820 err = physio(st_strategy, bp, dev, flag, st_uscsi_minphys, uio); 5821 mutex_enter(ST_MUTEX); 5822 } else { 5823 /* 5824 * Mimic physio 5825 */ 5826 bp->b_forw = (struct buf *)(uintptr_t)kcdb[0]; 5827 bp->b_back = (struct buf *)kcmd; 5828 bp->b_flags = B_BUSY | flag; 5829 bp->b_edev = dev; 5830 bp->b_dev = cmpdev(dev); 5831 bp->b_bcount = 0; 5832 bp->b_blkno = 0; 5833 bp->b_resid = 0; 5834 mutex_exit(ST_MUTEX); 5835 (void) st_strategy(bp); 5836 5837 /* 5838 * BugTraq #4260046 5839 * ---------------- 5840 * See comments in st_cmd. 5841 */ 5842 5843 err = biowait(bp); 5844 mutex_enter(ST_MUTEX); 5845 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5846 "st_ioctl_cmd: biowait returns %d\n", err); 5847 } 5848 5849 /* 5850 * Copy status from kernel copy of uscsi_cmd to user copy 5851 * of uscsi_cmd - this was saved in st_done_and_mutex_exit() 5852 */ 5853 ucmd->uscsi_status = kcmd->uscsi_status; 5854 5855 done: 5856 ucmd->uscsi_resid = bp->b_resid; 5857 5858 /* 5859 * Update the Request Sense status and resid 5860 */ 5861 rqlen = kcmd->uscsi_rqlen - kcmd->uscsi_rqresid; 5862 rqlen = min(((int)ucmd->uscsi_rqlen), rqlen); 5863 ucmd->uscsi_rqresid = ucmd->uscsi_rqlen - rqlen; 5864 ucmd->uscsi_rqstatus = kcmd->uscsi_rqstatus; 5865 /* 5866 * Copy out the sense data for user processes 5867 */ 5868 if (ucmd->uscsi_rqbuf && rqlen && rqbufspace == UIO_USERSPACE) { 5869 if (copyout(krqbuf, ucmd->uscsi_rqbuf, rqlen)) { 5870 err = EFAULT; 5871 } 5872 } 5873 5874 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5875 "st_ioctl_cmd status is 0x%x, resid is 0x%lx\n", 5876 ucmd->uscsi_status, ucmd->uscsi_resid); 5877 if (DEBUGGING && (rqlen != 0)) { 5878 int i, n, len; 5879 char *data = krqbuf; 5880 scsi_log(ST_DEVINFO, st_label, SCSI_DEBUG, 5881 "rqstatus=0x%x rqlen=0x%x rqresid=0x%x\n", 5882 ucmd->uscsi_rqstatus, ucmd->uscsi_rqlen, 5883 ucmd->uscsi_rqresid); 5884 len = (int)ucmd->uscsi_rqlen - ucmd->uscsi_rqresid; 5885 for (i = 0; i < len; i += 16) { 5886 n = min(16, len-1); 5887 st_clean_print(ST_DEVINFO, st_label, CE_NOTE, 5888 " ", &data[i], n); 5889 } 5890 } 5891 5892 exit_free: 5893 /* 5894 * Free resources 5895 */ 5896 un->un_sbuf_busy = 0; 5897 un->un_srqbufp = NULL; 5898 cv_signal(&un->un_sbuf_cv); 5899 5900 if (krqbuf) { 5901 kmem_free(krqbuf, SENSE_LENGTH); 5902 } 5903 kmem_free(kcdb, kcmd->uscsi_cdblen); 5904 kmem_free(kcmd, sizeof (struct uscsi_cmd)); 5905 5906 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5907 "st_ioctl_cmd returns 0x%x\n", err); 5908 5909 5910 exit: 5911 /* don't lose offline state */ 5912 if (offline_state) 5913 un->un_state = ST_STATE_OFFLINE; 5914 5915 ASSERT(mutex_owned(ST_MUTEX)); 5916 return (err); 5917 } 5918 5919 static int 5920 st_write_fm(dev_t dev, int wfm) 5921 { 5922 int i; 5923 5924 GET_SOFT_STATE(dev); 5925 5926 ASSERT(mutex_owned(ST_MUTEX)); 5927 5928 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 5929 "st_write_fm(dev = 0x%lx, wfm = %d)\n", dev, wfm); 5930 5931 /* 5932 * write one filemark at the time after EOT 5933 */ 5934 if (un->un_eof >= ST_EOT) { 5935 for (i = 0; i < wfm; i++) { 5936 if (st_cmd(dev, SCMD_WRITE_FILE_MARK, 1, SYNC_CMD)) { 5937 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5938 "st_write_fm : EIO : write EOT file mark"); 5939 return (EIO); 5940 } 5941 } 5942 } else if (st_cmd(dev, SCMD_WRITE_FILE_MARK, wfm, SYNC_CMD)) { 5943 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 5944 "st_write_fm : EIO : write file mark"); 5945 return (EIO); 5946 } 5947 5948 ASSERT(mutex_owned(ST_MUTEX)); 5949 return (0); 5950 } 5951 5952 #ifdef STDEBUG 5953 static void 5954 start_dump(struct scsi_tape *un, struct buf *bp) 5955 { 5956 struct scsi_pkt *pkt = BP_PKT(bp); 5957 uchar_t *cdbp = (uchar_t *)pkt->pkt_cdbp; 5958 5959 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5960 "st_start: cmd=0x%p count=%ld resid=%ld flags=0x%x pkt=0x%p\n", 5961 (void *)bp->b_forw, bp->b_bcount, 5962 bp->b_resid, bp->b_flags, (void *)BP_PKT(bp)); 5963 5964 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 5965 "st_start: cdb %x %x %x %x %x %x, fileno=%d, blk=%ld\n", 5966 cdbp[0], cdbp[1], cdbp[2], 5967 cdbp[3], cdbp[4], cdbp[5], un->un_fileno, 5968 un->un_blkno); 5969 } 5970 #endif 5971 5972 5973 /* 5974 * Command start && done functions 5975 */ 5976 5977 /* 5978 * st_start() 5979 * 5980 * Called from: 5981 * st_strategy() to start a command. 5982 * st_runout() to retry when scsi_pkt allocation fails on previous attempt(s). 5983 * st_attach() when resuming from power down state. 5984 * st_start_restart() to retry transport when device was previously busy. 5985 * st_done_and_mutex_exit() to start the next command when previous is done. 5986 * 5987 * On entry: 5988 * scsi_pkt may or may not be allocated. 5989 * 5990 */ 5991 static void 5992 st_start(struct scsi_tape *un) 5993 { 5994 struct buf *bp; 5995 int status; 5996 5997 ASSERT(mutex_owned(ST_MUTEX)); 5998 5999 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6000 "st_start(): dev = 0x%lx\n", un->un_dev); 6001 6002 if ((bp = un->un_quef) == NULL) { 6003 return; 6004 } 6005 6006 ASSERT((bp->b_flags & B_DONE) == 0); 6007 6008 /* 6009 * Don't send more than un_throttle commands to the HBA 6010 */ 6011 if ((un->un_throttle <= 0) || (un->un_ncmds >= un->un_throttle)) { 6012 return; 6013 } 6014 6015 /* 6016 * If the buf has no scsi_pkt call st_make_cmd() to get one and 6017 * build the command. 6018 */ 6019 if (BP_PKT(bp) == NULL) { 6020 ASSERT((bp->b_flags & B_DONE) == 0); 6021 st_make_cmd(un, bp, st_runout); 6022 ASSERT((bp->b_flags & B_DONE) == 0); 6023 status = geterror(bp); 6024 6025 /* 6026 * Some HBA's don't call bioerror() to set an error. 6027 * And geterror() returns zero if B_ERROR is not set. 6028 * So if we get zero we must check b_error. 6029 */ 6030 if (status == 0 && bp->b_error != 0) { 6031 status = bp->b_error; 6032 bioerror(bp, status); 6033 } 6034 6035 /* 6036 * Some HBA's convert DDI_DMA_NORESOURCES into ENOMEM. 6037 * In tape ENOMEM has special meaning so we'll change it. 6038 */ 6039 if (status == ENOMEM) { 6040 status = 0; 6041 bioerror(bp, status); 6042 } 6043 6044 /* 6045 * Did it fail and is it retryable? 6046 * If so return and wait for the callback through st_runout. 6047 * Also looks like scsi_init_pkt() will setup a callback even 6048 * if it isn't retryable. 6049 */ 6050 if (BP_PKT(bp) == NULL) { 6051 if (status == 0) { 6052 /* 6053 * If first attempt save state. 6054 */ 6055 if (un->un_state != ST_STATE_RESOURCE_WAIT) { 6056 un->un_laststate = un->un_state; 6057 un->un_state = ST_STATE_RESOURCE_WAIT; 6058 } 6059 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 6060 "temp no resources for pkt\n"); 6061 } else { 6062 /* 6063 * Unlikely that it would be retryable then not. 6064 */ 6065 if (un->un_state == ST_STATE_RESOURCE_WAIT) { 6066 un->un_state = un->un_laststate; 6067 } 6068 scsi_log(ST_DEVINFO, st_label, SCSI_DEBUG, 6069 "perm no resources for pkt errno = 0x%x\n", 6070 status); 6071 } 6072 return; 6073 } 6074 /* 6075 * Worked this time set the state back. 6076 */ 6077 if (un->un_state == ST_STATE_RESOURCE_WAIT) { 6078 un->un_state = un->un_laststate; 6079 } 6080 } 6081 6082 /* 6083 * move from waitq to runq 6084 */ 6085 un->un_quef = bp->b_actf; 6086 if (un->un_quel == bp) { 6087 /* 6088 * For the case of queue having one 6089 * element, set the tail pointer to 6090 * point to the element. 6091 */ 6092 un->un_quel = bp->b_actf; 6093 } 6094 6095 bp->b_actf = NULL; 6096 6097 if (un->un_runqf) { 6098 un->un_runql->b_actf = bp; 6099 } else { 6100 un->un_runqf = bp; 6101 } 6102 un->un_runql = bp; 6103 6104 6105 #ifdef STDEBUG 6106 start_dump(un, bp); 6107 #endif 6108 6109 /* could not get here if throttle was zero */ 6110 un->un_last_throttle = un->un_throttle; 6111 un->un_throttle = 0; /* so nothing else will come in here */ 6112 un->un_ncmds++; 6113 6114 ST_DO_KSTATS(bp, kstat_waitq_to_runq); 6115 6116 mutex_exit(ST_MUTEX); 6117 6118 status = scsi_transport(BP_PKT(bp)); 6119 6120 mutex_enter(ST_MUTEX); 6121 6122 if (un->un_last_throttle) { 6123 un->un_throttle = un->un_last_throttle; 6124 } 6125 6126 if (status != TRAN_ACCEPT) { 6127 ST_DO_KSTATS(bp, kstat_runq_back_to_waitq); 6128 mutex_exit(ST_MUTEX); 6129 6130 if (status == TRAN_BUSY) { 6131 /* if too many retries, fail the transport */ 6132 if (st_handle_start_busy(un, bp, 6133 ST_TRAN_BUSY_TIMEOUT) == 0) 6134 goto done; 6135 } 6136 scsi_log(ST_DEVINFO, st_label, CE_WARN, 6137 "transport rejected\n"); 6138 bp->b_resid = bp->b_bcount; 6139 6140 6141 #ifndef __lock_lint 6142 /* 6143 * warlock doesn't understand this potential 6144 * recursion? 6145 */ 6146 mutex_enter(ST_MUTEX); 6147 ST_DO_KSTATS(bp, kstat_waitq_exit); 6148 ST_DO_ERRSTATS(un, st_transerrs); 6149 st_bioerror(bp, EIO); 6150 SET_PE_FLAG(un); 6151 st_done_and_mutex_exit(un, bp); 6152 #endif 6153 } else { 6154 un->un_tran_retry_ct = 0; 6155 mutex_exit(ST_MUTEX); 6156 } 6157 6158 done: 6159 6160 mutex_enter(ST_MUTEX); 6161 } 6162 6163 /* 6164 * if the transport is busy, then put this bp back on the waitq 6165 */ 6166 static int 6167 st_handle_start_busy(struct scsi_tape *un, struct buf *bp, 6168 clock_t timeout_interval) 6169 { 6170 struct buf *last_quef, *runq_bp; 6171 int rval = 0; 6172 6173 mutex_enter(ST_MUTEX); 6174 6175 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6176 "st_handle_start_busy()\n"); 6177 6178 /* 6179 * Check to see if we hit the retry timeout and one last check for 6180 * making sure this is the last on the runq, if it is not, we have 6181 * to fail 6182 */ 6183 if (((int)un->un_tran_retry_ct++ > st_retry_count) || 6184 (un->un_runql != bp)) { 6185 rval = -1; 6186 goto exit; 6187 } 6188 6189 /* put the bp back on the waitq */ 6190 if (un->un_quef) { 6191 last_quef = un->un_quef; 6192 un->un_quef = bp; 6193 bp->b_actf = last_quef; 6194 } else { 6195 bp->b_actf = NULL; 6196 un->un_quef = bp; 6197 un->un_quel = bp; 6198 } 6199 6200 /* 6201 * Decrement un_ncmds so that this 6202 * gets thru' st_start() again. 6203 */ 6204 un->un_ncmds--; 6205 6206 /* 6207 * since this is an error case, we won't have to do 6208 * this list walking much. We've already made sure this bp was the 6209 * last on the runq 6210 */ 6211 runq_bp = un->un_runqf; 6212 6213 if (un->un_runqf == bp) { 6214 un->un_runqf = NULL; 6215 un->un_runql = NULL; 6216 } else { 6217 while (runq_bp) { 6218 if (runq_bp->b_actf == bp) { 6219 runq_bp->b_actf = NULL; 6220 un->un_runql = runq_bp; 6221 break; 6222 } 6223 runq_bp = runq_bp->b_actf; 6224 } 6225 } 6226 6227 6228 /* 6229 * send a marker pkt, if appropriate 6230 */ 6231 st_hba_unflush(un); 6232 6233 /* 6234 * all queues are aligned, we are just waiting to 6235 * transport, don't alloc any more buf p's, when 6236 * st_start is reentered. 6237 */ 6238 (void) timeout(st_start_restart, un, timeout_interval); 6239 6240 exit: 6241 mutex_exit(ST_MUTEX); 6242 return (rval); 6243 } 6244 6245 6246 6247 /* 6248 * st_runout a callback that is called what a resource allocatation failed 6249 */ 6250 static int 6251 st_runout(caddr_t arg) 6252 { 6253 struct scsi_tape *un = (struct scsi_tape *)arg; 6254 struct buf *bp; 6255 6256 ASSERT(un != NULL); 6257 6258 mutex_enter(ST_MUTEX); 6259 6260 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_runout()\n"); 6261 6262 bp = un->un_quef; 6263 6264 /* 6265 * failed scsi_init_pkt(). If errno is zero its retryable. 6266 */ 6267 if ((bp != NULL) && (geterror(bp) != 0)) { 6268 6269 scsi_log(ST_DEVINFO, st_label, CE_WARN, 6270 "errors after pkt alloc (b_flags=0x%x, b_error=0x%x)\n", 6271 bp->b_flags, geterror(bp)); 6272 ASSERT((bp->b_flags & B_DONE) == 0); 6273 6274 un->un_quef = bp->b_actf; 6275 if (un->un_quel == bp) { 6276 /* 6277 * For the case of queue having one 6278 * element, set the tail pointer to 6279 * point to the element. 6280 */ 6281 un->un_quel = bp->b_actf; 6282 } 6283 bp->b_actf = NULL; 6284 6285 ASSERT((bp->b_flags & B_DONE) == 0); 6286 6287 /* 6288 * Set resid, Error already set, then unblock calling thread. 6289 */ 6290 bp->b_resid = bp->b_bcount; 6291 biodone(bp); 6292 } else { 6293 /* 6294 * Try Again 6295 */ 6296 st_start(un); 6297 } 6298 6299 mutex_exit(ST_MUTEX); 6300 6301 /* 6302 * Comments courtesy of sd.c 6303 * The scsi_init_pkt routine allows for the callback function to 6304 * return a 0 indicating the callback should be rescheduled or a 1 6305 * indicating not to reschedule. This routine always returns 1 6306 * because the driver always provides a callback function to 6307 * scsi_init_pkt. This results in a callback always being scheduled 6308 * (via the scsi_init_pkt callback implementation) if a resource 6309 * failure occurs. 6310 */ 6311 6312 return (1); 6313 } 6314 6315 /* 6316 * st_done_and_mutex_exit() 6317 * - remove bp from runq 6318 * - start up the next request 6319 * - if this was an asynch bp, clean up 6320 * - exit with released mutex 6321 */ 6322 static void 6323 st_done_and_mutex_exit(struct scsi_tape *un, struct buf *bp) 6324 { 6325 struct buf *runqbp, *prevbp; 6326 int pe_flagged = 0; 6327 6328 ASSERT(MUTEX_HELD(&un->un_sd->sd_mutex)); 6329 #if !defined(lint) 6330 _NOTE(LOCK_RELEASED_AS_SIDE_EFFECT(&un->un_sd->sd_mutex)) 6331 #endif 6332 ASSERT(mutex_owned(ST_MUTEX)); 6333 6334 /* 6335 * if bp is still on the runq (anywhere), then remove it 6336 */ 6337 prevbp = NULL; 6338 for (runqbp = un->un_runqf; runqbp != 0; runqbp = runqbp->b_actf) { 6339 if (runqbp == bp) { 6340 if (runqbp == un->un_runqf) { 6341 un->un_runqf = bp->b_actf; 6342 } else { 6343 prevbp->b_actf = bp->b_actf; 6344 } 6345 if (un->un_runql == bp) { 6346 un->un_runql = prevbp; 6347 } 6348 break; 6349 } 6350 prevbp = runqbp; 6351 } 6352 bp->b_actf = NULL; 6353 6354 un->un_ncmds--; 6355 cv_signal(&un->un_queue_cv); 6356 6357 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6358 "st_done_and_mutex_exit(): cmd=0x%x count=%ld resid=%ld flags=0x%x\n", 6359 (int)*((caddr_t)(BP_PKT(bp))->pkt_cdbp), 6360 bp->b_bcount, bp->b_resid, bp->b_flags); 6361 6362 6363 /* 6364 * update kstats with transfer count info 6365 */ 6366 if (un->un_stats && (bp != un->un_sbufp) && IS_RW(bp)) { 6367 uint32_t n_done = bp->b_bcount - bp->b_resid; 6368 if (bp->b_flags & B_READ) { 6369 IOSP->reads++; 6370 IOSP->nread += n_done; 6371 } else { 6372 IOSP->writes++; 6373 IOSP->nwritten += n_done; 6374 } 6375 } 6376 6377 /* 6378 * Start the next one before releasing resources on this one, if 6379 * there is something on the queue and persistent errors has not been 6380 * flagged 6381 */ 6382 6383 if ((pe_flagged = IS_PE_FLAG_SET(un)) != 0) { 6384 un->un_last_resid = bp->b_resid; 6385 un->un_last_count = bp->b_bcount; 6386 } 6387 6388 if (un->un_pwr_mgmt == ST_PWR_SUSPENDED) { 6389 cv_broadcast(&un->un_tape_busy_cv); 6390 } else if (un->un_quef && un->un_throttle && !pe_flagged) { 6391 st_start(un); 6392 } 6393 6394 if (bp == un->un_sbufp && (bp->b_flags & B_ASYNC)) { 6395 /* 6396 * Since we marked this ourselves as ASYNC, 6397 * there isn't anybody around waiting for 6398 * completion any more. 6399 */ 6400 uchar_t com = (uchar_t)(uintptr_t)bp->b_forw; 6401 if (com == SCMD_READ || com == SCMD_WRITE) { 6402 bp->b_un.b_addr = (caddr_t)0; 6403 } 6404 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 6405 "st_done_and_mutex_exit(async): freeing pkt\n"); 6406 scsi_destroy_pkt(BP_PKT(bp)); 6407 un->un_sbuf_busy = 0; 6408 cv_signal(&un->un_sbuf_cv); 6409 mutex_exit(ST_MUTEX); 6410 return; 6411 } 6412 6413 if (bp == un->un_sbufp && BP_UCMD(bp)) { 6414 /* 6415 * Copy status from scsi_pkt to uscsi_cmd 6416 * since st_ioctl_cmd needs it 6417 */ 6418 BP_UCMD(bp)->uscsi_status = SCBP_C(BP_PKT(bp)); 6419 } 6420 6421 6422 #ifdef STDEBUG 6423 if ((st_debug >= 4) && 6424 (((un->un_blkno % 100) == 0) || IS_PE_FLAG_SET(un))) { 6425 6426 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 6427 "st_d_a_m_exit(): ncmds = %d, thr = %d, " 6428 "un_errno = %d, un_pe = %d\n", 6429 un->un_ncmds, un->un_throttle, un->un_errno, 6430 un->un_persist_errors); 6431 } 6432 6433 #endif 6434 6435 mutex_exit(ST_MUTEX); 6436 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 6437 "st_done_and_mutex_exit: freeing pkt\n"); 6438 6439 scsi_destroy_pkt(BP_PKT(bp)); 6440 6441 biodone(bp); 6442 6443 /* 6444 * now that we biodoned that command, if persistent errors have been 6445 * flagged, flush the waitq 6446 */ 6447 if (pe_flagged) 6448 st_flush(un); 6449 } 6450 6451 6452 /* 6453 * Tape error, flush tape driver queue. 6454 */ 6455 static void 6456 st_flush(struct scsi_tape *un) 6457 { 6458 struct buf *bp; 6459 6460 mutex_enter(ST_MUTEX); 6461 6462 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 6463 "st_flush(), ncmds = %d, quef = 0x%p\n", 6464 un->un_ncmds, (void *)un->un_quef); 6465 6466 /* 6467 * if we still have commands outstanding, wait for them to come in 6468 * before flushing the queue, and make sure there is a queue 6469 */ 6470 if (un->un_ncmds || !un->un_quef) 6471 goto exit; 6472 6473 /* 6474 * we have no more commands outstanding, so let's deal with special 6475 * cases in the queue for EOM and FM. If we are here, and un_errno 6476 * is 0, then we know there was no error and we return a 0 read or 6477 * write before showing errors 6478 */ 6479 6480 /* Flush the wait queue. */ 6481 while ((bp = un->un_quef) != NULL) { 6482 un->un_quef = bp->b_actf; 6483 6484 bp->b_resid = bp->b_bcount; 6485 6486 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 6487 "st_flush() : blkno=%ld, err=%d, b_bcount=%ld\n", 6488 un->un_blkno, un->un_errno, bp->b_bcount); 6489 6490 st_set_pe_errno(un); 6491 6492 bioerror(bp, un->un_errno); 6493 6494 mutex_exit(ST_MUTEX); 6495 /* it should have one, but check anyway */ 6496 if (BP_PKT(bp)) { 6497 scsi_destroy_pkt(BP_PKT(bp)); 6498 } 6499 biodone(bp); 6500 mutex_enter(ST_MUTEX); 6501 } 6502 6503 /* 6504 * It's not a bad practice to reset the 6505 * waitq tail pointer to NULL. 6506 */ 6507 un->un_quel = NULL; 6508 6509 exit: 6510 /* we mucked with the queue, so let others know about it */ 6511 cv_signal(&un->un_queue_cv); 6512 mutex_exit(ST_MUTEX); 6513 } 6514 6515 6516 /* 6517 * Utility functions 6518 */ 6519 static int 6520 st_determine_generic(dev_t dev) 6521 { 6522 int bsize; 6523 static char *cart = "0.25 inch cartridge"; 6524 char *sizestr; 6525 6526 GET_SOFT_STATE(dev); 6527 6528 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6529 "st_determine_generic(dev = 0x%lx)\n", dev); 6530 6531 ASSERT(mutex_owned(ST_MUTEX)); 6532 6533 if (st_modesense(un)) { 6534 return (-1); 6535 } 6536 6537 bsize = (un->un_mspl->high_bl << 16) | 6538 (un->un_mspl->mid_bl << 8) | 6539 (un->un_mspl->low_bl); 6540 6541 if (bsize == 0) { 6542 un->un_dp->options |= ST_VARIABLE; 6543 un->un_dp->bsize = 0; 6544 un->un_bsize = 0; 6545 } else if (bsize > ST_MAXRECSIZE_FIXED) { 6546 /* 6547 * record size of this device too big. 6548 * try and convert it to variable record length. 6549 * 6550 */ 6551 un->un_dp->options |= ST_VARIABLE; 6552 if (st_change_block_size(dev, 0) != 0) { 6553 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 6554 "Fixed Record Size %d is too large\n", bsize); 6555 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 6556 "Cannot switch to variable record size\n"); 6557 un->un_dp->options &= ~ST_VARIABLE; 6558 return (-1); 6559 } 6560 } else if (st_change_block_size(dev, 0) == 0) { 6561 /* 6562 * If the drive was set to a non zero block size, 6563 * See if it can be set to a zero block size. 6564 * If it works, ST_VARIABLE so user can set it as they want. 6565 */ 6566 un->un_dp->options |= ST_VARIABLE; 6567 un->un_dp->bsize = 0; 6568 un->un_bsize = 0; 6569 } else { 6570 un->un_dp->bsize = bsize; 6571 un->un_bsize = bsize; 6572 } 6573 6574 6575 switch (un->un_mspl->density) { 6576 default: 6577 case 0x0: 6578 /* 6579 * default density, cannot determine any other 6580 * information. 6581 */ 6582 sizestr = "Unknown type- assuming 0.25 inch cartridge"; 6583 un->un_dp->type = ST_TYPE_DEFAULT; 6584 un->un_dp->options |= (ST_AUTODEN_OVERRIDE|ST_QIC); 6585 break; 6586 case 0x1: 6587 case 0x2: 6588 case 0x3: 6589 case 0x6: 6590 /* 6591 * 1/2" reel 6592 */ 6593 sizestr = "0.50 inch reel"; 6594 un->un_dp->type = ST_TYPE_REEL; 6595 un->un_dp->options |= ST_REEL; 6596 un->un_dp->densities[0] = 0x1; 6597 un->un_dp->densities[1] = 0x2; 6598 un->un_dp->densities[2] = 0x6; 6599 un->un_dp->densities[3] = 0x3; 6600 break; 6601 case 0x4: 6602 case 0x5: 6603 case 0x7: 6604 case 0x0b: 6605 6606 /* 6607 * Quarter inch. 6608 */ 6609 sizestr = cart; 6610 un->un_dp->type = ST_TYPE_DEFAULT; 6611 un->un_dp->options |= ST_QIC; 6612 6613 un->un_dp->densities[1] = 0x4; 6614 un->un_dp->densities[2] = 0x5; 6615 un->un_dp->densities[3] = 0x7; 6616 un->un_dp->densities[0] = 0x0b; 6617 break; 6618 6619 case 0x0f: 6620 case 0x10: 6621 case 0x11: 6622 case 0x12: 6623 /* 6624 * QIC-120, QIC-150, QIC-320, QIC-600 6625 */ 6626 sizestr = cart; 6627 un->un_dp->type = ST_TYPE_DEFAULT; 6628 un->un_dp->options |= ST_QIC; 6629 un->un_dp->densities[0] = 0x0f; 6630 un->un_dp->densities[1] = 0x10; 6631 un->un_dp->densities[2] = 0x11; 6632 un->un_dp->densities[3] = 0x12; 6633 break; 6634 6635 case 0x09: 6636 case 0x0a: 6637 case 0x0c: 6638 case 0x0d: 6639 /* 6640 * 1/2" cartridge tapes. Include HI-TC. 6641 */ 6642 sizestr = cart; 6643 sizestr[2] = '5'; 6644 sizestr[3] = '0'; 6645 un->un_dp->type = ST_TYPE_HIC; 6646 un->un_dp->densities[0] = 0x09; 6647 un->un_dp->densities[1] = 0x0a; 6648 un->un_dp->densities[2] = 0x0c; 6649 un->un_dp->densities[3] = 0x0d; 6650 break; 6651 6652 case 0x13: 6653 /* DDS-2/DDS-3 scsi spec densities */ 6654 case 0x24: 6655 case 0x25: 6656 case 0x26: 6657 sizestr = "DAT Data Storage (DDS)"; 6658 un->un_dp->type = ST_TYPE_DAT; 6659 un->un_dp->options |= ST_AUTODEN_OVERRIDE; 6660 break; 6661 6662 case 0x14: 6663 /* 6664 * Helical Scan (Exabyte) devices 6665 */ 6666 sizestr = "8mm helical scan cartridge"; 6667 un->un_dp->type = ST_TYPE_EXABYTE; 6668 un->un_dp->options |= ST_AUTODEN_OVERRIDE; 6669 break; 6670 } 6671 6672 /* 6673 * Assume LONG ERASE, BSF and BSR 6674 */ 6675 6676 un->un_dp->options |= (ST_LONG_ERASE|ST_UNLOADABLE|ST_BSF| 6677 ST_BSR|ST_KNOWS_EOD); 6678 6679 /* 6680 * Only if mode sense data says no buffered write, set NOBUF 6681 */ 6682 if (un->un_mspl->bufm == 0) 6683 un->un_dp->options |= ST_NOBUF; 6684 6685 /* 6686 * set up large read and write retry counts 6687 */ 6688 6689 un->un_dp->max_rretries = un->un_dp->max_wretries = 1000; 6690 6691 /* 6692 * If this is a 0.50 inch reel tape, and 6693 * it is *not* variable mode, try and 6694 * set it to variable record length 6695 * mode. 6696 */ 6697 if ((un->un_dp->options & ST_REEL) && un->un_bsize != 0 && 6698 (un->un_dp->options & ST_VARIABLE)) { 6699 if (st_change_block_size(dev, 0) == 0) { 6700 un->un_dp->bsize = 0; 6701 un->un_mspl->high_bl = un->un_mspl->mid_bl = 6702 un->un_mspl->low_bl = 0; 6703 } 6704 } 6705 6706 /* 6707 * Write to console about type of device found 6708 */ 6709 ST_DEBUG6(ST_DEVINFO, st_label, CE_NOTE, 6710 "Generic Drive, Vendor=%s\n\t%s", un->un_dp->name, 6711 sizestr); 6712 if (un->un_dp->options & ST_VARIABLE) { 6713 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 6714 "!Variable record length I/O\n"); 6715 } else { 6716 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 6717 "!Fixed record length (%d byte blocks) I/O\n", 6718 un->un_dp->bsize); 6719 } 6720 ASSERT(mutex_owned(ST_MUTEX)); 6721 return (0); 6722 } 6723 6724 static int 6725 st_determine_density(dev_t dev, int rw) 6726 { 6727 int rval = 0; 6728 6729 GET_SOFT_STATE(dev); 6730 6731 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6732 "st_determine_density(dev = 0x%lx, rw = %s)\n", 6733 dev, (rw == B_WRITE ? wr_str: rd_str)); 6734 6735 ASSERT(mutex_owned(ST_MUTEX)); 6736 6737 /* 6738 * If we're past BOT, density is determined already. 6739 */ 6740 if (un->un_fileno > 0 || (un->un_fileno == 0 && un->un_blkno != 0)) { 6741 /* 6742 * XXX: put in a bitch message about attempting to 6743 * XXX: change density past BOT. 6744 */ 6745 goto exit; 6746 } 6747 6748 /* 6749 * If we're going to be writing, we set the density 6750 */ 6751 if (rw == 0 || rw == B_WRITE) { 6752 /* un_curdens is used as an index into densities table */ 6753 un->un_curdens = MT_DENSITY(un->un_dev); 6754 if (st_set_density(dev)) { 6755 rval = -1; 6756 } 6757 goto exit; 6758 } 6759 6760 /* 6761 * If density is known already, 6762 * we don't have to get it again.(?) 6763 */ 6764 if (!un->un_density_known) { 6765 if (st_get_density(dev)) { 6766 rval = -1; 6767 } 6768 } 6769 6770 exit: 6771 ASSERT(mutex_owned(ST_MUTEX)); 6772 return (rval); 6773 } 6774 6775 6776 /* 6777 * Try to determine density. We do this by attempting to read the 6778 * first record off the tape, cycling through the available density 6779 * codes as we go. 6780 */ 6781 6782 static int 6783 st_get_density(dev_t dev) 6784 { 6785 int succes = 0, rval = -1, i; 6786 uint_t size; 6787 uchar_t dens, olddens; 6788 6789 GET_SOFT_STATE(dev); 6790 6791 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6792 "st_get_density(dev = 0x%lx)\n", dev); 6793 6794 ASSERT(mutex_owned(ST_MUTEX)); 6795 6796 /* 6797 * If Auto Density override is enabled The drive has 6798 * only one density and there is no point in attempting 6799 * find the correct one. 6800 * 6801 * Since most modern drives auto detect the density 6802 * and format of the recorded media before they come 6803 * ready. What this function does is a legacy behavior 6804 * and modern drives not only don't need it, The backup 6805 * utilities that do positioning via uscsi find the un- 6806 * expected rewinds problematic. 6807 * 6808 * The drives that need this are old reel to reel devices. 6809 * I took a swag and said they must be scsi-1 or older. 6810 * I don't beleave there will any of the newer devices 6811 * that need this. There will be some scsi-1 devices that 6812 * don't need this but I don't think they will be using the 6813 * BIG aftermarket backup and restore utilitys. 6814 */ 6815 if ((un->un_dp->options & ST_AUTODEN_OVERRIDE) || 6816 (un->un_sd->sd_inq->inq_ansi > 1)) { 6817 un->un_density_known = 1; 6818 rval = 0; 6819 goto exit; 6820 } 6821 6822 /* 6823 * This will only work on variable record length tapes 6824 * if and only if all variable record length tapes autodensity 6825 * select. 6826 */ 6827 size = (unsigned)(un->un_dp->bsize ? un->un_dp->bsize : SECSIZE); 6828 un->un_tmpbuf = kmem_alloc(size, KM_SLEEP); 6829 6830 /* 6831 * Start at the specified density 6832 */ 6833 6834 dens = olddens = un->un_curdens = MT_DENSITY(un->un_dev); 6835 6836 for (i = 0; i < NDENSITIES; i++, ((un->un_curdens == NDENSITIES - 1) ? 6837 (un->un_curdens = 0) : 6838 (un->un_curdens += 1))) { 6839 /* 6840 * If we've done this density before, 6841 * don't bother to do it again. 6842 */ 6843 dens = un->un_dp->densities[un->un_curdens]; 6844 if (i > 0 && dens == olddens) 6845 continue; 6846 olddens = dens; 6847 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 6848 "trying density 0x%x\n", dens); 6849 if (st_set_density(dev)) { 6850 continue; 6851 } 6852 6853 /* 6854 * XXX - the creates lots of headaches and slowdowns - must 6855 * fix. 6856 */ 6857 succes = (st_cmd(dev, SCMD_READ, (int)size, SYNC_CMD) == 0); 6858 if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD)) { 6859 break; 6860 } 6861 if (succes) { 6862 st_init(un); 6863 rval = 0; 6864 un->un_density_known = 1; 6865 break; 6866 } 6867 } 6868 kmem_free(un->un_tmpbuf, size); 6869 un->un_tmpbuf = 0; 6870 6871 exit: 6872 ASSERT(mutex_owned(ST_MUTEX)); 6873 return (rval); 6874 } 6875 6876 static int 6877 st_set_density(dev_t dev) 6878 { 6879 int rval = 0; 6880 6881 GET_SOFT_STATE(dev); 6882 6883 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6884 "st_set_density(dev = 0x%lx): density = 0x%x\n", dev, 6885 un->un_dp->densities[un->un_curdens]); 6886 6887 ASSERT(mutex_owned(ST_MUTEX)); 6888 6889 un->un_mspl->density = un->un_dp->densities[un->un_curdens]; 6890 6891 if ((un->un_dp->options & ST_AUTODEN_OVERRIDE) == 0) { 6892 /* 6893 * If auto density override is not set, Use mode select 6894 * to set density and compression. 6895 */ 6896 if (st_modeselect(un)) { 6897 rval = -1; 6898 } 6899 } else if ((un->un_dp->options & ST_MODE_SEL_COMP) != 0) { 6900 /* 6901 * If auto density and mode select compression are set, 6902 * This is a drive with one density code but compression 6903 * can be enabled or disabled. 6904 * Set compression but no need to set density. 6905 */ 6906 rval = st_set_compression(un); 6907 if ((rval != 0) && (rval != EALREADY)) { 6908 rval = -1; 6909 } else { 6910 rval = 0; 6911 } 6912 } 6913 6914 /* If sucessful set density and/or compression, mark density known */ 6915 if (rval == 0) { 6916 un->un_density_known = 1; 6917 } 6918 6919 ASSERT(mutex_owned(ST_MUTEX)); 6920 return (rval); 6921 } 6922 6923 static int 6924 st_loadtape(dev_t dev) 6925 { 6926 int rval = 0; 6927 6928 GET_SOFT_STATE(dev); 6929 6930 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6931 "st_loadtape(dev = 0x%lx)\n", dev); 6932 6933 ASSERT(mutex_owned(ST_MUTEX)); 6934 6935 /* 6936 * 'LOAD' the tape to BOT by rewinding 6937 */ 6938 if (st_cmd(dev, SCMD_REWIND, 1, SYNC_CMD)) { 6939 rval = -1; 6940 } else { 6941 st_init(un); 6942 un->un_density_known = 0; 6943 } 6944 6945 ASSERT(mutex_owned(ST_MUTEX)); 6946 return (rval); 6947 } 6948 6949 6950 /* 6951 * Note: QIC devices aren't so smart. If you try to append 6952 * after EOM, the write can fail because the device doesn't know 6953 * it's at EOM. In that case, issue a read. The read should fail 6954 * because there's no data, but the device knows it's at EOM, 6955 * so a subsequent write should succeed. To further confuse matters, 6956 * the target returns the same error if the tape is positioned 6957 * such that a write would overwrite existing data. That's why 6958 * we have to do the append test. A read in the middle of 6959 * recorded data would succeed, thus indicating we're attempting 6960 * something illegal. 6961 */ 6962 6963 void bp_mapin(struct buf *bp); 6964 6965 static void 6966 st_test_append(struct buf *bp) 6967 { 6968 dev_t dev = bp->b_edev; 6969 struct scsi_tape *un; 6970 uchar_t status; 6971 unsigned bcount; 6972 6973 un = ddi_get_soft_state(st_state, MTUNIT(dev)); 6974 6975 ASSERT(mutex_owned(ST_MUTEX)); 6976 6977 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 6978 "st_test_append(): fileno %d\n", un->un_fileno); 6979 6980 un->un_laststate = un->un_state; 6981 un->un_state = ST_STATE_APPEND_TESTING; 6982 un->un_test_append = 0; 6983 6984 /* 6985 * first, map in the buffer, because we're doing a double write -- 6986 * first into the kernel, then onto the tape. 6987 */ 6988 bp_mapin(bp); 6989 6990 /* 6991 * get a copy of the data.... 6992 */ 6993 un->un_tmpbuf = kmem_alloc((unsigned)bp->b_bcount, KM_SLEEP); 6994 bcopy(bp->b_un.b_addr, un->un_tmpbuf, (uint_t)bp->b_bcount); 6995 6996 /* 6997 * attempt the write.. 6998 */ 6999 7000 if (st_cmd(dev, (int)SCMD_WRITE, (int)bp->b_bcount, SYNC_CMD) == 0) { 7001 success: 7002 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7003 "append write succeeded\n"); 7004 bp->b_resid = un->un_sbufp->b_resid; 7005 mutex_exit(ST_MUTEX); 7006 bcount = (unsigned)bp->b_bcount; 7007 biodone(bp); 7008 mutex_enter(ST_MUTEX); 7009 un->un_laststate = un->un_state; 7010 un->un_state = ST_STATE_OPEN; 7011 kmem_free(un->un_tmpbuf, bcount); 7012 un->un_tmpbuf = NULL; 7013 return; 7014 } 7015 7016 /* 7017 * The append failed. Do a short read. If that fails, we are at EOM 7018 * so we can retry the write command. If that succeeds, than we're 7019 * all screwed up (the controller reported a real error). 7020 * 7021 * XXX: should the dummy read be > SECSIZE? should it be the device's 7022 * XXX: block size? 7023 * 7024 */ 7025 status = un->un_status; 7026 un->un_status = 0; 7027 (void) st_cmd(dev, SCMD_READ, SECSIZE, SYNC_CMD); 7028 if (un->un_status == KEY_BLANK_CHECK) { 7029 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7030 "append at EOM\n"); 7031 /* 7032 * Okay- the read failed. We should actually have confused 7033 * the controller enough to allow writing. In any case, the 7034 * i/o is on its own from here on out. 7035 */ 7036 un->un_laststate = un->un_state; 7037 un->un_state = ST_STATE_OPEN; 7038 bcopy(bp->b_un.b_addr, un->un_tmpbuf, (uint_t)bp->b_bcount); 7039 if (st_cmd(dev, (int)SCMD_WRITE, (int)bp->b_bcount, 7040 SYNC_CMD) == 0) { 7041 goto success; 7042 } 7043 } 7044 7045 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7046 "append write failed- not at EOM\n"); 7047 bp->b_resid = bp->b_bcount; 7048 st_bioerror(bp, EIO); 7049 7050 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 7051 "st_test_append : EIO : append write failed - not at EOM"); 7052 7053 /* 7054 * backspace one record to get back to where we were 7055 */ 7056 if (st_cmd(dev, SCMD_SPACE, Blk(-1), SYNC_CMD)) { 7057 un->un_fileno = -1; 7058 } 7059 7060 un->un_err_resid = bp->b_resid; 7061 un->un_status = status; 7062 7063 /* 7064 * Note: biodone will do a bp_mapout() 7065 */ 7066 mutex_exit(ST_MUTEX); 7067 bcount = (unsigned)bp->b_bcount; 7068 biodone(bp); 7069 mutex_enter(ST_MUTEX); 7070 un->un_laststate = un->un_state; 7071 un->un_state = ST_STATE_OPEN_PENDING_IO; 7072 kmem_free(un->un_tmpbuf, bcount); 7073 un->un_tmpbuf = NULL; 7074 } 7075 7076 /* 7077 * Special command handler 7078 */ 7079 7080 /* 7081 * common st_cmd code. The fourth parameter states 7082 * whether the caller wishes to await the results 7083 * Note the release of the mutex during most of the function 7084 */ 7085 static int 7086 st_cmd(dev_t dev, int com, int count, int wait) 7087 { 7088 struct buf *bp; 7089 int err; 7090 7091 GET_SOFT_STATE(dev); 7092 7093 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 7094 "st_cmd(dev = 0x%lx, com = 0x%x, count = %x, wait = %d)\n", 7095 dev, com, count, wait); 7096 7097 ASSERT(MUTEX_HELD(&un->un_sd->sd_mutex)); 7098 ASSERT(mutex_owned(ST_MUTEX)); 7099 7100 #ifdef STDEBUG 7101 if (st_debug) 7102 st_debug_cmds(un, com, count, wait); 7103 #endif 7104 7105 while (un->un_sbuf_busy) 7106 cv_wait(&un->un_sbuf_cv, ST_MUTEX); 7107 un->un_sbuf_busy = 1; 7108 7109 bp = un->un_sbufp; 7110 bzero(bp, sizeof (buf_t)); 7111 7112 bp->b_flags = (wait) ? B_BUSY : B_BUSY|B_ASYNC; 7113 7114 /* 7115 * Set count to the actual size of the data tranfer. 7116 * For commands with no data transfer, set bp->b_bcount 7117 * to the value to be used when constructing the 7118 * cdb in st_make_cmd(). 7119 */ 7120 switch (com) { 7121 case SCMD_READ: 7122 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7123 "special read %d\n", count); 7124 bp->b_flags |= B_READ; 7125 bp->b_un.b_addr = un->un_tmpbuf; 7126 break; 7127 7128 case SCMD_WRITE: 7129 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7130 "special write %d\n", count); 7131 bp->b_un.b_addr = un->un_tmpbuf; 7132 break; 7133 7134 case SCMD_WRITE_FILE_MARK: 7135 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7136 "write %d file marks\n", count); 7137 bp->b_bcount = count; 7138 count = 0; 7139 break; 7140 7141 case SCMD_REWIND: 7142 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "rewind\n"); 7143 bp->b_bcount = 0; 7144 count = 0; 7145 break; 7146 7147 case SCMD_SPACE: 7148 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "space\n"); 7149 bp->b_bcount = count; 7150 count = 0; 7151 break; 7152 7153 case SCMD_RESERVE: 7154 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "reserve"); 7155 bp->b_bcount = 0; 7156 count = 0; 7157 break; 7158 7159 case SCMD_RELEASE: 7160 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "release"); 7161 bp->b_bcount = 0; 7162 count = 0; 7163 break; 7164 7165 case SCMD_LOAD: 7166 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7167 "%s tape\n", (count) ? "load" : "unload"); 7168 bp->b_bcount = count; 7169 count = 0; 7170 break; 7171 7172 case SCMD_ERASE: 7173 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7174 "erase tape\n"); 7175 bp->b_bcount = 0; 7176 count = 0; 7177 break; 7178 7179 case SCMD_MODE_SENSE: 7180 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7181 "mode sense\n"); 7182 bp->b_flags |= B_READ; 7183 bp->b_un.b_addr = (caddr_t)(un->un_mspl); 7184 break; 7185 7186 case SCMD_MODE_SELECT: 7187 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7188 "mode select\n"); 7189 bp->b_un.b_addr = (caddr_t)(un->un_mspl); 7190 break; 7191 7192 case SCMD_READ_BLKLIM: 7193 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7194 "read block limits\n"); 7195 bp->b_flags |= B_READ; 7196 bp->b_un.b_addr = (caddr_t)(un->un_rbl); 7197 break; 7198 7199 case SCMD_TEST_UNIT_READY: 7200 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7201 "test unit ready\n"); 7202 bp->b_bcount = 0; 7203 count = 0; 7204 break; 7205 default: 7206 ST_DEBUG(ST_DEVINFO, st_label, CE_PANIC, 7207 "Unhandled scsi command 0x%x in st_cmd()\n", com); 7208 } 7209 7210 mutex_exit(ST_MUTEX); 7211 7212 if (count > 0) { 7213 /* 7214 * We're going to do actual I/O. 7215 * Set things up for physio. 7216 */ 7217 struct iovec aiov; 7218 struct uio auio; 7219 struct uio *uio = &auio; 7220 7221 bzero(&auio, sizeof (struct uio)); 7222 bzero(&aiov, sizeof (struct iovec)); 7223 aiov.iov_base = bp->b_un.b_addr; 7224 aiov.iov_len = count; 7225 7226 uio->uio_iov = &aiov; 7227 uio->uio_iovcnt = 1; 7228 uio->uio_resid = aiov.iov_len; 7229 uio->uio_segflg = UIO_SYSSPACE; 7230 7231 /* 7232 * Let physio do the rest... 7233 */ 7234 bp->b_forw = (struct buf *)(uintptr_t)com; 7235 bp->b_back = NULL; 7236 err = physio(st_strategy, bp, dev, 7237 (bp->b_flags & B_READ) ? B_READ : B_WRITE, 7238 st_minphys, uio); 7239 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7240 "st_cmd: physio returns %d\n", err); 7241 } else { 7242 /* 7243 * Mimic physio 7244 */ 7245 bp->b_forw = (struct buf *)(uintptr_t)com; 7246 bp->b_back = NULL; 7247 bp->b_edev = dev; 7248 bp->b_dev = cmpdev(dev); 7249 bp->b_blkno = 0; 7250 bp->b_resid = 0; 7251 (void) st_strategy(bp); 7252 if (!wait) { 7253 /* 7254 * This is an async command- the caller won't wait 7255 * and doesn't care about errors. 7256 */ 7257 mutex_enter(ST_MUTEX); 7258 return (0); 7259 } 7260 7261 /* 7262 * BugTraq #4260046 7263 * ---------------- 7264 * Restore Solaris 2.5.1 behavior, namely call biowait 7265 * unconditionally. The old comment said... 7266 * 7267 * "if strategy was flagged with persistent errors, we would 7268 * have an error here, and the bp would never be sent, so we 7269 * don't want to wait on a bp that was never sent...or hang" 7270 * 7271 * The new rationale, courtesy of Chitrank... 7272 * 7273 * "we should unconditionally biowait() here because 7274 * st_strategy() will do a biodone() in the persistent error 7275 * case and the following biowait() will return immediately. 7276 * If not, in the case of "errors after pkt alloc" in 7277 * st_start(), we will not biowait here which will cause the 7278 * next biowait() to return immediately which will cause 7279 * us to send out the next command. In the case where both of 7280 * these use the sbuf, when the first command completes we'll 7281 * free the packet attached to sbuf and the same pkt will 7282 * get freed again when we complete the second command. 7283 * see esc 518987. BTW, it is necessary to do biodone() in 7284 * st_start() for the pkt alloc failure case because physio() 7285 * does biowait() and will hang if we don't do biodone()" 7286 */ 7287 7288 err = biowait(bp); 7289 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7290 "st_cmd: biowait returns %d\n", err); 7291 } 7292 mutex_enter(ST_MUTEX); 7293 7294 un->un_sbuf_busy = 0; 7295 cv_signal(&un->un_sbuf_cv); 7296 return (err); 7297 } 7298 7299 static int 7300 st_set_compression(struct scsi_tape *un) 7301 { 7302 int rval; 7303 int turn_compression_on; 7304 minor_t minor; 7305 7306 /* 7307 * Drive either dosn't have compression or it is controlled with 7308 * special density codes. Return ENOTTY so caller 7309 * knows nothing was done. 7310 */ 7311 if ((un->un_dp->options & ST_MODE_SEL_COMP) == 0) { 7312 un->un_comp_page = 0; 7313 return (ENOTTY); 7314 } 7315 7316 /* set compression based on minor node opened */ 7317 minor = MT_DENSITY(un->un_dev); 7318 7319 /* 7320 * If this the compression density or 7321 * the drive has two densities and uses mode select for 7322 * control of compression turn on compression for MT_DENSITY2 7323 * as well. 7324 */ 7325 if ((minor == ST_COMPRESSION_DENSITY) || 7326 (minor == MT_DENSITY(MT_DENSITY2)) && 7327 (un->un_dp->densities[0] == un->un_dp->densities[1]) && 7328 (un->un_dp->densities[2] == un->un_dp->densities[3]) && 7329 (un->un_dp->densities[0] != un->un_dp->densities[2])) { 7330 7331 turn_compression_on = 1; 7332 } else { 7333 turn_compression_on = 0; 7334 } 7335 7336 un->un_mspl->high_bl = (uchar_t)(un->un_bsize >> 16); 7337 un->un_mspl->mid_bl = (uchar_t)(un->un_bsize >> 8); 7338 un->un_mspl->low_bl = (uchar_t)(un->un_bsize); 7339 7340 /* 7341 * Need to determine which page does the device use for compression. 7342 * First try the data compression page. If this fails try the device 7343 * configuration page 7344 */ 7345 7346 if ((un->un_comp_page & ST_DEV_DATACOMP_PAGE) == ST_DEV_DATACOMP_PAGE) { 7347 rval = st_set_datacomp_page(un, turn_compression_on); 7348 if (rval == EALREADY) { 7349 return (rval); 7350 } 7351 if (rval != 0) { 7352 if (un->un_status == KEY_ILLEGAL_REQUEST) { 7353 /* 7354 * This device does not support data 7355 * compression page 7356 */ 7357 un->un_comp_page = ST_DEV_CONFIG_PAGE; 7358 } else if (un->un_state >= ST_STATE_OPEN) { 7359 un->un_fileno = -1; 7360 rval = EIO; 7361 } else { 7362 rval = -1; 7363 } 7364 } else { 7365 un->un_comp_page = ST_DEV_DATACOMP_PAGE; 7366 } 7367 } 7368 7369 if ((un->un_comp_page & ST_DEV_CONFIG_PAGE) == ST_DEV_CONFIG_PAGE) { 7370 rval = st_set_devconfig_page(un, turn_compression_on); 7371 if (rval == EALREADY) { 7372 return (rval); 7373 } 7374 if (rval != 0) { 7375 if (un->un_status == KEY_ILLEGAL_REQUEST) { 7376 /* 7377 * This device does not support 7378 * compression at all advice the 7379 * user and unset ST_MODE_SEL_COMP 7380 */ 7381 un->un_dp->options &= ~ST_MODE_SEL_COMP; 7382 un->un_comp_page = 0; 7383 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 7384 "Device Does Not Support Compression\n"); 7385 } else if (un->un_state >= ST_STATE_OPEN) { 7386 un->un_fileno = -1; 7387 rval = EIO; 7388 } else { 7389 rval = -1; 7390 } 7391 } 7392 } 7393 7394 return (rval); 7395 } 7396 7397 /* 7398 * set or unset compression thru device configuration page. 7399 */ 7400 static int 7401 st_set_devconfig_page(struct scsi_tape *un, int compression_on) 7402 { 7403 unsigned char cflag; 7404 int rval = 0; 7405 7406 ASSERT(mutex_owned(ST_MUTEX)); 7407 7408 /* 7409 * Figure what to set compression flag to. 7410 */ 7411 if (compression_on) { 7412 /* They have selected a compression node */ 7413 if (un->un_dp->type == ST_TYPE_FUJI) { 7414 cflag = 0x84; /* use EDRC */ 7415 } else { 7416 cflag = ST_DEV_CONFIG_DEF_COMP; 7417 } 7418 } else { 7419 cflag = ST_DEV_CONFIG_NO_COMP; 7420 } 7421 7422 /* 7423 * If compression is already set the way it was requested. 7424 * And if this not the first time we has tried. 7425 */ 7426 if ((cflag == un->un_mspl->page.dev.comp_alg) && 7427 (un->un_comp_page == ST_DEV_DATACOMP_PAGE)) { 7428 return (EALREADY); 7429 } 7430 7431 un->un_mspl->page.dev.comp_alg = cflag; 7432 /* 7433 * need to send mode select even if correct compression is 7434 * already set since need to set density code 7435 */ 7436 7437 #ifdef STDEBUG 7438 if (st_debug >= 6) { 7439 st_clean_print(ST_DEVINFO, st_label, SCSI_DEBUG, 7440 "st_set_devconfig_page: sense data for mode select", 7441 (char *)un->un_mspl, sizeof (struct seq_mode)); 7442 } 7443 #endif 7444 rval = st_gen_mode_select(un, un->un_mspl, sizeof (struct seq_mode)); 7445 7446 return (rval); 7447 } 7448 7449 /* 7450 * set/reset compression bit thru data compression page 7451 */ 7452 static int 7453 st_set_datacomp_page(struct scsi_tape *un, int compression_on) 7454 { 7455 int compression_on_already; 7456 int rval = 0; 7457 7458 ASSERT(mutex_owned(ST_MUTEX)); 7459 7460 /* 7461 * If drive is not capable of compression (at this time) 7462 * return EALREADY so caller doesn't think that this page 7463 * is not supported. This check is for drives that can 7464 * disable compression from the front panel or configuration. 7465 * I doubt that a drive that supports this page is not really 7466 * capable of compression. 7467 */ 7468 if (un->un_mspl->page.comp.dcc == 0) { 7469 return (EALREADY); 7470 } 7471 7472 /* See if compression currently turned on */ 7473 if (un->un_mspl->page.comp.dce) { 7474 compression_on_already = 1; 7475 } else { 7476 compression_on_already = 0; 7477 } 7478 7479 /* 7480 * If compression is already set the way it was requested. 7481 * And if this not the first time we has tried. 7482 */ 7483 if ((compression_on == compression_on_already) && 7484 (un->un_comp_page == ST_DEV_DATACOMP_PAGE)) { 7485 return (EALREADY); 7486 } 7487 7488 /* 7489 * if we are already set to the appropriate compression 7490 * mode, don't set it again 7491 */ 7492 if (compression_on) { 7493 /* compression selected */ 7494 un->un_mspl->page.comp.dce = 1; 7495 } else { 7496 un->un_mspl->page.comp.dce = 0; 7497 } 7498 7499 7500 #ifdef STDEBUG 7501 if (st_debug >= 6) { 7502 st_clean_print(ST_DEVINFO, st_label, SCSI_DEBUG, 7503 "st_set_datacomp_page: sense data for mode select", 7504 (char *)un->un_mspl, sizeof (struct seq_mode)); 7505 } 7506 #endif 7507 rval = st_gen_mode_select(un, un->un_mspl, sizeof (struct seq_mode)); 7508 7509 return (rval); 7510 } 7511 7512 static int 7513 st_modesense(struct scsi_tape *un) 7514 { 7515 int rval; 7516 uchar_t page; 7517 7518 page = un->un_comp_page; 7519 7520 switch (page) { 7521 case ST_DEV_DATACOMP_PAGE: 7522 case ST_DEV_CONFIG_PAGE: /* fall through */ 7523 rval = st_gen_mode_sense(un, page, un->un_mspl, 7524 sizeof (struct seq_mode)); 7525 break; 7526 7527 case ST_DEV_DATACOMP_PAGE | ST_DEV_CONFIG_PAGE: 7528 if (un->un_dp->options & ST_MODE_SEL_COMP) { 7529 page = ST_DEV_DATACOMP_PAGE; 7530 rval = st_gen_mode_sense(un, page, un->un_mspl, 7531 sizeof (struct seq_mode)); 7532 if (rval == 0 && un->un_mspl->page_code == page) { 7533 un->un_comp_page = page; 7534 break; 7535 } 7536 page = ST_DEV_CONFIG_PAGE; 7537 rval = st_gen_mode_sense(un, page, un->un_mspl, 7538 sizeof (struct seq_mode)); 7539 if (rval == 0 && un->un_mspl->page_code == page) { 7540 un->un_comp_page = page; 7541 break; 7542 } 7543 un->un_dp->options &= ~ST_MODE_SEL_COMP; 7544 un->un_comp_page = 0; 7545 } else { 7546 un->un_comp_page = 0; 7547 } 7548 7549 default: /* fall through */ 7550 rval = st_cmd(un->un_dev, SCMD_MODE_SENSE, MSIZE, SYNC_CMD); 7551 } 7552 return (rval); 7553 } 7554 7555 static int 7556 st_modeselect(struct scsi_tape *un) 7557 { 7558 int rval = 0; 7559 int ix; 7560 7561 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 7562 "st_modeselect(dev = 0x%lx): density = 0x%x\n", 7563 un->un_dev, un->un_mspl->density); 7564 7565 ASSERT(mutex_owned(ST_MUTEX)); 7566 7567 /* 7568 * The parameter list should be the same for all of the 7569 * cases that follow so set them here 7570 * 7571 * Try mode select first if if fails set fields manually 7572 */ 7573 rval = st_modesense(un); 7574 if (rval != 0) { 7575 ST_DEBUG3(ST_DEVINFO, st_label, CE_WARN, 7576 "st_modeselect: First mode sense failed\n"); 7577 un->un_mspl->bd_len = 8; 7578 un->un_mspl->high_nb = 0; 7579 un->un_mspl->mid_nb = 0; 7580 un->un_mspl->low_nb = 0; 7581 } 7582 un->un_mspl->high_bl = (uchar_t)(un->un_bsize >> 16); 7583 un->un_mspl->mid_bl = (uchar_t)(un->un_bsize >> 8); 7584 un->un_mspl->low_bl = (uchar_t)(un->un_bsize); 7585 7586 7587 /* 7588 * If configured to use a specific density code for a media type. 7589 * curdens is previously set by the minor node opened. 7590 * If the media type doesn't match the minor node we change it so it 7591 * looks like the correct one was opened. 7592 */ 7593 if (un->un_dp->options & ST_KNOWS_MEDIA) { 7594 uchar_t best; 7595 7596 for (best = 0xff, ix = 0; ix < NDENSITIES; ix++) { 7597 if (un->un_mspl->media_type == 7598 un->un_dp->mediatype[ix]) { 7599 best = ix; 7600 /* 7601 * It matches but it might not be the only one. 7602 * Use the highest matching media type but not 7603 * to exceed the density selected by the open. 7604 */ 7605 if (ix < un->un_curdens) { 7606 continue; 7607 } 7608 un->un_curdens = ix; 7609 break; 7610 } 7611 } 7612 /* If a match was found best will not be 0xff any more */ 7613 if (best < NDENSITIES) { 7614 ST_DEBUG3(ST_DEVINFO, st_label, CE_WARN, 7615 "found media 0x%X using density 0x%X\n", 7616 un->un_mspl->media_type, 7617 un->un_dp->densities[best]); 7618 } 7619 7620 un->un_mspl->density = un->un_dp->densities[best]; 7621 7622 } else { 7623 /* Otherwise set density based on minor node opened */ 7624 un->un_mspl->density = un->un_dp->densities[un->un_curdens]; 7625 } 7626 7627 if (un->un_dp->options & ST_NOBUF) { 7628 un->un_mspl->bufm = 0; 7629 } else { 7630 un->un_mspl->bufm = 1; 7631 } 7632 7633 rval = st_set_compression(un); 7634 7635 /* 7636 * If st_set_compression returned invalid or already it 7637 * found no need to do the mode select. 7638 * So do it here. 7639 */ 7640 if ((rval == ENOTTY) || (rval == EALREADY)) { 7641 7642 /* Zero non-writeable fields */ 7643 un->un_mspl->data_len = 0; 7644 un->un_mspl->media_type = 0; 7645 un->un_mspl->wp = 0; 7646 7647 /* need to set the density code */ 7648 rval = st_cmd(un->un_dev, SCMD_MODE_SELECT, MSIZE, SYNC_CMD); 7649 if (rval != 0) { 7650 if (un->un_state >= ST_STATE_OPEN) { 7651 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 7652 "unable to set tape mode\n"); 7653 un->un_fileno = -1; 7654 rval = EIO; 7655 } else { 7656 rval = -1; 7657 } 7658 } 7659 } 7660 7661 /* 7662 * The spec recommends to send a mode sense after a mode select 7663 */ 7664 (void) st_modesense(un); 7665 7666 ASSERT(mutex_owned(ST_MUTEX)); 7667 7668 return (rval); 7669 } 7670 7671 /* 7672 * st_gen_mode_sense 7673 * 7674 * generic mode sense.. it allows for any page 7675 */ 7676 static int 7677 st_gen_mode_sense(struct scsi_tape *un, int page, struct seq_mode *page_data, 7678 int page_size) 7679 { 7680 7681 int r; 7682 char cdb[CDB_GROUP0]; 7683 struct uscsi_cmd *com; 7684 7685 com = kmem_zalloc(sizeof (*com), KM_SLEEP); 7686 7687 bzero(cdb, CDB_GROUP0); 7688 cdb[0] = SCMD_MODE_SENSE; 7689 cdb[2] = (char)page; 7690 cdb[4] = (char)page_size; 7691 7692 com->uscsi_cdb = cdb; 7693 com->uscsi_cdblen = CDB_GROUP0; 7694 com->uscsi_bufaddr = (caddr_t)page_data; 7695 com->uscsi_buflen = page_size; 7696 com->uscsi_timeout = un->un_dp->non_motion_timeout; 7697 com->uscsi_flags = USCSI_DIAGNOSE | USCSI_SILENT | 7698 USCSI_READ | USCSI_RQENABLE; 7699 7700 r = st_ioctl_cmd(un->un_dev, com, UIO_SYSSPACE, UIO_SYSSPACE, 7701 UIO_SYSSPACE); 7702 kmem_free(com, sizeof (*com)); 7703 return (r); 7704 } 7705 7706 /* 7707 * st_gen_mode_select 7708 * 7709 * generic mode select.. it allows for any page 7710 */ 7711 static int 7712 st_gen_mode_select(struct scsi_tape *un, struct seq_mode *page_data, 7713 int page_size) 7714 { 7715 7716 int r; 7717 char cdb[CDB_GROUP0]; 7718 struct uscsi_cmd *com; 7719 7720 /* Zero non-writeable fields */ 7721 page_data->data_len = 0; 7722 page_data->media_type = 0; 7723 page_data->wp = 0; 7724 7725 /* 7726 * If mode select has any page data, zero the ps (Page Savable) bit. 7727 */ 7728 if (page_size > MSIZE) { 7729 page_data->ps = 0; 7730 } 7731 7732 7733 com = kmem_zalloc(sizeof (*com), KM_SLEEP); 7734 7735 /* 7736 * then, do a mode select to set what ever info 7737 */ 7738 bzero(cdb, CDB_GROUP0); 7739 cdb[0] = SCMD_MODE_SELECT; 7740 cdb[1] = 0x10; /* set PF bit for many third party drives */ 7741 cdb[4] = (char)page_size; 7742 7743 com->uscsi_cdb = cdb; 7744 com->uscsi_cdblen = CDB_GROUP0; 7745 com->uscsi_bufaddr = (caddr_t)page_data; 7746 com->uscsi_buflen = page_size; 7747 com->uscsi_timeout = un->un_dp->non_motion_timeout; 7748 com->uscsi_flags = USCSI_DIAGNOSE | USCSI_SILENT 7749 | USCSI_WRITE | USCSI_RQENABLE; 7750 7751 r = st_ioctl_cmd(un->un_dev, com, UIO_SYSSPACE, UIO_SYSSPACE, 7752 UIO_SYSSPACE); 7753 7754 kmem_free(com, sizeof (*com)); 7755 return (r); 7756 } 7757 7758 /* 7759 * Changes devices blocksize and bsize to requested blocksize nblksz. 7760 * Returns returned value from first failed call or zero on success. 7761 */ 7762 static int 7763 st_change_block_size(dev_t dev, uint32_t nblksz) 7764 { 7765 struct seq_mode *current; 7766 int rval; 7767 uint32_t oldblksz; 7768 7769 GET_SOFT_STATE(dev); 7770 7771 current = kmem_zalloc(MSIZE, KM_SLEEP); 7772 7773 /* Read current settings */ 7774 rval = st_gen_mode_sense(un, 0, current, MSIZE); 7775 if (rval != 0) { 7776 scsi_log(ST_DEVINFO, st_label, SCSI_DEBUG, 7777 "mode sense for change block size failed: rval = %d", rval); 7778 goto finish; 7779 } 7780 7781 /* Figure the current block size */ 7782 oldblksz = 7783 (current->high_bl << 16) | 7784 (current->mid_bl << 8) | 7785 (current->low_bl); 7786 7787 /* If current block size is the same as requested were done */ 7788 if (oldblksz == nblksz) { 7789 un->un_bsize = nblksz; 7790 rval = 0; 7791 goto finish; 7792 } 7793 7794 /* Change to requested block size */ 7795 current->high_bl = (uchar_t)(nblksz >> 16); 7796 current->mid_bl = (uchar_t)(nblksz >> 8); 7797 current->low_bl = (uchar_t)(nblksz); 7798 7799 /* Attempt to change block size */ 7800 rval = st_gen_mode_select(un, current, MSIZE); 7801 if (rval != 0) { 7802 scsi_log(ST_DEVINFO, st_label, SCSI_DEBUG, 7803 "Set new block size failed: rval = %d", rval); 7804 goto finish; 7805 } 7806 7807 /* Read back and verify setting */ 7808 rval = st_modesense(un); 7809 if (rval == 0) { 7810 un->un_bsize = 7811 (un->un_mspl->high_bl << 16) | 7812 (un->un_mspl->mid_bl << 8) | 7813 (un->un_mspl->low_bl); 7814 7815 if (un->un_bsize != nblksz) { 7816 scsi_log(ST_DEVINFO, st_label, SCSI_DEBUG, 7817 "Blocksize set does not equal requested blocksize" 7818 "(read: %u requested: %u)\n", nblksz, un->un_bsize); 7819 rval = EIO; 7820 } 7821 } 7822 finish: 7823 kmem_free(current, MSIZE); 7824 return (rval); 7825 } 7826 7827 7828 static void 7829 st_init(struct scsi_tape *un) 7830 { 7831 ASSERT(mutex_owned(ST_MUTEX)); 7832 7833 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 7834 "st_init(): dev = 0x%lx, will reset fileno, blkno, eof\n", un->un_dev); 7835 7836 un->un_blkno = 0; 7837 un->un_fileno = 0; 7838 un->un_lastop = ST_OP_NIL; 7839 un->un_eof = ST_NO_EOF; 7840 un->un_pwr_mgmt = ST_PWR_NORMAL; 7841 if (st_error_level != SCSI_ERR_ALL) { 7842 if (DEBUGGING) { 7843 st_error_level = SCSI_ERR_ALL; 7844 } else { 7845 st_error_level = SCSI_ERR_RETRYABLE; 7846 } 7847 } 7848 } 7849 7850 7851 static void 7852 st_make_cmd(struct scsi_tape *un, struct buf *bp, int (*func)(caddr_t)) 7853 { 7854 struct scsi_pkt *pkt; 7855 struct uscsi_cmd *ucmd; 7856 int count, tval = 0; 7857 int flags = 0; 7858 uchar_t com; 7859 char fixbit; 7860 7861 ASSERT(mutex_owned(ST_MUTEX)); 7862 7863 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 7864 "st_make_cmd(): dev = 0x%lx\n", un->un_dev); 7865 7866 7867 /* 7868 * fixbit is for setting the Fixed Mode and Suppress Incorrect 7869 * Length Indicator bits on read/write commands, for setting 7870 * the Long bit on erase commands, and for setting the Code 7871 * Field bits on space commands. 7872 * XXX why do we set lastop here? 7873 */ 7874 7875 if (bp != un->un_sbufp) { /* regular raw I/O */ 7876 int stat_size = (un->un_arq_enabled ? 7877 sizeof (struct scsi_arq_status) : 1); 7878 pkt = scsi_init_pkt(ROUTE, NULL, bp, 7879 CDB_GROUP0, stat_size, 0, 0, func, (caddr_t)un); 7880 if (pkt == NULL) { 7881 goto exit; 7882 } 7883 SET_BP_PKT(bp, pkt); 7884 if (un->un_bsize == 0) { 7885 count = bp->b_bcount; 7886 fixbit = 0; 7887 } else { 7888 count = bp->b_bcount / un->un_bsize; 7889 fixbit = 1; 7890 } 7891 if (bp->b_flags & B_READ) { 7892 com = SCMD_READ; 7893 un->un_lastop = ST_OP_READ; 7894 if ((un->un_bsize == 0) && /* Not Fixed Block */ 7895 (un->un_dp->options & ST_READ_IGNORE_ILI)) { 7896 fixbit = 2; 7897 } 7898 } else { 7899 com = SCMD_WRITE; 7900 un->un_lastop = ST_OP_WRITE; 7901 } 7902 7903 tval = un->un_dp->io_timeout; 7904 7905 /* 7906 * For really large xfers, increase timeout 7907 */ 7908 if (bp->b_bcount > (10 * ONE_MEG)) 7909 tval *= bp->b_bcount/(10 * ONE_MEG); 7910 7911 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7912 "%s %ld amt 0x%lx\n", (com == SCMD_WRITE) ? 7913 wr_str: rd_str, un->un_blkno, bp->b_bcount); 7914 7915 } else if ((ucmd = BP_UCMD(bp)) != NULL) { 7916 /* 7917 * uscsi - build command, allocate scsi resources 7918 */ 7919 st_make_uscsi_cmd(un, ucmd, bp, func); 7920 goto exit; 7921 7922 } else { /* special I/O */ 7923 struct buf *allocbp = NULL; 7924 int stat_size = (un->un_arq_enabled ? 7925 sizeof (struct scsi_arq_status) : 1); 7926 7927 7928 com = (uchar_t)(uintptr_t)bp->b_forw; 7929 count = bp->b_bcount; 7930 7931 switch (com) { 7932 case SCMD_READ: 7933 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7934 "special read %d\n", count); 7935 if (un->un_bsize == 0) { 7936 fixbit = 2; /* suppress SILI */ 7937 } else { 7938 fixbit = 1; /* Fixed Block Mode */ 7939 count /= un->un_bsize; 7940 } 7941 allocbp = bp; 7942 un->un_lastop = ST_OP_READ; 7943 tval = un->un_dp->io_timeout; 7944 break; 7945 7946 case SCMD_WRITE: 7947 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7948 "special write %d\n", count); 7949 if (un->un_bsize != 0) { 7950 fixbit = 1; /* Fixed Block Mode */ 7951 count /= un->un_bsize; 7952 } else { 7953 fixbit = 0; 7954 } 7955 allocbp = bp; 7956 un->un_lastop = ST_OP_WRITE; 7957 tval = un->un_dp->io_timeout; 7958 break; 7959 7960 case SCMD_WRITE_FILE_MARK: 7961 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7962 "write %d file marks\n", count); 7963 un->un_lastop = ST_OP_WEOF; 7964 fixbit = 0; 7965 tval = un->un_dp->io_timeout; 7966 break; 7967 7968 case SCMD_REWIND: 7969 fixbit = 0; 7970 count = 0; 7971 un->un_lastop = ST_OP_CTL; 7972 tval = un->un_dp->rewind_timeout; 7973 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7974 "rewind\n"); 7975 break; 7976 7977 case SCMD_SPACE: 7978 fixbit = Isfmk(count); 7979 count = (int)space_cnt(count); 7980 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7981 "space %d %s from file %d blk %ld\n", 7982 count, (fixbit) ? "filemarks" : "records", 7983 un->un_fileno, un->un_blkno); 7984 un->un_lastop = ST_OP_CTL; 7985 tval = un->un_dp->space_timeout; 7986 break; 7987 7988 case SCMD_LOAD: 7989 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 7990 "%s tape\n", (count & 1) ? "load" : "unload"); 7991 fixbit = 0; 7992 7993 /* Loading or Unloading */ 7994 if (count & 1) { 7995 tval = un->un_dp->load_timeout; 7996 } else { 7997 tval = un->un_dp->unload_timeout; 7998 } 7999 /* Is Retension requested */ 8000 if (count & 2) { 8001 tval += un->un_dp->rewind_timeout; 8002 } 8003 un->un_lastop = ST_OP_CTL; 8004 break; 8005 8006 case SCMD_ERASE: 8007 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8008 "erase tape\n"); 8009 count = 0; 8010 /* 8011 * We support long erase only 8012 */ 8013 fixbit = 1; 8014 tval = un->un_dp->erase_timeout; 8015 un->un_lastop = ST_OP_CTL; 8016 break; 8017 8018 case SCMD_MODE_SENSE: 8019 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8020 "mode sense\n"); 8021 allocbp = bp; 8022 fixbit = 0; 8023 tval = un->un_dp->non_motion_timeout; 8024 break; 8025 8026 case SCMD_MODE_SELECT: 8027 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8028 "mode select\n"); 8029 allocbp = bp; 8030 fixbit = 0; 8031 tval = un->un_dp->non_motion_timeout; 8032 break; 8033 8034 case SCMD_RESERVE: 8035 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8036 "reserve\n"); 8037 fixbit = 0; 8038 tval = un->un_dp->non_motion_timeout; 8039 break; 8040 8041 case SCMD_RELEASE: 8042 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8043 "release\n"); 8044 fixbit = 0; 8045 tval = un->un_dp->non_motion_timeout; 8046 break; 8047 8048 case SCMD_READ_BLKLIM: 8049 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8050 "read block limits\n"); 8051 allocbp = bp; 8052 fixbit = count = 0; 8053 tval = un->un_dp->non_motion_timeout; 8054 break; 8055 8056 case SCMD_TEST_UNIT_READY: 8057 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8058 "test unit ready\n"); 8059 fixbit = 0; 8060 tval = un->un_dp->non_motion_timeout; 8061 break; 8062 default: 8063 ST_DEBUG(ST_DEVINFO, st_label, CE_PANIC, 8064 "Unhandled scsi command 0x%x in st_make_cmd()\n", 8065 com); 8066 } 8067 pkt = scsi_init_pkt(ROUTE, NULL, allocbp, 8068 CDB_GROUP0, stat_size, 0, 0, func, (caddr_t)un); 8069 if (pkt == NULL) { 8070 goto exit; 8071 } 8072 if (allocbp) 8073 ASSERT(geterror(allocbp) == 0); 8074 8075 } 8076 8077 (void) scsi_setup_cdb((union scsi_cdb *)pkt->pkt_cdbp, 8078 com, 0, (uint_t)count, 0); 8079 FILL_SCSI1_LUN(un->un_sd, pkt); 8080 /* 8081 * Initialize the SILI/Fixed bits of the byte 1 of cdb. 8082 */ 8083 ((union scsi_cdb *)(pkt->pkt_cdbp))->t_code = fixbit; 8084 pkt->pkt_flags = flags; 8085 8086 /* 8087 * If ST_SHORT_FILEMARKS bit is ON for EXABYTE 8088 * device, set the Vendor Unique bit to 8089 * write Short File Mark. 8090 */ 8091 if (com == SCMD_WRITE_FILE_MARK && 8092 un->un_dp->options & ST_SHORT_FILEMARKS) { 8093 switch (un->un_dp->type) { 8094 case ST_TYPE_EXB8500: 8095 case ST_TYPE_EXABYTE: 8096 /* 8097 * Now the Vendor Unique bit 7 in Byte 5 of CDB 8098 * is set to to write Short File Mark 8099 */ 8100 ((union scsi_cdb *)pkt->pkt_cdbp)->g0_vu_1 = 1; 8101 break; 8102 8103 default: 8104 /* 8105 * Well, if ST_SHORT_FILEMARKS is set for other 8106 * tape drives, it is just ignored 8107 */ 8108 break; 8109 } 8110 } 8111 ASSERT(tval); 8112 pkt->pkt_time = tval; 8113 pkt->pkt_comp = st_intr; 8114 pkt->pkt_private = (opaque_t)bp; 8115 SET_BP_PKT(bp, pkt); 8116 8117 exit: 8118 ASSERT(mutex_owned(ST_MUTEX)); 8119 } 8120 8121 8122 /* 8123 * Build a command based on a uscsi command; 8124 */ 8125 static void 8126 st_make_uscsi_cmd(struct scsi_tape *un, struct uscsi_cmd *ucmd, 8127 struct buf *bp, int (*func)(caddr_t)) 8128 { 8129 struct scsi_pkt *pkt; 8130 caddr_t cdb; 8131 int cdblen; 8132 int stat_size; 8133 8134 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8135 "st_make_uscsi_cmd(): dev = 0x%lx\n", un->un_dev); 8136 8137 if (ucmd->uscsi_flags & USCSI_RQENABLE) { 8138 stat_size = (un->un_arq_enabled ? 8139 sizeof (struct scsi_arq_status) : 1); 8140 } else { 8141 stat_size = 1; 8142 } 8143 8144 ASSERT(mutex_owned(ST_MUTEX)); 8145 8146 un->un_lastop = ST_OP_CTL; /* usual */ 8147 8148 cdb = ucmd->uscsi_cdb; 8149 cdblen = ucmd->uscsi_cdblen; 8150 8151 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8152 "st_make_uscsi_cmd: buflen=%ld bcount=%ld\n", 8153 ucmd->uscsi_buflen, bp->b_bcount); 8154 pkt = scsi_init_pkt(ROUTE, NULL, 8155 (bp->b_bcount > 0) ? bp : NULL, 8156 cdblen, stat_size, 0, 0, func, (caddr_t)un); 8157 if (pkt == NULL) { 8158 goto exit; 8159 } 8160 8161 bcopy(cdb, pkt->pkt_cdbp, (uint_t)cdblen); 8162 8163 #ifdef STDEBUG 8164 if (st_debug >= 6) { 8165 st_clean_print(ST_DEVINFO, st_label, SCSI_DEBUG, 8166 "pkt_cdbp", (char *)cdb, cdblen); 8167 } 8168 #endif 8169 8170 if (ucmd->uscsi_flags & USCSI_SILENT) { 8171 pkt->pkt_flags |= FLAG_SILENT; 8172 } 8173 8174 pkt->pkt_time = ucmd->uscsi_timeout; 8175 pkt->pkt_comp = st_intr; 8176 pkt->pkt_private = (opaque_t)bp; 8177 SET_BP_PKT(bp, pkt); 8178 exit: 8179 ASSERT(mutex_owned(ST_MUTEX)); 8180 } 8181 8182 8183 /* 8184 * restart cmd currently at the head of the runq 8185 * 8186 * If scsi_transport() succeeds or the retries 8187 * count exhausted, restore the throttle that was 8188 * zeroed out in st_handle_intr_busy(). 8189 * 8190 */ 8191 static void 8192 st_intr_restart(void *arg) 8193 { 8194 struct scsi_tape *un = arg; 8195 struct buf *bp; 8196 int status = TRAN_ACCEPT; 8197 8198 mutex_enter(ST_MUTEX); 8199 8200 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8201 "st_intr_restart(), un = 0x%p\n", (void *)un); 8202 8203 un->un_hib_tid = 0; 8204 8205 /* 8206 * move from waitq to runq, if there is anything on the waitq 8207 */ 8208 if ((bp = un->un_quef) == NULL) { 8209 mutex_exit(ST_MUTEX); 8210 return; 8211 } 8212 8213 /* 8214 * Here we know : 8215 * throttle = 0, via st_handle_intr_busy 8216 */ 8217 8218 if (un->un_quel == bp) { 8219 un->un_quel = NULL; 8220 un->un_quef = NULL; /* we know it's the first one */ 8221 } else { 8222 un->un_quef = bp->b_actf; 8223 } 8224 bp->b_actf = NULL; 8225 8226 if (un->un_runqf) { 8227 /* 8228 * not good, we don't want to requeue something after 8229 * another. 8230 */ 8231 mutex_exit(ST_MUTEX); 8232 goto done_error; 8233 } else { 8234 un->un_runqf = bp; 8235 un->un_runql = bp; 8236 } 8237 8238 ST_DO_KSTATS(bp, kstat_waitq_to_runq); 8239 8240 mutex_exit(ST_MUTEX); 8241 8242 status = scsi_transport(BP_PKT(bp)); 8243 8244 mutex_enter(ST_MUTEX); 8245 8246 if (status != TRAN_ACCEPT) { 8247 ST_DO_KSTATS(bp, kstat_runq_back_to_waitq); 8248 mutex_exit(ST_MUTEX); 8249 8250 if (status == TRAN_BUSY) { 8251 if (st_handle_intr_busy(un, bp, 8252 ST_TRAN_BUSY_TIMEOUT) == 0) 8253 return; /* timeout is setup again */ 8254 } 8255 8256 } else { 8257 un->un_tran_retry_ct = 0; 8258 if (un->un_last_throttle) { 8259 un->un_throttle = un->un_last_throttle; 8260 } 8261 mutex_exit(ST_MUTEX); 8262 return; 8263 } 8264 8265 done_error: 8266 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 8267 "restart transport rejected\n"); 8268 bp->b_resid = bp->b_bcount; 8269 8270 #ifndef __lock_lint 8271 /* 8272 * warlock doesn't understand this potential 8273 * recursion? 8274 */ 8275 mutex_enter(ST_MUTEX); 8276 if (un->un_last_throttle) { 8277 un->un_throttle = un->un_last_throttle; 8278 } 8279 if (status != TRAN_ACCEPT) 8280 ST_DO_ERRSTATS(un, st_transerrs); 8281 ST_DO_KSTATS(bp, kstat_waitq_exit); 8282 SET_PE_FLAG(un); 8283 st_bioerror(bp, EIO); 8284 st_done_and_mutex_exit(un, bp); 8285 #endif 8286 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 8287 "busy restart aborted\n"); 8288 } 8289 8290 /* 8291 * st_check_media(): 8292 * Periodically check the media state using scsi_watch service; 8293 * this service calls back after TUR and possibly request sense 8294 * the callback handler (st_media_watch_cb()) decodes the request sense 8295 * data (if any) 8296 */ 8297 8298 static int 8299 st_check_media(dev_t dev, enum mtio_state state) 8300 { 8301 int rval = 0; 8302 enum mtio_state prev_state; 8303 opaque_t token = NULL; 8304 8305 GET_SOFT_STATE(dev); 8306 8307 mutex_enter(ST_MUTEX); 8308 8309 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8310 "st_check_media:state=%x, mediastate=%x\n", 8311 state, un->un_mediastate); 8312 8313 prev_state = un->un_mediastate; 8314 8315 /* 8316 * is there anything to do? 8317 */ 8318 retry: 8319 if (state == un->un_mediastate || un->un_mediastate == MTIO_NONE) { 8320 /* 8321 * submit the request to the scsi_watch service; 8322 * scsi_media_watch_cb() does the real work 8323 */ 8324 mutex_exit(ST_MUTEX); 8325 token = scsi_watch_request_submit(ST_SCSI_DEVP, 8326 st_check_media_time, SENSE_LENGTH, 8327 st_media_watch_cb, (caddr_t)dev); 8328 if (token == NULL) { 8329 rval = EAGAIN; 8330 goto done; 8331 } 8332 mutex_enter(ST_MUTEX); 8333 8334 un->un_swr_token = token; 8335 un->un_specified_mediastate = state; 8336 8337 /* 8338 * now wait for media change 8339 * we will not be signalled unless mediastate == state but it 8340 * still better to test for this condition, since there 8341 * is a 5 sec cv_broadcast delay when 8342 * mediastate == MTIO_INSERTED 8343 */ 8344 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8345 "st_check_media:waiting for media state change\n"); 8346 while (un->un_mediastate == state) { 8347 if (cv_wait_sig(&un->un_state_cv, ST_MUTEX) == 0) { 8348 mutex_exit(ST_MUTEX); 8349 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8350 "st_check_media:waiting for media state " 8351 "was interrupted\n"); 8352 rval = EINTR; 8353 goto done; 8354 } 8355 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8356 "st_check_media:received signal, state=%x\n", 8357 un->un_mediastate); 8358 } 8359 } 8360 8361 /* 8362 * if we transitioned to MTIO_INSERTED, media has really been 8363 * inserted. If TUR fails, it is probably a exabyte slow spin up. 8364 * Reset and retry the state change. If everything is ok, replay 8365 * the open() logic. 8366 */ 8367 if ((un->un_mediastate == MTIO_INSERTED) && 8368 (un->un_state == ST_STATE_OFFLINE)) { 8369 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8370 "st_check_media: calling st_cmd to confirm inserted\n"); 8371 8372 /* 8373 * set this early so that TUR will make it through strategy 8374 * without triggering a st_tape_init(). We needed it set 8375 * before calling st_tape_init() ourselves anyway. If TUR 8376 * fails, set it back 8377 */ 8378 un->un_state = ST_STATE_INITIALIZING; 8379 /* 8380 * If we haven't done/checked reservation on the 8381 * tape unit do it now. 8382 */ 8383 if (ST_RESERVE_SUPPORTED(un) && 8384 !(un->un_rsvd_status & ST_INIT_RESERVE)) { 8385 if (rval = st_tape_reservation_init(dev)) { 8386 mutex_exit(ST_MUTEX); 8387 goto done; 8388 } 8389 } 8390 8391 if (st_cmd(dev, SCMD_TEST_UNIT_READY, 0, SYNC_CMD)) { 8392 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8393 "st_check_media: TUR failed, going to retry\n"); 8394 un->un_mediastate = prev_state; 8395 un->un_state = ST_STATE_OFFLINE; 8396 goto retry; 8397 } 8398 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8399 "st_check_media: media inserted\n"); 8400 8401 /* this also rewinds the tape */ 8402 rval = st_tape_init(dev); 8403 if (rval != 0) { 8404 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8405 "st_check_media : OFFLINE init failure "); 8406 un->un_state = ST_STATE_OFFLINE; 8407 un->un_fileno = -1; 8408 } else { 8409 un->un_state = ST_STATE_OPEN_PENDING_IO; 8410 un->un_fileno = 0; 8411 un->un_blkno = 0; 8412 } 8413 } else if ((un->un_mediastate == MTIO_EJECTED) && 8414 (un->un_state != ST_STATE_OFFLINE)) { 8415 /* 8416 * supported devices must be rewound before ejection 8417 * rewind resets fileno & blkno 8418 */ 8419 un->un_laststate = un->un_state; 8420 un->un_state = ST_STATE_OFFLINE; 8421 } 8422 mutex_exit(ST_MUTEX); 8423 done: 8424 if (token) { 8425 (void) scsi_watch_request_terminate(token, 8426 SCSI_WATCH_TERMINATE_WAIT); 8427 mutex_enter(ST_MUTEX); 8428 un->un_swr_token = (opaque_t)NULL; 8429 mutex_exit(ST_MUTEX); 8430 } 8431 8432 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, "st_check_media: done\n"); 8433 8434 return (rval); 8435 } 8436 8437 /* 8438 * st_media_watch_cb() is called by scsi_watch_thread for 8439 * verifying the request sense data (if any) 8440 */ 8441 static int 8442 st_media_watch_cb(caddr_t arg, struct scsi_watch_result *resultp) 8443 { 8444 struct scsi_status *statusp = resultp->statusp; 8445 struct scsi_extended_sense *sensep = resultp->sensep; 8446 uchar_t actual_sense_length = resultp->actual_sense_length; 8447 struct scsi_tape *un; 8448 enum mtio_state state = MTIO_NONE; 8449 int instance; 8450 dev_t dev = (dev_t)arg; 8451 8452 instance = MTUNIT(dev); 8453 if ((un = ddi_get_soft_state(st_state, instance)) == NULL) { 8454 return (-1); 8455 } 8456 8457 mutex_enter(ST_MUTEX); 8458 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8459 "st_media_watch_cb: status=%x, sensep=%p, len=%x\n", 8460 *((char *)statusp), (void *)sensep, 8461 actual_sense_length); 8462 8463 /* 8464 * if there was a check condition then sensep points to valid 8465 * sense data 8466 * if status was not a check condition but a reservation or busy 8467 * status then the new state is MTIO_NONE 8468 */ 8469 if (sensep) { 8470 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8471 "st_media_watch_cb: KEY=%x, ASC=%x, ASCQ=%x\n", 8472 sensep->es_key, sensep->es_add_code, sensep->es_qual_code); 8473 8474 switch (un->un_dp->type) { 8475 default: 8476 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8477 "st_media_watch_cb: unknown drive type %d, default to ST_TYPE_HP\n", 8478 un->un_dp->type); 8479 /* FALLTHROUGH */ 8480 8481 case ST_TYPE_STC3490: /* STK 4220 1/2" cartridge */ 8482 case ST_TYPE_FUJI: /* 1/2" cartridge */ 8483 case ST_TYPE_HP: /* HP 88780 1/2" reel */ 8484 if (un->un_dp->type == ST_TYPE_FUJI) { 8485 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8486 "st_media_watch_cb: ST_TYPE_FUJI\n"); 8487 } else { 8488 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8489 "st_media_watch_cb: ST_TYPE_HP\n"); 8490 } 8491 switch (sensep->es_key) { 8492 case KEY_UNIT_ATTENTION: 8493 /* not ready to ready transition */ 8494 /* hp/es_qual_code == 80 on>off>on */ 8495 /* hp/es_qual_code == 0 on>off>unld>ld>on */ 8496 if (sensep->es_add_code == 0x28) { 8497 state = MTIO_INSERTED; 8498 } 8499 break; 8500 case KEY_NOT_READY: 8501 /* in process, rewinding or loading */ 8502 if ((sensep->es_add_code == 0x04) && 8503 (sensep->es_qual_code == 0x00)) { 8504 state = MTIO_EJECTED; 8505 } 8506 break; 8507 } 8508 break; 8509 8510 case ST_TYPE_EXB8500: /* Exabyte 8500 */ 8511 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8512 "st_media_watch_cb: ST_TYPE_EXB8500\n"); 8513 switch (sensep->es_key) { 8514 case KEY_UNIT_ATTENTION: 8515 /* operator medium removal request */ 8516 if ((sensep->es_add_code == 0x5a) && 8517 (sensep->es_qual_code == 0x01)) { 8518 state = MTIO_EJECTED; 8519 /* not ready to ready transition */ 8520 } else if ((sensep->es_add_code == 0x28) && 8521 (sensep->es_qual_code == 0x00)) { 8522 state = MTIO_INSERTED; 8523 } 8524 break; 8525 case KEY_NOT_READY: 8526 /* medium not present */ 8527 if (sensep->es_add_code == 0x3a) { 8528 state = MTIO_EJECTED; 8529 } 8530 break; 8531 } 8532 break; 8533 case ST_TYPE_EXABYTE: /* Exabyte 8200 */ 8534 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8535 "st_media_watch_cb: ST_TYPE_EXABYTE\n"); 8536 switch (sensep->es_key) { 8537 case KEY_NOT_READY: 8538 if ((sensep->es_add_code == 0x04) && 8539 (sensep->es_qual_code == 0x00)) { 8540 /* volume not mounted? */ 8541 state = MTIO_EJECTED; 8542 } else if (sensep->es_add_code == 0x3a) { 8543 state = MTIO_EJECTED; 8544 } 8545 break; 8546 case KEY_UNIT_ATTENTION: 8547 state = MTIO_EJECTED; 8548 break; 8549 } 8550 break; 8551 8552 case ST_TYPE_DLT: /* quantum DLT4xxx */ 8553 switch (sensep->es_key) { 8554 case KEY_UNIT_ATTENTION: 8555 if (sensep->es_add_code == 0x28) { 8556 state = MTIO_INSERTED; 8557 } 8558 break; 8559 case KEY_NOT_READY: 8560 if (sensep->es_add_code == 0x04) { 8561 /* in transition but could be either */ 8562 state = un->un_specified_mediastate; 8563 } else if ((sensep->es_add_code == 0x3a) && 8564 (sensep->es_qual_code == 0x00)) { 8565 state = MTIO_EJECTED; 8566 } 8567 break; 8568 } 8569 break; 8570 } 8571 } else if (*((char *)statusp) == STATUS_GOOD) { 8572 state = MTIO_INSERTED; 8573 } 8574 8575 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8576 "st_media_watch_cb:state=%x, specified=%x\n", 8577 state, un->un_specified_mediastate); 8578 8579 /* 8580 * now signal the waiting thread if this is *not* the specified state; 8581 * delay the signal if the state is MTIO_INSERTED 8582 * to allow the target to recover 8583 */ 8584 if (state != un->un_specified_mediastate) { 8585 un->un_mediastate = state; 8586 if (state == MTIO_INSERTED) { 8587 /* 8588 * delay the signal to give the drive a chance 8589 * to do what it apparently needs to do 8590 */ 8591 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8592 "st_media_watch_cb:delayed cv_broadcast\n"); 8593 un->un_delay_tid = timeout(st_delayed_cv_broadcast, 8594 un, drv_usectohz((clock_t)MEDIA_ACCESS_DELAY)); 8595 } else { 8596 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 8597 "st_media_watch_cb:immediate cv_broadcast\n"); 8598 cv_broadcast(&un->un_state_cv); 8599 } 8600 } 8601 mutex_exit(ST_MUTEX); 8602 return (0); 8603 } 8604 8605 /* 8606 * delayed cv_broadcast to allow for target to recover 8607 * from media insertion 8608 */ 8609 static void 8610 st_delayed_cv_broadcast(void *arg) 8611 { 8612 struct scsi_tape *un = arg; 8613 8614 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8615 "st_delayed_cv_broadcast:delayed cv_broadcast\n"); 8616 8617 mutex_enter(ST_MUTEX); 8618 cv_broadcast(&un->un_state_cv); 8619 mutex_exit(ST_MUTEX); 8620 } 8621 8622 /* 8623 * restart cmd currently at the start of the waitq 8624 */ 8625 static void 8626 st_start_restart(void *arg) 8627 { 8628 struct scsi_tape *un = arg; 8629 8630 ASSERT(un != NULL); 8631 8632 mutex_enter(ST_MUTEX); 8633 8634 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8635 "st_tran_restart()\n"); 8636 8637 if (un->un_quef) { 8638 st_start(un); 8639 } 8640 8641 mutex_exit(ST_MUTEX); 8642 } 8643 8644 8645 /* 8646 * Command completion processing 8647 * 8648 */ 8649 static void 8650 st_intr(struct scsi_pkt *pkt) 8651 { 8652 struct scsi_tape *un; 8653 struct buf *last_runqf; 8654 struct buf *bp; 8655 int action = COMMAND_DONE; 8656 clock_t timout; 8657 int status; 8658 8659 bp = (struct buf *)pkt->pkt_private; 8660 un = ddi_get_soft_state(st_state, MTUNIT(bp->b_edev)); 8661 8662 mutex_enter(ST_MUTEX); 8663 8664 un->un_rqs_state &= ~(ST_RQS_ERROR); 8665 8666 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_intr()\n"); 8667 8668 if (pkt->pkt_reason != CMD_CMPLT) { 8669 8670 /* If device has gone away not much else to do */ 8671 if (pkt->pkt_reason == CMD_DEV_GONE) { 8672 action = COMMAND_DONE_ERROR; 8673 } else if (un->un_state == ST_STATE_SENSING) { 8674 ST_DO_ERRSTATS(un, st_transerrs); 8675 action = COMMAND_DONE_ERROR; 8676 } else { 8677 action = st_handle_incomplete(un, bp); 8678 } 8679 /* 8680 * At this point we know that the command was successfully 8681 * completed. Now what? 8682 */ 8683 } else if (un->un_arq_enabled && 8684 (pkt->pkt_state & STATE_ARQ_DONE)) { 8685 /* 8686 * the transport layer successfully completed an autorqsense 8687 */ 8688 action = st_handle_autosense(un, bp); 8689 8690 } else if (un->un_state == ST_STATE_SENSING) { 8691 /* 8692 * okay. We were running a REQUEST SENSE. Find 8693 * out what to do next. 8694 * some actions are based on un_state, hence 8695 * restore the state st was in before ST_STATE_SENSING. 8696 */ 8697 un->un_state = un->un_laststate; 8698 action = st_handle_sense(un, bp); 8699 /* 8700 * set pkt back to original packet in case we will have 8701 * to requeue it 8702 */ 8703 pkt = BP_PKT(bp); 8704 } else if ((SCBP(pkt)->sts_busy) || (SCBP(pkt)->sts_chk)) { 8705 /* 8706 * Okay, we weren't running a REQUEST SENSE. Call a routine 8707 * to see if the status bits we're okay. If a request sense 8708 * is to be run, that will happen. 8709 */ 8710 action = st_check_error(un, pkt); 8711 } 8712 8713 if (un->un_pwr_mgmt == ST_PWR_SUSPENDED) { 8714 switch (action) { 8715 case QUE_COMMAND: 8716 /* 8717 * return cmd to head to the queue 8718 * since we are suspending so that 8719 * it gets restarted during resume 8720 */ 8721 if (un->un_runqf) { 8722 last_runqf = un->un_runqf; 8723 un->un_runqf = bp; 8724 bp->b_actf = last_runqf; 8725 } else { 8726 bp->b_actf = NULL; 8727 un->un_runqf = bp; 8728 un->un_runql = bp; 8729 } 8730 action = JUST_RETURN; 8731 break; 8732 8733 case QUE_SENSE: 8734 action = COMMAND_DONE_ERROR; 8735 break; 8736 8737 default: 8738 break; 8739 } 8740 } 8741 8742 /* 8743 * Restore old state if we were sensing. 8744 */ 8745 if (un->un_state == ST_STATE_SENSING && action != QUE_SENSE) { 8746 un->un_state = un->un_laststate; 8747 } 8748 8749 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 8750 "st_intr: pkt=%p, bp=%p, action=%x, status=%x\n", 8751 (void *)pkt, (void *)bp, action, SCBP_C(pkt)); 8752 8753 8754 switch (action) { 8755 case COMMAND_DONE_EACCES: 8756 /* this is to report a reservation conflict */ 8757 st_bioerror(bp, EACCES); 8758 ST_DEBUG(ST_DEVINFO, st_label, SCSI_DEBUG, 8759 "Reservation Conflict \n"); 8760 8761 /*FALLTHROUGH*/ 8762 case COMMAND_DONE_ERROR: 8763 if (un->un_eof < ST_EOT_PENDING && 8764 un->un_state >= ST_STATE_OPEN) { 8765 /* 8766 * all errors set state of the tape to 'unknown' 8767 * unless we're at EOT or are doing append testing. 8768 * If sense key was illegal request, preserve state. 8769 */ 8770 if (un->un_status != KEY_ILLEGAL_REQUEST) { 8771 un->un_fileno = -1; 8772 } 8773 } 8774 un->un_err_resid = bp->b_resid = bp->b_bcount; 8775 /* 8776 * since we have an error (COMMAND_DONE_ERROR), we want to 8777 * make sure an error ocurrs, so make sure at least EIO is 8778 * returned 8779 */ 8780 if (geterror(bp) == 0) 8781 st_bioerror(bp, EIO); 8782 8783 SET_PE_FLAG(un); 8784 if (!(un->un_rqs_state & ST_RQS_ERROR) && 8785 (un->un_errno == EIO)) { 8786 un->un_rqs_state &= ~(ST_RQS_VALID); 8787 } 8788 goto done; 8789 8790 case COMMAND_DONE_ERROR_RECOVERED: 8791 un->un_err_resid = bp->b_resid = bp->b_bcount; 8792 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 8793 "st_intr(): COMMAND_DONE_ERROR_RECOVERED"); 8794 if (geterror(bp) == 0) 8795 st_bioerror(bp, EIO); 8796 SET_PE_FLAG(un); 8797 if (!(un->un_rqs_state & ST_RQS_ERROR) && 8798 (un->un_errno == EIO)) { 8799 un->un_rqs_state &= ~(ST_RQS_VALID); 8800 } 8801 /*FALLTHROUGH*/ 8802 case COMMAND_DONE: 8803 st_set_state(un); 8804 done: 8805 ST_DO_KSTATS(bp, kstat_runq_exit); 8806 st_done_and_mutex_exit(un, bp); 8807 return; 8808 8809 case QUE_SENSE: 8810 if ((un->un_ncmds > 1) && !un->un_flush_on_errors) 8811 goto sense_error; 8812 8813 if (un->un_state != ST_STATE_SENSING) { 8814 un->un_laststate = un->un_state; 8815 un->un_state = ST_STATE_SENSING; 8816 } 8817 8818 un->un_rqs->pkt_private = (opaque_t)bp; 8819 bzero(ST_RQSENSE, SENSE_LENGTH); 8820 8821 if (un->un_throttle) { 8822 un->un_last_throttle = un->un_throttle; 8823 un->un_throttle = 0; 8824 } 8825 8826 mutex_exit(ST_MUTEX); 8827 8828 /* 8829 * never retry this, some other command will have nuked the 8830 * sense, anyway 8831 */ 8832 status = scsi_transport(un->un_rqs); 8833 8834 mutex_enter(ST_MUTEX); 8835 8836 if (un->un_last_throttle) { 8837 un->un_throttle = un->un_last_throttle; 8838 } 8839 8840 if (status == TRAN_ACCEPT) { 8841 mutex_exit(ST_MUTEX); 8842 return; 8843 } 8844 if (status != TRAN_BUSY) 8845 ST_DO_ERRSTATS(un, st_transerrs); 8846 sense_error: 8847 un->un_fileno = -1; 8848 st_bioerror(bp, EIO); 8849 SET_PE_FLAG(un); 8850 goto done; 8851 8852 case QUE_BUSY_COMMAND: 8853 /* longish timeout */ 8854 timout = ST_STATUS_BUSY_TIMEOUT; 8855 goto que_it_up; 8856 8857 case QUE_COMMAND: 8858 /* short timeout */ 8859 timout = ST_TRAN_BUSY_TIMEOUT; 8860 que_it_up: 8861 /* 8862 * let st_handle_intr_busy put this bp back on waitq and make 8863 * checks to see if it is ok to requeue the command. 8864 */ 8865 ST_DO_KSTATS(bp, kstat_runq_back_to_waitq); 8866 8867 /* 8868 * Save the throttle before setting up the timeout 8869 */ 8870 if (un->un_throttle) { 8871 un->un_last_throttle = un->un_throttle; 8872 } 8873 mutex_exit(ST_MUTEX); 8874 if (st_handle_intr_busy(un, bp, timout) == 0) 8875 return; /* timeout is setup again */ 8876 8877 mutex_enter(ST_MUTEX); 8878 un->un_fileno = -1; 8879 un->un_err_resid = bp->b_resid = bp->b_bcount; 8880 st_bioerror(bp, EIO); 8881 SET_PE_FLAG(un); 8882 goto done; 8883 8884 case QUE_LAST_COMMAND: 8885 8886 if ((un->un_ncmds > 1) && !un->un_flush_on_errors) { 8887 scsi_log(ST_DEVINFO, st_label, CE_CONT, 8888 "un_ncmds: %d can't retry cmd \n", un->un_ncmds); 8889 goto last_command_error; 8890 } 8891 mutex_exit(ST_MUTEX); 8892 if (st_handle_intr_retry_lcmd(un, bp) == 0) 8893 return; 8894 mutex_enter(ST_MUTEX); 8895 last_command_error: 8896 un->un_err_resid = bp->b_resid = bp->b_bcount; 8897 un->un_fileno = -1; 8898 st_bioerror(bp, EIO); 8899 SET_PE_FLAG(un); 8900 goto done; 8901 8902 case JUST_RETURN: 8903 default: 8904 ST_DO_KSTATS(bp, kstat_runq_back_to_waitq); 8905 mutex_exit(ST_MUTEX); 8906 return; 8907 } 8908 /*NOTREACHED*/ 8909 } 8910 8911 static int 8912 st_handle_incomplete(struct scsi_tape *un, struct buf *bp) 8913 { 8914 static char *fail = "SCSI transport failed: reason '%s': %s\n"; 8915 int rval = COMMAND_DONE_ERROR; 8916 struct scsi_pkt *pkt = (un->un_state == ST_STATE_SENSING) ? 8917 un->un_rqs : BP_PKT(bp); 8918 int result; 8919 8920 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 8921 "st_handle_incomplete(): dev = 0x%lx\n", un->un_dev); 8922 8923 ASSERT(mutex_owned(ST_MUTEX)); 8924 8925 switch (pkt->pkt_reason) { 8926 case CMD_INCOMPLETE: /* tran stopped with not normal state */ 8927 /* 8928 * this occurs when accessing a powered down drive, no 8929 * need to complain; just fail the open 8930 */ 8931 #ifdef STDEBUG 8932 if (st_debug >= 1) { 8933 st_clean_print(ST_DEVINFO, st_label, CE_WARN, 8934 "Failed CDB", (char *)pkt->pkt_cdbp, CDB_SIZE); 8935 } 8936 8937 #endif 8938 /* 8939 * if we have commands outstanding in HBA, and a command 8940 * comes back incomplete, we're hosed, so reset target 8941 * If we have the bus, but cmd_incomplete, we probably just 8942 * have a failed selection, so don't reset the target, just 8943 * requeue the command and try again 8944 */ 8945 if ((un->un_ncmds > 1) || (pkt->pkt_state != STATE_GOT_BUS)) { 8946 goto reset_target; 8947 } 8948 8949 /* 8950 * Retry selection a couple more times if we're 8951 * open. If opening, we only try just once to 8952 * reduce probe time for nonexistant devices. 8953 */ 8954 if ((un->un_laststate > ST_STATE_OPENING) && 8955 ((int)un->un_retry_ct < st_selection_retry_count)) { 8956 rval = QUE_COMMAND; 8957 } 8958 ST_DO_ERRSTATS(un, st_transerrs); 8959 break; 8960 8961 case CMD_ABORTED: 8962 /* 8963 * most likely this is caused by flush-on-error support. If 8964 * it was not there, the we're in trouble. 8965 */ 8966 if (!un->un_flush_on_errors) { 8967 un->un_status = SUN_KEY_FATAL; 8968 goto reset_target; 8969 } 8970 8971 st_set_pe_errno(un); 8972 bioerror(bp, un->un_errno); 8973 if (un->un_errno) 8974 return (COMMAND_DONE_ERROR); 8975 else 8976 return (COMMAND_DONE); 8977 8978 case CMD_TIMEOUT: /* Command timed out */ 8979 un->un_status = SUN_KEY_TIMEOUT; 8980 8981 /*FALLTHROUGH*/ 8982 default: 8983 reset_target: 8984 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 8985 "transport completed with %s\n", 8986 scsi_rname(pkt->pkt_reason)); 8987 ST_DO_ERRSTATS(un, st_transerrs); 8988 if ((pkt->pkt_state & STATE_GOT_TARGET) && 8989 ((pkt->pkt_statistics & (STAT_BUS_RESET | STAT_DEV_RESET | 8990 STAT_ABORTED)) == 0)) { 8991 8992 mutex_exit(ST_MUTEX); 8993 8994 result = scsi_reset(ROUTE, RESET_TARGET); 8995 /* 8996 * if target reset fails, then pull the chain 8997 */ 8998 if (result == 0) { 8999 result = scsi_reset(ROUTE, RESET_ALL); 9000 } 9001 mutex_enter(ST_MUTEX); 9002 9003 if ((result == 0) && (un->un_state >= ST_STATE_OPEN)) { 9004 /* no hope left to recover */ 9005 scsi_log(ST_DEVINFO, st_label, CE_WARN, 9006 "recovery by resets failed\n"); 9007 return (rval); 9008 } 9009 } 9010 } 9011 9012 if ((pkt->pkt_reason == CMD_RESET) || (pkt->pkt_statistics & 9013 (STAT_BUS_RESET | STAT_DEV_RESET))) { 9014 if ((un->un_rsvd_status & ST_RESERVE)) { 9015 un->un_rsvd_status |= ST_LOST_RESERVE; 9016 ST_DEBUG3(ST_DEVINFO, st_label, CE_WARN, 9017 "Lost Reservation\n"); 9018 } 9019 } 9020 9021 if ((int)un->un_retry_ct++ < st_retry_count) { 9022 if (un->un_pwr_mgmt == ST_PWR_SUSPENDED) { 9023 rval = QUE_COMMAND; 9024 } else if (bp == un->un_sbufp) { 9025 switch ((uchar_t)(uintptr_t)bp->b_forw) { 9026 case SCMD_MODE_SENSE: 9027 case SCMD_MODE_SELECT: 9028 case SCMD_READ_BLKLIM: 9029 case SCMD_REWIND: 9030 case SCMD_LOAD: 9031 case SCMD_TEST_UNIT_READY: 9032 /* 9033 * These commands can be rerun with impunity 9034 */ 9035 rval = QUE_COMMAND; 9036 break; 9037 9038 default: 9039 break; 9040 } 9041 } 9042 } else { 9043 rval = COMMAND_DONE_ERROR; 9044 } 9045 9046 if (un->un_state >= ST_STATE_OPEN) { 9047 scsi_log(ST_DEVINFO, st_label, CE_WARN, 9048 fail, scsi_rname(pkt->pkt_reason), 9049 (rval == COMMAND_DONE_ERROR)? 9050 "giving up" : "retrying command"); 9051 } 9052 return (rval); 9053 } 9054 9055 /* 9056 * if the device is busy, then put this bp back on the waitq, on the 9057 * interrupt thread, where we want the head of the queue and not the 9058 * end 9059 * 9060 * The callers of this routine should take measures to save the 9061 * un_throttle in un_last_throttle which will be restored in 9062 * st_intr_restart(). The only exception should be st_intr_restart() 9063 * calling this routine for which the saving is already done. 9064 */ 9065 static int 9066 st_handle_intr_busy(struct scsi_tape *un, struct buf *bp, 9067 clock_t timeout_interval) 9068 { 9069 struct buf *last_quef; 9070 int rval = 0; 9071 9072 mutex_enter(ST_MUTEX); 9073 9074 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9075 "st_handle_intr_busy(), un = 0x%p\n", (void *)un); 9076 9077 /* 9078 * Check to see if we hit the retry timeout. We check to make sure 9079 * this is the first one on the runq and make sure we have not 9080 * queued up any more, so this one has to be the last on the list 9081 * also. If it is not, we have to fail. If it is not the first, but 9082 * is the last we are in trouble anyway, as we are in the interrupt 9083 * context here. 9084 */ 9085 if (((int)un->un_tran_retry_ct++ > st_retry_count) || 9086 ((un->un_runqf != bp) && (un->un_runql != bp))) { 9087 rval = -1; 9088 goto exit; 9089 } 9090 9091 /* put the bp back on the waitq */ 9092 if (un->un_quef) { 9093 last_quef = un->un_quef; 9094 un->un_quef = bp; 9095 bp->b_actf = last_quef; 9096 } else { 9097 bp->b_actf = NULL; 9098 un->un_quef = bp; 9099 un->un_quel = bp; 9100 } 9101 9102 /* 9103 * We know that this is the first and last on the runq at this time, 9104 * so we just nullify those two queues 9105 */ 9106 un->un_runqf = NULL; 9107 un->un_runql = NULL; 9108 9109 /* 9110 * We don't want any other commands being started in the mean time. 9111 * If start had just released mutex after putting something on the 9112 * runq, we won't even get here. 9113 */ 9114 un->un_throttle = 0; 9115 9116 /* 9117 * send a marker pkt, if appropriate 9118 */ 9119 st_hba_unflush(un); 9120 9121 /* 9122 * all queues are aligned, we are just waiting to 9123 * transport 9124 */ 9125 un->un_hib_tid = timeout(st_intr_restart, un, timeout_interval); 9126 9127 exit: 9128 mutex_exit(ST_MUTEX); 9129 return (rval); 9130 } 9131 9132 static int 9133 st_handle_sense(struct scsi_tape *un, struct buf *bp) 9134 { 9135 struct scsi_pkt *rqpkt = un->un_rqs; 9136 int rval = COMMAND_DONE_ERROR; 9137 int amt; 9138 9139 ASSERT(mutex_owned(ST_MUTEX)); 9140 9141 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9142 "st_handle_sense()\n"); 9143 9144 if (SCBP(rqpkt)->sts_busy) { 9145 ST_DEBUG4(ST_DEVINFO, st_label, CE_WARN, 9146 "busy unit on request sense\n"); 9147 if ((int)un->un_retry_ct++ < st_retry_count) { 9148 rval = QUE_BUSY_COMMAND; 9149 } 9150 return (rval); 9151 } else if (SCBP(rqpkt)->sts_chk) { 9152 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9153 "Check Condition on REQUEST SENSE\n"); 9154 return (rval); 9155 } 9156 9157 /* was there enough data? */ 9158 amt = (int)SENSE_LENGTH - rqpkt->pkt_resid; 9159 if ((rqpkt->pkt_state & STATE_XFERRED_DATA) == 0 || 9160 (amt < SUN_MIN_SENSE_LENGTH)) { 9161 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9162 "REQUEST SENSE couldn't get sense data\n"); 9163 return (rval); 9164 } 9165 return (st_decode_sense(un, bp, amt, SCBP(rqpkt))); 9166 } 9167 9168 static int 9169 st_handle_autosense(struct scsi_tape *un, struct buf *bp) 9170 { 9171 struct scsi_pkt *pkt = BP_PKT(bp); 9172 struct scsi_arq_status *arqstat = 9173 (struct scsi_arq_status *)pkt->pkt_scbp; 9174 int rval = COMMAND_DONE_ERROR; 9175 int amt; 9176 9177 ASSERT(mutex_owned(ST_MUTEX)); 9178 9179 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9180 "st_handle_autosense()\n"); 9181 9182 if (arqstat->sts_rqpkt_status.sts_busy) { 9183 ST_DEBUG4(ST_DEVINFO, st_label, CE_WARN, 9184 "busy unit on request sense\n"); 9185 /* 9186 * we return QUE_SENSE so st_intr will setup the SENSE cmd. 9187 * the disadvantage is that we do not have any delay for the 9188 * second retry of rqsense and we have to keep a packet around 9189 */ 9190 return (QUE_SENSE); 9191 9192 } else if (arqstat->sts_rqpkt_reason != CMD_CMPLT) { 9193 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9194 "transport error on REQUEST SENSE\n"); 9195 if ((arqstat->sts_rqpkt_state & STATE_GOT_TARGET) && 9196 ((arqstat->sts_rqpkt_statistics & 9197 (STAT_BUS_RESET | STAT_DEV_RESET | STAT_ABORTED)) == 0)) { 9198 mutex_exit(ST_MUTEX); 9199 if (scsi_reset(ROUTE, RESET_TARGET) == 0) { 9200 /* 9201 * if target reset fails, then pull the chain 9202 */ 9203 if (scsi_reset(ROUTE, RESET_ALL) == 0) { 9204 ST_DEBUG6(ST_DEVINFO, st_label, 9205 CE_WARN, 9206 "recovery by resets failed\n"); 9207 } 9208 } 9209 mutex_enter(ST_MUTEX); 9210 } 9211 return (rval); 9212 9213 } else if (arqstat->sts_rqpkt_status.sts_chk) { 9214 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9215 "Check Condition on REQUEST SENSE\n"); 9216 return (rval); 9217 } 9218 9219 9220 /* was there enough data? */ 9221 amt = (int)SENSE_LENGTH - arqstat->sts_rqpkt_resid; 9222 if ((arqstat->sts_rqpkt_state & STATE_XFERRED_DATA) == 0 || 9223 (amt < SUN_MIN_SENSE_LENGTH)) { 9224 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9225 "REQUEST SENSE couldn't get sense data\n"); 9226 return (rval); 9227 } 9228 9229 bcopy(&arqstat->sts_sensedata, ST_RQSENSE, SENSE_LENGTH); 9230 9231 return (st_decode_sense(un, bp, amt, &arqstat->sts_rqpkt_status)); 9232 } 9233 9234 static int 9235 st_decode_sense(struct scsi_tape *un, struct buf *bp, int amt, 9236 struct scsi_status *statusp) 9237 { 9238 struct scsi_pkt *pkt = BP_PKT(bp); 9239 int rval = COMMAND_DONE_ERROR; 9240 long resid; 9241 struct scsi_extended_sense *sensep = ST_RQSENSE; 9242 int severity; 9243 int get_error; 9244 9245 ASSERT(mutex_owned(ST_MUTEX)); 9246 9247 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9248 "st_decode_sense()\n"); 9249 9250 /* 9251 * For uscsi commands, squirrel away a copy of the 9252 * results of the Request Sense. 9253 */ 9254 if (USCSI_CMD(bp)) { 9255 struct uscsi_cmd *ucmd = BP_UCMD(bp); 9256 ucmd->uscsi_rqstatus = *(uchar_t *)statusp; 9257 if (ucmd->uscsi_rqlen && un->un_srqbufp) { 9258 uchar_t rqlen = min((uchar_t)amt, ucmd->uscsi_rqlen); 9259 ucmd->uscsi_rqresid = ucmd->uscsi_rqlen - rqlen; 9260 bcopy(ST_RQSENSE, un->un_srqbufp, rqlen); 9261 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 9262 "st_decode_sense: stat=0x%x resid=0x%x\n", 9263 ucmd->uscsi_rqstatus, ucmd->uscsi_rqresid); 9264 } 9265 } 9266 9267 /* 9268 * If the drive is an MT-02, reposition the 9269 * secondary error code into the proper place. 9270 * 9271 * XXX MT-02 is non-CCS tape, so secondary error code 9272 * is in byte 8. However, in SCSI-2, tape has CCS definition 9273 * so it's in byte 12. 9274 */ 9275 if (un->un_dp->type == ST_TYPE_EMULEX) { 9276 sensep->es_code = sensep->es_add_info[0]; 9277 } 9278 9279 /* for normal I/O check extract the resid values. */ 9280 if (bp != un->un_sbufp) { 9281 if (sensep->es_valid) { 9282 resid = (sensep->es_info_1 << 24) | 9283 (sensep->es_info_2 << 16) | 9284 (sensep->es_info_3 << 8) | 9285 (sensep->es_info_4); 9286 if (un->un_bsize) { 9287 resid *= un->un_bsize; 9288 } 9289 } else if (pkt->pkt_state & STATE_XFERRED_DATA) { 9290 resid = pkt->pkt_resid; 9291 } else { 9292 resid = bp->b_bcount; 9293 } 9294 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9295 "st_handle_sense (rw): xferred bit = %d, resid=%ld (%d), " 9296 "pkt_resid=%ld\n", pkt->pkt_state & STATE_XFERRED_DATA, 9297 resid, 9298 (sensep->es_info_1 << 24) | 9299 (sensep->es_info_2 << 16) | 9300 (sensep->es_info_3 << 8) | 9301 (sensep->es_info_4), 9302 pkt->pkt_resid); 9303 /* 9304 * The problem is, what should we believe? 9305 */ 9306 if (resid && (pkt->pkt_resid == 0)) { 9307 pkt->pkt_resid = resid; 9308 } 9309 } else { 9310 /* 9311 * If the command is SCMD_SPACE, we need to get the 9312 * residual as returned in the sense data, to adjust 9313 * our idea of current tape position correctly 9314 */ 9315 if ((CDBP(pkt)->scc_cmd == SCMD_SPACE || 9316 CDBP(pkt)->scc_cmd == SCMD_WRITE_FILE_MARK) && 9317 (sensep->es_valid)) { 9318 resid = (sensep->es_info_1 << 24) | 9319 (sensep->es_info_2 << 16) | 9320 (sensep->es_info_3 << 8) | 9321 (sensep->es_info_4); 9322 bp->b_resid = resid; 9323 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9324 "st_handle_sense(other): resid=%ld\n", 9325 resid); 9326 } else { 9327 /* 9328 * If the special command is SCMD_READ, 9329 * the correct resid will be set later. 9330 */ 9331 resid = bp->b_bcount; 9332 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9333 "st_handle_sense(special read): resid=%ld\n", 9334 resid); 9335 } 9336 } 9337 9338 if ((un->un_state >= ST_STATE_OPEN) && 9339 (DEBUGGING || st_error_level == SCSI_ERR_ALL)) { 9340 st_clean_print(ST_DEVINFO, st_label, CE_NOTE, 9341 "Failed CDB", (char *)pkt->pkt_cdbp, CDB_SIZE); 9342 st_clean_print(ST_DEVINFO, st_label, CE_CONT, 9343 "sense data", (char *)sensep, amt); 9344 scsi_log(ST_DEVINFO, st_label, CE_CONT, 9345 "count 0x%lx resid 0x%lx pktresid 0x%lx\n", 9346 bp->b_bcount, resid, pkt->pkt_resid); 9347 } 9348 9349 switch (un->un_status = sensep->es_key) { 9350 case KEY_NO_SENSE: 9351 severity = SCSI_ERR_INFO; 9352 goto common; 9353 9354 case KEY_RECOVERABLE_ERROR: 9355 severity = SCSI_ERR_RECOVERED; 9356 if ((sensep->es_class == CLASS_EXTENDED_SENSE) && 9357 (sensep->es_code == ST_DEFERRED_ERROR)) { 9358 if (un->un_dp->options & 9359 ST_RETRY_ON_RECOVERED_DEFERRED_ERROR) { 9360 rval = QUE_LAST_COMMAND; 9361 scsi_errmsg(ST_SCSI_DEVP, pkt, st_label, severity, 9362 un->un_blkno, un->un_err_blkno, scsi_cmds, 9363 sensep); 9364 scsi_log(ST_DEVINFO, st_label, CE_CONT, 9365 "Command will be retried\n"); 9366 } else { 9367 severity = SCSI_ERR_FATAL; 9368 rval = COMMAND_DONE_ERROR_RECOVERED; 9369 ST_DO_ERRSTATS(un, st_softerrs); 9370 scsi_errmsg(ST_SCSI_DEVP, pkt, st_label, severity, 9371 un->un_blkno, un->un_err_blkno, scsi_cmds, 9372 sensep); 9373 } 9374 break; 9375 } 9376 common: 9377 /* 9378 * XXX only want reads to be stopped by filemarks. 9379 * Don't want them to be stopped by EOT. EOT matters 9380 * only on write. 9381 */ 9382 if (sensep->es_filmk && !sensep->es_eom) { 9383 rval = COMMAND_DONE; 9384 } else if (sensep->es_eom) { 9385 rval = COMMAND_DONE; 9386 } else if (sensep->es_ili) { 9387 /* 9388 * Fun with variable length record devices: 9389 * for specifying larger blocks sizes than the 9390 * actual physical record size. 9391 */ 9392 if (un->un_bsize == 0 && resid > 0) { 9393 /* 9394 * XXX! Ugly. 9395 * The requested blocksize is > tape blocksize, 9396 * so this is ok, so we just return the 9397 * actual size xferred. 9398 */ 9399 pkt->pkt_resid = resid; 9400 rval = COMMAND_DONE; 9401 } else if (un->un_bsize == 0 && resid < 0) { 9402 /* 9403 * The requested blocksize is < tape blocksize, 9404 * so this is not ok, so we err with ENOMEM 9405 */ 9406 rval = COMMAND_DONE_ERROR_RECOVERED; 9407 st_bioerror(bp, ENOMEM); 9408 } else { 9409 ST_DO_ERRSTATS(un, st_softerrs); 9410 severity = SCSI_ERR_FATAL; 9411 rval = COMMAND_DONE_ERROR; 9412 st_bioerror(bp, EINVAL); 9413 } 9414 } else { 9415 /* 9416 * we hope and pray for this just being 9417 * something we can ignore (ie. a 9418 * truly recoverable soft error) 9419 */ 9420 rval = COMMAND_DONE; 9421 } 9422 if (sensep->es_filmk) { 9423 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9424 "filemark\n"); 9425 un->un_status = SUN_KEY_EOF; 9426 un->un_eof = ST_EOF_PENDING; 9427 SET_PE_FLAG(un); 9428 } 9429 9430 /* 9431 * ignore eom when reading, a fmk should terminate reading 9432 */ 9433 if ((sensep->es_eom) && 9434 (CDBP(pkt)->scc_cmd != SCMD_READ)) { 9435 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "eom\n"); 9436 un->un_status = SUN_KEY_EOT; 9437 un->un_eof = ST_EOM; 9438 SET_PE_FLAG(un); 9439 } 9440 9441 break; 9442 9443 case KEY_ILLEGAL_REQUEST: 9444 9445 if (un->un_laststate >= ST_STATE_OPEN) { 9446 ST_DO_ERRSTATS(un, st_softerrs); 9447 severity = SCSI_ERR_FATAL; 9448 } else { 9449 severity = SCSI_ERR_INFO; 9450 } 9451 break; 9452 9453 case KEY_MEDIUM_ERROR: 9454 ST_DO_ERRSTATS(un, st_harderrs); 9455 severity = SCSI_ERR_FATAL; 9456 9457 /* 9458 * for (buffered) writes, a medium error must be fatal 9459 */ 9460 if (CDBP(pkt)->scc_cmd != SCMD_WRITE) { 9461 rval = COMMAND_DONE_ERROR_RECOVERED; 9462 } 9463 9464 check_keys: 9465 /* 9466 * attempt to process the keys in the presence of 9467 * other errors 9468 */ 9469 if (sensep->es_ili && rval != COMMAND_DONE_ERROR) { 9470 /* 9471 * Fun with variable length record devices: 9472 * for specifying larger blocks sizes than the 9473 * actual physical record size. 9474 */ 9475 if (un->un_bsize == 0 && resid > 0) { 9476 /* 9477 * XXX! Ugly 9478 */ 9479 pkt->pkt_resid = resid; 9480 } else if (un->un_bsize == 0 && resid < 0) { 9481 st_bioerror(bp, EINVAL); 9482 } else { 9483 severity = SCSI_ERR_FATAL; 9484 rval = COMMAND_DONE_ERROR; 9485 st_bioerror(bp, EINVAL); 9486 } 9487 } 9488 if (sensep->es_filmk) { 9489 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9490 "filemark\n"); 9491 un->un_status = SUN_KEY_EOF; 9492 un->un_eof = ST_EOF_PENDING; 9493 SET_PE_FLAG(un); 9494 } 9495 9496 /* 9497 * ignore eom when reading, a fmk should terminate reading 9498 */ 9499 if ((sensep->es_eom) && 9500 (CDBP(pkt)->scc_cmd != SCMD_READ)) { 9501 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, "eom\n"); 9502 un->un_status = SUN_KEY_EOT; 9503 un->un_eof = ST_EOM; 9504 SET_PE_FLAG(un); 9505 } 9506 9507 break; 9508 9509 case KEY_VOLUME_OVERFLOW: 9510 ST_DO_ERRSTATS(un, st_softerrs); 9511 un->un_eof = ST_EOM; 9512 severity = SCSI_ERR_FATAL; 9513 rval = COMMAND_DONE_ERROR; 9514 goto check_keys; 9515 9516 case KEY_HARDWARE_ERROR: 9517 ST_DO_ERRSTATS(un, st_harderrs); 9518 severity = SCSI_ERR_FATAL; 9519 rval = COMMAND_DONE_ERROR; 9520 if (un->un_dp->options & ST_EJECT_ON_CHANGER_FAILURE) 9521 un->un_eject_tape_on_failure = st_check_asc_ascq(un); 9522 break; 9523 9524 case KEY_BLANK_CHECK: 9525 ST_DO_ERRSTATS(un, st_softerrs); 9526 severity = SCSI_ERR_INFO; 9527 9528 /* 9529 * if not a special request and some data was xferred then it 9530 * it is not an error yet 9531 */ 9532 if (bp != un->un_sbufp && (bp->b_flags & B_READ)) { 9533 /* 9534 * no error for read with or without data xferred 9535 */ 9536 un->un_status = SUN_KEY_EOT; 9537 un->un_eof = ST_EOT; 9538 rval = COMMAND_DONE_ERROR; 9539 SET_PE_FLAG(un); 9540 goto check_keys; 9541 } else if (bp != un->un_sbufp && 9542 (pkt->pkt_state & STATE_XFERRED_DATA)) { 9543 rval = COMMAND_DONE; 9544 } else { 9545 rval = COMMAND_DONE_ERROR_RECOVERED; 9546 } 9547 9548 if (un->un_laststate >= ST_STATE_OPEN) { 9549 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9550 "blank check\n"); 9551 un->un_eof = ST_EOM; 9552 } 9553 if ((CDBP(pkt)->scc_cmd == SCMD_SPACE) && 9554 (un->un_dp->options & ST_KNOWS_EOD) && 9555 (severity = SCSI_ERR_INFO)) { 9556 /* 9557 * we were doing a fast forward by skipping 9558 * multiple fmk at the time 9559 */ 9560 st_bioerror(bp, EIO); 9561 severity = SCSI_ERR_RECOVERED; 9562 rval = COMMAND_DONE; 9563 } 9564 SET_PE_FLAG(un); 9565 goto check_keys; 9566 9567 case KEY_WRITE_PROTECT: 9568 if (st_wrongtapetype(un)) { 9569 un->un_status = SUN_KEY_WRONGMEDIA; 9570 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9571 "wrong tape for writing- use DC6150 tape (or equivalent)\n"); 9572 severity = SCSI_ERR_UNKNOWN; 9573 } else { 9574 severity = SCSI_ERR_FATAL; 9575 } 9576 ST_DO_ERRSTATS(un, st_harderrs); 9577 rval = COMMAND_DONE_ERROR; 9578 st_bioerror(bp, EACCES); 9579 break; 9580 9581 case KEY_UNIT_ATTENTION: 9582 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9583 "KEY_UNIT_ATTENTION : un_state = %d\n", un->un_state); 9584 9585 /* 9586 * If we have detected a Bus Reset and the tape 9587 * drive has been reserved. 9588 */ 9589 if (ST_RQSENSE->es_add_code == 0x29 && 9590 (un->un_rsvd_status & ST_RESERVE)) { 9591 un->un_rsvd_status |= ST_LOST_RESERVE; 9592 ST_DEBUG(ST_DEVINFO, st_label, CE_WARN, 9593 "st_decode_sense: Lost Reservation\n"); 9594 } 9595 9596 if (un->un_state <= ST_STATE_OPENING) { 9597 /* 9598 * Look, the tape isn't open yet, now determine 9599 * if the cause is a BUS RESET, Save the file and 9600 * Block positions for the callers to recover from 9601 * the loss of position. 9602 */ 9603 if ((un->un_fileno >= 0) && 9604 (un->un_fileno || un->un_blkno)) { 9605 if (ST_RQSENSE->es_add_code == 0x29) { 9606 un->un_save_fileno = un->un_fileno; 9607 un->un_save_blkno = un->un_blkno; 9608 un->un_restore_pos = 1; 9609 } 9610 } 9611 9612 if ((int)un->un_retry_ct++ < st_retry_count) { 9613 rval = QUE_COMMAND; 9614 } else { 9615 rval = COMMAND_DONE_ERROR; 9616 } 9617 severity = SCSI_ERR_INFO; 9618 9619 } else { 9620 /* 9621 * Check if it is an Unexpected Unit Attention. 9622 * If state is >= ST_STATE_OPEN, we have 9623 * already done the initialization . 9624 * In this case it is Fatal Error 9625 * since no further reading/writing 9626 * can be done with fileno set to < 0. 9627 */ 9628 if (un->un_state >= ST_STATE_OPEN) { 9629 ST_DO_ERRSTATS(un, st_harderrs); 9630 severity = SCSI_ERR_FATAL; 9631 } else { 9632 severity = SCSI_ERR_INFO; 9633 } 9634 rval = COMMAND_DONE_ERROR; 9635 } 9636 un->un_fileno = -1; 9637 9638 break; 9639 9640 case KEY_NOT_READY: 9641 /* 9642 * If in process of getting ready retry. 9643 */ 9644 if (sensep->es_add_code == 0x04 && 9645 sensep->es_qual_code == 0x01 && 9646 un->un_retry_ct++ < st_retry_count) { 9647 rval = QUE_COMMAND; 9648 severity = SCSI_ERR_INFO; 9649 } else { 9650 /* give up */ 9651 rval = COMMAND_DONE_ERROR; 9652 severity = SCSI_ERR_FATAL; 9653 } 9654 9655 /* 9656 * If this was an error and after device opened 9657 * do error stats. 9658 */ 9659 if (rval == COMMAND_DONE_ERROR && 9660 un->un_state > ST_STATE_OPENING) { 9661 ST_DO_ERRSTATS(un, st_harderrs); 9662 } 9663 9664 if (ST_RQSENSE->es_add_code == 0x3a) { 9665 if (st_error_level >= SCSI_ERR_FATAL) 9666 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 9667 "Tape not inserted in drive\n"); 9668 un->un_mediastate = MTIO_EJECTED; 9669 cv_broadcast(&un->un_state_cv); 9670 } 9671 if ((un->un_dp->options & ST_EJECT_ON_CHANGER_FAILURE) && 9672 (rval != QUE_COMMAND)) 9673 un->un_eject_tape_on_failure = st_check_asc_ascq(un); 9674 break; 9675 9676 case KEY_ABORTED_COMMAND: 9677 9678 /* 9679 * Probably a parity error... 9680 * if we retry here then this may cause data to be 9681 * written twice or data skipped during reading 9682 */ 9683 ST_DO_ERRSTATS(un, st_harderrs); 9684 severity = SCSI_ERR_FATAL; 9685 rval = COMMAND_DONE_ERROR; 9686 goto check_keys; 9687 9688 default: 9689 /* 9690 * Undecoded sense key. Try retries and hope 9691 * that will fix the problem. Otherwise, we're 9692 * dead. 9693 */ 9694 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9695 "Unhandled Sense Key '%s'\n", 9696 sense_keys[un->un_status]); 9697 ST_DO_ERRSTATS(un, st_harderrs); 9698 severity = SCSI_ERR_FATAL; 9699 rval = COMMAND_DONE_ERROR; 9700 goto check_keys; 9701 } 9702 9703 if ((!(pkt->pkt_flags & FLAG_SILENT) && 9704 un->un_state >= ST_STATE_OPEN) && (DEBUGGING || 9705 (un->un_laststate > ST_STATE_OPENING) && 9706 (severity >= st_error_level))) { 9707 9708 scsi_errmsg(ST_SCSI_DEVP, pkt, st_label, severity, 9709 un->un_blkno, un->un_err_blkno, scsi_cmds, sensep); 9710 if (sensep->es_filmk) { 9711 scsi_log(ST_DEVINFO, st_label, CE_CONT, 9712 "File Mark Detected\n"); 9713 } 9714 if (sensep->es_eom) { 9715 scsi_log(ST_DEVINFO, st_label, CE_CONT, 9716 "End-of-Media Detected\n"); 9717 } 9718 if (sensep->es_ili) { 9719 scsi_log(ST_DEVINFO, st_label, CE_CONT, 9720 "Incorrect Length Indicator Set\n"); 9721 } 9722 } 9723 get_error = geterror(bp); 9724 if (((rval == COMMAND_DONE_ERROR) || 9725 (rval == COMMAND_DONE_ERROR_RECOVERED)) && 9726 ((get_error == EIO) || (get_error == 0))) { 9727 un->un_rqs_state |= (ST_RQS_ERROR | ST_RQS_VALID); 9728 bcopy(ST_RQSENSE, un->un_uscsi_rqs_buf, SENSE_LENGTH); 9729 if (un->un_rqs_state & ST_RQS_READ) { 9730 un->un_rqs_state &= ~(ST_RQS_READ); 9731 } else { 9732 un->un_rqs_state |= ST_RQS_OVR; 9733 } 9734 } 9735 9736 return (rval); 9737 } 9738 9739 9740 static int 9741 st_handle_intr_retry_lcmd(struct scsi_tape *un, struct buf *bp) 9742 { 9743 int status = TRAN_ACCEPT; 9744 9745 mutex_enter(ST_MUTEX); 9746 9747 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9748 "st_handle_intr_rtr_lcmd(), un = 0x%p\n", (void *)un); 9749 9750 /* 9751 * Check to see if we hit the retry timeout. We check to make sure 9752 * this is the first one on the runq and make sure we have not 9753 * queued up any more, so this one has to be the last on the list 9754 * also. If it is not, we have to fail. If it is not the first, but 9755 * is the last we are in trouble anyway, as we are in the interrupt 9756 * context here. 9757 */ 9758 if (((int)un->un_retry_ct > st_retry_count) || 9759 ((un->un_runqf != bp) && (un->un_runql != bp))) { 9760 goto exit; 9761 } 9762 9763 if (un->un_throttle) { 9764 un->un_last_throttle = un->un_throttle; 9765 un->un_throttle = 0; 9766 } 9767 9768 /* 9769 * Here we know : bp is the first and last one on the runq 9770 * it is not necessary to put it back on the head of the 9771 * waitq and then move from waitq to runq. Save this queuing 9772 * and call scsi_transport. 9773 */ 9774 9775 mutex_exit(ST_MUTEX); 9776 9777 status = scsi_transport(BP_PKT(bp)); 9778 9779 mutex_enter(ST_MUTEX); 9780 9781 if (status == TRAN_ACCEPT) { 9782 un->un_tran_retry_ct = 0; 9783 if (un->un_last_throttle) { 9784 un->un_throttle = un->un_last_throttle; 9785 } 9786 mutex_exit(ST_MUTEX); 9787 9788 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9789 "restart transport \n"); 9790 return (0); 9791 } 9792 9793 ST_DO_KSTATS(bp, kstat_runq_back_to_waitq); 9794 mutex_exit(ST_MUTEX); 9795 9796 if (status == TRAN_BUSY) { 9797 if (st_handle_intr_busy(un, bp, 9798 ST_TRAN_BUSY_TIMEOUT) == 0) 9799 return (0); 9800 } 9801 ST_DEBUG6(ST_DEVINFO, st_label, CE_WARN, 9802 "restart transport rejected\n"); 9803 mutex_enter(ST_MUTEX); 9804 ST_DO_ERRSTATS(un, st_transerrs); 9805 if (un->un_last_throttle) { 9806 un->un_throttle = un->un_last_throttle; 9807 } 9808 exit: 9809 mutex_exit(ST_MUTEX); 9810 return (-1); 9811 } 9812 9813 static int 9814 st_wrongtapetype(struct scsi_tape *un) 9815 { 9816 9817 ASSERT(mutex_owned(ST_MUTEX)); 9818 9819 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9820 "st_wrongtapetype()\n"); 9821 9822 /* 9823 * Hack to handle 600A, 600XTD, 6150 && 660 vs. 300XL tapes... 9824 */ 9825 if (un->un_dp && (un->un_dp->options & ST_QIC) && un->un_mspl) { 9826 switch (un->un_dp->type) { 9827 case ST_TYPE_WANGTEK: 9828 case ST_TYPE_ARCHIVE: 9829 /* 9830 * If this really worked, we could go off of 9831 * the density codes set in the modesense 9832 * page. For this drive, 0x10 == QIC-120, 9833 * 0xf == QIC-150, and 0x5 should be for 9834 * both QIC-24 and, maybe, QIC-11. However, 9835 * the h/w doesn't do what the manual says 9836 * that it should, so we'll key off of 9837 * getting a WRITE PROTECT error AND wp *not* 9838 * set in the mode sense information. 9839 */ 9840 /* 9841 * XXX but we already know that status is 9842 * write protect, so don't check it again. 9843 */ 9844 9845 if (un->un_status == KEY_WRITE_PROTECT && 9846 un->un_mspl->wp == 0) { 9847 return (1); 9848 } 9849 break; 9850 default: 9851 break; 9852 } 9853 } 9854 return (0); 9855 } 9856 9857 static int 9858 st_check_error(struct scsi_tape *un, struct scsi_pkt *pkt) 9859 { 9860 int action; 9861 9862 ASSERT(mutex_owned(ST_MUTEX)); 9863 9864 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_check_error()\n"); 9865 9866 if (SCBP_C(pkt) == STATUS_RESERVATION_CONFLICT) { 9867 action = COMMAND_DONE_EACCES; 9868 un->un_rsvd_status |= ST_RESERVATION_CONFLICT; 9869 } else if (SCBP(pkt)->sts_busy) { 9870 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, "unit busy\n"); 9871 if ((int)un->un_retry_ct++ < st_retry_count) { 9872 action = QUE_BUSY_COMMAND; 9873 } else { 9874 ST_DEBUG2(ST_DEVINFO, st_label, CE_WARN, 9875 "unit busy too long\n"); 9876 mutex_exit(ST_MUTEX); 9877 if (scsi_reset(ROUTE, RESET_TARGET) == 0) { 9878 (void) scsi_reset(ROUTE, RESET_ALL); 9879 } 9880 mutex_enter(ST_MUTEX); 9881 action = COMMAND_DONE_ERROR; 9882 } 9883 } else if (SCBP(pkt)->sts_chk) { 9884 /* 9885 * we should only get here if the auto rqsense failed 9886 * thru a uscsi cmd without autorequest sense 9887 * so we just try again 9888 */ 9889 action = QUE_SENSE; 9890 } else { 9891 action = COMMAND_DONE; 9892 } 9893 return (action); 9894 } 9895 9896 static void 9897 st_calc_bnum(struct scsi_tape *un, struct buf *bp) 9898 { 9899 int n; 9900 9901 ASSERT(mutex_owned(ST_MUTEX)); 9902 9903 if (un->un_bsize == 0) { 9904 n = ((bp->b_bcount - bp->b_resid == 0) ? 0 : 1); 9905 un->un_kbytes_xferred += (bp->b_bcount - bp->b_resid)/1000; 9906 } else { 9907 n = ((bp->b_bcount - bp->b_resid) / un->un_bsize); 9908 } 9909 un->un_blkno += n; 9910 } 9911 9912 static void 9913 st_set_state(struct scsi_tape *un) 9914 { 9915 struct buf *bp = un->un_runqf; 9916 struct scsi_pkt *sp = BP_PKT(bp); 9917 struct uscsi_cmd *ucmd; 9918 9919 ASSERT(mutex_owned(ST_MUTEX)); 9920 9921 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 9922 "st_set_state(): un_eof=%x fmneeded=%x pkt_resid=0x%lx (%ld)\n", 9923 un->un_eof, un->un_fmneeded, sp->pkt_resid, sp->pkt_resid); 9924 9925 if (bp != un->un_sbufp) { 9926 #ifdef STDEBUG 9927 if (DEBUGGING && sp->pkt_resid) { 9928 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 9929 "pkt_resid %ld bcount %ld\n", 9930 sp->pkt_resid, bp->b_bcount); 9931 } 9932 #endif 9933 bp->b_resid = sp->pkt_resid; 9934 st_calc_bnum(un, bp); 9935 if (bp->b_flags & B_READ) { 9936 un->un_lastop = ST_OP_READ; 9937 un->un_fmneeded = 0; 9938 } else { 9939 un->un_lastop = ST_OP_WRITE; 9940 if (un->un_dp->options & ST_REEL) { 9941 un->un_fmneeded = 2; 9942 } else { 9943 un->un_fmneeded = 1; 9944 } 9945 } 9946 /* 9947 * all is honky dory at this point, so let's 9948 * readjust the throttle, to increase speed, if we 9949 * have not throttled down. 9950 */ 9951 if (un->un_throttle) 9952 un->un_throttle = un->un_max_throttle; 9953 } else { 9954 char saved_lastop = un->un_lastop; 9955 uchar_t cmd = (uchar_t)(intptr_t)bp->b_forw; 9956 9957 un->un_lastop = ST_OP_CTL; 9958 9959 switch (cmd) { 9960 case SCMD_WRITE: 9961 bp->b_resid = sp->pkt_resid; 9962 un->un_lastop = ST_OP_WRITE; 9963 st_calc_bnum(un, bp); 9964 if (un->un_dp->options & ST_REEL) { 9965 un->un_fmneeded = 2; 9966 } else { 9967 un->un_fmneeded = 1; 9968 } 9969 break; 9970 case SCMD_READ: 9971 bp->b_resid = sp->pkt_resid; 9972 un->un_lastop = ST_OP_READ; 9973 st_calc_bnum(un, bp); 9974 un->un_fmneeded = 0; 9975 break; 9976 case SCMD_WRITE_FILE_MARK: 9977 if (un->un_eof != ST_EOM) 9978 un->un_eof = ST_NO_EOF; 9979 un->un_lastop = ST_OP_WEOF; 9980 un->un_fileno += (bp->b_bcount - bp->b_resid); 9981 un->un_blkno = 0; 9982 if (un->un_dp->options & ST_REEL) { 9983 un->un_fmneeded -= 9984 (bp->b_bcount - bp->b_resid); 9985 if (un->un_fmneeded < 0) { 9986 un->un_fmneeded = 0; 9987 } 9988 } else { 9989 un->un_fmneeded = 0; 9990 } 9991 9992 break; 9993 case SCMD_REWIND: 9994 un->un_eof = ST_NO_EOF; 9995 un->un_fileno = 0; 9996 un->un_blkno = 0; 9997 break; 9998 9999 case SCMD_SPACE: 10000 { 10001 int space_fmk, count; 10002 long resid; 10003 10004 count = (int)space_cnt(bp->b_bcount); 10005 resid = (long)space_cnt(bp->b_resid); 10006 space_fmk = ((bp->b_bcount) & (1<<24)) ? 1 : 0; 10007 10008 10009 if (count >= 0) { 10010 if (space_fmk) { 10011 if (un->un_eof <= ST_EOF) { 10012 un->un_eof = ST_NO_EOF; 10013 } 10014 un->un_fileno += (count - resid); 10015 un->un_blkno = 0; 10016 } else { 10017 un->un_blkno += count - resid; 10018 } 10019 } else if (count < 0) { 10020 if (space_fmk) { 10021 un->un_fileno -= 10022 ((-count) - resid); 10023 if (un->un_fileno < 0) { 10024 un->un_fileno = 0; 10025 un->un_blkno = 0; 10026 } else { 10027 un->un_blkno = INF; 10028 } 10029 } else { 10030 if (un->un_eof >= ST_EOF_PENDING) { 10031 /* 10032 * we stepped back into 10033 * a previous file; we are not 10034 * making an effort to pretend that 10035 * we are still in the current file 10036 * ie. logical == physical position 10037 * and leave it to st_ioctl to correct 10038 */ 10039 if (un->un_fileno > 0) { 10040 un->un_fileno--; 10041 un->un_blkno = INF; 10042 } else { 10043 un->un_blkno = 0; 10044 } 10045 } else { 10046 un->un_blkno -= 10047 (-count) - resid; 10048 } 10049 } 10050 } 10051 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10052 "aft_space rs %ld fil %d blk %ld\n", 10053 resid, un->un_fileno, un->un_blkno); 10054 break; 10055 } 10056 case SCMD_LOAD: 10057 if (bp->b_bcount & 0x1) { 10058 un->un_fileno = 0; 10059 } else { 10060 un->un_state = ST_STATE_OFFLINE; 10061 un->un_fileno = -1; 10062 } 10063 un->un_density_known = 0; 10064 un->un_eof = ST_NO_EOF; 10065 un->un_blkno = 0; 10066 break; 10067 case SCMD_ERASE: 10068 un->un_eof = ST_NO_EOF; 10069 un->un_blkno = 0; 10070 un->un_fileno = 0; 10071 break; 10072 case SCMD_RESERVE: 10073 un->un_rsvd_status |= ST_RESERVE; 10074 un->un_rsvd_status &= 10075 ~(ST_RELEASE | ST_LOST_RESERVE | 10076 ST_RESERVATION_CONFLICT); 10077 un->un_lastop = saved_lastop; 10078 break; 10079 case SCMD_RELEASE: 10080 un->un_rsvd_status |= ST_RELEASE; 10081 un->un_rsvd_status &= 10082 ~(ST_RESERVE | ST_LOST_RESERVE | 10083 ST_RESERVATION_CONFLICT); 10084 un->un_lastop = saved_lastop; 10085 break; 10086 case SCMD_TEST_UNIT_READY: 10087 case SCMD_READ_BLKLIM: 10088 case SCMD_REQUEST_SENSE: 10089 case SCMD_INQUIRY: 10090 case SCMD_RECOVER_BUF: 10091 case SCMD_MODE_SELECT: 10092 case SCMD_MODE_SENSE: 10093 case SCMD_DOORLOCK: 10094 case SCMD_READ_POSITION: 10095 case SCMD_READ_BUFFER: 10096 case SCMD_REPORT_DENSITIES: 10097 case SCMD_LOG_SELECT_G1: 10098 case SCMD_LOG_SENSE_G1: 10099 case SCMD_REPORT_LUNS: 10100 un->un_lastop = saved_lastop; 10101 break; 10102 case SCMD_LOCATE: /* Locate makes position unknown */ 10103 default: 10104 /* 10105 * Unknown command, If was USCSI and USCSI_SILENT 10106 * flag was not set, set position to unknown. 10107 */ 10108 if ((((ucmd = BP_UCMD(bp)) != NULL) && 10109 (ucmd->uscsi_flags & USCSI_SILENT) == 0)) { 10110 ST_DEBUG2(ST_DEVINFO, st_label, CE_WARN, 10111 "unknown cmd 0x%X caused loss of state\n", 10112 cmd); 10113 } else { 10114 break; 10115 } 10116 /* FALLTHROUGH */ 10117 case SCMD_WRITE_BUFFER: /* Writes new firmware to device */ 10118 un->un_fileno = -1; 10119 break; 10120 } 10121 } 10122 10123 /* 10124 * In the st driver we have a logical and physical file position. 10125 * Under BSD behavior, when you get a zero read, the logical position 10126 * is before the filemark but after the last record of the file. 10127 * The physical position is after the filemark. MTIOCGET should always 10128 * return the logical file position. 10129 * 10130 * The next read gives a silent skip to the next file. 10131 * Under SVR4, the logical file position remains before the filemark 10132 * until the file is closed or a space operation is performed. 10133 * Hence set err_resid and err_file before changing fileno if case 10134 * BSD Behaviour. 10135 */ 10136 un->un_err_resid = bp->b_resid; 10137 un->un_err_fileno = un->un_fileno; 10138 un->un_err_blkno = un->un_blkno; 10139 un->un_retry_ct = 0; 10140 10141 10142 /* 10143 * If we've seen a filemark via the last read operation 10144 * advance the file counter, but mark things such that 10145 * the next read operation gets a zero count. We have 10146 * to put this here to handle the case of sitting right 10147 * at the end of a tape file having seen the file mark, 10148 * but the tape is closed and then re-opened without 10149 * any further i/o. That is, the position information 10150 * must be updated before a close. 10151 */ 10152 10153 if (un->un_lastop == ST_OP_READ && un->un_eof == ST_EOF_PENDING) { 10154 /* 10155 * If we're a 1/2" tape, and we get a filemark 10156 * right on block 0, *AND* we were not in the 10157 * first file on the tape, and we've hit logical EOM. 10158 * We'll mark the state so that later we do the 10159 * right thing (in st_close(), st_strategy() or 10160 * st_ioctl()). 10161 * 10162 */ 10163 if ((un->un_dp->options & ST_REEL) && 10164 !(un->un_dp->options & ST_READ_IGNORE_EOFS) && 10165 un->un_blkno == 0 && un->un_fileno > 0) { 10166 un->un_eof = ST_EOT_PENDING; 10167 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10168 "eot pending\n"); 10169 un->un_fileno++; 10170 un->un_blkno = 0; 10171 } else if (BSD_BEHAVIOR) { 10172 /* 10173 * If the read of the filemark was a side effect 10174 * of reading some blocks (i.e., data was actually 10175 * read), then the EOF mark is pending and the 10176 * bump into the next file awaits the next read 10177 * operation (which will return a zero count), or 10178 * a close or a space operation, else the bump 10179 * into the next file occurs now. 10180 */ 10181 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10182 "resid=%lx, bcount=%lx\n", 10183 bp->b_resid, bp->b_bcount); 10184 if (bp->b_resid != bp->b_bcount) { 10185 un->un_eof = ST_EOF; 10186 } else { 10187 un->un_silent_skip = 1; 10188 un->un_eof = ST_NO_EOF; 10189 un->un_fileno++; 10190 un->un_save_blkno = un->un_blkno; 10191 un->un_blkno = 0; 10192 } 10193 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10194 "eof of file %d, un_eof=%d\n", 10195 un->un_fileno, un->un_eof); 10196 } else if (SVR4_BEHAVIOR) { 10197 /* 10198 * If the read of the filemark was a side effect 10199 * of reading some blocks (i.e., data was actually 10200 * read), then the next read should return 0 10201 */ 10202 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10203 "resid=%lx, bcount=%lx\n", 10204 bp->b_resid, bp->b_bcount); 10205 if (bp->b_resid == bp->b_bcount) { 10206 un->un_eof = ST_EOF; 10207 } 10208 ST_DEBUG6(ST_DEVINFO, st_label, SCSI_DEBUG, 10209 "eof of file=%d, un_eof=%d\n", 10210 un->un_fileno, un->un_eof); 10211 } 10212 } 10213 } 10214 10215 /* 10216 * set the correct un_errno, to take corner cases into consideration 10217 */ 10218 static void 10219 st_set_pe_errno(struct scsi_tape *un) 10220 { 10221 ASSERT(mutex_owned(ST_MUTEX)); 10222 10223 /* if errno is already set, don't reset it */ 10224 if (un->un_errno) 10225 return; 10226 10227 /* here un_errno == 0 */ 10228 /* 10229 * if the last transfer before flushing all the 10230 * waiting I/O's, was 0 (resid = count), then we 10231 * want to give the user an error on all the rest, 10232 * so here. If there was a transfer, we set the 10233 * resid and counts to 0, and let it drop through, 10234 * giving a zero return. the next I/O will then 10235 * give an error. 10236 */ 10237 if (un->un_last_resid == un->un_last_count) { 10238 switch (un->un_eof) { 10239 case ST_EOM: 10240 un->un_errno = ENOMEM; 10241 break; 10242 case ST_EOT: 10243 case ST_EOF: 10244 un->un_errno = EIO; 10245 break; 10246 } 10247 } else { 10248 /* 10249 * we know they did not have a zero, so make 10250 * sure they get one 10251 */ 10252 un->un_last_resid = un->un_last_count = 0; 10253 } 10254 } 10255 10256 10257 /* 10258 * send in a marker pkt to terminate flushing of commands by BBA (via 10259 * flush-on-errors) property. The HBA will always return TRAN_ACCEPT 10260 */ 10261 static void 10262 st_hba_unflush(struct scsi_tape *un) 10263 { 10264 ASSERT(mutex_owned(ST_MUTEX)); 10265 10266 if (!un->un_flush_on_errors) 10267 return; 10268 10269 #ifdef FLUSH_ON_ERRORS 10270 10271 if (!un->un_mkr_pkt) { 10272 un->un_mkr_pkt = scsi_init_pkt(ROUTE, NULL, (struct buf *)NULL, 10273 NULL, 0, 0, 0, SLEEP_FUNC, NULL); 10274 10275 /* we slept, so it must be there */ 10276 pkt->pkt_flags |= FLAG_FLUSH_MARKER; 10277 } 10278 10279 mutex_exit(ST_MUTEX); 10280 scsi_transport(un->un_mkr_pkt); 10281 mutex_enter(ST_MUTEX); 10282 #endif 10283 } 10284 10285 static void 10286 st_clean_print(dev_info_t *dev, char *label, uint_t level, 10287 char *title, char *data, int len) 10288 { 10289 int i; 10290 char buf[256]; 10291 10292 (void) sprintf(buf, "%s: ", title); 10293 for (i = 0; i < len; i++) { 10294 (void) sprintf(&buf[(int)strlen(buf)], "0x%x ", 10295 (data[i] & 0xff)); 10296 } 10297 (void) sprintf(&buf[(int)strlen(buf)], "\n"); 10298 10299 scsi_log(dev, label, level, "%s", buf); 10300 } 10301 10302 /* 10303 * Conditionally enabled debugging 10304 */ 10305 #ifdef STDEBUG 10306 static void 10307 st_debug_cmds(struct scsi_tape *un, int com, int count, int wait) 10308 { 10309 char tmpbuf[64]; 10310 10311 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10312 "cmd=%s count=0x%x (%d) %ssync\n", 10313 scsi_cmd_name(com, scsi_cmds, tmpbuf), 10314 count, count, 10315 wait == ASYNC_CMD ? "a" : ""); 10316 } 10317 10318 /* 10319 * Returns pointer to name of minor node name of device 'dev'. 10320 */ 10321 static char * 10322 st_dev_name(dev_t dev) 10323 { 10324 const char density[] = { 'l', 'm', 'h', 'c' }; 10325 static char name[4]; 10326 minor_t minor; 10327 int nprt = 0; 10328 10329 minor = getminor(dev); 10330 name[nprt] = density[(minor & MT_DENSITY_MASK) >> 3]; 10331 10332 if (minor & MT_BSD) { 10333 name[++nprt] = 'b'; 10334 } 10335 10336 if (minor & MT_NOREWIND) { 10337 name[++nprt] = 'n'; 10338 } 10339 10340 /* NULL terminator */ 10341 name[++nprt] = 0; 10342 10343 return (name); 10344 } 10345 #endif /* STDEBUG */ 10346 10347 /* 10348 * Soft error reporting, so far unique to each drive 10349 * 10350 * Currently supported: exabyte and DAT soft error reporting 10351 */ 10352 static int 10353 st_report_exabyte_soft_errors(dev_t dev, int flag) 10354 { 10355 uchar_t *sensep; 10356 int amt; 10357 int rval = 0; 10358 char cdb[CDB_GROUP0], *c = cdb; 10359 struct uscsi_cmd *com; 10360 10361 GET_SOFT_STATE(dev); 10362 10363 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10364 "st_report_exabyte_soft_errors(dev = 0x%lx, flag = %d)\n", 10365 dev, flag); 10366 10367 ASSERT(mutex_owned(ST_MUTEX)); 10368 10369 com = kmem_zalloc(sizeof (*com), KM_SLEEP); 10370 sensep = kmem_zalloc(TAPE_SENSE_LENGTH, KM_SLEEP); 10371 10372 *c++ = SCMD_REQUEST_SENSE; 10373 *c++ = 0; 10374 *c++ = 0; 10375 *c++ = 0; 10376 *c++ = TAPE_SENSE_LENGTH; 10377 /* 10378 * set CLRCNT (byte 5, bit 7 which clears the error counts) 10379 */ 10380 *c = (char)0x80; 10381 10382 com->uscsi_cdb = cdb; 10383 com->uscsi_cdblen = CDB_GROUP0; 10384 com->uscsi_bufaddr = (caddr_t)sensep; 10385 com->uscsi_buflen = TAPE_SENSE_LENGTH; 10386 com->uscsi_flags = USCSI_DIAGNOSE | USCSI_SILENT 10387 | USCSI_READ | USCSI_RQENABLE; 10388 com->uscsi_timeout = un->un_dp->non_motion_timeout; 10389 10390 rval = st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, 10391 UIO_SYSSPACE); 10392 if (rval || com->uscsi_status) { 10393 goto done; 10394 } 10395 10396 /* 10397 * was there enough data? 10398 */ 10399 amt = (int)TAPE_SENSE_LENGTH - com->uscsi_resid; 10400 10401 if ((amt >= 19) && un->un_kbytes_xferred) { 10402 uint_t count, error_rate; 10403 uint_t rate; 10404 10405 if (sensep[21] & CLN) { 10406 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10407 "Periodic head cleaning required"); 10408 } 10409 if (un->un_kbytes_xferred < (EXABYTE_MIN_TRANSFER/1000)) 10410 goto done; 10411 /* 10412 * check if soft error reporting needs to be done. 10413 */ 10414 count = sensep[16] << 16 | sensep[17] << 8 | sensep[18]; 10415 count &= 0xffffff; 10416 error_rate = (count * 100)/un->un_kbytes_xferred; 10417 10418 #ifdef STDEBUG 10419 if (st_soft_error_report_debug) { 10420 scsi_log(ST_DEVINFO, st_label, CE_NOTE, 10421 "Exabyte Soft Error Report:\n"); 10422 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10423 "read/write error counter: %d\n", count); 10424 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10425 "number of bytes transferred: %dK\n", 10426 un->un_kbytes_xferred); 10427 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10428 "error_rate: %d%%\n", error_rate); 10429 10430 if (amt >= 22) { 10431 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10432 "unit sense: 0x%b 0x%b 0x%b\n", 10433 sensep[19], SENSE_19_BITS, 10434 sensep[20], SENSE_20_BITS, 10435 sensep[21], SENSE_21_BITS); 10436 } 10437 if (amt >= 27) { 10438 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10439 "tracking retry counter: %d\n", 10440 sensep[26]); 10441 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10442 "read/write retry counter: %d\n", 10443 sensep[27]); 10444 } 10445 } 10446 #endif 10447 10448 if (flag & FWRITE) { 10449 rate = EXABYTE_WRITE_ERROR_THRESHOLD; 10450 } else { 10451 rate = EXABYTE_READ_ERROR_THRESHOLD; 10452 } 10453 if (error_rate >= rate) { 10454 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10455 "Soft error rate (%d%%) during %s was too high", 10456 error_rate, 10457 ((flag & FWRITE) ? wrg_str : rdg_str)); 10458 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10459 "Please, replace tape cartridge\n"); 10460 } 10461 } 10462 10463 done: 10464 kmem_free(com, sizeof (*com)); 10465 kmem_free(sensep, TAPE_SENSE_LENGTH); 10466 10467 if (rval != 0) { 10468 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10469 "exabyte soft error reporting failed\n"); 10470 } 10471 return (rval); 10472 } 10473 10474 /* 10475 * this is very specific to Archive 4mm dat 10476 */ 10477 #define ONEGIG (1024 * 1024 * 1024) 10478 10479 static int 10480 st_report_dat_soft_errors(dev_t dev, int flag) 10481 { 10482 uchar_t *sensep; 10483 int amt, i; 10484 int rval = 0; 10485 char cdb[CDB_GROUP1], *c = cdb; 10486 struct uscsi_cmd *com; 10487 10488 GET_SOFT_STATE(dev); 10489 10490 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10491 "st_report_dat_soft_errors(dev = 0x%lx, flag = %d)\n", dev, flag); 10492 10493 ASSERT(mutex_owned(ST_MUTEX)); 10494 10495 com = kmem_zalloc(sizeof (*com), KM_SLEEP); 10496 sensep = kmem_zalloc(LOG_SENSE_LENGTH, KM_SLEEP); 10497 10498 *c++ = SCMD_LOG_SENSE_G1; 10499 *c++ = 0; 10500 *c++ = (flag & FWRITE) ? 0x42 : 0x43; 10501 *c++ = 0; 10502 *c++ = 0; 10503 *c++ = 0; 10504 *c++ = 2; 10505 *c++ = 0; 10506 *c++ = (char)LOG_SENSE_LENGTH; 10507 *c = 0; 10508 com->uscsi_cdb = cdb; 10509 com->uscsi_cdblen = CDB_GROUP1; 10510 com->uscsi_bufaddr = (caddr_t)sensep; 10511 com->uscsi_buflen = LOG_SENSE_LENGTH; 10512 com->uscsi_flags = 10513 USCSI_DIAGNOSE | USCSI_SILENT | USCSI_READ | USCSI_RQENABLE; 10514 com->uscsi_timeout = un->un_dp->non_motion_timeout; 10515 rval = 10516 st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 10517 if (rval) { 10518 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10519 "DAT soft error reporting failed\n"); 10520 } 10521 if (rval || com->uscsi_status) { 10522 goto done; 10523 } 10524 10525 /* 10526 * was there enough data? 10527 */ 10528 amt = (int)LOG_SENSE_LENGTH - com->uscsi_resid; 10529 10530 if ((amt >= MIN_LOG_SENSE_LENGTH) && un->un_kbytes_xferred) { 10531 int total, retries, param_code; 10532 10533 total = -1; 10534 retries = -1; 10535 amt = sensep[3] + 4; 10536 10537 10538 #ifdef STDEBUG 10539 if (st_soft_error_report_debug) { 10540 (void) printf("logsense:"); 10541 for (i = 0; i < MIN_LOG_SENSE_LENGTH; i++) { 10542 if (i % 16 == 0) { 10543 (void) printf("\t\n"); 10544 } 10545 (void) printf(" %x", sensep[i]); 10546 } 10547 (void) printf("\n"); 10548 } 10549 #endif 10550 10551 /* 10552 * parse the param_codes 10553 */ 10554 if (sensep[0] == 2 || sensep[0] == 3) { 10555 for (i = 4; i < amt; i++) { 10556 param_code = (sensep[i++] << 8); 10557 param_code += sensep[i++]; 10558 i++; /* skip control byte */ 10559 if (param_code == 5) { 10560 if (sensep[i++] == 4) { 10561 total = (sensep[i++] << 24); 10562 total += (sensep[i++] << 16); 10563 total += (sensep[i++] << 8); 10564 total += sensep[i]; 10565 } 10566 } else if (param_code == 0x8007) { 10567 if (sensep[i++] == 2) { 10568 retries = sensep[i++] << 8; 10569 retries += sensep[i]; 10570 } 10571 } else { 10572 i += sensep[i]; 10573 } 10574 } 10575 } 10576 10577 /* 10578 * if the log sense returned valid numbers then determine 10579 * the read and write error thresholds based on the amount of 10580 * data transferred 10581 */ 10582 10583 if (total > 0 && retries > 0) { 10584 short normal_retries = 0; 10585 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 10586 "total xferred (%s) =%x, retries=%x\n", 10587 ((flag & FWRITE) ? wrg_str : rdg_str), 10588 total, retries); 10589 10590 if (flag & FWRITE) { 10591 if (total <= 10592 WRITE_SOFT_ERROR_WARNING_THRESHOLD) { 10593 normal_retries = 10594 DAT_SMALL_WRITE_ERROR_THRESHOLD; 10595 } else { 10596 normal_retries = 10597 DAT_LARGE_WRITE_ERROR_THRESHOLD; 10598 } 10599 } else { 10600 if (total <= 10601 READ_SOFT_ERROR_WARNING_THRESHOLD) { 10602 normal_retries = 10603 DAT_SMALL_READ_ERROR_THRESHOLD; 10604 } else { 10605 normal_retries = 10606 DAT_LARGE_READ_ERROR_THRESHOLD; 10607 } 10608 } 10609 10610 ST_DEBUG4(ST_DEVINFO, st_label, SCSI_DEBUG, 10611 "normal retries=%d\n", normal_retries); 10612 10613 if (retries >= normal_retries) { 10614 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10615 "Soft error rate (retries = %d) during " 10616 "%s was too high", retries, 10617 ((flag & FWRITE) ? wrg_str : rdg_str)); 10618 scsi_log(ST_DEVINFO, st_label, CE_CONT, 10619 "Periodic head cleaning required " 10620 "and/or replace tape cartridge\n"); 10621 } 10622 10623 } else if (total == -1 || retries == -1) { 10624 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10625 "log sense parameter code does not make sense\n"); 10626 } 10627 } 10628 10629 /* 10630 * reset all values 10631 */ 10632 c = cdb; 10633 *c++ = SCMD_LOG_SELECT_G1; 10634 *c++ = 2; /* this resets all values */ 10635 *c++ = (char)0xc0; 10636 *c++ = 0; 10637 *c++ = 0; 10638 *c++ = 0; 10639 *c++ = 0; 10640 *c++ = 0; 10641 *c++ = 0; 10642 *c = 0; 10643 com->uscsi_bufaddr = NULL; 10644 com->uscsi_buflen = 0; 10645 com->uscsi_flags = USCSI_DIAGNOSE | USCSI_SILENT | USCSI_RQENABLE; 10646 rval = 10647 st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 10648 if (rval) { 10649 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10650 "DAT soft error reset failed\n"); 10651 } 10652 done: 10653 kmem_free(com, sizeof (*com)); 10654 kmem_free(sensep, LOG_SENSE_LENGTH); 10655 return (rval); 10656 } 10657 10658 static int 10659 st_report_soft_errors(dev_t dev, int flag) 10660 { 10661 GET_SOFT_STATE(dev); 10662 10663 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10664 "st_report_soft_errors(dev = 0x%lx, flag = %d)\n", dev, flag); 10665 10666 ASSERT(mutex_owned(ST_MUTEX)); 10667 10668 switch (un->un_dp->type) { 10669 case ST_TYPE_EXB8500: 10670 case ST_TYPE_EXABYTE: 10671 return (st_report_exabyte_soft_errors(dev, flag)); 10672 /*NOTREACHED*/ 10673 case ST_TYPE_PYTHON: 10674 return (st_report_dat_soft_errors(dev, flag)); 10675 /*NOTREACHED*/ 10676 default: 10677 un->un_dp->options &= ~ST_SOFT_ERROR_REPORTING; 10678 return (-1); 10679 } 10680 } 10681 10682 /* 10683 * persistent error routines 10684 */ 10685 10686 /* 10687 * enable persistent errors, and set the throttle appropriately, checking 10688 * for flush-on-errors capability 10689 */ 10690 static void 10691 st_turn_pe_on(struct scsi_tape *un) 10692 { 10693 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_pe_on\n"); 10694 ASSERT(mutex_owned(ST_MUTEX)); 10695 10696 un->un_persistence = 1; 10697 10698 /* 10699 * only use flush-on-errors if auto-request-sense and untagged-qing are 10700 * enabled. This will simplify the error handling for request senses 10701 */ 10702 10703 if (un->un_arq_enabled && un->un_untagged_qing) { 10704 uchar_t f_o_e; 10705 10706 mutex_exit(ST_MUTEX); 10707 f_o_e = (scsi_ifsetcap(ROUTE, "flush-on-errors", 1, 1) == 1) ? 10708 1 : 0; 10709 mutex_enter(ST_MUTEX); 10710 10711 un->un_flush_on_errors = f_o_e; 10712 } else { 10713 un->un_flush_on_errors = 0; 10714 } 10715 10716 if (un->un_flush_on_errors) 10717 un->un_max_throttle = (uchar_t)st_max_throttle; 10718 else 10719 un->un_max_throttle = 1; 10720 10721 if (un->un_dp->options & ST_RETRY_ON_RECOVERED_DEFERRED_ERROR) 10722 un->un_max_throttle = 1; 10723 10724 /* this will send a marker pkt */ 10725 CLEAR_PE(un); 10726 } 10727 10728 /* 10729 * This turns persistent errors permanently off 10730 */ 10731 static void 10732 st_turn_pe_off(struct scsi_tape *un) 10733 { 10734 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_pe_off\n"); 10735 ASSERT(mutex_owned(ST_MUTEX)); 10736 10737 /* turn it off for good */ 10738 un->un_persistence = 0; 10739 10740 /* this will send a marker pkt */ 10741 CLEAR_PE(un); 10742 10743 /* turn off flush on error capability, if enabled */ 10744 if (un->un_flush_on_errors) { 10745 mutex_exit(ST_MUTEX); 10746 (void) scsi_ifsetcap(ROUTE, "flush-on-errors", 0, 1); 10747 mutex_enter(ST_MUTEX); 10748 } 10749 10750 10751 un->un_flush_on_errors = 0; 10752 } 10753 10754 /* 10755 * This clear persistent errors, allowing more commands through, and also 10756 * sending a marker packet. 10757 */ 10758 static void 10759 st_clear_pe(struct scsi_tape *un) 10760 { 10761 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_pe_clear\n"); 10762 ASSERT(mutex_owned(ST_MUTEX)); 10763 10764 un->un_persist_errors = 0; 10765 un->un_throttle = un->un_last_throttle = 1; 10766 un->un_errno = 0; 10767 st_hba_unflush(un); 10768 } 10769 10770 /* 10771 * This will flag persistent errors, shutting everything down, if the 10772 * application had enabled persistent errors via MTIOCPERSISTENT 10773 */ 10774 static void 10775 st_set_pe_flag(struct scsi_tape *un) 10776 { 10777 ASSERT(mutex_owned(ST_MUTEX)); 10778 10779 if (un->un_persistence) { 10780 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, "st_pe_flag\n"); 10781 un->un_persist_errors = 1; 10782 un->un_throttle = un->un_last_throttle = 0; 10783 } 10784 } 10785 10786 int 10787 st_reserve_release(dev_t dev, int cmd) 10788 { 10789 struct uscsi_cmd uscsi_cmd; 10790 struct uscsi_cmd *com = &uscsi_cmd; 10791 int rval; 10792 char cdb[CDB_GROUP0]; 10793 10794 10795 GET_SOFT_STATE(dev); 10796 ASSERT(mutex_owned(ST_MUTEX)); 10797 10798 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10799 "st_reserve_release: %s \n", (cmd == ST_RELEASE)? 10800 "Releasing":"Reserving"); 10801 10802 bzero(cdb, CDB_GROUP0); 10803 if (cmd == ST_RELEASE) { 10804 cdb[0] = SCMD_RELEASE; 10805 } else { 10806 cdb[0] = SCMD_RESERVE; 10807 } 10808 bzero(com, sizeof (struct uscsi_cmd)); 10809 com->uscsi_flags = USCSI_WRITE; 10810 com->uscsi_cdb = cdb; 10811 com->uscsi_cdblen = CDB_GROUP0; 10812 com->uscsi_timeout = un->un_dp->non_motion_timeout; 10813 10814 rval = st_ioctl_cmd(dev, com, 10815 UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 10816 10817 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10818 "st_reserve_release: rval(1)=%d\n", rval); 10819 10820 if (rval) { 10821 if (com->uscsi_status == STATUS_RESERVATION_CONFLICT) 10822 rval = EACCES; 10823 /* 10824 * dynamically turn off reserve/release support 10825 * in case of drives which do not support 10826 * reserve/release command(ATAPI drives). 10827 */ 10828 if (un->un_status == KEY_ILLEGAL_REQUEST) { 10829 if (ST_RESERVE_SUPPORTED(un)) { 10830 un->un_dp->options |= ST_NO_RESERVE_RELEASE; 10831 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10832 "Tape unit does not support " 10833 "reserve/release \n"); 10834 } 10835 rval = 0; 10836 } 10837 } 10838 return (rval); 10839 } 10840 10841 static int 10842 st_take_ownership(dev_t dev) 10843 { 10844 int rval; 10845 10846 GET_SOFT_STATE(dev); 10847 ASSERT(mutex_owned(ST_MUTEX)); 10848 10849 ST_DEBUG3(ST_DEVINFO, st_label, SCSI_DEBUG, 10850 "st_take_ownership: Entering ...\n"); 10851 10852 10853 rval = st_reserve_release(dev, ST_RESERVE); 10854 /* 10855 * XXX -> Should reset be done only if we get EACCES. 10856 * . 10857 */ 10858 if (rval) { 10859 mutex_exit(ST_MUTEX); 10860 if (scsi_reset(ROUTE, RESET_TARGET) == 0) { 10861 if (scsi_reset(ROUTE, RESET_ALL) == 0) { 10862 mutex_enter(ST_MUTEX); 10863 return (EIO); 10864 } 10865 } 10866 mutex_enter(ST_MUTEX); 10867 un->un_rsvd_status &= 10868 ~(ST_LOST_RESERVE | ST_RESERVATION_CONFLICT); 10869 10870 mutex_exit(ST_MUTEX); 10871 delay(drv_usectohz(ST_RESERVATION_DELAY)); 10872 mutex_enter(ST_MUTEX); 10873 /* 10874 * remove the check condition. 10875 */ 10876 (void) st_reserve_release(dev, ST_RESERVE); 10877 if ((rval = st_reserve_release(dev, ST_RESERVE)) != 0) { 10878 if ((st_reserve_release(dev, ST_RESERVE)) != 0) { 10879 rval = (un->un_rsvd_status & 10880 ST_RESERVATION_CONFLICT) ? EACCES : EIO; 10881 return (rval); 10882 } 10883 } 10884 /* 10885 * Set tape state to ST_STATE_OFFLINE , in case if 10886 * the user wants to continue and start using 10887 * the tape. 10888 */ 10889 un->un_state = ST_STATE_OFFLINE; 10890 un->un_rsvd_status |= ST_INIT_RESERVE; 10891 } 10892 return (rval); 10893 } 10894 10895 static int 10896 st_create_errstats(struct scsi_tape *un, int instance) 10897 { 10898 char kstatname[KSTAT_STRLEN]; 10899 10900 /* 10901 * Create device error kstats 10902 */ 10903 10904 if (un->un_errstats == (kstat_t *)0) { 10905 (void) sprintf(kstatname, "st%d,err", instance); 10906 un->un_errstats = kstat_create("sterr", instance, kstatname, 10907 "device_error", KSTAT_TYPE_NAMED, 10908 sizeof (struct st_errstats) / sizeof (kstat_named_t), 10909 KSTAT_FLAG_PERSISTENT); 10910 10911 if (un->un_errstats) { 10912 struct st_errstats *stp; 10913 10914 stp = (struct st_errstats *)un->un_errstats->ks_data; 10915 kstat_named_init(&stp->st_softerrs, "Soft Errors", 10916 KSTAT_DATA_ULONG); 10917 kstat_named_init(&stp->st_harderrs, "Hard Errors", 10918 KSTAT_DATA_ULONG); 10919 kstat_named_init(&stp->st_transerrs, "Transport Errors", 10920 KSTAT_DATA_ULONG); 10921 kstat_named_init(&stp->st_vid, "Vendor", 10922 KSTAT_DATA_CHAR); 10923 kstat_named_init(&stp->st_pid, "Product", 10924 KSTAT_DATA_CHAR); 10925 kstat_named_init(&stp->st_revision, "Revision", 10926 KSTAT_DATA_CHAR); 10927 kstat_named_init(&stp->st_serial, "Serial No", 10928 KSTAT_DATA_CHAR); 10929 un->un_errstats->ks_private = un; 10930 un->un_errstats->ks_update = nulldev; 10931 kstat_install(un->un_errstats); 10932 /* 10933 * Fill in the static data 10934 */ 10935 (void) strncpy(&stp->st_vid.value.c[0], 10936 ST_INQUIRY->inq_vid, 8); 10937 /* 10938 * XXX: Emulex MT-02 (and emulators) predates 10939 * SCSI-1 and has no vid & pid inquiry data. 10940 */ 10941 if (ST_INQUIRY->inq_len != 0) { 10942 (void) strncpy(&stp->st_pid.value.c[0], 10943 ST_INQUIRY->inq_pid, 16); 10944 (void) strncpy(&stp->st_revision.value.c[0], 10945 ST_INQUIRY->inq_revision, 4); 10946 (void) strncpy(&stp->st_serial.value.c[0], 10947 ST_INQUIRY->inq_serial, 12); 10948 } 10949 } 10950 } 10951 return (0); 10952 } 10953 10954 static int 10955 st_validate_tapemarks(struct scsi_tape *un, int fileno, daddr_t blkno) 10956 { 10957 dev_t dev; 10958 10959 ASSERT(MUTEX_HELD(&un->un_sd->sd_mutex)); 10960 ASSERT(mutex_owned(ST_MUTEX)); 10961 10962 dev = un->un_dev; 10963 10964 scsi_log(ST_DEVINFO, st_label, CE_NOTE, "Restoring tape" 10965 " position at fileno=%x, blkno=%lx....", fileno, blkno); 10966 10967 /* 10968 * Rewind ? Oh yeah, Fidelity has got the STK F/W changed 10969 * so as not to rewind tape on RESETS: Gee, Has life ever 10970 * been simple in tape land ? 10971 */ 10972 if (st_cmd(dev, SCMD_REWIND, 0, SYNC_CMD)) { 10973 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10974 "Failed to restore the last file and block position: In" 10975 " this state, Tape will be loaded at BOT during next open"); 10976 un->un_fileno = -1; 10977 return (1); 10978 } 10979 10980 if (fileno) { 10981 if (st_cmd(dev, SCMD_SPACE, Fmk(fileno), SYNC_CMD)) { 10982 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10983 "Failed to restore the last file position: In this " 10984 " state, Tape will be loaded at BOT during next open"); 10985 un->un_fileno = -1; 10986 return (2); 10987 } 10988 } 10989 10990 if (blkno) { 10991 if (st_cmd(dev, SCMD_SPACE, Blk(blkno), SYNC_CMD)) { 10992 scsi_log(ST_DEVINFO, st_label, CE_WARN, 10993 "Failed to restore the last block position: In this" 10994 " state, tape will be loaded at BOT during next open"); 10995 un->un_fileno = -1; 10996 return (3); 10997 } 10998 } 10999 11000 return (0); 11001 } 11002 11003 /* 11004 * check sense key, ASC, ASCQ in order to determine if the tape needs 11005 * to be ejected 11006 */ 11007 11008 static int 11009 st_check_asc_ascq(struct scsi_tape *un) 11010 { 11011 struct scsi_extended_sense *sensep = ST_RQSENSE; 11012 struct tape_failure_code *code; 11013 11014 for (code = st_tape_failure_code; code->key != 0xff; code++) { 11015 if ((code->key == sensep->es_key) && 11016 (code->add_code == sensep->es_add_code) && 11017 (code->qual_code == sensep->es_qual_code)) 11018 return (1); 11019 } 11020 return (0); 11021 } 11022 11023 /* 11024 * st_logpage_supported() sends a Log Sense command with 11025 * page code = 0 = Supported Log Pages Page to the device, 11026 * to see whether the page 'page' is supported. 11027 * Return values are: 11028 * -1 if the Log Sense command fails 11029 * 0 if page is not supported 11030 * 1 if page is supported 11031 */ 11032 11033 static int 11034 st_logpage_supported(dev_t dev, uchar_t page) 11035 { 11036 uchar_t *sp, *sensep; 11037 unsigned length; 11038 struct uscsi_cmd *com; 11039 int rval; 11040 char cdb[CDB_GROUP1] = { 11041 SCMD_LOG_SENSE_G1, 11042 0, 11043 SUPPORTED_LOG_PAGES_PAGE, 11044 0, 11045 0, 11046 0, 11047 0, 11048 0, 11049 (char)LOG_SENSE_LENGTH, 11050 0 11051 }; 11052 11053 GET_SOFT_STATE(dev); 11054 ASSERT(mutex_owned(ST_MUTEX)); 11055 11056 com = kmem_zalloc(sizeof (struct uscsi_cmd), KM_SLEEP); 11057 sensep = kmem_zalloc(LOG_SENSE_LENGTH, KM_SLEEP); 11058 11059 com->uscsi_cdb = cdb; 11060 com->uscsi_cdblen = CDB_GROUP1; 11061 com->uscsi_bufaddr = (caddr_t)sensep; 11062 com->uscsi_buflen = LOG_SENSE_LENGTH; 11063 com->uscsi_flags = 11064 USCSI_DIAGNOSE | USCSI_SILENT | USCSI_READ | USCSI_RQENABLE; 11065 com->uscsi_timeout = un->un_dp->non_motion_timeout; 11066 rval = st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 11067 if (rval || com->uscsi_status) { 11068 /* uscsi-command failed */ 11069 rval = -1; 11070 } else { 11071 11072 sp = sensep + 3; 11073 11074 for (length = *sp++; length > 0; length--, sp++) { 11075 11076 if (*sp == page) { 11077 rval = 1; 11078 break; 11079 } 11080 } 11081 } 11082 kmem_free(com, sizeof (struct uscsi_cmd)); 11083 kmem_free(sensep, LOG_SENSE_LENGTH); 11084 return (rval); 11085 } 11086 11087 11088 /* 11089 * st_check_clean_bit() gets the status of the tape's cleaning bit. 11090 * 11091 * If the device does support the TapeAlert log page, then the cleaning bit 11092 * information will be read from this page. Otherwise we will see if one of 11093 * ST_CLN_TYPE_1, ST_CLN_TYPE_2 or ST_CLN_TYPE_3 is set in the properties of 11094 * the device, which means, that we can get the cleaning bit information via 11095 * a RequestSense command. 11096 * If both methods of getting cleaning bit information are not supported 11097 * st_check_clean_bit() will return with 0. Otherwise st_check_clean_bit() 11098 * returns with 11099 * - MTF_TAPE_CLN_SUPPORTED if cleaning bit is not set or 11100 * - MTF_TAPE_CLN_SUPPORTED | MTF_TAPE_HEAD_DIRTY if cleaning bit is set. 11101 * If the call to st_ioctl_cmd() to do the Log Sense or the Request Sense 11102 * command fails, or if the amount of Request Sense data is not enough, then 11103 * st_check_clean_bit() returns with -1. 11104 */ 11105 11106 static int 11107 st_check_clean_bit(dev_t dev) 11108 { 11109 int rval = 0; 11110 11111 GET_SOFT_STATE(dev); 11112 11113 ASSERT(mutex_owned(ST_MUTEX)); 11114 11115 if (un->un_HeadClean & TAPE_ALERT_NOT_SUPPORTED) { 11116 return (rval); 11117 } 11118 11119 if (un->un_HeadClean == TAPE_ALERT_SUPPORT_UNKNOWN) { 11120 11121 rval = st_logpage_supported(dev, TAPE_SEQUENTIAL_PAGE); 11122 if (rval == 1) { 11123 11124 un->un_HeadClean |= TAPE_SEQUENTIAL_SUPPORTED; 11125 } 11126 11127 rval = st_logpage_supported(dev, TAPE_ALERT_PAGE); 11128 if (rval == 1) { 11129 11130 un->un_HeadClean |= TAPE_ALERT_SUPPORTED; 11131 } 11132 11133 if (un->un_HeadClean == TAPE_ALERT_SUPPORT_UNKNOWN) { 11134 11135 un->un_HeadClean = TAPE_ALERT_NOT_SUPPORTED; 11136 } 11137 } 11138 11139 rval = 0; 11140 11141 if (un->un_HeadClean & TAPE_SEQUENTIAL_SUPPORTED) { 11142 11143 rval = st_check_sequential_clean_bit(dev); 11144 } 11145 11146 if ((rval <= 0) && (un->un_HeadClean & TAPE_ALERT_SUPPORTED)) { 11147 11148 rval = st_check_alert_clean_bit(dev); 11149 } 11150 11151 if ((rval <= 0) && (un->un_dp->options & ST_CLN_MASK)) { 11152 11153 rval = st_check_sense_clean_bit(dev); 11154 } 11155 11156 if (rval < 0) { 11157 return (rval); 11158 } 11159 11160 /* 11161 * If found a supported means to check need to clean. 11162 */ 11163 if (rval & MTF_TAPE_CLN_SUPPORTED) { 11164 11165 /* 11166 * head needs to be cleaned. 11167 */ 11168 if (rval & MTF_TAPE_HEAD_DIRTY) { 11169 11170 /* 11171 * Print log message only first time 11172 * found needing cleaned. 11173 */ 11174 if ((un->un_HeadClean & TAPE_PREVIOUSLY_DIRTY) == 0) { 11175 11176 scsi_log(ST_DEVINFO, st_label, CE_WARN, 11177 "Periodic head cleaning required"); 11178 11179 un->un_HeadClean |= TAPE_PREVIOUSLY_DIRTY; 11180 } 11181 11182 } else { 11183 11184 un->un_HeadClean &= ~TAPE_PREVIOUSLY_DIRTY; 11185 } 11186 } 11187 11188 return (rval); 11189 } 11190 11191 11192 static int 11193 st_check_sequential_clean_bit(dev_t dev) 11194 { 11195 int rval; 11196 int ix; 11197 ushort_t parameter; 11198 struct uscsi_cmd *cmd; 11199 struct log_sequential_page *sp; 11200 struct log_sequential_page_parameter *prm; 11201 char cdb[CDB_GROUP1] = { 11202 SCMD_LOG_SENSE_G1, 11203 0, 11204 TAPE_SEQUENTIAL_PAGE | CURRENT_CUMULATIVE_VALUES, 11205 0, 11206 0, 11207 0, 11208 0, 11209 (char)(sizeof (struct log_sequential_page) >> 8), 11210 (char)(sizeof (struct log_sequential_page)), 11211 0 11212 }; 11213 11214 GET_SOFT_STATE(dev); 11215 11216 cmd = kmem_zalloc(sizeof (struct uscsi_cmd), KM_SLEEP); 11217 sp = kmem_zalloc(sizeof (struct log_sequential_page), KM_SLEEP); 11218 11219 cmd->uscsi_flags = 11220 USCSI_DIAGNOSE | USCSI_SILENT | USCSI_READ | USCSI_RQENABLE; 11221 cmd->uscsi_timeout = un->un_dp->non_motion_timeout; 11222 cmd->uscsi_cdb = cdb; 11223 cmd->uscsi_cdblen = CDB_GROUP1; 11224 cmd->uscsi_bufaddr = (caddr_t)sp; 11225 cmd->uscsi_buflen = sizeof (struct log_sequential_page); 11226 11227 rval = st_ioctl_cmd(dev, cmd, UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 11228 11229 if (rval || cmd->uscsi_status || cmd->uscsi_resid) { 11230 11231 rval = -1; 11232 11233 } else if (sp->log_page.code != TAPE_SEQUENTIAL_PAGE) { 11234 11235 rval = -1; 11236 } 11237 11238 prm = &sp->param[0]; 11239 11240 for (ix = 0; rval == 0 && ix < TAPE_SEQUENTIAL_PAGE_PARA; ix++) { 11241 11242 if (prm->log_param.length == 0) { 11243 break; 11244 } 11245 11246 parameter = (((prm->log_param.pc_hi << 8) & 0xff00) + 11247 (prm->log_param.pc_lo & 0xff)); 11248 11249 if (parameter == SEQUENTIAL_NEED_CLN) { 11250 11251 rval = MTF_TAPE_CLN_SUPPORTED; 11252 if (prm->param_value[prm->log_param.length - 1]) { 11253 11254 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11255 "sequential log says head dirty\n"); 11256 rval |= MTF_TAPE_HEAD_DIRTY; 11257 } 11258 } 11259 prm = (struct log_sequential_page_parameter *) 11260 &prm->param_value[prm->log_param.length]; 11261 } 11262 11263 kmem_free(cmd, sizeof (struct uscsi_cmd)); 11264 kmem_free(sp, sizeof (struct log_sequential_page)); 11265 11266 return (rval); 11267 } 11268 11269 11270 static int 11271 st_check_alert_clean_bit(dev_t dev) 11272 { 11273 struct st_tape_alert *ta; 11274 struct uscsi_cmd *com; 11275 unsigned ix, length; 11276 int rval; 11277 ushort_t parameter; 11278 char cdb[CDB_GROUP1] = { 11279 SCMD_LOG_SENSE_G1, 11280 0, 11281 TAPE_ALERT_PAGE | CURRENT_THRESHOLD_VALUES, 11282 0, 11283 0, 11284 0, 11285 0, 11286 (char)(sizeof (struct st_tape_alert) >> 8), 11287 (char)(sizeof (struct st_tape_alert)), 11288 0 11289 }; 11290 11291 GET_SOFT_STATE(dev); 11292 11293 com = kmem_zalloc(sizeof (struct uscsi_cmd), KM_SLEEP); 11294 ta = kmem_zalloc(sizeof (struct st_tape_alert), KM_SLEEP); 11295 11296 com->uscsi_cdb = cdb; 11297 com->uscsi_cdblen = CDB_GROUP1; 11298 com->uscsi_bufaddr = (caddr_t)ta; 11299 com->uscsi_buflen = sizeof (struct st_tape_alert); 11300 com->uscsi_flags = 11301 USCSI_DIAGNOSE | USCSI_SILENT | USCSI_READ | USCSI_RQENABLE; 11302 com->uscsi_timeout = un->un_dp->non_motion_timeout; 11303 11304 rval = st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, UIO_SYSSPACE); 11305 11306 if (rval || com->uscsi_status || com->uscsi_resid) { 11307 11308 rval = -1; /* uscsi-command failed */ 11309 11310 } else if (ta->log_page.code != TAPE_ALERT_PAGE) { 11311 11312 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11313 "Not Alert Log Page returned 0x%X\n", ta->log_page.code); 11314 rval = -1; 11315 } 11316 11317 length = (ta->log_page.length_hi << 8) + ta->log_page.length_lo; 11318 11319 11320 if (length != TAPE_ALERT_PARAMETER_LENGTH) { 11321 11322 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11323 "TapeAlert length %d\n", length); 11324 } 11325 11326 11327 for (ix = 0; ix < TAPE_ALERT_MAX_PARA; ix++) { 11328 11329 /* 11330 * if rval is bad before the first pass don't bother 11331 */ 11332 if (ix == 0 && rval != 0) { 11333 11334 break; 11335 } 11336 11337 parameter = ((ta->param[ix].log_param.pc_hi << 8) + 11338 ta->param[ix].log_param.pc_lo); 11339 11340 /* 11341 * check to see if current parameter is of interest. 11342 * CLEAN_FOR_ERRORS is vendor specific to 9840 9940 stk's. 11343 */ 11344 if ((parameter == CLEAN_NOW) || 11345 (parameter == CLEAN_PERIODIC) || 11346 ((parameter == CLEAN_FOR_ERRORS) && 11347 (un->un_dp->type == ST_TYPE_STK9840))) { 11348 11349 rval = MTF_TAPE_CLN_SUPPORTED; 11350 11351 if (ta->param[ix].param_value & 1) { 11352 11353 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11354 "alert_page drive needs clean %d\n", 11355 parameter); 11356 un->un_HeadClean |= TAPE_ALERT_STILL_DIRTY; 11357 rval |= MTF_TAPE_HEAD_DIRTY; 11358 } 11359 11360 } else if (parameter == CLEANING_MEDIA) { 11361 11362 if (ta->param[ix].param_value & 1) { 11363 11364 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11365 "alert_page drive was cleaned\n"); 11366 un->un_HeadClean &= ~TAPE_ALERT_STILL_DIRTY; 11367 } 11368 } 11369 11370 } 11371 11372 /* 11373 * Report it as dirty till we see it cleaned 11374 */ 11375 if (un->un_HeadClean & TAPE_ALERT_STILL_DIRTY) { 11376 11377 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11378 "alert_page still dirty\n"); 11379 rval |= MTF_TAPE_HEAD_DIRTY; 11380 } 11381 11382 kmem_free(com, sizeof (struct uscsi_cmd)); 11383 kmem_free(ta, sizeof (struct st_tape_alert)); 11384 11385 return (rval); 11386 } 11387 11388 11389 static int 11390 st_check_sense_clean_bit(dev_t dev) 11391 { 11392 uchar_t *sensep; 11393 char cdb[CDB_GROUP0]; 11394 struct uscsi_cmd *com; 11395 ushort_t byte_pos; 11396 uchar_t bit_mask; 11397 unsigned length; 11398 int index; 11399 int rval; 11400 11401 GET_SOFT_STATE(dev); 11402 11403 /* 11404 * Since this tape does not support Tape Alert, 11405 * we now try to get the cleanbit status via 11406 * Request Sense. 11407 */ 11408 11409 if ((un->un_dp->options & ST_CLN_MASK) == ST_CLN_TYPE_1) { 11410 11411 index = 0; 11412 11413 } else if ((un->un_dp->options & ST_CLN_MASK) == ST_CLN_TYPE_2) { 11414 11415 index = 1; 11416 11417 } else if ((un->un_dp->options & ST_CLN_MASK) == ST_CLN_TYPE_3) { 11418 11419 index = 2; 11420 11421 } else { 11422 11423 return (-1); 11424 } 11425 11426 byte_pos = st_cln_bit_position[index].cln_bit_byte; 11427 bit_mask = st_cln_bit_position[index].cln_bit_mask; 11428 length = byte_pos + 1; 11429 11430 com = kmem_zalloc(sizeof (struct uscsi_cmd), KM_SLEEP); 11431 sensep = kmem_zalloc(length, KM_SLEEP); 11432 11433 cdb[0] = SCMD_REQUEST_SENSE; 11434 cdb[1] = 0; 11435 cdb[2] = 0; 11436 cdb[3] = 0; 11437 cdb[4] = (char)length; 11438 cdb[5] = 0; 11439 11440 com->uscsi_cdb = cdb; 11441 com->uscsi_cdblen = CDB_GROUP0; 11442 com->uscsi_bufaddr = (caddr_t)sensep; 11443 com->uscsi_buflen = length; 11444 com->uscsi_flags = 11445 USCSI_DIAGNOSE | USCSI_SILENT | USCSI_READ | USCSI_RQENABLE; 11446 com->uscsi_timeout = un->un_dp->non_motion_timeout; 11447 11448 rval = st_ioctl_cmd(dev, com, UIO_SYSSPACE, UIO_SYSSPACE, 11449 UIO_SYSSPACE); 11450 11451 if (rval || com->uscsi_status || com->uscsi_resid) { 11452 11453 rval = -1; 11454 11455 } else { 11456 11457 rval = MTF_TAPE_CLN_SUPPORTED; 11458 if ((sensep[byte_pos] & bit_mask) == bit_mask) { 11459 11460 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11461 "sense data says head dirty\n"); 11462 rval |= MTF_TAPE_HEAD_DIRTY; 11463 } 11464 } 11465 11466 kmem_free(com, sizeof (struct uscsi_cmd)); 11467 kmem_free(sensep, length); 11468 return (rval); 11469 } 11470 11471 /* 11472 * st_clear_unit_attention 11473 * 11474 * run test unit ready's to clear out outstanding 11475 * unit attentions. 11476 * returns zero for SUCCESS or the errno from st_cmd call 11477 */ 11478 static int 11479 st_clear_unit_attentions(dev_t dev_instance, int max_trys) 11480 { 11481 int i = 0; 11482 int rval; 11483 11484 do { 11485 rval = st_cmd(dev_instance, SCMD_TEST_UNIT_READY, 0, SYNC_CMD); 11486 } while ((rval != 0) && (rval != ENXIO) && (++i < max_trys)); 11487 return (rval); 11488 } 11489 11490 static void 11491 st_calculate_timeouts(struct scsi_tape *un) 11492 { 11493 if (un->un_dp->non_motion_timeout == 0) { 11494 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11495 un->un_dp->non_motion_timeout = 11496 st_io_time * st_long_timeout_x; 11497 } else { 11498 un->un_dp->non_motion_timeout = (ushort_t)st_io_time; 11499 } 11500 } 11501 11502 if (un->un_dp->io_timeout == 0) { 11503 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11504 un->un_dp->io_timeout = st_io_time * st_long_timeout_x; 11505 } else { 11506 un->un_dp->io_timeout = (ushort_t)st_io_time; 11507 } 11508 } 11509 11510 if (un->un_dp->rewind_timeout == 0) { 11511 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11512 un->un_dp->rewind_timeout = 11513 st_space_time * st_long_timeout_x; 11514 } else { 11515 un->un_dp->rewind_timeout = (ushort_t)st_space_time; 11516 } 11517 } 11518 11519 if (un->un_dp->space_timeout == 0) { 11520 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11521 un->un_dp->space_timeout = 11522 st_space_time * st_long_timeout_x; 11523 } else { 11524 un->un_dp->space_timeout = (ushort_t)st_space_time; 11525 } 11526 } 11527 11528 if (un->un_dp->load_timeout == 0) { 11529 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11530 un->un_dp->load_timeout = 11531 st_space_time * st_long_timeout_x; 11532 } else { 11533 un->un_dp->load_timeout = (ushort_t)st_space_time; 11534 } 11535 } 11536 11537 if (un->un_dp->unload_timeout == 0) { 11538 if (un->un_dp->options & ST_LONG_TIMEOUTS) { 11539 un->un_dp->unload_timeout = 11540 st_space_time * st_long_timeout_x; 11541 } else { 11542 un->un_dp->unload_timeout = (ushort_t)st_space_time; 11543 } 11544 } 11545 11546 if (un->un_dp->erase_timeout == 0) { 11547 if (un->un_dp->options & ST_LONG_ERASE) { 11548 un->un_dp->erase_timeout = 11549 st_space_time * st_long_space_time_x; 11550 } else { 11551 un->un_dp->erase_timeout = (ushort_t)st_space_time; 11552 } 11553 } 11554 } 11555 11556 #if defined(__i386) || defined(__amd64) 11557 11558 /* 11559 * release contig_mem and wake up waiting thread, if any 11560 */ 11561 static void 11562 st_release_contig_mem(struct scsi_tape *un, struct contig_mem *cp) 11563 { 11564 mutex_enter(ST_MUTEX); 11565 11566 cp->cm_next = un->un_contig_mem; 11567 un->un_contig_mem = cp; 11568 un->un_contig_mem_available_num++; 11569 cv_broadcast(&un->un_contig_mem_cv); 11570 11571 mutex_exit(ST_MUTEX); 11572 } 11573 11574 /* 11575 * St_get_contig_mem will return a contig_mem if there is one available 11576 * in current system. Otherwise, it will try to alloc one, if the total 11577 * number of contig_mem is within st_max_contig_mem_num. 11578 * It will sleep, if allowed by caller or return NULL, if no contig_mem 11579 * is available for now. 11580 */ 11581 static struct contig_mem * 11582 st_get_contig_mem(struct scsi_tape *un, size_t len, int alloc_flags) 11583 { 11584 size_t rlen; 11585 struct contig_mem *cp = NULL; 11586 ddi_acc_handle_t acc_hdl; 11587 caddr_t addr; 11588 int big_enough = 0; 11589 int (*dma_alloc_cb)() = (alloc_flags == KM_SLEEP) ? 11590 DDI_DMA_SLEEP : DDI_DMA_DONTWAIT; 11591 11592 /* Try to get one available contig_mem */ 11593 mutex_enter(ST_MUTEX); 11594 if (un->un_contig_mem_available_num > 0) { 11595 ST_GET_CONTIG_MEM_HEAD(un, cp, len, big_enough); 11596 } else if (un->un_contig_mem_total_num < st_max_contig_mem_num) { 11597 /* 11598 * we failed to get one. we're going to 11599 * alloc one more contig_mem for this I/O 11600 */ 11601 mutex_exit(ST_MUTEX); 11602 cp = (struct contig_mem *)kmem_zalloc( 11603 sizeof (struct contig_mem) + biosize(), 11604 alloc_flags); 11605 if (cp == NULL) { 11606 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11607 "alloc contig_mem failure\n"); 11608 return (NULL); /* cannot get one */ 11609 } 11610 cp->cm_bp = (struct buf *) 11611 (((caddr_t)cp) + sizeof (struct contig_mem)); 11612 bioinit(cp->cm_bp); 11613 mutex_enter(ST_MUTEX); 11614 un->un_contig_mem_total_num++; /* one more available */ 11615 } else { 11616 /* 11617 * we failed to get one and we're NOT allowed to 11618 * alloc more contig_mem 11619 */ 11620 if (alloc_flags == KM_SLEEP) { 11621 while (un->un_contig_mem_available_num <= 0) { 11622 cv_wait(&un->un_contig_mem_cv, 11623 ST_MUTEX); 11624 } 11625 ST_GET_CONTIG_MEM_HEAD(un, cp, len, big_enough); 11626 } else { 11627 mutex_exit(ST_MUTEX); 11628 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11629 "alloc contig_mem failure\n"); 11630 return (NULL); /* cannot get one */ 11631 } 11632 } 11633 mutex_exit(ST_MUTEX); 11634 11635 /* We need to check if this block of mem is big enough for this I/O */ 11636 if (cp->cm_len < len) { 11637 /* not big enough, need to alloc a new one */ 11638 if (ddi_dma_mem_alloc(un->un_contig_mem_hdl, len, &st_acc_attr, 11639 DDI_DMA_STREAMING, dma_alloc_cb, NULL, 11640 &addr, &rlen, &acc_hdl) != DDI_SUCCESS) { 11641 ST_DEBUG2(ST_DEVINFO, st_label, SCSI_DEBUG, 11642 "alloc contig_mem failure: not enough mem\n"); 11643 st_release_contig_mem(un, cp); 11644 cp = NULL; 11645 } else { 11646 if (cp->cm_addr) { 11647 /* release previous one before attach new one */ 11648 ddi_dma_mem_free(&cp->cm_acc_hdl); 11649 } 11650 mutex_enter(ST_MUTEX); 11651 un->un_max_contig_mem_len = 11652 un->un_max_contig_mem_len >= len ? 11653 un->un_max_contig_mem_len : len; 11654 mutex_exit(ST_MUTEX); 11655 11656 /* attach new mem to this cp */ 11657 cp->cm_addr = addr; 11658 cp->cm_acc_hdl = acc_hdl; 11659 cp->cm_len = len; 11660 11661 goto alloc_ok; /* get one usable cp */ 11662 } 11663 } else { 11664 goto alloc_ok; /* get one usable cp */ 11665 } 11666 11667 /* cannot find/alloc a usable cp, when we get here */ 11668 11669 if ((un->un_max_contig_mem_len < len) || 11670 (alloc_flags != KM_SLEEP)) { 11671 return (NULL); 11672 } 11673 11674 /* 11675 * we're allowed to sleep, and there is one big enough 11676 * contig mem in the system, which is currently in use, 11677 * wait for it... 11678 */ 11679 mutex_enter(ST_MUTEX); 11680 big_enough = 1; 11681 do { 11682 cv_wait(&un->un_contig_mem_cv, ST_MUTEX); 11683 ST_GET_CONTIG_MEM_HEAD(un, cp, len, big_enough); 11684 } while (cp == NULL); 11685 mutex_exit(ST_MUTEX); 11686 11687 /* we get the big enough contig mem, finally */ 11688 11689 alloc_ok: 11690 /* init bp attached to this cp */ 11691 bioreset(cp->cm_bp); 11692 cp->cm_bp->b_un.b_addr = cp->cm_addr; 11693 cp->cm_bp->b_private = (void *)cp; 11694 11695 return (cp); 11696 } 11697 11698 /* 11699 * this is the biodone func for the bp used in big block I/O 11700 */ 11701 static int 11702 st_bigblk_xfer_done(struct buf *bp) 11703 { 11704 struct contig_mem *cp; 11705 struct buf *orig_bp; 11706 int remapped = 0; 11707 int ioerr; 11708 struct scsi_tape *un; 11709 11710 /* sanity check */ 11711 if (bp == NULL) { 11712 return (DDI_FAILURE); 11713 } 11714 11715 un = ddi_get_soft_state(st_state, MTUNIT(bp->b_edev)); 11716 if (un == NULL) { 11717 return (DDI_FAILURE); 11718 } 11719 11720 cp = (struct contig_mem *)bp->b_private; 11721 orig_bp = cp->cm_bp; /* get back the bp we have replaced */ 11722 cp->cm_bp = bp; 11723 11724 /* special handling for special I/O */ 11725 if (cp->cm_use_sbuf) { 11726 ASSERT(un->un_sbuf_busy); 11727 un->un_sbufp = orig_bp; 11728 cp->cm_use_sbuf = 0; 11729 } 11730 11731 orig_bp->b_resid = bp->b_resid; 11732 ioerr = geterror(bp); 11733 if (ioerr != 0) { 11734 bioerror(orig_bp, ioerr); 11735 } else if (orig_bp->b_flags & B_READ) { 11736 /* copy data back to original bp */ 11737 if (orig_bp->b_flags & (B_PHYS | B_PAGEIO)) { 11738 bp_mapin(orig_bp); 11739 remapped = 1; 11740 } 11741 bcopy(bp->b_un.b_addr, orig_bp->b_un.b_addr, 11742 bp->b_bcount - bp->b_resid); 11743 if (remapped) 11744 bp_mapout(orig_bp); 11745 } 11746 11747 st_release_contig_mem(un, cp); 11748 11749 biodone(orig_bp); 11750 11751 return (DDI_SUCCESS); 11752 } 11753 11754 /* 11755 * We use this func to replace original bp that may not be able to do I/O 11756 * in big block size with one that can 11757 */ 11758 static struct buf * 11759 st_get_bigblk_bp(struct buf *bp) 11760 { 11761 struct contig_mem *cp; 11762 struct scsi_tape *un; 11763 struct buf *cont_bp; 11764 int remapped = 0; 11765 11766 un = ddi_get_soft_state(st_state, MTUNIT(bp->b_edev)); 11767 if (un == NULL) { 11768 return (bp); 11769 } 11770 11771 /* try to get one contig_mem */ 11772 cp = st_get_contig_mem(un, bp->b_bcount, KM_SLEEP); 11773 if (!cp) { 11774 scsi_log(ST_DEVINFO, st_label, CE_WARN, 11775 "Cannot alloc contig buf for I/O for %lu blk size", 11776 bp->b_bcount); 11777 return (bp); 11778 } 11779 cont_bp = cp->cm_bp; 11780 cp->cm_bp = bp; 11781 11782 /* make sure that we "are" using un_sbufp for special I/O */ 11783 if (bp == un->un_sbufp) { 11784 ASSERT(un->un_sbuf_busy); 11785 un->un_sbufp = cont_bp; 11786 cp->cm_use_sbuf = 1; 11787 } 11788 11789 /* clone bp */ 11790 cont_bp->b_bcount = bp->b_bcount; 11791 cont_bp->b_resid = bp->b_resid; 11792 cont_bp->b_iodone = st_bigblk_xfer_done; 11793 cont_bp->b_file = bp->b_file; 11794 cont_bp->b_offset = bp->b_offset; 11795 cont_bp->b_dip = bp->b_dip; 11796 cont_bp->b_error = 0; 11797 cont_bp->b_proc = NULL; 11798 cont_bp->b_flags = bp->b_flags & ~(B_PAGEIO | B_PHYS | B_SHADOW); 11799 cont_bp->b_shadow = NULL; 11800 cont_bp->b_pages = NULL; 11801 cont_bp->b_edev = bp->b_edev; 11802 cont_bp->b_dev = bp->b_dev; 11803 cont_bp->b_lblkno = bp->b_lblkno; 11804 cont_bp->b_forw = bp->b_forw; 11805 cont_bp->b_back = bp->b_back; 11806 cont_bp->av_forw = bp->av_forw; 11807 cont_bp->av_back = bp->av_back; 11808 cont_bp->b_bufsize = bp->b_bufsize; 11809 11810 /* get data in original bp */ 11811 if (bp->b_flags & B_WRITE) { 11812 if (bp->b_flags & (B_PHYS | B_PAGEIO)) { 11813 bp_mapin(bp); 11814 remapped = 1; 11815 } 11816 bcopy(bp->b_un.b_addr, cont_bp->b_un.b_addr, bp->b_bcount); 11817 if (remapped) 11818 bp_mapout(bp); 11819 } 11820 11821 return (cont_bp); 11822 } 11823 #endif 11824