tag | line | file | source code |
SCpnt | 741 | drivers/scsi/AM53C974.c | int AM53C974_command(Scsi_Cmnd *SCpnt) |
SCpnt | 290 | drivers/scsi/AM53C974.h | int AM53C974_command(Scsi_Cmnd *SCpnt); |
SCpnt | 647 | drivers/scsi/NCR53c406a.c | static void internal_done(Scsi_Cmnd *SCpnt) { |
SCpnt | 648 | drivers/scsi/NCR53c406a.c | internal_done_errcode = SCpnt->result; |
SCpnt | 670 | drivers/scsi/NCR53c406a.c | int NCR53c406a_command(Scsi_Cmnd *SCpnt){ |
SCpnt | 672 | drivers/scsi/NCR53c406a.c | NCR53c406a_queue(SCpnt, internal_done); |
SCpnt | 685 | drivers/scsi/NCR53c406a.c | NCR53c406a_queue(Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *)){ |
SCpnt | 691 | drivers/scsi/NCR53c406a.c | SCpnt->cmnd[0], |
SCpnt | 692 | drivers/scsi/NCR53c406a.c | SCpnt->cmd_len, |
SCpnt | 693 | drivers/scsi/NCR53c406a.c | SCpnt->target, |
SCpnt | 694 | drivers/scsi/NCR53c406a.c | SCpnt->lun, |
SCpnt | 695 | drivers/scsi/NCR53c406a.c | SCpnt->request_bufflen)); |
SCpnt | 698 | drivers/scsi/NCR53c406a.c | VDEB(for(i=0; i<SCpnt->cmd_len; i++) |
SCpnt | 699 | drivers/scsi/NCR53c406a.c | printk("cmd[%d]=%02x ", i, SCpnt->cmnd[i])); |
SCpnt | 703 | drivers/scsi/NCR53c406a.c | current_SC = SCpnt; |
SCpnt | 712 | drivers/scsi/NCR53c406a.c | outb(SCpnt->target, DEST_ID); /* set destination */ |
SCpnt | 715 | drivers/scsi/NCR53c406a.c | for(i=0; i<SCpnt->cmd_len; i++){ |
SCpnt | 716 | drivers/scsi/NCR53c406a.c | outb(SCpnt->cmnd[i], SCSI_FIFO); |
SCpnt | 726 | drivers/scsi/NCR53c406a.c | NCR53c406a_abort(Scsi_Cmnd *SCpnt){ |
SCpnt | 732 | drivers/scsi/NCR53c406a.c | NCR53c406a_reset(Scsi_Cmnd *SCpnt){ |
SCpnt | 131 | drivers/scsi/a2091.c | static void dma_stop (struct Scsi_Host *instance, Scsi_Cmnd *SCpnt, |
SCpnt | 161 | drivers/scsi/a2091.c | if (SCpnt && SCpnt->use_sg) { |
SCpnt | 167 | drivers/scsi/a2091.c | memcpy (SCpnt->SCp.ptr, |
SCpnt | 169 | drivers/scsi/a2091.c | SCpnt->SCp.this_residual); |
SCpnt | 177 | drivers/scsi/a2091.c | if (HDATA(instance)->dma_dir && SCpnt) |
SCpnt | 178 | drivers/scsi/a2091.c | memcpy (SCpnt->request_buffer, |
SCpnt | 180 | drivers/scsi/a2091.c | SCpnt->request_bufflen); |
SCpnt | 127 | drivers/scsi/a3000.c | static void dma_stop (struct Scsi_Host *instance, Scsi_Cmnd *SCpnt, |
SCpnt | 159 | drivers/scsi/a3000.c | if (SCpnt && SCpnt->use_sg) { |
SCpnt | 160 | drivers/scsi/a3000.c | if (HDATA(instance)->dma_dir && SCpnt) |
SCpnt | 161 | drivers/scsi/a3000.c | memcpy (SCpnt->SCp.ptr, |
SCpnt | 163 | drivers/scsi/a3000.c | SCpnt->SCp.this_residual); |
SCpnt | 169 | drivers/scsi/a3000.c | if (HDATA(instance)->dma_dir && SCpnt) |
SCpnt | 170 | drivers/scsi/a3000.c | memcpy (SCpnt->request_buffer, |
SCpnt | 172 | drivers/scsi/a3000.c | SCpnt->request_bufflen); |
SCpnt | 872 | drivers/scsi/aha152x.c | int aha152x_queue(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 874 | drivers/scsi/aha152x.c | struct Scsi_Host *shpnt = SCpnt->host; |
SCpnt | 890 | drivers/scsi/aha152x.c | SCpnt->target, SCpnt->lun); |
SCpnt | 891 | drivers/scsi/aha152x.c | print_command(SCpnt->cmnd); |
SCpnt | 893 | drivers/scsi/aha152x.c | SCpnt->cmd_len, SCpnt->use_sg, SCpnt->request_bufflen); |
SCpnt | 898 | drivers/scsi/aha152x.c | SCpnt->scsi_done = done; |
SCpnt | 906 | drivers/scsi/aha152x.c | SCpnt->SCp.phase = not_issued; |
SCpnt | 907 | drivers/scsi/aha152x.c | if (SCpnt->use_sg) |
SCpnt | 909 | drivers/scsi/aha152x.c | SCpnt->SCp.buffer = |
SCpnt | 910 | drivers/scsi/aha152x.c | (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 911 | drivers/scsi/aha152x.c | SCpnt->SCp.ptr = SCpnt->SCp.buffer->address; |
SCpnt | 912 | drivers/scsi/aha152x.c | SCpnt->SCp.this_residual = SCpnt->SCp.buffer->length; |
SCpnt | 913 | drivers/scsi/aha152x.c | SCpnt->SCp.buffers_residual = SCpnt->use_sg - 1; |
SCpnt | 917 | drivers/scsi/aha152x.c | SCpnt->SCp.ptr = (char *)SCpnt->request_buffer; |
SCpnt | 918 | drivers/scsi/aha152x.c | SCpnt->SCp.this_residual = SCpnt->request_bufflen; |
SCpnt | 919 | drivers/scsi/aha152x.c | SCpnt->SCp.buffer = NULL; |
SCpnt | 920 | drivers/scsi/aha152x.c | SCpnt->SCp.buffers_residual = 0; |
SCpnt | 923 | drivers/scsi/aha152x.c | SCpnt->SCp.Status = CHECK_CONDITION; |
SCpnt | 924 | drivers/scsi/aha152x.c | SCpnt->SCp.Message = 0; |
SCpnt | 925 | drivers/scsi/aha152x.c | SCpnt->SCp.have_data_in = 0; |
SCpnt | 926 | drivers/scsi/aha152x.c | SCpnt->SCp.sent_command = 0; |
SCpnt | 939 | drivers/scsi/aha152x.c | append_SC(&ISSUE_SC, SCpnt); |
SCpnt | 959 | drivers/scsi/aha152x.c | int aha152x_command(Scsi_Cmnd *SCpnt) |
SCpnt | 969 | drivers/scsi/aha152x.c | int aha152x_abort(Scsi_Cmnd *SCpnt) |
SCpnt | 971 | drivers/scsi/aha152x.c | struct Scsi_Host *shpnt = SCpnt->host; |
SCpnt | 981 | drivers/scsi/aha152x.c | printk("aha152x: abort(), SCpnt=0x%08x, ", (unsigned int) SCpnt); |
SCpnt | 988 | drivers/scsi/aha152x.c | ptr && ptr!=SCpnt; |
SCpnt | 1009 | drivers/scsi/aha152x.c | if (TESTLO(SSTAT1, BUSFREE) || (CURRENT_SC && CURRENT_SC!=SCpnt)) |
SCpnt | 1034 | drivers/scsi/aha152x.c | ptr && ptr!=SCpnt; |
SCpnt | 1126 | drivers/scsi/aha152x.c | int aha152x_reset(Scsi_Cmnd *SCpnt) |
SCpnt | 1128 | drivers/scsi/aha152x.c | struct Scsi_Host *shpnt = SCpnt->host; |
SCpnt | 510 | drivers/scsi/aha1542.c | int aha1542_queuecommand(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 514 | drivers/scsi/aha1542.c | unchar *cmd = (unchar *) SCpnt->cmnd; |
SCpnt | 515 | drivers/scsi/aha1542.c | unchar target = SCpnt->target; |
SCpnt | 516 | drivers/scsi/aha1542.c | unchar lun = SCpnt->lun; |
SCpnt | 518 | drivers/scsi/aha1542.c | void *buff = SCpnt->request_buffer; |
SCpnt | 519 | drivers/scsi/aha1542.c | int bufflen = SCpnt->request_bufflen; |
SCpnt | 526 | drivers/scsi/aha1542.c | mb = HOSTDATA(SCpnt->host)->mb; |
SCpnt | 527 | drivers/scsi/aha1542.c | ccb = HOSTDATA(SCpnt->host)->ccb; |
SCpnt | 530 | drivers/scsi/aha1542.c | SCpnt->result = DID_TIME_OUT << 16; |
SCpnt | 531 | drivers/scsi/aha1542.c | done(SCpnt); return 0;}); |
SCpnt | 535 | drivers/scsi/aha1542.c | if (bufflen != sizeof(SCpnt->sense_buffer)) { |
SCpnt | 539 | drivers/scsi/aha1542.c | SCpnt->result = 0; |
SCpnt | 540 | drivers/scsi/aha1542.c | done(SCpnt); |
SCpnt | 557 | drivers/scsi/aha1542.c | for (i = 0; i < SCpnt->cmd_len; i++) printk("%02x ", cmd[i]); |
SCpnt | 567 | drivers/scsi/aha1542.c | mbo = HOSTDATA(SCpnt->host)->aha1542_last_mbo_used + 1; |
SCpnt | 571 | drivers/scsi/aha1542.c | if(mb[mbo].status == 0 && HOSTDATA(SCpnt->host)->SCint[mbo] == NULL) |
SCpnt | 575 | drivers/scsi/aha1542.c | } while (mbo != HOSTDATA(SCpnt->host)->aha1542_last_mbo_used); |
SCpnt | 577 | drivers/scsi/aha1542.c | if(mb[mbo].status || HOSTDATA(SCpnt->host)->SCint[mbo]) |
SCpnt | 580 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->SCint[mbo] = SCpnt; /* This will effectively prevent someone else from |
SCpnt | 583 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->aha1542_last_mbo_used = mbo; |
SCpnt | 594 | drivers/scsi/aha1542.c | ccb[mbo].cdblen = SCpnt->cmd_len; |
SCpnt | 604 | drivers/scsi/aha1542.c | if (SCpnt->use_sg) { |
SCpnt | 612 | drivers/scsi/aha1542.c | SCpnt->host_scribble = (unsigned char *) scsi_malloc(512); |
SCpnt | 613 | drivers/scsi/aha1542.c | sgpnt = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 614 | drivers/scsi/aha1542.c | cptr = (struct chain *) SCpnt->host_scribble; |
SCpnt | 616 | drivers/scsi/aha1542.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 617 | drivers/scsi/aha1542.c | if(sgpnt[i].length == 0 || SCpnt->use_sg > 16 || |
SCpnt | 620 | drivers/scsi/aha1542.c | printk("Bad segment list supplied to aha1542.c (%d, %d)\n",SCpnt->use_sg,i); |
SCpnt | 621 | drivers/scsi/aha1542.c | for(i=0;i<SCpnt->use_sg;i++){ |
SCpnt | 634 | drivers/scsi/aha1542.c | any2scsi(ccb[mbo].datalen, SCpnt->use_sg * sizeof(struct chain)); |
SCpnt | 643 | drivers/scsi/aha1542.c | SCpnt->host_scribble = NULL; |
SCpnt | 663 | drivers/scsi/aha1542.c | SCpnt->scsi_done = done; |
SCpnt | 665 | drivers/scsi/aha1542.c | aha1542_out(SCpnt->host->io_port, &ahacmd, 1); /* start scsi command */ |
SCpnt | 676 | drivers/scsi/aha1542.c | static void internal_done(Scsi_Cmnd * SCpnt) |
SCpnt | 678 | drivers/scsi/aha1542.c | SCpnt->SCp.Status++; |
SCpnt | 681 | drivers/scsi/aha1542.c | int aha1542_command(Scsi_Cmnd * SCpnt) |
SCpnt | 685 | drivers/scsi/aha1542.c | aha1542_queuecommand(SCpnt, internal_done); |
SCpnt | 687 | drivers/scsi/aha1542.c | SCpnt->SCp.Status = 0; |
SCpnt | 688 | drivers/scsi/aha1542.c | while (!SCpnt->SCp.Status) |
SCpnt | 690 | drivers/scsi/aha1542.c | return SCpnt->result; |
SCpnt | 1109 | drivers/scsi/aha1542.c | int aha1542_abort(Scsi_Cmnd * SCpnt) |
SCpnt | 1118 | drivers/scsi/aha1542.c | inb(STATUS(SCpnt->host->io_port)), |
SCpnt | 1119 | drivers/scsi/aha1542.c | inb(INTRFLAGS(SCpnt->host->io_port))); |
SCpnt | 1123 | drivers/scsi/aha1542.c | mb = HOSTDATA(SCpnt->host)->mb; |
SCpnt | 1124 | drivers/scsi/aha1542.c | mbi = HOSTDATA(SCpnt->host)->aha1542_last_mbi_used + 1; |
SCpnt | 1131 | drivers/scsi/aha1542.c | } while (mbi != HOSTDATA(SCpnt->host)->aha1542_last_mbi_used); |
SCpnt | 1136 | drivers/scsi/aha1542.c | SCpnt->host->irq); |
SCpnt | 1137 | drivers/scsi/aha1542.c | aha1542_intr_handle(SCpnt->host->irq, NULL); |
SCpnt | 1145 | drivers/scsi/aha1542.c | if(HOSTDATA(SCpnt->host)->SCint[i]) |
SCpnt | 1147 | drivers/scsi/aha1542.c | if(HOSTDATA(SCpnt->host)->SCint[i] == SCpnt) { |
SCpnt | 1149 | drivers/scsi/aha1542.c | kdevname(SCpnt->request.rq_dev)); |
SCpnt | 1150 | drivers/scsi/aha1542.c | if (HOSTDATA(SCpnt->host)->mb[i].status) { |
SCpnt | 1152 | drivers/scsi/aha1542.c | aha1542_out(SCpnt->host->io_port, &ahacmd, 1); |
SCpnt | 1156 | drivers/scsi/aha1542.c | kdevname(SCpnt->request.rq_dev)); |
SCpnt | 1166 | drivers/scsi/aha1542.c | if (SCpnt == HOSTDATA(SCpnt->host)->SCint[mbo]){ |
SCpnt | 1168 | drivers/scsi/aha1542.c | aha1542_out(SCpnt->host->io_port, &ahacmd, 1); /* start scsi command */ |
SCpnt | 1182 | drivers/scsi/aha1542.c | int aha1542_reset(Scsi_Cmnd * SCpnt, unsigned int reset_flags) |
SCpnt | 1198 | drivers/scsi/aha1542.c | outb(HRST | SCRST, CONTROL(SCpnt->host->io_port)); |
SCpnt | 1207 | drivers/scsi/aha1542.c | WAIT(STATUS(SCpnt->host->io_port), |
SCpnt | 1214 | drivers/scsi/aha1542.c | setup_mailboxes(SCpnt->host->io_port, SCpnt->host); |
SCpnt | 1222 | drivers/scsi/aha1542.c | printk("Sent BUS RESET to scsi host %d\n", SCpnt->host->host_no); |
SCpnt | 1225 | drivers/scsi/aha1542.c | if(HOSTDATA(SCpnt->host)->SCint[i] != NULL) |
SCpnt | 1228 | drivers/scsi/aha1542.c | SCtmp = HOSTDATA(SCpnt->host)->SCint[i]; |
SCpnt | 1231 | drivers/scsi/aha1542.c | printk("Sending DID_RESET for target %d\n", SCpnt->target); |
SCpnt | 1232 | drivers/scsi/aha1542.c | SCtmp->scsi_done(SCpnt); |
SCpnt | 1234 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->SCint[i] = NULL; |
SCpnt | 1235 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->mb[i].status = 0; |
SCpnt | 1255 | drivers/scsi/aha1542.c | if(HOSTDATA(SCpnt->host)->SCint[i] == SCpnt) |
SCpnt | 1257 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->ccb[i].op = 0x81; /* BUS DEVICE RESET */ |
SCpnt | 1259 | drivers/scsi/aha1542.c | aha1542_out(SCpnt->host->io_port, &ahacmd, 1); |
SCpnt | 1265 | drivers/scsi/aha1542.c | printk("Sent BUS DEVICE RESET to target %d\n", SCpnt->target); |
SCpnt | 1271 | drivers/scsi/aha1542.c | if(HOSTDATA(SCpnt->host)->SCint[i] && |
SCpnt | 1272 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->SCint[i]->target == SCpnt->target) |
SCpnt | 1275 | drivers/scsi/aha1542.c | SCtmp = HOSTDATA(SCpnt->host)->SCint[i]; |
SCpnt | 1278 | drivers/scsi/aha1542.c | printk("Sending DID_RESET for target %d\n", SCpnt->target); |
SCpnt | 1279 | drivers/scsi/aha1542.c | SCtmp->scsi_done(SCpnt); |
SCpnt | 1281 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->SCint[i] = NULL; |
SCpnt | 1282 | drivers/scsi/aha1542.c | HOSTDATA(SCpnt->host)->mb[i].status = 0; |
SCpnt | 206 | drivers/scsi/aha1740.c | SCtmp = ecbptr->SCpnt; |
SCpnt | 252 | drivers/scsi/aha1740.c | int aha1740_queuecommand(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 255 | drivers/scsi/aha1740.c | unchar *cmd = (unchar *) SCpnt->cmnd; |
SCpnt | 256 | drivers/scsi/aha1740.c | unchar target = SCpnt->target; |
SCpnt | 258 | drivers/scsi/aha1740.c | void *buff = SCpnt->request_buffer; |
SCpnt | 259 | drivers/scsi/aha1740.c | int bufflen = SCpnt->request_bufflen; |
SCpnt | 266 | drivers/scsi/aha1740.c | if (bufflen != sizeof(SCpnt->sense_buffer)) |
SCpnt | 270 | drivers/scsi/aha1740.c | SCpnt->result = 0; |
SCpnt | 271 | drivers/scsi/aha1740.c | done(SCpnt); |
SCpnt | 284 | drivers/scsi/aha1740.c | for (i = 0; i < SCpnt->cmd_len; i++) printk("%02x ", cmd[i]); |
SCpnt | 314 | drivers/scsi/aha1740.c | ecb[ecbno].cdblen = SCpnt->cmd_len; /* SCSI Command Descriptor Block Length */ |
SCpnt | 324 | drivers/scsi/aha1740.c | if (SCpnt->use_sg) |
SCpnt | 333 | drivers/scsi/aha1740.c | SCpnt->host_scribble = (unsigned char *) scsi_malloc(512); |
SCpnt | 334 | drivers/scsi/aha1740.c | sgpnt = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 335 | drivers/scsi/aha1740.c | cptr = (struct aha1740_chain *) SCpnt->host_scribble; |
SCpnt | 337 | drivers/scsi/aha1740.c | for(i=0; i<SCpnt->use_sg; i++) |
SCpnt | 342 | drivers/scsi/aha1740.c | ecb[ecbno].datalen = SCpnt->use_sg * sizeof(struct aha1740_chain); |
SCpnt | 352 | drivers/scsi/aha1740.c | SCpnt->host_scribble = NULL; |
SCpnt | 356 | drivers/scsi/aha1740.c | ecb[ecbno].lun = SCpnt->lun; |
SCpnt | 364 | drivers/scsi/aha1740.c | ecb[ecbno].SCpnt = SCpnt; |
SCpnt | 415 | drivers/scsi/aha1740.c | static void internal_done(Scsi_Cmnd * SCpnt) |
SCpnt | 417 | drivers/scsi/aha1740.c | internal_done_errcode = SCpnt->result; |
SCpnt | 421 | drivers/scsi/aha1740.c | int aha1740_command(Scsi_Cmnd * SCpnt) |
SCpnt | 423 | drivers/scsi/aha1740.c | aha1740_queuecommand(SCpnt, internal_done); |
SCpnt | 492 | drivers/scsi/aha1740.c | int aha1740_abort(Scsi_Cmnd * SCpnt) |
SCpnt | 502 | drivers/scsi/aha1740.c | int aha1740_reset(Scsi_Cmnd * SCpnt) |
SCpnt | 143 | drivers/scsi/aha1740.h | Scsi_Cmnd *SCpnt; /* Link to the SCSI Command Block */ |
SCpnt | 376 | drivers/scsi/constants.c | void print_sense(const char * devclass, Scsi_Cmnd * SCpnt) |
SCpnt | 380 | drivers/scsi/constants.c | unsigned char * sense_buffer = SCpnt->sense_buffer; |
SCpnt | 389 | drivers/scsi/constants.c | if(s > sizeof(SCpnt->sense_buffer)) s = sizeof(SCpnt->sense_buffer); |
SCpnt | 413 | drivers/scsi/constants.c | kdevname(SCpnt->request.rq_dev), snstext[sense_buffer[2] & 0x0f]); |
SCpnt | 416 | drivers/scsi/constants.c | kdevname(SCpnt->request.rq_dev), sense_buffer[0], sense_buffer[2]); |
SCpnt | 445 | drivers/scsi/constants.c | kdevname(SCpnt->request.rq_dev), snstext[sense_buffer[0] & 0x0f]); |
SCpnt | 449 | drivers/scsi/constants.c | kdevname(SCpnt->request.rq_dev), sense_buffer[0], sense_buffer[2]); |
SCpnt | 264 | drivers/scsi/eata.c | Scsi_Cmnd *SCpnt; /* Address set in cp */ |
SCpnt | 291 | drivers/scsi/eata.c | Scsi_Cmnd *SCpnt; /* Address to be returned is sp */ |
SCpnt | 593 | drivers/scsi/eata.c | static inline void build_sg_list(struct mscp *cpp, Scsi_Cmnd *SCpnt) { |
SCpnt | 597 | drivers/scsi/eata.c | sgpnt = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 599 | drivers/scsi/eata.c | for (k = 0; k < SCpnt->use_sg; k++) { |
SCpnt | 605 | drivers/scsi/eata.c | cpp->data_len = htonl((SCpnt->use_sg * sizeof(struct sg_list))); |
SCpnt | 608 | drivers/scsi/eata.c | int eata2x_queuecommand (Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *)) { |
SCpnt | 622 | drivers/scsi/eata.c | j = ((struct hostdata *) SCpnt->host->hostdata)->board_number; |
SCpnt | 624 | drivers/scsi/eata.c | if (!done) panic("%s: qcomm, pid %ld, null done.\n", BN(j), SCpnt->pid); |
SCpnt | 645 | drivers/scsi/eata.c | else if (eata2x_reset(SCpnt, SCSI_RESET_SUGGEST_BUS_RESET) |
SCpnt | 649 | drivers/scsi/eata.c | SCpnt->result = DID_BUS_BUSY << 16; |
SCpnt | 650 | drivers/scsi/eata.c | SCpnt->host_scribble = NULL; |
SCpnt | 651 | drivers/scsi/eata.c | printk("%s: qcomm, pid %ld, DID_BUS_BUSY, done.\n", BN(j), SCpnt->pid); |
SCpnt | 653 | drivers/scsi/eata.c | done(SCpnt); |
SCpnt | 670 | drivers/scsi/eata.c | SCpnt->scsi_done = done; |
SCpnt | 672 | drivers/scsi/eata.c | SCpnt->host_scribble = (unsigned char *) &cpp->index; |
SCpnt | 675 | drivers/scsi/eata.c | BN(j), i, SCpnt->target, SCpnt->pid); |
SCpnt | 678 | drivers/scsi/eata.c | if (SCpnt->cmnd[0] == data_out_cmds[k]) { |
SCpnt | 687 | drivers/scsi/eata.c | cpp->target = SCpnt->target; |
SCpnt | 688 | drivers/scsi/eata.c | cpp->lun = SCpnt->lun; |
SCpnt | 689 | drivers/scsi/eata.c | cpp->SCpnt = SCpnt; |
SCpnt | 690 | drivers/scsi/eata.c | cpp->sense_addr = htonl((unsigned int) SCpnt->sense_buffer); |
SCpnt | 691 | drivers/scsi/eata.c | cpp->sense_len = sizeof SCpnt->sense_buffer; |
SCpnt | 693 | drivers/scsi/eata.c | if (SCpnt->use_sg) { |
SCpnt | 695 | drivers/scsi/eata.c | build_sg_list(cpp, SCpnt); |
SCpnt | 698 | drivers/scsi/eata.c | cpp->data_address = htonl((unsigned int) SCpnt->request_buffer); |
SCpnt | 699 | drivers/scsi/eata.c | cpp->data_len = htonl(SCpnt->request_bufflen); |
SCpnt | 702 | drivers/scsi/eata.c | memcpy(cpp->cdb, SCpnt->cmnd, SCpnt->cmd_len); |
SCpnt | 706 | drivers/scsi/eata.c | SCpnt->result = DID_ERROR << 16; |
SCpnt | 707 | drivers/scsi/eata.c | SCpnt->host_scribble = NULL; |
SCpnt | 709 | drivers/scsi/eata.c | BN(j), SCpnt->target, SCpnt->pid); |
SCpnt | 711 | drivers/scsi/eata.c | done(SCpnt); |
SCpnt | 756 | drivers/scsi/eata.c | if (SCarg != HD(j)->cp[i].SCpnt) |
SCpnt | 758 | drivers/scsi/eata.c | BN(j), i, SCarg, HD(j)->cp[i].SCpnt); |
SCpnt | 782 | drivers/scsi/eata.c | Scsi_Cmnd *SCpnt; |
SCpnt | 819 | drivers/scsi/eata.c | SCpnt = HD(j)->cp[i].SCpnt; |
SCpnt | 822 | drivers/scsi/eata.c | BN(j), i, SCpnt->pid); |
SCpnt | 824 | drivers/scsi/eata.c | if (SCpnt == NULL) |
SCpnt | 827 | drivers/scsi/eata.c | if (SCpnt->host_scribble == NULL) |
SCpnt | 830 | drivers/scsi/eata.c | if (*(unsigned int *)SCpnt->host_scribble != i) |
SCpnt | 833 | drivers/scsi/eata.c | if (SCpnt->scsi_done == NULL) |
SCpnt | 836 | drivers/scsi/eata.c | if (SCpnt == SCarg) arg_done = TRUE; |
SCpnt | 863 | drivers/scsi/eata.c | SCpnt = HD(j)->cp[i].SCpnt; |
SCpnt | 864 | drivers/scsi/eata.c | SCpnt->result = DID_RESET << 16; |
SCpnt | 865 | drivers/scsi/eata.c | SCpnt->host_scribble = NULL; |
SCpnt | 871 | drivers/scsi/eata.c | BN(j), i, SCpnt->pid); |
SCpnt | 873 | drivers/scsi/eata.c | SCpnt->scsi_done(SCpnt); |
SCpnt | 892 | drivers/scsi/eata.c | Scsi_Cmnd *SCpnt; |
SCpnt | 958 | drivers/scsi/eata.c | SCpnt = spp->SCpnt; |
SCpnt | 960 | drivers/scsi/eata.c | if (SCpnt == NULL) |
SCpnt | 963 | drivers/scsi/eata.c | if (SCpnt != cpp->SCpnt) |
SCpnt | 965 | drivers/scsi/eata.c | BN(j), i, SCpnt, cpp->SCpnt); |
SCpnt | 967 | drivers/scsi/eata.c | if (SCpnt->host_scribble == NULL) |
SCpnt | 969 | drivers/scsi/eata.c | BN(j), i, SCpnt->pid, SCpnt); |
SCpnt | 971 | drivers/scsi/eata.c | if (*(unsigned int *)SCpnt->host_scribble != i) |
SCpnt | 973 | drivers/scsi/eata.c | " irq %d.\n", BN(j), i, SCpnt->pid, |
SCpnt | 974 | drivers/scsi/eata.c | *(unsigned int *)SCpnt->host_scribble, irq); |
SCpnt | 982 | drivers/scsi/eata.c | if (tstatus == BUSY && SCpnt->device->type != TYPE_TAPE) |
SCpnt | 987 | drivers/scsi/eata.c | && SCpnt->device->type == TYPE_DISK |
SCpnt | 988 | drivers/scsi/eata.c | && HD(j)->target_reset[SCpnt->target]) |
SCpnt | 993 | drivers/scsi/eata.c | && SCpnt->device->type == TYPE_DISK |
SCpnt | 994 | drivers/scsi/eata.c | && (SCpnt->sense_buffer[2] & 0xf) == RECOVERED_ERROR) |
SCpnt | 1001 | drivers/scsi/eata.c | HD(j)->target_reset[SCpnt->target] = FALSE; |
SCpnt | 1003 | drivers/scsi/eata.c | if (spp->target_status && SCpnt->device->type == TYPE_DISK) |
SCpnt | 1006 | drivers/scsi/eata.c | SCpnt->target, SCpnt->lun, SCpnt->pid, |
SCpnt | 1007 | drivers/scsi/eata.c | spp->target_status, SCpnt->sense_buffer[2]); |
SCpnt | 1009 | drivers/scsi/eata.c | HD(j)->target_time_out[SCpnt->target] = 0; |
SCpnt | 1015 | drivers/scsi/eata.c | if (HD(j)->target_time_out[SCpnt->target] > 1) |
SCpnt | 1019 | drivers/scsi/eata.c | HD(j)->target_time_out[SCpnt->target]++; |
SCpnt | 1026 | drivers/scsi/eata.c | if (SCpnt->device->type != TYPE_TAPE) |
SCpnt | 1048 | drivers/scsi/eata.c | SCpnt->result = status | spp->target_status; |
SCpnt | 1054 | drivers/scsi/eata.c | if (SCpnt->result || do_trace) |
SCpnt | 1064 | drivers/scsi/eata.c | SCpnt->target, SCpnt->lun, SCpnt->pid, HD(j)->iocount); |
SCpnt | 1067 | drivers/scsi/eata.c | SCpnt->host_scribble = NULL; |
SCpnt | 1070 | drivers/scsi/eata.c | SCpnt->scsi_done(SCpnt); |
SCpnt | 627 | drivers/scsi/esp.c | int esp_queue(Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 635 | drivers/scsi/esp.c | SCpnt->scsi_done = done; |
SCpnt | 636 | drivers/scsi/esp.c | SCpnt->SCp.phase = not_issued; |
SCpnt | 638 | drivers/scsi/esp.c | esp = (struct Sparc_ESP *) SCpnt->host->hostdata; |
SCpnt | 641 | drivers/scsi/esp.c | if(!SCpnt->use_sg) { |
SCpnt | 642 | drivers/scsi/esp.c | SCpnt->SCp.this_residual = SCpnt->request_bufflen; |
SCpnt | 643 | drivers/scsi/esp.c | SCpnt->SCp.buffer = |
SCpnt | 644 | drivers/scsi/esp.c | (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 645 | drivers/scsi/esp.c | SCpnt->SCp.buffers_residual = 0; |
SCpnt | 646 | drivers/scsi/esp.c | SCpnt->SCp.Status = CHECK_CONDITION; |
SCpnt | 647 | drivers/scsi/esp.c | SCpnt->SCp.Message = 0; |
SCpnt | 648 | drivers/scsi/esp.c | SCpnt->SCp.have_data_in = 0; |
SCpnt | 649 | drivers/scsi/esp.c | SCpnt->SCp.sent_command = 0; |
SCpnt | 650 | drivers/scsi/esp.c | SCpnt->SCp.ptr = mmu_get_scsi_one((char *)SCpnt->SCp.buffer, |
SCpnt | 651 | drivers/scsi/esp.c | SCpnt->SCp.this_residual, |
SCpnt | 656 | drivers/scsi/esp.c | SCpnt->buffer, SCpnt->use_sg); |
SCpnt | 658 | drivers/scsi/esp.c | SCpnt->SCp.buffer = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 659 | drivers/scsi/esp.c | SCpnt->SCp.buffers_residual = SCpnt->use_sg - 1; |
SCpnt | 660 | drivers/scsi/esp.c | SCpnt->SCp.this_residual = SCpnt->SCp.buffer->length; |
SCpnt | 661 | drivers/scsi/esp.c | mmu_get_scsi_sgl((struct mmu_sglist *) SCpnt->SCp.buffer, |
SCpnt | 662 | drivers/scsi/esp.c | SCpnt->SCp.buffers_residual, |
SCpnt | 664 | drivers/scsi/esp.c | SCpnt->SCp.ptr = (char *) SCpnt->SCp.buffer->alt_address; |
SCpnt | 668 | drivers/scsi/esp.c | append_SC(&esp->issue_SC, SCpnt); |
SCpnt | 679 | drivers/scsi/esp.c | int esp_command(Scsi_Cmnd *SCpnt) |
SCpnt | 688 | drivers/scsi/esp.c | int esp_abort(Scsi_Cmnd *SCpnt) |
SCpnt | 764 | drivers/scsi/esp.c | struct Scsi_Cmnd *SCpnt; |
SCpnt | 766 | drivers/scsi/esp.c | SCpnt = remove_first_SC(esp->eatme_SC); |
SCpnt | 767 | drivers/scsi/esp.c | esp_done(esp, error, SCpnt); |
SCpnt | 1706 | drivers/scsi/fdomain.c | int fdomain_16x0_queue( Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 1713 | drivers/scsi/fdomain.c | SCpnt->target, |
SCpnt | 1714 | drivers/scsi/fdomain.c | *(unsigned char *)SCpnt->cmnd, |
SCpnt | 1715 | drivers/scsi/fdomain.c | SCpnt->use_sg, |
SCpnt | 1716 | drivers/scsi/fdomain.c | SCpnt->request_bufflen ); |
SCpnt | 1721 | drivers/scsi/fdomain.c | current_SC = SCpnt; /* Save this for the done function */ |
SCpnt | 1764 | drivers/scsi/fdomain.c | static void internal_done( Scsi_Cmnd *SCpnt ) |
SCpnt | 1766 | drivers/scsi/fdomain.c | internal_done_errcode = SCpnt->result; |
SCpnt | 1770 | drivers/scsi/fdomain.c | int fdomain_16x0_command( Scsi_Cmnd *SCpnt ) |
SCpnt | 1772 | drivers/scsi/fdomain.c | fdomain_16x0_queue( SCpnt, internal_done ); |
SCpnt | 1782 | drivers/scsi/fdomain.c | void print_info( Scsi_Cmnd *SCpnt ) |
SCpnt | 1788 | drivers/scsi/fdomain.c | if (!SCpnt || !SCpnt->host) { |
SCpnt | 1792 | drivers/scsi/fdomain.c | printk( "%s\n", fdomain_16x0_info( SCpnt->host ) ); |
SCpnt | 1793 | drivers/scsi/fdomain.c | print_banner( SCpnt->host ); |
SCpnt | 1794 | drivers/scsi/fdomain.c | switch (SCpnt->SCp.phase) { |
SCpnt | 1802 | drivers/scsi/fdomain.c | SCpnt->SCp.phase, |
SCpnt | 1803 | drivers/scsi/fdomain.c | SCpnt->target, |
SCpnt | 1804 | drivers/scsi/fdomain.c | *(unsigned char *)SCpnt->cmnd, |
SCpnt | 1805 | drivers/scsi/fdomain.c | SCpnt->use_sg, |
SCpnt | 1806 | drivers/scsi/fdomain.c | SCpnt->request_bufflen ); |
SCpnt | 1808 | drivers/scsi/fdomain.c | SCpnt->SCp.sent_command, |
SCpnt | 1809 | drivers/scsi/fdomain.c | SCpnt->SCp.have_data_in, |
SCpnt | 1810 | drivers/scsi/fdomain.c | SCpnt->timeout ); |
SCpnt | 1851 | drivers/scsi/fdomain.c | int fdomain_16x0_abort( Scsi_Cmnd *SCpnt) |
SCpnt | 1869 | drivers/scsi/fdomain.c | print_info( SCpnt ); |
SCpnt | 1886 | drivers/scsi/fdomain.c | int fdomain_16x0_reset( Scsi_Cmnd *SCpnt ) |
SCpnt | 1893 | drivers/scsi/fdomain.c | if (SCpnt) printk( "fdomain: SCSI Bus Reset\n" ); |
SCpnt | 138 | drivers/scsi/gvp11.c | static void dma_stop (struct Scsi_Host *instance, Scsi_Cmnd *SCpnt, |
SCpnt | 148 | drivers/scsi/gvp11.c | if (SCpnt && SCpnt->use_sg) { |
SCpnt | 154 | drivers/scsi/gvp11.c | memcpy (SCpnt->SCp.ptr, |
SCpnt | 156 | drivers/scsi/gvp11.c | SCpnt->SCp.this_residual); |
SCpnt | 164 | drivers/scsi/gvp11.c | if (HDATA(instance)->dma_dir && SCpnt) |
SCpnt | 165 | drivers/scsi/gvp11.c | memcpy (SCpnt->request_buffer, |
SCpnt | 167 | drivers/scsi/gvp11.c | SCpnt->request_bufflen); |
SCpnt | 88 | drivers/scsi/scsi.c | static void scsi_done (Scsi_Cmnd *SCpnt); |
SCpnt | 91 | drivers/scsi/scsi.c | static void scsi_times_out (Scsi_Cmnd * SCpnt); |
SCpnt | 93 | drivers/scsi/scsi.c | Scsi_Device ** SDpnt, Scsi_Cmnd * SCpnt, |
SCpnt | 375 | drivers/scsi/scsi.c | static void scan_scsis_done (Scsi_Cmnd * SCpnt) |
SCpnt | 379 | drivers/scsi/scsi.c | printk ("scan_scsis_done(%p, %06x)\n", SCpnt->host, SCpnt->result); |
SCpnt | 381 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_DONE; |
SCpnt | 383 | drivers/scsi/scsi.c | if (SCpnt->request.sem != NULL) |
SCpnt | 384 | drivers/scsi/scsi.c | up(SCpnt->request.sem); |
SCpnt | 415 | drivers/scsi/scsi.c | Scsi_Cmnd *SCpnt; |
SCpnt | 417 | drivers/scsi/scsi.c | SCpnt = (Scsi_Cmnd *) scsi_init_malloc (sizeof (Scsi_Cmnd), GFP_ATOMIC | GFP_DMA); |
SCpnt | 419 | drivers/scsi/scsi.c | memset (SCpnt, 0, sizeof (Scsi_Cmnd)); |
SCpnt | 433 | drivers/scsi/scsi.c | shpnt->host_queue->prev = SCpnt; |
SCpnt | 434 | drivers/scsi/scsi.c | SCpnt->next = shpnt->host_queue; |
SCpnt | 435 | drivers/scsi/scsi.c | SCpnt->prev = NULL; |
SCpnt | 436 | drivers/scsi/scsi.c | shpnt->host_queue = SCpnt; |
SCpnt | 449 | drivers/scsi/scsi.c | &SDpnt, SCpnt, shpnt, scsi_result); |
SCpnt | 484 | drivers/scsi/scsi.c | &SDpnt, SCpnt, shpnt, scsi_result)) |
SCpnt | 496 | drivers/scsi/scsi.c | for(hqptr = shpnt->host_queue; hqptr != SCpnt; hqptr = hqptr->next) ; |
SCpnt | 512 | drivers/scsi/scsi.c | if (SCpnt != NULL) |
SCpnt | 513 | drivers/scsi/scsi.c | scsi_init_free ((char *) SCpnt, sizeof (Scsi_Cmnd)); |
SCpnt | 527 | drivers/scsi/scsi.c | Scsi_Device **SDpnt2, Scsi_Cmnd * SCpnt, struct Scsi_Host * shpnt, |
SCpnt | 561 | drivers/scsi/scsi.c | SCpnt->host = SDpnt->host; |
SCpnt | 562 | drivers/scsi/scsi.c | SCpnt->device = SDpnt; |
SCpnt | 563 | drivers/scsi/scsi.c | SCpnt->target = SDpnt->id; |
SCpnt | 564 | drivers/scsi/scsi.c | SCpnt->lun = SDpnt->lun; |
SCpnt | 565 | drivers/scsi/scsi.c | SCpnt->channel = SDpnt->channel; |
SCpnt | 568 | drivers/scsi/scsi.c | SCpnt->request.sem = &sem; |
SCpnt | 569 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 570 | drivers/scsi/scsi.c | scsi_do_cmd (SCpnt, (void *) scsi_cmd, |
SCpnt | 578 | drivers/scsi/scsi.c | dev, lun, SCpnt->result); |
SCpnt | 579 | drivers/scsi/scsi.c | print_driverbyte(SCpnt->result); print_hostbyte(SCpnt->result); |
SCpnt | 583 | drivers/scsi/scsi.c | if (host_byte(SCpnt->result) != DID_OK) { |
SCpnt | 584 | drivers/scsi/scsi.c | if (((driver_byte (SCpnt->result) & DRIVER_SENSE) || |
SCpnt | 585 | drivers/scsi/scsi.c | (status_byte (SCpnt->result) & CHECK_CONDITION)) && |
SCpnt | 586 | drivers/scsi/scsi.c | ((SCpnt->sense_buffer[0] & 0x70) >> 4) == 7) { |
SCpnt | 587 | drivers/scsi/scsi.c | if (((SCpnt->sense_buffer[2] & 0xf) != NOT_READY) && |
SCpnt | 588 | drivers/scsi/scsi.c | ((SCpnt->sense_buffer[2] & 0xf) != UNIT_ATTENTION) && |
SCpnt | 589 | drivers/scsi/scsi.c | ((SCpnt->sense_buffer[2] & 0xf) != ILLEGAL_REQUEST || lun > 0)) |
SCpnt | 608 | drivers/scsi/scsi.c | SCpnt->cmd_len = 0; |
SCpnt | 611 | drivers/scsi/scsi.c | SCpnt->request.sem = &sem; |
SCpnt | 612 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 613 | drivers/scsi/scsi.c | scsi_do_cmd (SCpnt, (void *) scsi_cmd, |
SCpnt | 621 | drivers/scsi/scsi.c | SCpnt->result ? "failed" : "successful", SCpnt->result); |
SCpnt | 624 | drivers/scsi/scsi.c | if (SCpnt->result) |
SCpnt | 757 | drivers/scsi/scsi.c | SCpnt->cmd_len = 0; |
SCpnt | 760 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 761 | drivers/scsi/scsi.c | SCpnt->request.sem = &sem; |
SCpnt | 762 | drivers/scsi/scsi.c | scsi_do_cmd (SCpnt, (void *) scsi_cmd, |
SCpnt | 830 | drivers/scsi/scsi.c | static void scsi_times_out (Scsi_Cmnd * SCpnt) |
SCpnt | 833 | drivers/scsi/scsi.c | switch (SCpnt->internal_timeout & (IN_ABORT | IN_RESET | IN_RESET2 | IN_RESET3)) |
SCpnt | 842 | drivers/scsi/scsi.c | if (!scsi_abort (SCpnt, DID_TIME_OUT)) |
SCpnt | 846 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->pid); |
SCpnt | 847 | drivers/scsi/scsi.c | if (!scsi_reset (SCpnt, SCSI_RESET_ASYNCHRONOUS)) |
SCpnt | 857 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->channel, SCpnt->pid); |
SCpnt | 858 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_RESET; |
SCpnt | 859 | drivers/scsi/scsi.c | SCpnt->internal_timeout |= IN_RESET2; |
SCpnt | 860 | drivers/scsi/scsi.c | scsi_reset (SCpnt, |
SCpnt | 870 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->pid); |
SCpnt | 871 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~(IN_RESET | IN_RESET2); |
SCpnt | 872 | drivers/scsi/scsi.c | SCpnt->internal_timeout |= IN_RESET3; |
SCpnt | 873 | drivers/scsi/scsi.c | scsi_reset (SCpnt, |
SCpnt | 879 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->pid); |
SCpnt | 897 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 915 | drivers/scsi/scsi.c | SCpnt = device->device_queue; |
SCpnt | 916 | drivers/scsi/scsi.c | while(SCpnt){ |
SCpnt | 917 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status == RQ_INACTIVE) break; |
SCpnt | 918 | drivers/scsi/scsi.c | SCpnt = SCpnt->device_next; |
SCpnt | 921 | drivers/scsi/scsi.c | SCpnt = device->host->host_queue; |
SCpnt | 922 | drivers/scsi/scsi.c | while(SCpnt){ |
SCpnt | 923 | drivers/scsi/scsi.c | if(SCpnt->channel == device->channel |
SCpnt | 924 | drivers/scsi/scsi.c | && SCpnt->target == device->id) { |
SCpnt | 925 | drivers/scsi/scsi.c | if (SCpnt->lun == device->lun) { |
SCpnt | 927 | drivers/scsi/scsi.c | && SCpnt->request.rq_status == RQ_INACTIVE) |
SCpnt | 929 | drivers/scsi/scsi.c | found=SCpnt; |
SCpnt | 932 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status != RQ_INACTIVE) { |
SCpnt | 941 | drivers/scsi/scsi.c | SCpnt = SCpnt->next; |
SCpnt | 943 | drivers/scsi/scsi.c | SCpnt = found; |
SCpnt | 946 | drivers/scsi/scsi.c | if (!SCpnt) return NULL; |
SCpnt | 951 | drivers/scsi/scsi.c | memcpy(&SCpnt->request, req, sizeof(struct request)); |
SCpnt | 968 | drivers/scsi/scsi.c | SCpnt->request.bhtail = bh; |
SCpnt | 974 | drivers/scsi/scsi.c | SCpnt->request.nr_sectors -= req->nr_sectors; |
SCpnt | 977 | drivers/scsi/scsi.c | SCpnt->request.sem = NULL; /* Wait until whole thing done */ |
SCpnt | 983 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; /* Busy, but no request */ |
SCpnt | 984 | drivers/scsi/scsi.c | SCpnt->request.sem = NULL; /* And no one is waiting for the device |
SCpnt | 988 | drivers/scsi/scsi.c | SCpnt->use_sg = 0; /* Reset the scatter-gather flag */ |
SCpnt | 989 | drivers/scsi/scsi.c | SCpnt->old_use_sg = 0; |
SCpnt | 990 | drivers/scsi/scsi.c | SCpnt->transfersize = 0; |
SCpnt | 991 | drivers/scsi/scsi.c | SCpnt->underflow = 0; |
SCpnt | 992 | drivers/scsi/scsi.c | SCpnt->cmd_len = 0; |
SCpnt | 997 | drivers/scsi/scsi.c | SCpnt->channel = device->channel; |
SCpnt | 998 | drivers/scsi/scsi.c | SCpnt->lun = device->lun; |
SCpnt | 999 | drivers/scsi/scsi.c | SCpnt->target = device->id; |
SCpnt | 1001 | drivers/scsi/scsi.c | return SCpnt; |
SCpnt | 1023 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 1045 | drivers/scsi/scsi.c | SCpnt = device->device_queue; |
SCpnt | 1046 | drivers/scsi/scsi.c | while(SCpnt){ |
SCpnt | 1047 | drivers/scsi/scsi.c | SCwait = SCpnt; |
SCpnt | 1048 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status == RQ_INACTIVE) break; |
SCpnt | 1049 | drivers/scsi/scsi.c | SCpnt = SCpnt->device_next; |
SCpnt | 1052 | drivers/scsi/scsi.c | SCpnt = device->host->host_queue; |
SCpnt | 1053 | drivers/scsi/scsi.c | while(SCpnt){ |
SCpnt | 1054 | drivers/scsi/scsi.c | if(SCpnt->channel == device->channel |
SCpnt | 1055 | drivers/scsi/scsi.c | && SCpnt->target == device->id) { |
SCpnt | 1056 | drivers/scsi/scsi.c | if (SCpnt->lun == device->lun) { |
SCpnt | 1057 | drivers/scsi/scsi.c | SCwait = SCpnt; |
SCpnt | 1059 | drivers/scsi/scsi.c | && SCpnt->request.rq_status == RQ_INACTIVE) |
SCpnt | 1061 | drivers/scsi/scsi.c | found=SCpnt; |
SCpnt | 1064 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status != RQ_INACTIVE) { |
SCpnt | 1074 | drivers/scsi/scsi.c | SCpnt = SCpnt->next; |
SCpnt | 1076 | drivers/scsi/scsi.c | SCpnt = found; |
SCpnt | 1087 | drivers/scsi/scsi.c | if (!SCpnt || SCpnt->request.rq_status != RQ_INACTIVE) /* Might have changed */ |
SCpnt | 1117 | drivers/scsi/scsi.c | memcpy(&SCpnt->request, req, sizeof(struct request)); |
SCpnt | 1134 | drivers/scsi/scsi.c | SCpnt->request.bhtail = bh; |
SCpnt | 1139 | drivers/scsi/scsi.c | SCpnt->request.nr_sectors -= req->nr_sectors; |
SCpnt | 1142 | drivers/scsi/scsi.c | SCpnt->request.sem = NULL; /* Wait until whole thing done*/ |
SCpnt | 1151 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 1152 | drivers/scsi/scsi.c | SCpnt->request.sem = NULL; /* And no one is waiting for this |
SCpnt | 1160 | drivers/scsi/scsi.c | SCpnt->use_sg = 0; /* Reset the scatter-gather flag */ |
SCpnt | 1161 | drivers/scsi/scsi.c | SCpnt->old_use_sg = 0; |
SCpnt | 1162 | drivers/scsi/scsi.c | SCpnt->transfersize = 0; /* No default transfer size */ |
SCpnt | 1163 | drivers/scsi/scsi.c | SCpnt->cmd_len = 0; |
SCpnt | 1165 | drivers/scsi/scsi.c | SCpnt->underflow = 0; /* Do not flag underflow conditions */ |
SCpnt | 1170 | drivers/scsi/scsi.c | SCpnt->channel = device->channel; |
SCpnt | 1171 | drivers/scsi/scsi.c | SCpnt->lun = device->lun; |
SCpnt | 1172 | drivers/scsi/scsi.c | SCpnt->target = device->id; |
SCpnt | 1174 | drivers/scsi/scsi.c | return SCpnt; |
SCpnt | 1181 | drivers/scsi/scsi.c | inline void internal_cmnd (Scsi_Cmnd * SCpnt) |
SCpnt | 1190 | drivers/scsi/scsi.c | host = SCpnt->host; |
SCpnt | 1200 | drivers/scsi/scsi.c | SCpnt->serial_number = serial_number; |
SCpnt | 1206 | drivers/scsi/scsi.c | update_timeout(SCpnt, SCpnt->timeout_per_command); |
SCpnt | 1215 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->channel, SCpnt->target, SCpnt->cmnd, |
SCpnt | 1216 | drivers/scsi/scsi.c | SCpnt->buffer, SCpnt->bufflen, SCpnt->done); |
SCpnt | 1234 | drivers/scsi/scsi.c | if(!intr_count && SCpnt->host->irq) |
SCpnt | 1235 | drivers/scsi/scsi.c | disable_irq(SCpnt->host->irq); |
SCpnt | 1237 | drivers/scsi/scsi.c | host->hostt->queuecommand (SCpnt, scsi_done); |
SCpnt | 1239 | drivers/scsi/scsi.c | if(!intr_count && SCpnt->host->irq) |
SCpnt | 1240 | drivers/scsi/scsi.c | enable_irq(SCpnt->host->irq); |
SCpnt | 1248 | drivers/scsi/scsi.c | temp=host->hostt->command (SCpnt); |
SCpnt | 1249 | drivers/scsi/scsi.c | SCpnt->result = temp; |
SCpnt | 1256 | drivers/scsi/scsi.c | scsi_done(SCpnt); |
SCpnt | 1263 | drivers/scsi/scsi.c | static void scsi_request_sense (Scsi_Cmnd * SCpnt) |
SCpnt | 1269 | drivers/scsi/scsi.c | SCpnt->flags |= WAS_SENSE | ASKED_FOR_SENSE; |
SCpnt | 1270 | drivers/scsi/scsi.c | update_timeout(SCpnt, SENSE_TIMEOUT); |
SCpnt | 1274 | drivers/scsi/scsi.c | memcpy ((void *) SCpnt->cmnd , (void *) generic_sense, |
SCpnt | 1277 | drivers/scsi/scsi.c | SCpnt->cmnd[1] = SCpnt->lun << 5; |
SCpnt | 1278 | drivers/scsi/scsi.c | SCpnt->cmnd[4] = sizeof(SCpnt->sense_buffer); |
SCpnt | 1280 | drivers/scsi/scsi.c | SCpnt->request_buffer = &SCpnt->sense_buffer; |
SCpnt | 1281 | drivers/scsi/scsi.c | SCpnt->request_bufflen = sizeof(SCpnt->sense_buffer); |
SCpnt | 1282 | drivers/scsi/scsi.c | SCpnt->use_sg = 0; |
SCpnt | 1283 | drivers/scsi/scsi.c | SCpnt->cmd_len = COMMAND_SIZE(SCpnt->cmnd[0]); |
SCpnt | 1284 | drivers/scsi/scsi.c | internal_cmnd (SCpnt); |
SCpnt | 1296 | drivers/scsi/scsi.c | void scsi_do_cmd (Scsi_Cmnd * SCpnt, const void *cmnd , |
SCpnt | 1301 | drivers/scsi/scsi.c | struct Scsi_Host * host = SCpnt->host; |
SCpnt | 1306 | drivers/scsi/scsi.c | int target = SCpnt->target; |
SCpnt | 1310 | drivers/scsi/scsi.c | "command : " , host->host_no, SCpnt->channel, target, buffer, |
SCpnt | 1334 | drivers/scsi/scsi.c | SCpnt->pid = scsi_pid++; |
SCpnt | 1354 | drivers/scsi/scsi.c | memcpy ((void *) SCpnt->data_cmnd , (const void *) cmnd, 12); |
SCpnt | 1356 | drivers/scsi/scsi.c | SCpnt->host = host; |
SCpnt | 1357 | drivers/scsi/scsi.c | SCpnt->channel = channel; |
SCpnt | 1358 | drivers/scsi/scsi.c | SCpnt->target = target; |
SCpnt | 1359 | drivers/scsi/scsi.c | SCpnt->lun = (SCpnt->data_cmnd[1] >> 5); |
SCpnt | 1361 | drivers/scsi/scsi.c | SCpnt->reset_chain = NULL; |
SCpnt | 1362 | drivers/scsi/scsi.c | SCpnt->serial_number = 0; |
SCpnt | 1363 | drivers/scsi/scsi.c | SCpnt->bufflen = bufflen; |
SCpnt | 1364 | drivers/scsi/scsi.c | SCpnt->buffer = buffer; |
SCpnt | 1365 | drivers/scsi/scsi.c | SCpnt->flags=0; |
SCpnt | 1366 | drivers/scsi/scsi.c | SCpnt->retries=0; |
SCpnt | 1367 | drivers/scsi/scsi.c | SCpnt->allowed=retries; |
SCpnt | 1368 | drivers/scsi/scsi.c | SCpnt->done = done; |
SCpnt | 1369 | drivers/scsi/scsi.c | SCpnt->timeout_per_command = timeout; |
SCpnt | 1371 | drivers/scsi/scsi.c | memcpy ((void *) SCpnt->cmnd , (const void *) cmnd, 12); |
SCpnt | 1375 | drivers/scsi/scsi.c | memset ((void *) SCpnt->sense_buffer, 0, sizeof SCpnt->sense_buffer); |
SCpnt | 1376 | drivers/scsi/scsi.c | SCpnt->request_buffer = buffer; |
SCpnt | 1377 | drivers/scsi/scsi.c | SCpnt->request_bufflen = bufflen; |
SCpnt | 1378 | drivers/scsi/scsi.c | SCpnt->old_use_sg = SCpnt->use_sg; |
SCpnt | 1379 | drivers/scsi/scsi.c | if (SCpnt->cmd_len == 0) |
SCpnt | 1380 | drivers/scsi/scsi.c | SCpnt->cmd_len = COMMAND_SIZE(SCpnt->cmnd[0]); |
SCpnt | 1381 | drivers/scsi/scsi.c | SCpnt->old_cmd_len = SCpnt->cmd_len; |
SCpnt | 1385 | drivers/scsi/scsi.c | SCpnt->internal_timeout = 0; |
SCpnt | 1386 | drivers/scsi/scsi.c | SCpnt->abort_reason = 0; |
SCpnt | 1387 | drivers/scsi/scsi.c | internal_cmnd (SCpnt); |
SCpnt | 1394 | drivers/scsi/scsi.c | static int check_sense (Scsi_Cmnd * SCpnt) |
SCpnt | 1400 | drivers/scsi/scsi.c | if (((SCpnt->sense_buffer[0] & 0x70) >> 4) != 7) { |
SCpnt | 1401 | drivers/scsi/scsi.c | if(!(SCpnt->flags & ASKED_FOR_SENSE)) |
SCpnt | 1407 | drivers/scsi/scsi.c | SCpnt->flags &= ~ASKED_FOR_SENSE; |
SCpnt | 1410 | drivers/scsi/scsi.c | printk("scsi%d, channel%d : ", SCpnt->host->host_no, SCpnt->channel); |
SCpnt | 1411 | drivers/scsi/scsi.c | print_sense("", SCpnt); |
SCpnt | 1414 | drivers/scsi/scsi.c | if (SCpnt->sense_buffer[2] & 0xe0) |
SCpnt | 1417 | drivers/scsi/scsi.c | switch (SCpnt->sense_buffer[2] & 0xf) |
SCpnt | 1434 | drivers/scsi/scsi.c | if( SCpnt->device->expecting_cc_ua ) |
SCpnt | 1436 | drivers/scsi/scsi.c | SCpnt->device->expecting_cc_ua = 0; |
SCpnt | 1478 | drivers/scsi/scsi.c | static void scsi_done (Scsi_Cmnd * SCpnt) |
SCpnt | 1484 | drivers/scsi/scsi.c | struct Scsi_Host * host = SCpnt->host; |
SCpnt | 1485 | drivers/scsi/scsi.c | int result = SCpnt->result; |
SCpnt | 1486 | drivers/scsi/scsi.c | SCpnt->serial_number = 0; |
SCpnt | 1487 | drivers/scsi/scsi.c | oldto = update_timeout(SCpnt, 0); |
SCpnt | 1491 | drivers/scsi/scsi.c | result, SCpnt->target, SCpnt->lun); |
SCpnt | 1497 | drivers/scsi/scsi.c | if(host_byte(result) == DID_ABORT && SCpnt->abort_reason) |
SCpnt | 1498 | drivers/scsi/scsi.c | SCpnt->result = result = (result & 0xff00ffff) | |
SCpnt | 1499 | drivers/scsi/scsi.c | (SCpnt->abort_reason << 16); |
SCpnt | 1511 | drivers/scsi/scsi.c | if(SCpnt->flags & WAS_SENSE) |
SCpnt | 1513 | drivers/scsi/scsi.c | SCpnt->use_sg = SCpnt->old_use_sg; |
SCpnt | 1514 | drivers/scsi/scsi.c | SCpnt->cmd_len = SCpnt->old_cmd_len; |
SCpnt | 1520 | drivers/scsi/scsi.c | if (status_byte(result) && (SCpnt->flags & WAS_SENSE)) |
SCpnt | 1523 | drivers/scsi/scsi.c | SCpnt->flags &= ~WAS_SENSE; |
SCpnt | 1525 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~SENSE_TIMEOUT; |
SCpnt | 1528 | drivers/scsi/scsi.c | if (!(SCpnt->flags & WAS_RESET)) |
SCpnt | 1532 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->channel, SCpnt->target, |
SCpnt | 1533 | drivers/scsi/scsi.c | SCpnt->lun); |
SCpnt | 1534 | drivers/scsi/scsi.c | scsi_reset(SCpnt, SCSI_RESET_SYNCHRONOUS); |
SCpnt | 1549 | drivers/scsi/scsi.c | if (SCpnt->flags & WAS_SENSE) |
SCpnt | 1554 | drivers/scsi/scsi.c | SCpnt->flags &= ~WAS_SENSE; |
SCpnt | 1556 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~SENSE_TIMEOUT; |
SCpnt | 1559 | drivers/scsi/scsi.c | switch (checked = check_sense(SCpnt)) |
SCpnt | 1566 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1602 | drivers/scsi/scsi.c | switch (check_sense(SCpnt)) |
SCpnt | 1605 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1618 | drivers/scsi/scsi.c | scsi_request_sense (SCpnt); |
SCpnt | 1630 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1636 | drivers/scsi/scsi.c | " reset.\n", SCpnt->host->host_no, SCpnt->channel); |
SCpnt | 1637 | drivers/scsi/scsi.c | scsi_reset(SCpnt, SCSI_RESET_SYNCHRONOUS); |
SCpnt | 1661 | drivers/scsi/scsi.c | if (SCpnt->flags & WAS_TIMEDOUT) |
SCpnt | 1670 | drivers/scsi/scsi.c | if (SCpnt->cmnd[0] != TEST_UNIT_READY && |
SCpnt | 1671 | drivers/scsi/scsi.c | SCpnt->cmnd[0] != INQUIRY) |
SCpnt | 1680 | drivers/scsi/scsi.c | SCpnt->flags |= WAS_TIMEDOUT; |
SCpnt | 1681 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1704 | drivers/scsi/scsi.c | if (SCpnt->flags & IS_RESETTING) |
SCpnt | 1706 | drivers/scsi/scsi.c | SCpnt->flags &= ~IS_RESETTING; |
SCpnt | 1713 | drivers/scsi/scsi.c | switch (check_sense(SCpnt)) { |
SCpnt | 1715 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1728 | drivers/scsi/scsi.c | scsi_request_sense (SCpnt); |
SCpnt | 1749 | drivers/scsi/scsi.c | SCpnt->allowed, SCpnt->retries); |
SCpnt | 1751 | drivers/scsi/scsi.c | if ((++SCpnt->retries) < SCpnt->allowed) |
SCpnt | 1753 | drivers/scsi/scsi.c | if ((SCpnt->retries >= (SCpnt->allowed >> 1)) |
SCpnt | 1754 | drivers/scsi/scsi.c | && !(jiffies < SCpnt->host->last_reset + MIN_RESET_PERIOD) |
SCpnt | 1755 | drivers/scsi/scsi.c | && !(SCpnt->flags & WAS_RESET)) |
SCpnt | 1758 | drivers/scsi/scsi.c | SCpnt->host->host_no, SCpnt->channel); |
SCpnt | 1759 | drivers/scsi/scsi.c | scsi_reset(SCpnt, SCSI_RESET_SYNCHRONOUS); |
SCpnt | 1773 | drivers/scsi/scsi.c | if (SCpnt->flags & WAS_SENSE) |
SCpnt | 1774 | drivers/scsi/scsi.c | scsi_request_sense(SCpnt); |
SCpnt | 1777 | drivers/scsi/scsi.c | memcpy ((void *) SCpnt->cmnd, |
SCpnt | 1778 | drivers/scsi/scsi.c | (void*) SCpnt->data_cmnd, |
SCpnt | 1779 | drivers/scsi/scsi.c | sizeof(SCpnt->data_cmnd)); |
SCpnt | 1780 | drivers/scsi/scsi.c | SCpnt->request_buffer = SCpnt->buffer; |
SCpnt | 1781 | drivers/scsi/scsi.c | SCpnt->request_bufflen = SCpnt->bufflen; |
SCpnt | 1782 | drivers/scsi/scsi.c | SCpnt->use_sg = SCpnt->old_use_sg; |
SCpnt | 1783 | drivers/scsi/scsi.c | SCpnt->cmd_len = SCpnt->old_cmd_len; |
SCpnt | 1784 | drivers/scsi/scsi.c | internal_cmnd (SCpnt); |
SCpnt | 1793 | drivers/scsi/scsi.c | printk("Calling done function - at address %p\n", SCpnt->done); |
SCpnt | 1801 | drivers/scsi/scsi.c | if (MAJOR(SCpnt->request.rq_dev) != SCSI_DISK_MAJOR && |
SCpnt | 1802 | drivers/scsi/scsi.c | MAJOR(SCpnt->request.rq_dev) != SCSI_CDROM_MAJOR) { |
SCpnt | 1812 | drivers/scsi/scsi.c | SCpnt->result = result | ((exit & 0xff) << 24); |
SCpnt | 1813 | drivers/scsi/scsi.c | SCpnt->use_sg = SCpnt->old_use_sg; |
SCpnt | 1814 | drivers/scsi/scsi.c | SCpnt->cmd_len = SCpnt->old_cmd_len; |
SCpnt | 1815 | drivers/scsi/scsi.c | SCpnt->done (SCpnt); |
SCpnt | 1840 | drivers/scsi/scsi.c | int scsi_abort (Scsi_Cmnd * SCpnt, int why) |
SCpnt | 1844 | drivers/scsi/scsi.c | struct Scsi_Host * host = SCpnt->host; |
SCpnt | 1855 | drivers/scsi/scsi.c | if (SCpnt->serial_number != SCpnt->serial_number_at_timeout) { |
SCpnt | 1860 | drivers/scsi/scsi.c | if (SCpnt->internal_timeout & IN_ABORT) |
SCpnt | 1863 | drivers/scsi/scsi.c | while (SCpnt->internal_timeout & IN_ABORT) |
SCpnt | 1868 | drivers/scsi/scsi.c | SCpnt->internal_timeout |= IN_ABORT; |
SCpnt | 1869 | drivers/scsi/scsi.c | oldto = update_timeout(SCpnt, ABORT_TIMEOUT); |
SCpnt | 1871 | drivers/scsi/scsi.c | if ((SCpnt->flags & IS_RESETTING) && SCpnt->device->soft_reset) { |
SCpnt | 1877 | drivers/scsi/scsi.c | SCpnt->channel, SCpnt->target, SCpnt->lun); |
SCpnt | 1882 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1883 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1888 | drivers/scsi/scsi.c | SCpnt->pid, SCpnt->host->host_no, (int) SCpnt->channel, |
SCpnt | 1889 | drivers/scsi/scsi.c | (int) SCpnt->target, (int) SCpnt->lun); |
SCpnt | 1890 | drivers/scsi/scsi.c | print_command (SCpnt->cmnd); |
SCpnt | 1891 | drivers/scsi/scsi.c | if (SCpnt->serial_number != SCpnt->serial_number_at_timeout) |
SCpnt | 1893 | drivers/scsi/scsi.c | SCpnt->abort_reason = why; |
SCpnt | 1894 | drivers/scsi/scsi.c | switch(host->hostt->abort(SCpnt)) { |
SCpnt | 1906 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1907 | drivers/scsi/scsi.c | if(SCpnt->flags & WAS_TIMEDOUT) { |
SCpnt | 1914 | drivers/scsi/scsi.c | SCpnt->flags |= WAS_TIMEDOUT; |
SCpnt | 1915 | drivers/scsi/scsi.c | oldto = SCpnt->timeout_per_command; |
SCpnt | 1916 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1925 | drivers/scsi/scsi.c | update_timeout(SCpnt, oldto); |
SCpnt | 1933 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1936 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1937 | drivers/scsi/scsi.c | update_timeout(SCpnt, 0); |
SCpnt | 1941 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~IN_ABORT; |
SCpnt | 1962 | drivers/scsi/scsi.c | Scsi_Cmnd *SCpnt; |
SCpnt | 1963 | drivers/scsi/scsi.c | for (SCpnt = Host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 1964 | drivers/scsi/scsi.c | scsi_mark_device_reset(SCpnt->device); |
SCpnt | 1972 | drivers/scsi/scsi.c | Scsi_Cmnd *SCpnt; |
SCpnt | 1973 | drivers/scsi/scsi.c | for (SCpnt = Host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 1974 | drivers/scsi/scsi.c | if (SCpnt->channel == channel) |
SCpnt | 1975 | drivers/scsi/scsi.c | scsi_mark_device_reset(SCpnt->device); |
SCpnt | 1979 | drivers/scsi/scsi.c | int scsi_reset (Scsi_Cmnd * SCpnt, unsigned int reset_flags) |
SCpnt | 1984 | drivers/scsi/scsi.c | struct Scsi_Host * host = SCpnt->host; |
SCpnt | 1987 | drivers/scsi/scsi.c | host->host_no, SCpnt->channel); |
SCpnt | 1997 | drivers/scsi/scsi.c | SCpnt->host->suggest_bus_reset = FALSE; |
SCpnt | 2033 | drivers/scsi/scsi.c | SCpnt->host->suggest_bus_reset = TRUE; |
SCpnt | 2045 | drivers/scsi/scsi.c | if (SCpnt->serial_number != SCpnt->serial_number_at_timeout) { |
SCpnt | 2050 | drivers/scsi/scsi.c | if (SCpnt->internal_timeout & IN_RESET) |
SCpnt | 2053 | drivers/scsi/scsi.c | while (SCpnt->internal_timeout & IN_RESET) |
SCpnt | 2058 | drivers/scsi/scsi.c | SCpnt->internal_timeout |= IN_RESET; |
SCpnt | 2059 | drivers/scsi/scsi.c | update_timeout(SCpnt, RESET_TIMEOUT); |
SCpnt | 2078 | drivers/scsi/scsi.c | temp = host->hostt->reset(SCpnt, reset_flags); |
SCpnt | 2086 | drivers/scsi/scsi.c | SCpnt->flags |= (WAS_RESET | IS_RESETTING); |
SCpnt | 2087 | drivers/scsi/scsi.c | temp = host->hostt->reset(SCpnt, reset_flags); |
SCpnt | 2110 | drivers/scsi/scsi.c | scsi_mark_bus_reset(host, SCpnt->channel); |
SCpnt | 2111 | drivers/scsi/scsi.c | else scsi_mark_device_reset(SCpnt->device); |
SCpnt | 2114 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~(IN_RESET|IN_RESET2|IN_RESET3); |
SCpnt | 2121 | drivers/scsi/scsi.c | scsi_mark_bus_reset(host, SCpnt->channel); |
SCpnt | 2122 | drivers/scsi/scsi.c | else scsi_mark_device_reset(SCpnt->device); |
SCpnt | 2126 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~(IN_RESET|IN_RESET2|IN_RESET3); |
SCpnt | 2127 | drivers/scsi/scsi.c | scsi_request_sense (SCpnt); |
SCpnt | 2133 | drivers/scsi/scsi.c | scsi_mark_bus_reset(host, SCpnt->channel); |
SCpnt | 2134 | drivers/scsi/scsi.c | else scsi_mark_device_reset(SCpnt->device); |
SCpnt | 2135 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~(IN_RESET|IN_RESET2|IN_RESET3); |
SCpnt | 2136 | drivers/scsi/scsi.c | scsi_request_sense (SCpnt); |
SCpnt | 2148 | drivers/scsi/scsi.c | && SCpnt1 != SCpnt) |
SCpnt | 2156 | drivers/scsi/scsi.c | && SCpnt1 != SCpnt |
SCpnt | 2157 | drivers/scsi/scsi.c | && SCpnt1->channel == SCpnt->channel) |
SCpnt | 2158 | drivers/scsi/scsi.c | scsi_request_sense (SCpnt); |
SCpnt | 2171 | drivers/scsi/scsi.c | SCpnt->internal_timeout &= ~(IN_RESET|IN_RESET2|IN_RESET3); |
SCpnt | 2172 | drivers/scsi/scsi.c | update_timeout(SCpnt, 0); |
SCpnt | 2195 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 2208 | drivers/scsi/scsi.c | for (SCpnt = host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 2209 | drivers/scsi/scsi.c | if (SCpnt->timeout == -1) |
SCpnt | 2211 | drivers/scsi/scsi.c | SCpnt->timeout = 0; |
SCpnt | 2212 | drivers/scsi/scsi.c | SCpnt->serial_number_at_timeout = SCpnt->serial_number; |
SCpnt | 2218 | drivers/scsi/scsi.c | for (SCpnt = host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 2219 | drivers/scsi/scsi.c | if (SCpnt->serial_number_at_timeout > 0 && |
SCpnt | 2220 | drivers/scsi/scsi.c | SCpnt->serial_number_at_timeout == SCpnt->serial_number) |
SCpnt | 2223 | drivers/scsi/scsi.c | scsi_times_out(SCpnt); |
SCpnt | 2224 | drivers/scsi/scsi.c | SCpnt->serial_number_at_timeout = 0; |
SCpnt | 2246 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 2294 | drivers/scsi/scsi.c | for(SCpnt = host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 2295 | drivers/scsi/scsi.c | if (SCpnt->timeout > 0) { |
SCpnt | 2296 | drivers/scsi/scsi.c | if (SCpnt != SCset) |
SCpnt | 2297 | drivers/scsi/scsi.c | SCpnt->timeout -= used; |
SCpnt | 2298 | drivers/scsi/scsi.c | if(SCpnt->timeout <= 0) SCpnt->timeout = -1; |
SCpnt | 2299 | drivers/scsi/scsi.c | if(SCpnt->timeout > 0 && SCpnt->timeout < least) |
SCpnt | 2300 | drivers/scsi/scsi.c | least = SCpnt->timeout; |
SCpnt | 2442 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt; |
SCpnt | 2449 | drivers/scsi/scsi.c | SCpnt = (Scsi_Cmnd *) |
SCpnt | 2453 | drivers/scsi/scsi.c | SCpnt->host = host; |
SCpnt | 2454 | drivers/scsi/scsi.c | SCpnt->device = SDpnt; |
SCpnt | 2455 | drivers/scsi/scsi.c | SCpnt->target = SDpnt->id; |
SCpnt | 2456 | drivers/scsi/scsi.c | SCpnt->lun = SDpnt->lun; |
SCpnt | 2457 | drivers/scsi/scsi.c | SCpnt->channel = SDpnt->channel; |
SCpnt | 2458 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 2459 | drivers/scsi/scsi.c | SCpnt->use_sg = 0; |
SCpnt | 2460 | drivers/scsi/scsi.c | SCpnt->old_use_sg = 0; |
SCpnt | 2461 | drivers/scsi/scsi.c | SCpnt->old_cmd_len = 0; |
SCpnt | 2462 | drivers/scsi/scsi.c | SCpnt->timeout = 0; |
SCpnt | 2463 | drivers/scsi/scsi.c | SCpnt->underflow = 0; |
SCpnt | 2464 | drivers/scsi/scsi.c | SCpnt->transfersize = 0; |
SCpnt | 2465 | drivers/scsi/scsi.c | SCpnt->serial_number = 0; |
SCpnt | 2466 | drivers/scsi/scsi.c | SCpnt->serial_number_at_timeout = 0; |
SCpnt | 2467 | drivers/scsi/scsi.c | SCpnt->host_scribble = NULL; |
SCpnt | 2469 | drivers/scsi/scsi.c | host->host_queue->prev = SCpnt; |
SCpnt | 2470 | drivers/scsi/scsi.c | SCpnt->next = host->host_queue; |
SCpnt | 2471 | drivers/scsi/scsi.c | SCpnt->prev = NULL; |
SCpnt | 2472 | drivers/scsi/scsi.c | host->host_queue = SCpnt; |
SCpnt | 2473 | drivers/scsi/scsi.c | SCpnt->device_next = SDpnt->device_queue; |
SCpnt | 2474 | drivers/scsi/scsi.c | SDpnt->device_queue = SCpnt; |
SCpnt | 2607 | drivers/scsi/scsi.c | Scsi_Cmnd *SCpnt; |
SCpnt | 2749 | drivers/scsi/scsi.c | for(SCpnt=scd->host->host_queue; SCpnt; SCpnt = SCpnt->next){ |
SCpnt | 2750 | drivers/scsi/scsi.c | if(SCpnt->device == scd) { |
SCpnt | 2751 | drivers/scsi/scsi.c | if(SCpnt->prev != NULL) |
SCpnt | 2752 | drivers/scsi/scsi.c | SCpnt->prev->next = SCpnt->next; |
SCpnt | 2753 | drivers/scsi/scsi.c | if(SCpnt->next != NULL) |
SCpnt | 2754 | drivers/scsi/scsi.c | SCpnt->next->prev = SCpnt->prev; |
SCpnt | 2755 | drivers/scsi/scsi.c | if(SCpnt == scd->host->host_queue) |
SCpnt | 2756 | drivers/scsi/scsi.c | scd->host->host_queue = SCpnt->next; |
SCpnt | 2757 | drivers/scsi/scsi.c | scsi_init_free((char *) SCpnt, sizeof(*SCpnt)); |
SCpnt | 3010 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt; |
SCpnt | 3026 | drivers/scsi/scsi.c | for(SCpnt = shpnt->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 3030 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status != RQ_INACTIVE) { |
SCpnt | 3032 | drivers/scsi/scsi.c | for(SCpnt = shpnt->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 3033 | drivers/scsi/scsi.c | if(SCpnt->request.rq_status == RQ_SCSI_DISCONNECTING) |
SCpnt | 3034 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 3038 | drivers/scsi/scsi.c | SCpnt->request.rq_status = RQ_SCSI_DISCONNECTING; /* Mark as busy */ |
SCpnt | 3061 | drivers/scsi/scsi.c | SCpnt = sdpnt->host->host_queue->next; |
SCpnt | 3063 | drivers/scsi/scsi.c | sdpnt->host->host_queue = SCpnt; |
SCpnt | 3064 | drivers/scsi/scsi.c | if (SCpnt) SCpnt->prev = NULL; |
SCpnt | 3210 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt; |
SCpnt | 3231 | drivers/scsi/scsi.c | for(SCpnt = SDpnt->host->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 3233 | drivers/scsi/scsi.c | if(SCpnt->device == SDpnt) |
SCpnt | 3235 | drivers/scsi/scsi.c | if(SCpnt->prev != NULL) |
SCpnt | 3236 | drivers/scsi/scsi.c | SCpnt->prev->next = SCpnt->next; |
SCpnt | 3237 | drivers/scsi/scsi.c | if(SCpnt->next != NULL) |
SCpnt | 3238 | drivers/scsi/scsi.c | SCpnt->next->prev = SCpnt->prev; |
SCpnt | 3239 | drivers/scsi/scsi.c | if(SCpnt == SDpnt->host->host_queue) |
SCpnt | 3240 | drivers/scsi/scsi.c | SDpnt->host->host_queue = SCpnt->next; |
SCpnt | 3241 | drivers/scsi/scsi.c | scsi_init_free((char *) SCpnt, sizeof(*SCpnt)); |
SCpnt | 3324 | drivers/scsi/scsi.c | Scsi_Cmnd * SCpnt; |
SCpnt | 3328 | drivers/scsi/scsi.c | for(SCpnt=shpnt->host_queue; SCpnt; SCpnt = SCpnt->next) |
SCpnt | 3332 | drivers/scsi/scsi.c | i++, SCpnt->host->host_no, |
SCpnt | 3333 | drivers/scsi/scsi.c | SCpnt->channel, |
SCpnt | 3334 | drivers/scsi/scsi.c | SCpnt->target, |
SCpnt | 3335 | drivers/scsi/scsi.c | SCpnt->lun, |
SCpnt | 3336 | drivers/scsi/scsi.c | kdevname(SCpnt->request.rq_dev), |
SCpnt | 3337 | drivers/scsi/scsi.c | SCpnt->request.sector, |
SCpnt | 3338 | drivers/scsi/scsi.c | SCpnt->request.nr_sectors, |
SCpnt | 3339 | drivers/scsi/scsi.c | SCpnt->request.current_nr_sectors, |
SCpnt | 3340 | drivers/scsi/scsi.c | SCpnt->use_sg, |
SCpnt | 3341 | drivers/scsi/scsi.c | SCpnt->retries, |
SCpnt | 3342 | drivers/scsi/scsi.c | SCpnt->allowed, |
SCpnt | 3343 | drivers/scsi/scsi.c | SCpnt->flags, |
SCpnt | 3344 | drivers/scsi/scsi.c | SCpnt->timeout_per_command, |
SCpnt | 3345 | drivers/scsi/scsi.c | SCpnt->timeout, |
SCpnt | 3346 | drivers/scsi/scsi.c | SCpnt->internal_timeout, |
SCpnt | 3347 | drivers/scsi/scsi.c | SCpnt->cmnd[0], |
SCpnt | 3348 | drivers/scsi/scsi.c | SCpnt->sense_buffer[2], |
SCpnt | 3349 | drivers/scsi/scsi.c | SCpnt->result); |
SCpnt | 491 | drivers/scsi/scsi.h | static Scsi_Cmnd * end_scsi_request(Scsi_Cmnd * SCpnt, int uptodate, int sectors) |
SCpnt | 496 | drivers/scsi/scsi.h | req = &SCpnt->request; |
SCpnt | 523 | drivers/scsi/scsi.h | return SCpnt; |
SCpnt | 530 | drivers/scsi/scsi.h | if (SCpnt->host->block) { |
SCpnt | 533 | drivers/scsi/scsi.h | for (next = SCpnt->host->block; next != SCpnt->host; |
SCpnt | 540 | drivers/scsi/scsi.h | wake_up(&SCpnt->device->device_wait); |
SCpnt | 84 | drivers/scsi/scsi_debug.c | if ((MINOR(SCpnt->request.rq_dev) & 0xf) != 0) start = starts[(MINOR(SCpnt->request.rq_dev) & 0xf) - 1]; \ |
SCpnt | 91 | drivers/scsi/scsi_debug.c | if (bh->b_dev != SCpnt->request.rq_dev) \ |
SCpnt | 96 | drivers/scsi/scsi_debug.c | if (bufflen != 1024 && (!SCpnt->use_sg)) {printk("%x %d\n ",bufflen, SCpnt->use_sg); panic("Bad bufflen");}; \ |
SCpnt | 98 | drivers/scsi/scsi_debug.c | if ((MINOR(SCpnt->request.rq_dev) & 0xf) > npart) panic ("Bad partition"); \ |
SCpnt | 99 | drivers/scsi/scsi_debug.c | if ((MINOR(SCpnt->request.rq_dev) & 0xf) != 0) start = starts[(MINOR(SCpnt->request.rq_dev) & 0xf) - 1]; \ |
SCpnt | 100 | drivers/scsi/scsi_debug.c | if (SCpnt->request.cmd != RW) panic ("Wrong operation"); \ |
SCpnt | 101 | drivers/scsi/scsi_debug.c | if (SCpnt->request.sector + start != block) panic("Wrong block."); \ |
SCpnt | 102 | drivers/scsi/scsi_debug.c | if (SCpnt->request.current_nr_sectors != 2 && (!SCpnt->use_sg)) panic ("Wrong # blocks"); \ |
SCpnt | 103 | drivers/scsi/scsi_debug.c | if (SCpnt->request.bh){ \ |
SCpnt | 104 | drivers/scsi/scsi_debug.c | if (SCpnt->request.bh->b_size != 1024) panic ("Wrong bh size"); \ |
SCpnt | 105 | drivers/scsi/scsi_debug.c | if ((SCpnt->request.bh->b_blocknr << 1) + start != block) \ |
SCpnt | 106 | drivers/scsi/scsi_debug.c | { printk("Wrong bh block# %d %d ",SCpnt->request.bh->b_blocknr, block); \ |
SCpnt | 109 | drivers/scsi/scsi_debug.c | if (SCpnt->request.bh->b_dev != SCpnt->request.rq_dev) \ |
SCpnt | 128 | drivers/scsi/scsi_debug.c | static void scsi_dump(Scsi_Cmnd * SCpnt, int flag){ |
SCpnt | 135 | drivers/scsi/scsi_debug.c | printk("use_sg: %d",SCpnt->use_sg); |
SCpnt | 136 | drivers/scsi/scsi_debug.c | if (SCpnt->use_sg){ |
SCpnt | 137 | drivers/scsi/scsi_debug.c | sgpnt = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 138 | drivers/scsi/scsi_debug.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 144 | drivers/scsi/scsi_debug.c | printk("nosg: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer, |
SCpnt | 145 | drivers/scsi/scsi_debug.c | SCpnt->bufflen); |
SCpnt | 146 | drivers/scsi/scsi_debug.c | lpnt = (int *) SCpnt->request.buffer; |
SCpnt | 149 | drivers/scsi/scsi_debug.c | lpnt = (unsigned int *) SCpnt; |
SCpnt | 173 | drivers/scsi/scsi_debug.c | int scsi_debug_queuecommand(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 175 | drivers/scsi/scsi_debug.c | unchar *cmd = (unchar *) SCpnt->cmnd; |
SCpnt | 183 | drivers/scsi/scsi_debug.c | int target = SCpnt->target; |
SCpnt | 184 | drivers/scsi/scsi_debug.c | int bufflen = SCpnt->request_bufflen; |
SCpnt | 190 | drivers/scsi/scsi_debug.c | DEB(if (target > 1) { SCpnt->result = DID_TIME_OUT << 16;done(SCpnt);return 0;}); |
SCpnt | 192 | drivers/scsi/scsi_debug.c | buff = (unsigned char *) SCpnt->request_buffer; |
SCpnt | 194 | drivers/scsi/scsi_debug.c | if(target>=1 || SCpnt->lun != 0) { |
SCpnt | 195 | drivers/scsi/scsi_debug.c | SCpnt->result = DID_NO_CONNECT << 16; |
SCpnt | 196 | drivers/scsi/scsi_debug.c | done(SCpnt); |
SCpnt | 203 | drivers/scsi/scsi_debug.c | memset(SCpnt->sense_buffer, 0, sizeof(SCpnt->sense_buffer)); |
SCpnt | 204 | drivers/scsi/scsi_debug.c | SCpnt->sense_buffer[0] = 0x70; |
SCpnt | 205 | drivers/scsi/scsi_debug.c | SCpnt->sense_buffer[2] = UNIT_ATTENTION; |
SCpnt | 206 | drivers/scsi/scsi_debug.c | SCpnt->result = (CHECK_CONDITION << 1); |
SCpnt | 207 | drivers/scsi/scsi_debug.c | done(SCpnt); |
SCpnt | 215 | drivers/scsi/scsi_debug.c | printk("scsi_debug: Requesting sense buffer (%x %x %x %d):", SCpnt, buff, done, bufflen); |
SCpnt | 223 | drivers/scsi/scsi_debug.c | SCpnt->result = 0; |
SCpnt | 224 | drivers/scsi/scsi_debug.c | done(SCpnt); |
SCpnt | 251 | drivers/scsi/scsi_debug.c | if(NR_REAL < 0) NR_REAL = (MINOR(SCpnt->request.rq_dev) >> 4) & 0x0f; |
SCpnt | 276 | drivers/scsi/scsi_debug.c | usec = (SCpnt->request.nr_sectors << 9) * 1.0e6 / SCSI_DATARATE; |
SCpnt | 283 | drivers/scsi/scsi_debug.c | printk("(r%d)",SCpnt->request.nr_sectors); |
SCpnt | 286 | drivers/scsi/scsi_debug.c | if(SCpnt->use_sg){ |
SCpnt | 291 | drivers/scsi/scsi_debug.c | bh = SCpnt->request.bh; |
SCpnt | 318 | drivers/scsi/scsi_debug.c | if (SCpnt->use_sg) printk("Block %x (%d %d)\n",block, SCpnt->request.nr_sectors, |
SCpnt | 319 | drivers/scsi/scsi_debug.c | SCpnt->request.current_nr_sectors); |
SCpnt | 348 | drivers/scsi/scsi_debug.c | memcpy(buff+64, SCpnt, sizeof(Scsi_Cmnd)); |
SCpnt | 351 | drivers/scsi/scsi_debug.c | if(SCpnt->use_sg){ |
SCpnt | 366 | drivers/scsi/scsi_debug.c | SCpnt->result = 0; |
SCpnt | 367 | drivers/scsi/scsi_debug.c | (done)(SCpnt); |
SCpnt | 370 | drivers/scsi/scsi_debug.c | if (SCpnt->use_sg && !scsi_debug_errsts) |
SCpnt | 371 | drivers/scsi/scsi_debug.c | if(bh) scsi_dump(SCpnt, 0); |
SCpnt | 384 | drivers/scsi/scsi_debug.c | if (SCpnt->use_sg){ |
SCpnt | 385 | drivers/scsi/scsi_debug.c | if ((bufflen >> 9) != SCpnt->request.nr_sectors) |
SCpnt | 393 | drivers/scsi/scsi_debug.c | scsi_dump(SCpnt,1); |
SCpnt | 401 | drivers/scsi/scsi_debug.c | SCpnt->result = DID_NO_CONNECT << 16; |
SCpnt | 402 | drivers/scsi/scsi_debug.c | done(SCpnt); |
SCpnt | 415 | drivers/scsi/scsi_debug.c | SCint[i] = SCpnt; |
SCpnt | 430 | drivers/scsi/scsi_debug.c | SCpnt->result = scsi_debug_errsts; |
SCpnt | 443 | drivers/scsi/scsi_debug.c | SCpnt->result = scsi_debug_errsts; |
SCpnt | 456 | drivers/scsi/scsi_debug.c | static void internal_done(Scsi_Cmnd * SCpnt) |
SCpnt | 458 | drivers/scsi/scsi_debug.c | internal_done_errcode = SCpnt->result; |
SCpnt | 462 | drivers/scsi/scsi_debug.c | int scsi_debug_command(Scsi_Cmnd * SCpnt) |
SCpnt | 465 | drivers/scsi/scsi_debug.c | scsi_debug_queuecommand(SCpnt, internal_done); |
SCpnt | 563 | drivers/scsi/scsi_debug.c | int scsi_debug_abort(Scsi_Cmnd * SCpnt) |
SCpnt | 571 | drivers/scsi/scsi_debug.c | SCpnt->result = SCpnt->abort_reason << 16; |
SCpnt | 573 | drivers/scsi/scsi_debug.c | if(SCpnt == SCint[j]) { |
SCpnt | 575 | drivers/scsi/scsi_debug.c | my_done(SCpnt); |
SCpnt | 597 | drivers/scsi/scsi_debug.c | int scsi_debug_reset(Scsi_Cmnd * SCpnt) |
SCpnt | 603 | drivers/scsi/scsi_debug.c | printk("Bus unlocked by reset(%d)\n", SCpnt->host->suggest_bus_reset); |
SCpnt | 92 | drivers/scsi/scsi_ioctl.c | static void scsi_ioctl_done (Scsi_Cmnd * SCpnt) |
SCpnt | 96 | drivers/scsi/scsi_ioctl.c | req = &SCpnt->request; |
SCpnt | 107 | drivers/scsi/scsi_ioctl.c | Scsi_Cmnd * SCpnt; |
SCpnt | 109 | drivers/scsi/scsi_ioctl.c | SCpnt = allocate_device(NULL, dev, 1); |
SCpnt | 112 | drivers/scsi/scsi_ioctl.c | SCpnt->request.sem = &sem; |
SCpnt | 113 | drivers/scsi/scsi_ioctl.c | scsi_do_cmd(SCpnt, cmd, NULL, 0, |
SCpnt | 119 | drivers/scsi/scsi_ioctl.c | if(driver_byte(SCpnt->result) != 0) |
SCpnt | 120 | drivers/scsi/scsi_ioctl.c | switch(SCpnt->sense_buffer[2] & 0xf) { |
SCpnt | 133 | drivers/scsi/scsi_ioctl.c | SCpnt->result = 0; /* This is no longer considered an error */ |
SCpnt | 142 | drivers/scsi/scsi_ioctl.c | SCpnt->result); |
SCpnt | 144 | drivers/scsi/scsi_ioctl.c | sense_class(SCpnt->sense_buffer[0]), |
SCpnt | 145 | drivers/scsi/scsi_ioctl.c | sense_error(SCpnt->sense_buffer[0]), |
SCpnt | 146 | drivers/scsi/scsi_ioctl.c | SCpnt->sense_buffer[2] & 0xf); |
SCpnt | 150 | drivers/scsi/scsi_ioctl.c | result = SCpnt->result; |
SCpnt | 151 | drivers/scsi/scsi_ioctl.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 153 | drivers/scsi/scsi_ioctl.c | if(SCpnt->device->scsi_request_fn) |
SCpnt | 154 | drivers/scsi/scsi_ioctl.c | (*SCpnt->device->scsi_request_fn)(); |
SCpnt | 156 | drivers/scsi/scsi_ioctl.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 170 | drivers/scsi/scsi_ioctl.c | Scsi_Cmnd * SCpnt; |
SCpnt | 244 | drivers/scsi/scsi_ioctl.c | SCpnt = allocate_device(NULL, dev, 1); |
SCpnt | 248 | drivers/scsi/scsi_ioctl.c | SCpnt->request.sem = &sem; |
SCpnt | 249 | drivers/scsi/scsi_ioctl.c | scsi_do_cmd(SCpnt, cmd, buf, needed, scsi_ioctl_done, MAX_TIMEOUT, |
SCpnt | 257 | drivers/scsi/scsi_ioctl.c | if(SCpnt->result) { |
SCpnt | 260 | drivers/scsi/scsi_ioctl.c | sizeof(SCpnt->sense_buffer)); |
SCpnt | 263 | drivers/scsi/scsi_ioctl.c | SCpnt->sense_buffer, |
SCpnt | 264 | drivers/scsi/scsi_ioctl.c | sizeof(SCpnt->sense_buffer)); |
SCpnt | 270 | drivers/scsi/scsi_ioctl.c | result = SCpnt->result; |
SCpnt | 272 | drivers/scsi/scsi_ioctl.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 276 | drivers/scsi/scsi_ioctl.c | if(SCpnt->device->scsi_request_fn) |
SCpnt | 277 | drivers/scsi/scsi_ioctl.c | (*SCpnt->device->scsi_request_fn)(); |
SCpnt | 279 | drivers/scsi/scsi_ioctl.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 38 | drivers/scsi/scsi_syms.c | extern void print_sense(const char * devclass, Scsi_Cmnd * SCpnt); |
SCpnt | 79 | drivers/scsi/sd.c | static void requeue_sd_request (Scsi_Cmnd * SCpnt); |
SCpnt | 216 | drivers/scsi/sd.c | static void rw_intr (Scsi_Cmnd *SCpnt) |
SCpnt | 218 | drivers/scsi/sd.c | int result = SCpnt->result; |
SCpnt | 219 | drivers/scsi/sd.c | int this_count = SCpnt->bufflen >> 9; |
SCpnt | 222 | drivers/scsi/sd.c | printk("sd%c : rw_intr(%d, %d)\n", 'a' + MINOR(SCpnt->request.rq_dev), |
SCpnt | 223 | drivers/scsi/sd.c | SCpnt->host->host_no, result); |
SCpnt | 235 | drivers/scsi/sd.c | printk("sd%c : %d sectors remain.\n", 'a' + MINOR(SCpnt->request.rq_dev), |
SCpnt | 236 | drivers/scsi/sd.c | SCpnt->request.nr_sectors); |
SCpnt | 237 | drivers/scsi/sd.c | printk("use_sg is %d\n ",SCpnt->use_sg); |
SCpnt | 239 | drivers/scsi/sd.c | if (SCpnt->use_sg) { |
SCpnt | 242 | drivers/scsi/sd.c | sgpnt = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 243 | drivers/scsi/sd.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 249 | drivers/scsi/sd.c | if (SCpnt->request.cmd == READ) |
SCpnt | 257 | drivers/scsi/sd.c | scsi_free(SCpnt->buffer, SCpnt->sglist_len); |
SCpnt | 259 | drivers/scsi/sd.c | if (SCpnt->buffer != SCpnt->request.buffer) { |
SCpnt | 261 | drivers/scsi/sd.c | printk("nosg: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer, |
SCpnt | 262 | drivers/scsi/sd.c | SCpnt->bufflen); |
SCpnt | 264 | drivers/scsi/sd.c | if (SCpnt->request.cmd == READ) |
SCpnt | 265 | drivers/scsi/sd.c | memcpy(SCpnt->request.buffer, SCpnt->buffer, |
SCpnt | 266 | drivers/scsi/sd.c | SCpnt->bufflen); |
SCpnt | 267 | drivers/scsi/sd.c | scsi_free(SCpnt->buffer, SCpnt->bufflen); |
SCpnt | 275 | drivers/scsi/sd.c | if (SCpnt->request.nr_sectors > this_count) |
SCpnt | 277 | drivers/scsi/sd.c | SCpnt->request.errors = 0; |
SCpnt | 279 | drivers/scsi/sd.c | if (!SCpnt->request.bh) |
SCpnt | 283 | drivers/scsi/sd.c | 'a' + MINOR(SCpnt->request.rq_dev)); |
SCpnt | 290 | drivers/scsi/sd.c | SCpnt->request.sector, this_count); |
SCpnt | 293 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 1, this_count); |
SCpnt | 294 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 299 | drivers/scsi/sd.c | if (SCpnt->use_sg) { |
SCpnt | 302 | drivers/scsi/sd.c | sgpnt = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 303 | drivers/scsi/sd.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 305 | drivers/scsi/sd.c | printk("err: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer, |
SCpnt | 306 | drivers/scsi/sd.c | SCpnt->bufflen); |
SCpnt | 312 | drivers/scsi/sd.c | scsi_free(SCpnt->buffer, SCpnt->sglist_len); /* Free list of scatter-gather pointers */ |
SCpnt | 315 | drivers/scsi/sd.c | printk("nosgerr: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer, |
SCpnt | 316 | drivers/scsi/sd.c | SCpnt->bufflen); |
SCpnt | 318 | drivers/scsi/sd.c | if (SCpnt->buffer != SCpnt->request.buffer) |
SCpnt | 319 | drivers/scsi/sd.c | scsi_free(SCpnt->buffer, SCpnt->bufflen); |
SCpnt | 335 | drivers/scsi/sd.c | if rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].remap |
SCpnt | 343 | drivers/scsi/sd.c | if ((SCpnt->sense_buffer[0] & 0x7f) == 0x70) { |
SCpnt | 344 | drivers/scsi/sd.c | if ((SCpnt->sense_buffer[2] & 0xf) == UNIT_ATTENTION) { |
SCpnt | 345 | drivers/scsi/sd.c | if(rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->removable) { |
SCpnt | 349 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->changed = 1; |
SCpnt | 350 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, this_count); |
SCpnt | 351 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 361 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 375 | drivers/scsi/sd.c | if (SCpnt->sense_buffer[2] == ILLEGAL_REQUEST) { |
SCpnt | 376 | drivers/scsi/sd.c | if (rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].ten) { |
SCpnt | 377 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].ten = 0; |
SCpnt | 378 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 387 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->host->host_no, |
SCpnt | 388 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->channel, |
SCpnt | 389 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->id, |
SCpnt | 390 | drivers/scsi/sd.c | rscsi_disks[DEVICE_NR(SCpnt->request.rq_dev)].device->lun, result); |
SCpnt | 393 | drivers/scsi/sd.c | print_sense("sd", SCpnt); |
SCpnt | 394 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.current_nr_sectors); |
SCpnt | 395 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 408 | drivers/scsi/sd.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 459 | drivers/scsi/sd.c | SCpnt = allocate_device(&CURRENT, |
SCpnt | 461 | drivers/scsi/sd.c | else SCpnt = NULL; |
SCpnt | 479 | drivers/scsi/sd.c | if (!SCpnt && sd_template.nr_dev > 1){ |
SCpnt | 485 | drivers/scsi/sd.c | SCpnt = request_queueable(req, rscsi_disks[DEVICE_NR(req->rq_dev)].device); |
SCpnt | 486 | drivers/scsi/sd.c | if(SCpnt) break; |
SCpnt | 490 | drivers/scsi/sd.c | if (SCpnt && req->rq_status == RQ_INACTIVE) { |
SCpnt | 499 | drivers/scsi/sd.c | if (!SCpnt) return; /* Could not find anything to do */ |
SCpnt | 502 | drivers/scsi/sd.c | requeue_sd_request(SCpnt); |
SCpnt | 506 | drivers/scsi/sd.c | static void requeue_sd_request (Scsi_Cmnd * SCpnt) |
SCpnt | 517 | drivers/scsi/sd.c | if(!SCpnt || SCpnt->request.rq_status == RQ_INACTIVE) { |
SCpnt | 522 | drivers/scsi/sd.c | devm = MINOR(SCpnt->request.rq_dev); |
SCpnt | 523 | drivers/scsi/sd.c | dev = DEVICE_NR(SCpnt->request.rq_dev); |
SCpnt | 525 | drivers/scsi/sd.c | block = SCpnt->request.sector; |
SCpnt | 534 | drivers/scsi/sd.c | block + SCpnt->request.nr_sectors > sd[devm].nr_sects) |
SCpnt | 536 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 549 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 570 | drivers/scsi/sd.c | if((block & 1) || (SCpnt->request.nr_sectors & 1)) { |
SCpnt | 572 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 576 | drivers/scsi/sd.c | switch (SCpnt->request.cmd) |
SCpnt | 581 | drivers/scsi/sd.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 590 | drivers/scsi/sd.c | panic ("Unknown sd command %d\n", SCpnt->request.cmd); |
SCpnt | 593 | drivers/scsi/sd.c | SCpnt->this_count = 0; |
SCpnt | 598 | drivers/scsi/sd.c | contiguous = (!CLUSTERABLE_DEVICE(SCpnt) ? 0 :1); |
SCpnt | 600 | drivers/scsi/sd.c | bounce_size = (SCpnt->request.nr_sectors << 9); |
SCpnt | 606 | drivers/scsi/sd.c | if (contiguous && SCpnt->request.bh && |
SCpnt | 607 | drivers/scsi/sd.c | ((long) SCpnt->request.bh->b_data) |
SCpnt | 608 | drivers/scsi/sd.c | + (SCpnt->request.nr_sectors << 9) - 1 > ISA_DMA_THRESHOLD |
SCpnt | 609 | drivers/scsi/sd.c | && SCpnt->host->unchecked_isa_dma) { |
SCpnt | 610 | drivers/scsi/sd.c | if(((long) SCpnt->request.bh->b_data) > ISA_DMA_THRESHOLD) |
SCpnt | 615 | drivers/scsi/sd.c | if(contiguous && SCpnt->request.bh && SCpnt->request.bh->b_reqnext) |
SCpnt | 616 | drivers/scsi/sd.c | for(bh = SCpnt->request.bh, bhp = bh->b_reqnext; bhp; bh = bhp, |
SCpnt | 624 | drivers/scsi/sd.c | if (!SCpnt->request.bh || contiguous) { |
SCpnt | 627 | drivers/scsi/sd.c | this_count = SCpnt->request.nr_sectors; |
SCpnt | 628 | drivers/scsi/sd.c | buff = SCpnt->request.buffer; |
SCpnt | 629 | drivers/scsi/sd.c | SCpnt->use_sg = 0; |
SCpnt | 631 | drivers/scsi/sd.c | } else if (SCpnt->host->sg_tablesize == 0 || |
SCpnt | 641 | drivers/scsi/sd.c | if (SCpnt->host->sg_tablesize != 0 && |
SCpnt | 646 | drivers/scsi/sd.c | this_count = SCpnt->request.current_nr_sectors; |
SCpnt | 647 | drivers/scsi/sd.c | buff = SCpnt->request.buffer; |
SCpnt | 648 | drivers/scsi/sd.c | SCpnt->use_sg = 0; |
SCpnt | 657 | drivers/scsi/sd.c | bh = SCpnt->request.bh; |
SCpnt | 665 | drivers/scsi/sd.c | !CLUSTERABLE_DEVICE(SCpnt) || |
SCpnt | 666 | drivers/scsi/sd.c | (SCpnt->host->unchecked_isa_dma && |
SCpnt | 668 | drivers/scsi/sd.c | if (count < SCpnt->host->sg_tablesize) count++; |
SCpnt | 676 | drivers/scsi/sd.c | if(SCpnt->host->unchecked_isa_dma && |
SCpnt | 677 | drivers/scsi/sd.c | ((unsigned int) SCpnt->request.bh->b_data-1) == ISA_DMA_THRESHOLD) count--; |
SCpnt | 679 | drivers/scsi/sd.c | SCpnt->use_sg = count; /* Number of chains */ |
SCpnt | 681 | drivers/scsi/sd.c | while( count < (SCpnt->use_sg * sizeof(struct scatterlist))) |
SCpnt | 683 | drivers/scsi/sd.c | SCpnt->sglist_len = count; |
SCpnt | 685 | drivers/scsi/sd.c | if(SCpnt->host->sg_tablesize < max_sg) |
SCpnt | 686 | drivers/scsi/sd.c | max_sg = SCpnt->host->sg_tablesize; |
SCpnt | 690 | drivers/scsi/sd.c | SCpnt->use_sg = 0; /* No memory left - bail out */ |
SCpnt | 691 | drivers/scsi/sd.c | this_count = SCpnt->request.current_nr_sectors; |
SCpnt | 692 | drivers/scsi/sd.c | buff = SCpnt->request.buffer; |
SCpnt | 699 | drivers/scsi/sd.c | for(count = 0, bh = SCpnt->request.bh, bhp = bh->b_reqnext; |
SCpnt | 700 | drivers/scsi/sd.c | count < SCpnt->use_sg && bh; |
SCpnt | 710 | drivers/scsi/sd.c | ISA_DMA_THRESHOLD && (SCpnt->host->unchecked_isa_dma) && |
SCpnt | 737 | drivers/scsi/sd.c | this_count = SCpnt->request.current_nr_sectors; |
SCpnt | 738 | drivers/scsi/sd.c | buff = SCpnt->request.buffer; |
SCpnt | 739 | drivers/scsi/sd.c | SCpnt->use_sg = 0; |
SCpnt | 740 | drivers/scsi/sd.c | scsi_free(sgpnt, SCpnt->sglist_len); |
SCpnt | 742 | drivers/scsi/sd.c | SCpnt->use_sg = count; |
SCpnt | 753 | drivers/scsi/sd.c | && CLUSTERABLE_DEVICE(SCpnt)) { |
SCpnt | 758 | drivers/scsi/sd.c | (SCpnt->host->unchecked_isa_dma) && |
SCpnt | 767 | drivers/scsi/sd.c | max_sg = SCpnt->use_sg; |
SCpnt | 780 | drivers/scsi/sd.c | if (SCpnt->use_sg < max_sg) SCpnt->use_sg++; |
SCpnt | 787 | drivers/scsi/sd.c | if(count < SCpnt->use_sg || SCpnt->use_sg |
SCpnt | 788 | drivers/scsi/sd.c | > SCpnt->host->sg_tablesize){ |
SCpnt | 789 | drivers/scsi/sd.c | bh = SCpnt->request.bh; |
SCpnt | 791 | drivers/scsi/sd.c | SCpnt->use_sg, count, dma_free_sectors); |
SCpnt | 798 | drivers/scsi/sd.c | if(SCpnt->use_sg < 16) |
SCpnt | 799 | drivers/scsi/sd.c | for(count=0; count<SCpnt->use_sg; count++) |
SCpnt | 807 | drivers/scsi/sd.c | if (SCpnt->request.cmd == WRITE) |
SCpnt | 808 | drivers/scsi/sd.c | for(count=0; count<SCpnt->use_sg; count++) |
SCpnt | 817 | drivers/scsi/sd.c | if(SCpnt->use_sg == 0){ |
SCpnt | 819 | drivers/scsi/sd.c | (SCpnt->host->unchecked_isa_dma)) { |
SCpnt | 825 | drivers/scsi/sd.c | this_count = SCpnt->request.current_nr_sectors; |
SCpnt | 829 | drivers/scsi/sd.c | if (SCpnt->request.cmd == WRITE) |
SCpnt | 830 | drivers/scsi/sd.c | memcpy(buff, (char *)SCpnt->request.buffer, this_count << 9); |
SCpnt | 836 | drivers/scsi/sd.c | (SCpnt->request.cmd == WRITE) ? "writing" : "reading", |
SCpnt | 837 | drivers/scsi/sd.c | this_count, SCpnt->request.nr_sectors); |
SCpnt | 840 | drivers/scsi/sd.c | cmd[1] = (SCpnt->lun << 5) & 0xe0; |
SCpnt | 886 | drivers/scsi/sd.c | SCpnt->transfersize = rscsi_disks[dev].sector_size; |
SCpnt | 887 | drivers/scsi/sd.c | SCpnt->underflow = this_count << 9; |
SCpnt | 888 | drivers/scsi/sd.c | scsi_do_cmd (SCpnt, (void *) cmd, buff, |
SCpnt | 891 | drivers/scsi/sd.c | (SCpnt->device->type == TYPE_DISK ? |
SCpnt | 939 | drivers/scsi/sd.c | static void sd_init_done (Scsi_Cmnd * SCpnt) |
SCpnt | 943 | drivers/scsi/sd.c | req = &SCpnt->request; |
SCpnt | 957 | drivers/scsi/sd.c | Scsi_Cmnd * SCpnt; |
SCpnt | 964 | drivers/scsi/sd.c | SCpnt = allocate_device(NULL, rscsi_disks[i].device, 1); |
SCpnt | 978 | drivers/scsi/sd.c | SCpnt->cmd_len = 0; |
SCpnt | 979 | drivers/scsi/sd.c | SCpnt->sense_buffer[0] = 0; |
SCpnt | 980 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] = 0; |
SCpnt | 985 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 986 | drivers/scsi/sd.c | SCpnt->request.sem = &sem; |
SCpnt | 987 | drivers/scsi/sd.c | scsi_do_cmd (SCpnt, |
SCpnt | 994 | drivers/scsi/sd.c | the_result = SCpnt->result; |
SCpnt | 997 | drivers/scsi/sd.c | || SCpnt->sense_buffer[2] != UNIT_ATTENTION) |
SCpnt | 1004 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] == NOT_READY) { |
SCpnt | 1013 | drivers/scsi/sd.c | SCpnt->cmd_len = 0; |
SCpnt | 1014 | drivers/scsi/sd.c | SCpnt->sense_buffer[0] = 0; |
SCpnt | 1015 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] = 0; |
SCpnt | 1020 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 1021 | drivers/scsi/sd.c | SCpnt->request.sem = &sem; |
SCpnt | 1022 | drivers/scsi/sd.c | scsi_do_cmd (SCpnt, |
SCpnt | 1051 | drivers/scsi/sd.c | SCpnt->cmd_len = 0; |
SCpnt | 1052 | drivers/scsi/sd.c | SCpnt->sense_buffer[0] = 0; |
SCpnt | 1053 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] = 0; |
SCpnt | 1058 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 1059 | drivers/scsi/sd.c | SCpnt->request.sem = &sem; |
SCpnt | 1060 | drivers/scsi/sd.c | scsi_do_cmd (SCpnt, |
SCpnt | 1067 | drivers/scsi/sd.c | the_result = SCpnt->result; |
SCpnt | 1072 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1074 | drivers/scsi/sd.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 1104 | drivers/scsi/sd.c | 'a' + i, SCpnt->sense_buffer[2] & 0xf); |
SCpnt | 1116 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] == NOT_READY) |
SCpnt | 1205 | drivers/scsi/sd.c | SCpnt->cmd_len = 0; |
SCpnt | 1206 | drivers/scsi/sd.c | SCpnt->sense_buffer[0] = 0; |
SCpnt | 1207 | drivers/scsi/sd.c | SCpnt->sense_buffer[2] = 0; |
SCpnt | 1212 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; /* Mark as really busy again */ |
SCpnt | 1213 | drivers/scsi/sd.c | SCpnt->request.sem = &sem; |
SCpnt | 1214 | drivers/scsi/sd.c | scsi_do_cmd (SCpnt, |
SCpnt | 1221 | drivers/scsi/sd.c | the_result = SCpnt->result; |
SCpnt | 1222 | drivers/scsi/sd.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1223 | drivers/scsi/sd.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 552 | drivers/scsi/seagate.c | int seagate_st0x_queue_command (Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 558 | drivers/scsi/seagate.c | current_target = SCpnt->target; |
SCpnt | 559 | drivers/scsi/seagate.c | current_lun = SCpnt->lun; |
SCpnt | 560 | drivers/scsi/seagate.c | (const void *) current_cmnd = SCpnt->cmnd; |
SCpnt | 561 | drivers/scsi/seagate.c | current_data = (unsigned char *) SCpnt->request_buffer; |
SCpnt | 562 | drivers/scsi/seagate.c | current_bufflen = SCpnt->request_bufflen; |
SCpnt | 563 | drivers/scsi/seagate.c | SCint = SCpnt; |
SCpnt | 574 | drivers/scsi/seagate.c | current_cmnd[SCpnt->cmd_len] |= 0x01; |
SCpnt | 613 | drivers/scsi/seagate.c | int seagate_st0x_command (Scsi_Cmnd * SCpnt) { |
SCpnt | 614 | drivers/scsi/seagate.c | return internal_command (SCpnt->target, SCpnt->lun, SCpnt->cmnd, SCpnt->request_buffer, |
SCpnt | 615 | drivers/scsi/seagate.c | SCpnt->request_bufflen, |
SCpnt | 1589 | drivers/scsi/seagate.c | int seagate_st0x_abort (Scsi_Cmnd * SCpnt) |
SCpnt | 1600 | drivers/scsi/seagate.c | int seagate_st0x_reset (Scsi_Cmnd * SCpnt) |
SCpnt | 263 | drivers/scsi/sg.c | static void sg_command_done(Scsi_Cmnd * SCpnt) |
SCpnt | 265 | drivers/scsi/sg.c | int dev = MINOR(SCpnt->request.rq_dev); |
SCpnt | 270 | drivers/scsi/sg.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 278 | drivers/scsi/sg.c | memcpy(device->header.sense_buffer, SCpnt->sense_buffer, sizeof(SCpnt->sense_buffer)); |
SCpnt | 279 | drivers/scsi/sg.c | if (SCpnt->sense_buffer[0]) |
SCpnt | 284 | drivers/scsi/sg.c | device->header.result=SCpnt->result; |
SCpnt | 291 | drivers/scsi/sg.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 304 | drivers/scsi/sg.c | Scsi_Cmnd * SCpnt; |
SCpnt | 404 | drivers/scsi/sg.c | if (!(SCpnt=allocate_device(NULL,device->device, !(filp->f_flags & O_NONBLOCK)))) |
SCpnt | 416 | drivers/scsi/sg.c | SCpnt->request.rq_dev = devt; |
SCpnt | 417 | drivers/scsi/sg.c | SCpnt->request.rq_status = RQ_ACTIVE; |
SCpnt | 418 | drivers/scsi/sg.c | SCpnt->sense_buffer[0]=0; |
SCpnt | 419 | drivers/scsi/sg.c | SCpnt->cmd_len = size; |
SCpnt | 448 | drivers/scsi/sg.c | scsi_do_cmd (SCpnt,(void *) cmnd, |
SCpnt | 66 | drivers/scsi/sr.c | void requeue_sr_request (Scsi_Cmnd * SCpnt); |
SCpnt | 150 | drivers/scsi/sr.c | static void rw_intr (Scsi_Cmnd * SCpnt) |
SCpnt | 152 | drivers/scsi/sr.c | int result = SCpnt->result; |
SCpnt | 153 | drivers/scsi/sr.c | int this_count = SCpnt->this_count; |
SCpnt | 156 | drivers/scsi/sr.c | printk("sr.c done: %x %x\n",result, SCpnt->request.bh->b_data); |
SCpnt | 160 | drivers/scsi/sr.c | if (SCpnt->use_sg == 0) { |
SCpnt | 161 | drivers/scsi/sr.c | if (SCpnt->buffer != SCpnt->request.buffer) |
SCpnt | 164 | drivers/scsi/sr.c | offset = (SCpnt->request.sector % 4) << 9; |
SCpnt | 165 | drivers/scsi/sr.c | memcpy((char *)SCpnt->request.buffer, |
SCpnt | 166 | drivers/scsi/sr.c | (char *)SCpnt->buffer + offset, |
SCpnt | 173 | drivers/scsi/sr.c | SCpnt->request.nr_sectors > this_count && |
SCpnt | 174 | drivers/scsi/sr.c | SCpnt->request.bh && |
SCpnt | 175 | drivers/scsi/sr.c | SCpnt->request.bh->b_reqnext && |
SCpnt | 176 | drivers/scsi/sr.c | SCpnt->request.bh->b_reqnext->b_size == 1024) { |
SCpnt | 177 | drivers/scsi/sr.c | memcpy((char *)SCpnt->request.bh->b_reqnext->b_data, |
SCpnt | 178 | drivers/scsi/sr.c | (char *)SCpnt->buffer + 1024, |
SCpnt | 183 | drivers/scsi/sr.c | scsi_free(SCpnt->buffer, 2048); |
SCpnt | 188 | drivers/scsi/sr.c | sgpnt = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 189 | drivers/scsi/sr.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 197 | drivers/scsi/sr.c | scsi_free(SCpnt->buffer, SCpnt->sglist_len); /* Free list of scatter-gather pointers */ |
SCpnt | 198 | drivers/scsi/sr.c | if(SCpnt->request.sector % 4) this_count -= 2; |
SCpnt | 200 | drivers/scsi/sr.c | if(this_count > SCpnt->request.nr_sectors) |
SCpnt | 205 | drivers/scsi/sr.c | printk("(%x %x %x) ",SCpnt->request.bh, SCpnt->request.nr_sectors, |
SCpnt | 208 | drivers/scsi/sr.c | if (SCpnt->request.nr_sectors > this_count) |
SCpnt | 210 | drivers/scsi/sr.c | SCpnt->request.errors = 0; |
SCpnt | 211 | drivers/scsi/sr.c | if (!SCpnt->request.bh) |
SCpnt | 213 | drivers/scsi/sr.c | SCpnt->request.sector, this_count); |
SCpnt | 216 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 1, this_count); /* All done */ |
SCpnt | 217 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); |
SCpnt | 224 | drivers/scsi/sr.c | if (SCpnt->use_sg) { |
SCpnt | 227 | drivers/scsi/sr.c | sgpnt = (struct scatterlist *) SCpnt->buffer; |
SCpnt | 228 | drivers/scsi/sr.c | for(i=0; i<SCpnt->use_sg; i++) { |
SCpnt | 233 | drivers/scsi/sr.c | scsi_free(SCpnt->buffer, SCpnt->sglist_len); /* Free list of scatter-gather pointers */ |
SCpnt | 235 | drivers/scsi/sr.c | if (SCpnt->buffer != SCpnt->request.buffer) |
SCpnt | 236 | drivers/scsi/sr.c | scsi_free(SCpnt->buffer, SCpnt->bufflen); |
SCpnt | 240 | drivers/scsi/sr.c | if ((SCpnt->sense_buffer[0] & 0x7f) == 0x70) { |
SCpnt | 241 | drivers/scsi/sr.c | if ((SCpnt->sense_buffer[2] & 0xf) == UNIT_ATTENTION) { |
SCpnt | 245 | drivers/scsi/sr.c | scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].device->changed = 1; |
SCpnt | 246 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, this_count); |
SCpnt | 247 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); |
SCpnt | 252 | drivers/scsi/sr.c | if (SCpnt->sense_buffer[2] == ILLEGAL_REQUEST) { |
SCpnt | 254 | drivers/scsi/sr.c | print_sense("sr", SCpnt); |
SCpnt | 256 | drivers/scsi/sr.c | print_command(SCpnt->cmnd); |
SCpnt | 257 | drivers/scsi/sr.c | if (scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].ten) { |
SCpnt | 258 | drivers/scsi/sr.c | scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].ten = 0; |
SCpnt | 259 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); |
SCpnt | 263 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, this_count); |
SCpnt | 264 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); /* Do next request */ |
SCpnt | 270 | drivers/scsi/sr.c | if (SCpnt->sense_buffer[2] == NOT_READY) { |
SCpnt | 272 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, this_count); |
SCpnt | 273 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); /* Do next request */ |
SCpnt | 281 | drivers/scsi/sr.c | scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].device->host->host_no, |
SCpnt | 282 | drivers/scsi/sr.c | scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].device->id, |
SCpnt | 283 | drivers/scsi/sr.c | scsi_CDs[DEVICE_NR(SCpnt->request.rq_dev)].device->lun, |
SCpnt | 287 | drivers/scsi/sr.c | print_sense("sr", SCpnt); |
SCpnt | 289 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.current_nr_sectors); |
SCpnt | 290 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); |
SCpnt | 561 | drivers/scsi/sr.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 600 | drivers/scsi/sr.c | SCpnt = allocate_device(&CURRENT, |
SCpnt | 602 | drivers/scsi/sr.c | else SCpnt = NULL; |
SCpnt | 612 | drivers/scsi/sr.c | if (!SCpnt && sr_template.nr_dev > 1){ |
SCpnt | 619 | drivers/scsi/sr.c | SCpnt = request_queueable(req, |
SCpnt | 621 | drivers/scsi/sr.c | if(SCpnt) break; |
SCpnt | 625 | drivers/scsi/sr.c | if (SCpnt && req->rq_status == RQ_INACTIVE) { |
SCpnt | 634 | drivers/scsi/sr.c | if (!SCpnt) |
SCpnt | 640 | drivers/scsi/sr.c | requeue_sr_request(SCpnt); |
SCpnt | 644 | drivers/scsi/sr.c | void requeue_sr_request (Scsi_Cmnd * SCpnt) |
SCpnt | 653 | drivers/scsi/sr.c | if(!SCpnt || SCpnt->request.rq_status == RQ_INACTIVE) { |
SCpnt | 658 | drivers/scsi/sr.c | dev = MINOR(SCpnt->request.rq_dev); |
SCpnt | 659 | drivers/scsi/sr.c | block = SCpnt->request.sector; |
SCpnt | 665 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 672 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 683 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 688 | drivers/scsi/sr.c | switch (SCpnt->request.cmd) |
SCpnt | 691 | drivers/scsi/sr.c | SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors); |
SCpnt | 698 | drivers/scsi/sr.c | panic ("Unknown sr command %d\n", SCpnt->request.cmd); |
SCpnt | 701 | drivers/scsi/sr.c | cmd[1] = (SCpnt->lun << 5) & 0xe0; |
SCpnt | 720 | drivers/scsi/sr.c | SCpnt->use_sg = 0; |
SCpnt | 722 | drivers/scsi/sr.c | if (SCpnt->host->sg_tablesize > 0 && |
SCpnt | 728 | drivers/scsi/sr.c | bh = SCpnt->request.bh; |
SCpnt | 734 | drivers/scsi/sr.c | this_count = SCpnt->request.sector % 4; |
SCpnt | 736 | drivers/scsi/sr.c | while(bh && count < SCpnt->host->sg_tablesize) { |
SCpnt | 745 | drivers/scsi/sr.c | if (count < SCpnt->host->sg_tablesize) { |
SCpnt | 754 | drivers/scsi/sr.c | SCpnt->use_sg = count; /* Number of chains */ |
SCpnt | 756 | drivers/scsi/sr.c | while( count < (SCpnt->use_sg * sizeof(struct scatterlist))) |
SCpnt | 758 | drivers/scsi/sr.c | SCpnt->sglist_len = count; |
SCpnt | 762 | drivers/scsi/sr.c | SCpnt->use_sg = 0; /* No memory left - bail out */ |
SCpnt | 766 | drivers/scsi/sr.c | bh = SCpnt->request.bh; |
SCpnt | 767 | drivers/scsi/sr.c | if(SCpnt->request.sector % 4) { |
SCpnt | 768 | drivers/scsi/sr.c | sgpnt[count].length = (SCpnt->request.sector % 4) << 9; |
SCpnt | 775 | drivers/scsi/sr.c | for(bh = SCpnt->request.bh; count < SCpnt->use_sg; |
SCpnt | 786 | drivers/scsi/sr.c | if (count+1 != SCpnt->use_sg) panic("Bad sr request list"); |
SCpnt | 790 | drivers/scsi/sr.c | SCpnt->host->unchecked_isa_dma) { |
SCpnt | 811 | drivers/scsi/sr.c | SCpnt->use_sg = 0; |
SCpnt | 812 | drivers/scsi/sr.c | scsi_free(buffer, SCpnt->sglist_len); |
SCpnt | 818 | drivers/scsi/sr.c | printk("SR: %d %d %d %d %d *** ",SCpnt->use_sg, SCpnt->request.sector, |
SCpnt | 820 | drivers/scsi/sr.c | SCpnt->request.current_nr_sectors, |
SCpnt | 821 | drivers/scsi/sr.c | SCpnt->request.nr_sectors); |
SCpnt | 822 | drivers/scsi/sr.c | for(count=0; count<SCpnt->use_sg; count++) |
SCpnt | 831 | drivers/scsi/sr.c | if (SCpnt->use_sg == 0){ |
SCpnt | 833 | drivers/scsi/sr.c | if (!SCpnt->request.bh) |
SCpnt | 834 | drivers/scsi/sr.c | this_count = SCpnt->request.nr_sectors; |
SCpnt | 836 | drivers/scsi/sr.c | this_count = (SCpnt->request.bh->b_size >> 9); |
SCpnt | 852 | drivers/scsi/sr.c | buffer = (unsigned char *) SCpnt->request.buffer; |
SCpnt | 854 | drivers/scsi/sr.c | SCpnt->host->unchecked_isa_dma) |
SCpnt | 904 | drivers/scsi/sr.c | printk("Use sg: %d\n", SCpnt->use_sg); |
SCpnt | 921 | drivers/scsi/sr.c | SCpnt->transfersize = (scsi_CDs[dev].sector_size > 1024) ? |
SCpnt | 924 | drivers/scsi/sr.c | SCpnt->this_count = this_count; |
SCpnt | 925 | drivers/scsi/sr.c | scsi_do_cmd (SCpnt, (void *) cmd, buffer, |
SCpnt | 967 | drivers/scsi/sr.c | static void sr_init_done (Scsi_Cmnd * SCpnt) |
SCpnt | 971 | drivers/scsi/sr.c | req = &SCpnt->request; |
SCpnt | 983 | drivers/scsi/sr.c | Scsi_Cmnd * SCpnt; |
SCpnt | 986 | drivers/scsi/sr.c | SCpnt = allocate_device(NULL, scsi_CDs[i].device, 1); |
SCpnt | 993 | drivers/scsi/sr.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; /* Mark as really busy */ |
SCpnt | 994 | drivers/scsi/sr.c | SCpnt->cmd_len = 0; |
SCpnt | 1001 | drivers/scsi/sr.c | SCpnt->request.sem = &sem; |
SCpnt | 1002 | drivers/scsi/sr.c | scsi_do_cmd (SCpnt, |
SCpnt | 1009 | drivers/scsi/sr.c | the_result = SCpnt->result; |
SCpnt | 1014 | drivers/scsi/sr.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1016 | drivers/scsi/sr.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 25 | drivers/scsi/sr_ioctl.c | static void sr_ioctl_done(Scsi_Cmnd * SCpnt) |
SCpnt | 29 | drivers/scsi/sr_ioctl.c | req = &SCpnt->request; |
SCpnt | 43 | drivers/scsi/sr_ioctl.c | Scsi_Cmnd * SCpnt; |
SCpnt | 46 | drivers/scsi/sr_ioctl.c | SCpnt = allocate_device(NULL, scsi_CDs[target].device, 1); |
SCpnt | 49 | drivers/scsi/sr_ioctl.c | SCpnt->request.sem = &sem; |
SCpnt | 50 | drivers/scsi/sr_ioctl.c | scsi_do_cmd(SCpnt, |
SCpnt | 56 | drivers/scsi/sr_ioctl.c | result = SCpnt->result; |
SCpnt | 60 | drivers/scsi/sr_ioctl.c | switch(SCpnt->sense_buffer[2] & 0xf) { |
SCpnt | 78 | drivers/scsi/sr_ioctl.c | sense_class(SCpnt->sense_buffer[0]), |
SCpnt | 79 | drivers/scsi/sr_ioctl.c | sense_error(SCpnt->sense_buffer[0]), |
SCpnt | 80 | drivers/scsi/sr_ioctl.c | SCpnt->sense_buffer[2] & 0xf); |
SCpnt | 84 | drivers/scsi/sr_ioctl.c | result = SCpnt->result; |
SCpnt | 85 | drivers/scsi/sr_ioctl.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Deallocate */ |
SCpnt | 86 | drivers/scsi/sr_ioctl.c | wake_up(&SCpnt->device->device_wait); |
SCpnt | 121 | drivers/scsi/st.c | st_chk_result(Scsi_Cmnd * SCpnt) |
SCpnt | 123 | drivers/scsi/st.c | int dev = TAPE_NR(SCpnt->request.rq_dev); |
SCpnt | 124 | drivers/scsi/st.c | int result = SCpnt->result; |
SCpnt | 125 | drivers/scsi/st.c | unsigned char * sense = SCpnt->sense_buffer, scode; |
SCpnt | 136 | drivers/scsi/st.c | SCpnt->data_cmnd[0], SCpnt->data_cmnd[1], SCpnt->data_cmnd[2], |
SCpnt | 137 | drivers/scsi/st.c | SCpnt->data_cmnd[3], SCpnt->data_cmnd[4], SCpnt->data_cmnd[5], |
SCpnt | 138 | drivers/scsi/st.c | SCpnt->request_bufflen); |
SCpnt | 140 | drivers/scsi/st.c | print_sense("st", SCpnt); |
SCpnt | 153 | drivers/scsi/st.c | SCpnt->data_cmnd[0] != MODE_SENSE && |
SCpnt | 154 | drivers/scsi/st.c | SCpnt->data_cmnd[0] != TEST_UNIT_READY)) { /* Abnormal conditions for tape */ |
SCpnt | 158 | drivers/scsi/st.c | print_sense("st", SCpnt); |
SCpnt | 168 | drivers/scsi/st.c | && SCpnt->data_cmnd[0] != WRITE_6 |
SCpnt | 169 | drivers/scsi/st.c | && SCpnt->data_cmnd[0] != WRITE_FILEMARKS |
SCpnt | 176 | drivers/scsi/st.c | if (SCpnt->data_cmnd[0] == READ_6) |
SCpnt | 178 | drivers/scsi/st.c | else if (SCpnt->data_cmnd[0] == WRITE_6) |
SCpnt | 195 | drivers/scsi/st.c | st_sleep_done (Scsi_Cmnd * SCpnt) |
SCpnt | 201 | drivers/scsi/st.c | if ((st_nbr = TAPE_NR(SCpnt->request.rq_dev)) < st_template.nr_dev) { |
SCpnt | 204 | drivers/scsi/st.c | (SCpnt->sense_buffer[0] & 0x70) == 0x70 && |
SCpnt | 205 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x40)) { |
SCpnt | 207 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x80) != 0) |
SCpnt | 208 | drivers/scsi/st.c | remainder = (SCpnt->sense_buffer[3] << 24) | |
SCpnt | 209 | drivers/scsi/st.c | (SCpnt->sense_buffer[4] << 16) | |
SCpnt | 210 | drivers/scsi/st.c | (SCpnt->sense_buffer[5] << 8) | SCpnt->sense_buffer[6]; |
SCpnt | 213 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[2] & 0x0f) == VOLUME_OVERFLOW || |
SCpnt | 215 | drivers/scsi/st.c | (STp->buffer)->last_result = SCpnt->result; /* Error */ |
SCpnt | 220 | drivers/scsi/st.c | (STp->buffer)->last_result = SCpnt->result; |
SCpnt | 223 | drivers/scsi/st.c | (STp->buffer)->last_result_fatal = st_chk_result(SCpnt); |
SCpnt | 224 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 227 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_SCSI_DONE; |
SCpnt | 232 | drivers/scsi/st.c | up(SCpnt->request.sem); |
SCpnt | 243 | drivers/scsi/st.c | st_do_scsi(Scsi_Cmnd *SCpnt, Scsi_Tape *STp, unsigned char *cmd, int bytes, |
SCpnt | 246 | drivers/scsi/st.c | if (SCpnt == NULL) |
SCpnt | 247 | drivers/scsi/st.c | if ((SCpnt = allocate_device(NULL, STp->device, 1)) == NULL) { |
SCpnt | 252 | drivers/scsi/st.c | cmd[1] |= (SCpnt->lun << 5) & 0xe0; |
SCpnt | 254 | drivers/scsi/st.c | SCpnt->request.sem = &(STp->sem); |
SCpnt | 255 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 256 | drivers/scsi/st.c | SCpnt->request.rq_dev = STp->devt; |
SCpnt | 258 | drivers/scsi/st.c | scsi_do_cmd(SCpnt, (void *)cmd, (STp->buffer)->b_data, bytes, |
SCpnt | 261 | drivers/scsi/st.c | down(SCpnt->request.sem); |
SCpnt | 263 | drivers/scsi/st.c | (STp->buffer)->last_result_fatal = st_chk_result(SCpnt); |
SCpnt | 265 | drivers/scsi/st.c | return SCpnt; |
SCpnt | 308 | drivers/scsi/st.c | Scsi_Cmnd *SCpnt; |
SCpnt | 316 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, cmd, 0, ST_TIMEOUT, MAX_RETRIES); |
SCpnt | 317 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 320 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 339 | drivers/scsi/st.c | Scsi_Cmnd *SCpnt; |
SCpnt | 378 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, cmd, transfer, ST_TIMEOUT, MAX_WRITE_RETRIES); |
SCpnt | 379 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 384 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x70) == 0x70 && |
SCpnt | 385 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x40) && |
SCpnt | 386 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) != VOLUME_OVERFLOW) { |
SCpnt | 401 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 510 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt; |
SCpnt | 576 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, cmd, 0, ST_LONG_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 577 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 580 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x70) == 0x70 && |
SCpnt | 581 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == UNIT_ATTENTION) { /* New media? */ |
SCpnt | 586 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, 0, ST_LONG_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 604 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x70) == 0x70 && |
SCpnt | 605 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == NO_TAPE) { |
SCpnt | 613 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 634 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, 6, ST_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 636 | drivers/scsi/st.c | if (!SCpnt->result && !SCpnt->sense_buffer[0]) { |
SCpnt | 660 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, 12, ST_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 705 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 781 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt; |
SCpnt | 817 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, cmd, 0, ST_TIMEOUT, MAX_WRITE_RETRIES); |
SCpnt | 818 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 821 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 877 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 1013 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, transfer, ST_TIMEOUT, MAX_WRITE_RETRIES); |
SCpnt | 1014 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 1022 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x70) == 0x70 && |
SCpnt | 1023 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x40)) { |
SCpnt | 1024 | drivers/scsi/st.c | if (STp->block_size != 0 && (SCpnt->sense_buffer[0] & 0x80) != 0) |
SCpnt | 1025 | drivers/scsi/st.c | transfer = (SCpnt->sense_buffer[3] << 24) | |
SCpnt | 1026 | drivers/scsi/st.c | (SCpnt->sense_buffer[4] << 16) | |
SCpnt | 1027 | drivers/scsi/st.c | (SCpnt->sense_buffer[5] << 8) | SCpnt->sense_buffer[6]; |
SCpnt | 1029 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == VOLUME_OVERFLOW) |
SCpnt | 1067 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1097 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 1105 | drivers/scsi/st.c | if (!SCpnt) { |
SCpnt | 1106 | drivers/scsi/st.c | SCpnt = allocate_device(NULL, STp->device, 1); |
SCpnt | 1107 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 1126 | drivers/scsi/st.c | SCpnt->request.sem = &(STp->sem); |
SCpnt | 1127 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_SCSI_BUSY; |
SCpnt | 1128 | drivers/scsi/st.c | SCpnt->request.rq_dev = STp->devt; |
SCpnt | 1133 | drivers/scsi/st.c | scsi_do_cmd (SCpnt, |
SCpnt | 1138 | drivers/scsi/st.c | else if (SCpnt != NULL) |
SCpnt | 1139 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1153 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 1237 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, bytes, ST_TIMEOUT, MAX_RETRIES); |
SCpnt | 1238 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 1250 | drivers/scsi/st.c | SCpnt->sense_buffer[0], SCpnt->sense_buffer[1], |
SCpnt | 1251 | drivers/scsi/st.c | SCpnt->sense_buffer[2], SCpnt->sense_buffer[3], |
SCpnt | 1252 | drivers/scsi/st.c | SCpnt->sense_buffer[4], SCpnt->sense_buffer[5], |
SCpnt | 1253 | drivers/scsi/st.c | SCpnt->sense_buffer[6], SCpnt->sense_buffer[7]); |
SCpnt | 1255 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x70) == 0x70) { /* extended sense */ |
SCpnt | 1257 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[2] & 0xe0) != 0) { /* EOF, EOM, or ILI */ |
SCpnt | 1259 | drivers/scsi/st.c | if ((SCpnt->sense_buffer[0] & 0x80) != 0) |
SCpnt | 1260 | drivers/scsi/st.c | transfer = (SCpnt->sense_buffer[3] << 24) | |
SCpnt | 1261 | drivers/scsi/st.c | (SCpnt->sense_buffer[4] << 16) | |
SCpnt | 1262 | drivers/scsi/st.c | (SCpnt->sense_buffer[5] << 8) | SCpnt->sense_buffer[6]; |
SCpnt | 1266 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == MEDIUM_ERROR) |
SCpnt | 1269 | drivers/scsi/st.c | if (SCpnt->sense_buffer[2] & 0x20) { |
SCpnt | 1276 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1297 | drivers/scsi/st.c | SCpnt = NULL; |
SCpnt | 1300 | drivers/scsi/st.c | else if (SCpnt->sense_buffer[2] & 0x40) { |
SCpnt | 1313 | drivers/scsi/st.c | else if (SCpnt->sense_buffer[2] & 0x80) { |
SCpnt | 1333 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; |
SCpnt | 1338 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == BLANK_CHECK) { |
SCpnt | 1354 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1389 | drivers/scsi/st.c | if (SCpnt != NULL) |
SCpnt | 1390 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1409 | drivers/scsi/st.c | if (SCpnt != NULL) |
SCpnt | 1410 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1594 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 1606 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, cmd[4], ST_TIMEOUT, 0); |
SCpnt | 1607 | drivers/scsi/st.c | if (SCpnt == NULL) |
SCpnt | 1609 | drivers/scsi/st.c | dev = TAPE_NR(SCpnt->request.rq_dev); |
SCpnt | 1616 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1631 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1649 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, cmd[4], ST_TIMEOUT, 0); |
SCpnt | 1656 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1666 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 1681 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt; |
SCpnt | 2007 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, cmd, datalen, timeout, MAX_RETRIES); |
SCpnt | 2008 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 2013 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 2064 | drivers/scsi/st.c | if (SCpnt->sense_buffer[2] & 0x40) { |
SCpnt | 2072 | drivers/scsi/st.c | (SCpnt->sense_buffer[3] << 24) + |
SCpnt | 2073 | drivers/scsi/st.c | (SCpnt->sense_buffer[4] << 16) + |
SCpnt | 2074 | drivers/scsi/st.c | (SCpnt->sense_buffer[5] << 8) + |
SCpnt | 2075 | drivers/scsi/st.c | SCpnt->sense_buffer[6] ); |
SCpnt | 2088 | drivers/scsi/st.c | if (SCpnt->sense_buffer[2] & 0x80) { /* Hit filemark */ |
SCpnt | 2100 | drivers/scsi/st.c | if (SCpnt->sense_buffer[2] & 0x80) { /* Hit filemark */ |
SCpnt | 2116 | drivers/scsi/st.c | (SCpnt->sense_buffer[2] & 0x0f) == BLANK_CHECK) |
SCpnt | 2137 | drivers/scsi/st.c | Scsi_Cmnd *SCpnt; |
SCpnt | 2153 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, scmd, 20, ST_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 2154 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 2191 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 2210 | drivers/scsi/st.c | Scsi_Cmnd *SCpnt; |
SCpnt | 2274 | drivers/scsi/st.c | SCpnt = st_do_scsi(NULL, STp, scmd, 20, timeout, MAX_READY_RETRIES); |
SCpnt | 2275 | drivers/scsi/st.c | if (!SCpnt) |
SCpnt | 2303 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 2355 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 2368 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, 200, ST_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 2369 | drivers/scsi/st.c | if (SCpnt == NULL) |
SCpnt | 2371 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 2400 | drivers/scsi/st.c | Scsi_Cmnd * SCpnt = NULL; |
SCpnt | 2442 | drivers/scsi/st.c | SCpnt = st_do_scsi(SCpnt, STp, cmd, cmd[4], ST_LONG_TIMEOUT, MAX_READY_RETRIES); |
SCpnt | 2443 | drivers/scsi/st.c | if (SCpnt == NULL) |
SCpnt | 2445 | drivers/scsi/st.c | SCpnt->request.rq_status = RQ_INACTIVE; /* Mark as not busy */ |
SCpnt | 63 | drivers/scsi/st.h | Scsi_Cmnd SCpnt; |
SCpnt | 261 | drivers/scsi/u14-34f.c | Scsi_Cmnd *SCpnt; |
SCpnt | 557 | drivers/scsi/u14-34f.c | static inline void build_sg_list(struct mscp *cpp, Scsi_Cmnd *SCpnt) { |
SCpnt | 561 | drivers/scsi/u14-34f.c | sgpnt = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 563 | drivers/scsi/u14-34f.c | for (k = 0; k < SCpnt->use_sg; k++) { |
SCpnt | 569 | drivers/scsi/u14-34f.c | cpp->use_sg = SCpnt->use_sg; |
SCpnt | 574 | drivers/scsi/u14-34f.c | int u14_34f_queuecommand(Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *)) { |
SCpnt | 587 | drivers/scsi/u14-34f.c | j = ((struct hostdata *) SCpnt->host->hostdata)->board_number; |
SCpnt | 589 | drivers/scsi/u14-34f.c | if (!done) panic("%s: qcomm, pid %ld, null done.\n", BN(j), SCpnt->pid); |
SCpnt | 610 | drivers/scsi/u14-34f.c | else if (u14_34f_reset(SCpnt, SCSI_RESET_SUGGEST_BUS_RESET) |
SCpnt | 614 | drivers/scsi/u14-34f.c | SCpnt->result = DID_BUS_BUSY << 16; |
SCpnt | 615 | drivers/scsi/u14-34f.c | SCpnt->host_scribble = NULL; |
SCpnt | 616 | drivers/scsi/u14-34f.c | printk("%s: qcomm, pid %ld, DID_BUS_BUSY, done.\n", BN(j), SCpnt->pid); |
SCpnt | 618 | drivers/scsi/u14-34f.c | done(SCpnt); |
SCpnt | 626 | drivers/scsi/u14-34f.c | SCpnt->scsi_done = done; |
SCpnt | 628 | drivers/scsi/u14-34f.c | SCpnt->host_scribble = (unsigned char *) &cpp->index; |
SCpnt | 631 | drivers/scsi/u14-34f.c | BN(j), i, SCpnt->target, SCpnt->pid); |
SCpnt | 636 | drivers/scsi/u14-34f.c | if (SCpnt->cmnd[0] == data_out_cmds[k]) { |
SCpnt | 642 | drivers/scsi/u14-34f.c | cpp->target = SCpnt->target; |
SCpnt | 643 | drivers/scsi/u14-34f.c | cpp->lun = SCpnt->lun; |
SCpnt | 644 | drivers/scsi/u14-34f.c | cpp->SCpnt = SCpnt; |
SCpnt | 645 | drivers/scsi/u14-34f.c | cpp->sense_addr = (unsigned int) SCpnt->sense_buffer; |
SCpnt | 646 | drivers/scsi/u14-34f.c | cpp->sense_len = sizeof SCpnt->sense_buffer; |
SCpnt | 648 | drivers/scsi/u14-34f.c | if (SCpnt->use_sg) { |
SCpnt | 650 | drivers/scsi/u14-34f.c | build_sg_list(cpp, SCpnt); |
SCpnt | 653 | drivers/scsi/u14-34f.c | cpp->data_address = (unsigned int)SCpnt->request_buffer; |
SCpnt | 654 | drivers/scsi/u14-34f.c | cpp->data_len = SCpnt->request_bufflen; |
SCpnt | 657 | drivers/scsi/u14-34f.c | cpp->scsi_cdbs_len = SCpnt->cmd_len; |
SCpnt | 658 | drivers/scsi/u14-34f.c | memcpy(cpp->scsi_cdbs, SCpnt->cmnd, cpp->scsi_cdbs_len); |
SCpnt | 661 | drivers/scsi/u14-34f.c | SCpnt->result = DID_ERROR << 16; |
SCpnt | 662 | drivers/scsi/u14-34f.c | SCpnt->host_scribble = NULL; |
SCpnt | 664 | drivers/scsi/u14-34f.c | BN(j), SCpnt->target, SCpnt->pid); |
SCpnt | 666 | drivers/scsi/u14-34f.c | done(SCpnt); |
SCpnt | 717 | drivers/scsi/u14-34f.c | if (SCarg != HD(j)->cp[i].SCpnt) |
SCpnt | 719 | drivers/scsi/u14-34f.c | BN(j), i, SCarg, HD(j)->cp[i].SCpnt); |
SCpnt | 743 | drivers/scsi/u14-34f.c | Scsi_Cmnd *SCpnt; |
SCpnt | 780 | drivers/scsi/u14-34f.c | SCpnt = HD(j)->cp[i].SCpnt; |
SCpnt | 783 | drivers/scsi/u14-34f.c | BN(j), i, SCpnt->pid); |
SCpnt | 785 | drivers/scsi/u14-34f.c | if (SCpnt == NULL) |
SCpnt | 788 | drivers/scsi/u14-34f.c | if (SCpnt->host_scribble == NULL) |
SCpnt | 791 | drivers/scsi/u14-34f.c | if (*(unsigned int *)SCpnt->host_scribble != i) |
SCpnt | 794 | drivers/scsi/u14-34f.c | if (SCpnt->scsi_done == NULL) |
SCpnt | 797 | drivers/scsi/u14-34f.c | if (SCpnt == SCarg) arg_done = TRUE; |
SCpnt | 825 | drivers/scsi/u14-34f.c | SCpnt = HD(j)->cp[i].SCpnt; |
SCpnt | 826 | drivers/scsi/u14-34f.c | SCpnt->result = DID_RESET << 16; |
SCpnt | 827 | drivers/scsi/u14-34f.c | SCpnt->host_scribble = NULL; |
SCpnt | 833 | drivers/scsi/u14-34f.c | BN(j), i, SCpnt->pid); |
SCpnt | 835 | drivers/scsi/u14-34f.c | SCpnt->scsi_done(SCpnt); |
SCpnt | 864 | drivers/scsi/u14-34f.c | Scsi_Cmnd *SCpnt; |
SCpnt | 926 | drivers/scsi/u14-34f.c | SCpnt = spp->SCpnt; |
SCpnt | 928 | drivers/scsi/u14-34f.c | if (SCpnt == NULL) |
SCpnt | 931 | drivers/scsi/u14-34f.c | if (SCpnt->host_scribble == NULL) |
SCpnt | 933 | drivers/scsi/u14-34f.c | BN(j), i, SCpnt->pid, SCpnt); |
SCpnt | 935 | drivers/scsi/u14-34f.c | if (*(unsigned int *)SCpnt->host_scribble != i) |
SCpnt | 937 | drivers/scsi/u14-34f.c | " irq %d.\n", BN(j), i, SCpnt->pid, |
SCpnt | 938 | drivers/scsi/u14-34f.c | *(unsigned int *)SCpnt->host_scribble, irq); |
SCpnt | 946 | drivers/scsi/u14-34f.c | if (tstatus == BUSY && SCpnt->device->type != TYPE_TAPE) |
SCpnt | 951 | drivers/scsi/u14-34f.c | && SCpnt->device->type == TYPE_DISK |
SCpnt | 952 | drivers/scsi/u14-34f.c | && HD(j)->target_reset[SCpnt->target]) |
SCpnt | 957 | drivers/scsi/u14-34f.c | && SCpnt->device->type == TYPE_DISK |
SCpnt | 958 | drivers/scsi/u14-34f.c | && (SCpnt->sense_buffer[2] & 0xf) == RECOVERED_ERROR) |
SCpnt | 965 | drivers/scsi/u14-34f.c | HD(j)->target_reset[SCpnt->target] = FALSE; |
SCpnt | 967 | drivers/scsi/u14-34f.c | if (spp->target_status && SCpnt->device->type == TYPE_DISK) |
SCpnt | 970 | drivers/scsi/u14-34f.c | SCpnt->target, SCpnt->lun, SCpnt->pid, |
SCpnt | 971 | drivers/scsi/u14-34f.c | spp->target_status, SCpnt->sense_buffer[2]); |
SCpnt | 973 | drivers/scsi/u14-34f.c | HD(j)->target_time_out[SCpnt->target] = 0; |
SCpnt | 978 | drivers/scsi/u14-34f.c | if (HD(j)->target_time_out[SCpnt->target] > 1) |
SCpnt | 982 | drivers/scsi/u14-34f.c | HD(j)->target_time_out[SCpnt->target]++; |
SCpnt | 992 | drivers/scsi/u14-34f.c | if (SCpnt->device->type != TYPE_TAPE) |
SCpnt | 1013 | drivers/scsi/u14-34f.c | SCpnt->result = status | spp->target_status; |
SCpnt | 1019 | drivers/scsi/u14-34f.c | if (SCpnt->result || do_trace) |
SCpnt | 1029 | drivers/scsi/u14-34f.c | SCpnt->target, SCpnt->lun, SCpnt->pid, HD(j)->iocount); |
SCpnt | 1032 | drivers/scsi/u14-34f.c | SCpnt->host_scribble = NULL; |
SCpnt | 1035 | drivers/scsi/u14-34f.c | SCpnt->scsi_done(SCpnt); |
SCpnt | 297 | drivers/scsi/ultrastor.c | static inline void build_sg_list(struct mscp *, Scsi_Cmnd *SCpnt); |
SCpnt | 656 | drivers/scsi/ultrastor.c | static inline void build_sg_list(register struct mscp *mscp, Scsi_Cmnd *SCpnt) |
SCpnt | 662 | drivers/scsi/ultrastor.c | sl = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 663 | drivers/scsi/ultrastor.c | max = SCpnt->use_sg; |
SCpnt | 677 | drivers/scsi/ultrastor.c | int ultrastor_queuecommand(Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 715 | drivers/scsi/ultrastor.c | my_mscp->ca = SCpnt->device->type != TYPE_TAPE; |
SCpnt | 716 | drivers/scsi/ultrastor.c | my_mscp->target_id = SCpnt->target; |
SCpnt | 718 | drivers/scsi/ultrastor.c | my_mscp->lun = SCpnt->lun; |
SCpnt | 719 | drivers/scsi/ultrastor.c | if (SCpnt->use_sg) { |
SCpnt | 722 | drivers/scsi/ultrastor.c | build_sg_list(my_mscp, SCpnt); |
SCpnt | 726 | drivers/scsi/ultrastor.c | my_mscp->transfer_data = (unsigned int)SCpnt->request_buffer; |
SCpnt | 727 | drivers/scsi/ultrastor.c | my_mscp->transfer_data_length = SCpnt->request_bufflen; |
SCpnt | 731 | drivers/scsi/ultrastor.c | my_mscp->length_of_sense_byte = sizeof SCpnt->sense_buffer; |
SCpnt | 732 | drivers/scsi/ultrastor.c | my_mscp->length_of_scsi_cdbs = SCpnt->cmd_len; |
SCpnt | 733 | drivers/scsi/ultrastor.c | memcpy(my_mscp->scsi_cdbs, SCpnt->cmnd, my_mscp->length_of_scsi_cdbs); |
SCpnt | 736 | drivers/scsi/ultrastor.c | my_mscp->sense_data = (unsigned int)&SCpnt->sense_buffer; |
SCpnt | 738 | drivers/scsi/ultrastor.c | my_mscp->SCint = SCpnt; |
SCpnt | 739 | drivers/scsi/ultrastor.c | SCpnt->host_scribble = (unsigned char *)my_mscp; |
SCpnt | 785 | drivers/scsi/ultrastor.c | SCpnt->result = status; |
SCpnt | 786 | drivers/scsi/ultrastor.c | done(SCpnt); |
SCpnt | 829 | drivers/scsi/ultrastor.c | int ultrastor_abort(Scsi_Cmnd *SCpnt) |
SCpnt | 844 | drivers/scsi/ultrastor.c | if(!SCpnt->host_scribble) |
SCpnt | 847 | drivers/scsi/ultrastor.c | mscp_index = ((struct mscp *)SCpnt->host_scribble) - config.mscp; |
SCpnt | 935 | drivers/scsi/ultrastor.c | if (config.mscp[mscp_index].SCint != SCpnt) |
SCpnt | 937 | drivers/scsi/ultrastor.c | config.mscp[mscp_index].SCint, SCpnt); |
SCpnt | 942 | drivers/scsi/ultrastor.c | if (config.mscp[mscp_index].SCint != SCpnt) panic("Bad abort"); |
SCpnt | 946 | drivers/scsi/ultrastor.c | SCpnt->result = DID_ABORT << 16; |
SCpnt | 948 | drivers/scsi/ultrastor.c | done(SCpnt); |
SCpnt | 954 | drivers/scsi/ultrastor.c | int ultrastor_reset(Scsi_Cmnd * SCpnt) |
SCpnt | 1317 | drivers/scsi/wd33c93.c | int wd33c93_reset(Scsi_Cmnd *SCpnt, unsigned int reset_flags) |
SCpnt | 1319 | drivers/scsi/wd33c93.c | int wd33c93_reset(Scsi_Cmnd *SCpnt) |
SCpnt | 1327 | drivers/scsi/wd33c93.c | instance = SCpnt->host; |
SCpnt | 1350 | drivers/scsi/wd33c93.c | SCpnt->result = DID_RESET << 16; |
SCpnt | 181 | drivers/scsi/wd33c93.h | typedef int (*dma_setup_t) (Scsi_Cmnd *SCpnt, int dir_in); |
SCpnt | 182 | drivers/scsi/wd33c93.h | typedef void (*dma_stop_t) (struct Scsi_Host *instance, Scsi_Cmnd *SCpnt, |
SCpnt | 351 | drivers/scsi/wd7000.c | Scsi_Cmnd *SCpnt; /* Scsi_Cmnd using this SCB */ |
SCpnt | 682 | drivers/scsi/wd7000.c | scbs[i].next = &(scbs[i+1]); scbs[i].SCpnt = NULL; |
SCpnt | 685 | drivers/scsi/wd7000.c | scbs[MAX_SCBS-1].SCpnt = NULL; |
SCpnt | 800 | drivers/scsi/wd7000.c | static void wd7000_scsi_done(Scsi_Cmnd * SCpnt) |
SCpnt | 803 | drivers/scsi/wd7000.c | printk("wd7000_scsi_done: %06x\n",(unsigned int) SCpnt); |
SCpnt | 805 | drivers/scsi/wd7000.c | SCpnt->SCp.phase = 0; |
SCpnt | 817 | drivers/scsi/wd7000.c | register Scsi_Cmnd *SCpnt; |
SCpnt | 874 | drivers/scsi/wd7000.c | SCpnt = scb->SCpnt; |
SCpnt | 875 | drivers/scsi/wd7000.c | if (--(SCpnt->SCp.phase) <= 0) { /* all scbs are done */ |
SCpnt | 879 | drivers/scsi/wd7000.c | SCpnt->result = errstatus; |
SCpnt | 883 | drivers/scsi/wd7000.c | SCpnt->scsi_done(SCpnt); |
SCpnt | 898 | drivers/scsi/wd7000.c | int wd7000_queuecommand(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *)) |
SCpnt | 902 | drivers/scsi/wd7000.c | register unchar *cdb = (unchar *) SCpnt->cmnd; |
SCpnt | 905 | drivers/scsi/wd7000.c | Adapter *host = (Adapter *) SCpnt->host->hostdata; |
SCpnt | 907 | drivers/scsi/wd7000.c | cdblen = SCpnt->cmd_len; |
SCpnt | 908 | drivers/scsi/wd7000.c | idlun = ((SCpnt->target << 5) & 0xe0) | (SCpnt->lun & 7); |
SCpnt | 909 | drivers/scsi/wd7000.c | SCpnt->scsi_done = done; |
SCpnt | 910 | drivers/scsi/wd7000.c | SCpnt->SCp.phase = 1; |
SCpnt | 916 | drivers/scsi/wd7000.c | scb->SCpnt = SCpnt; /* so we can find stuff later */ |
SCpnt | 917 | drivers/scsi/wd7000.c | SCpnt->host_scribble = (unchar *) scb; |
SCpnt | 920 | drivers/scsi/wd7000.c | if (SCpnt->use_sg) { |
SCpnt | 921 | drivers/scsi/wd7000.c | struct scatterlist *sg = (struct scatterlist *) SCpnt->request_buffer; |
SCpnt | 924 | drivers/scsi/wd7000.c | if (SCpnt->host->sg_tablesize == SG_NONE) { |
SCpnt | 928 | drivers/scsi/wd7000.c | printk("Using scatter/gather with %d elements.\n",SCpnt->use_sg); |
SCpnt | 934 | drivers/scsi/wd7000.c | any2scsi(scb->maxlen, SCpnt->use_sg * sizeof (Sgb) ); |
SCpnt | 936 | drivers/scsi/wd7000.c | for (i = 0; i < SCpnt->use_sg; i++) { |
SCpnt | 942 | drivers/scsi/wd7000.c | any2scsi(scb->dataptr, (int) SCpnt->request_buffer); |
SCpnt | 943 | drivers/scsi/wd7000.c | any2scsi(scb->maxlen, SCpnt->request_bufflen); |
SCpnt | 951 | drivers/scsi/wd7000.c | int wd7000_command(Scsi_Cmnd *SCpnt) |
SCpnt | 953 | drivers/scsi/wd7000.c | wd7000_queuecommand(SCpnt, wd7000_scsi_done); |
SCpnt | 955 | drivers/scsi/wd7000.c | while (SCpnt->SCp.phase > 0) barrier(); /* phase counts scbs down to 0 */ |
SCpnt | 957 | drivers/scsi/wd7000.c | return SCpnt->result; |
SCpnt | 1194 | drivers/scsi/wd7000.c | int wd7000_abort(Scsi_Cmnd * SCpnt) |
SCpnt | 1196 | drivers/scsi/wd7000.c | Adapter *host = (Adapter *) SCpnt->host->hostdata; |
SCpnt | 1211 | drivers/scsi/wd7000.c | int wd7000_reset(Scsi_Cmnd * SCpnt) |