Lines Matching refs:srb

329 	struct scsi_cmnd srb;  member
398 static void isd200_build_sense(struct us_data *us, struct scsi_cmnd *srb) in isd200_build_sense() argument
401 struct sense_data *buf = (struct sense_data *) &srb->sense_buffer[0]; in isd200_build_sense()
451 struct scsi_cmnd *srb = &info->srb; in isd200_set_srb() local
456 srb->sc_data_direction = dir; in isd200_set_srb()
457 srb->sdb.table.sgl = buff ? &info->sg : NULL; in isd200_set_srb()
458 srb->sdb.length = bufflen; in isd200_set_srb()
459 srb->sdb.table.nents = buff ? 1 : 0; in isd200_set_srb()
462 static void isd200_srb_set_bufflen(struct scsi_cmnd *srb, unsigned bufflen) in isd200_srb_set_bufflen() argument
464 srb->sdb.length = bufflen; in isd200_srb_set_bufflen()
483 struct scsi_cmnd *srb = &info->srb; in isd200_action() local
487 srb->cmnd = info->cmnd; in isd200_action()
488 srb->device = &srb_dev; in isd200_action()
554 memcpy(srb->cmnd, &ata, sizeof(ata.generic)); in isd200_action()
555 srb->cmd_len = sizeof(ata.generic); in isd200_action()
556 status = usb_stor_Bulk_transport(srb, us); in isd200_action()
607 struct scsi_cmnd *srb, in isd200_invoke_transport() argument
615 memcpy(srb->cmnd, ataCdb, sizeof(ataCdb->generic)); in isd200_invoke_transport()
616 srb->cmd_len = sizeof(ataCdb->generic); in isd200_invoke_transport()
617 transferStatus = usb_stor_Bulk_transport(srb, us); in isd200_invoke_transport()
632 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
637 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
647 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
653 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
658 if ((scsi_get_resid(srb) > 0) && in isd200_invoke_transport()
659 !((srb->cmnd[0] == REQUEST_SENSE) || in isd200_invoke_transport()
660 (srb->cmnd[0] == INQUIRY) || in isd200_invoke_transport()
661 (srb->cmnd[0] == MODE_SENSE) || in isd200_invoke_transport()
662 (srb->cmnd[0] == LOG_SENSE) || in isd200_invoke_transport()
663 (srb->cmnd[0] == MODE_SENSE_10))) { in isd200_invoke_transport()
675 isd200_build_sense(us, srb); in isd200_invoke_transport()
676 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
679 if ((srb->sense_buffer[2] & 0xf) == 0x0) in isd200_invoke_transport()
680 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
682 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
692 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
700 srb->result = DID_ABORT << 16; in isd200_invoke_transport()
1218 static int isd200_scsi_to_ata(struct scsi_cmnd *srb, struct us_data *us, in isd200_scsi_to_ata() argument
1233 switch (srb->cmnd[0]) { in isd200_scsi_to_ata()
1239 sizeof(info->InquiryData), srb); in isd200_scsi_to_ata()
1240 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1248 usb_stor_set_xfer_buf(senseData, sizeof(senseData), srb); in isd200_scsi_to_ata()
1257 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1260 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1275 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1278 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1300 sizeof(readCapacityData), srb); in isd200_scsi_to_ata()
1301 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1309 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1310 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1341 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1342 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1375 srb->cmnd[4]); in isd200_scsi_to_ata()
1381 ataCdb->write.CommandByte = (srb->cmnd[4] & 0x1) ? in isd200_scsi_to_ata()
1383 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1386 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1393 usb_stor_dbg(us, " srb->cmnd[4] = 0x%X\n", srb->cmnd[4]); in isd200_scsi_to_ata()
1395 if ((srb->cmnd[4] & 0x3) == 0x2) { in isd200_scsi_to_ata()
1402 } else if ((srb->cmnd[4] & 0x3) == 0x1) { in isd200_scsi_to_ata()
1409 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1412 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1419 srb->cmnd[0]); in isd200_scsi_to_ata()
1420 srb->result = DID_ERROR << 16; in isd200_scsi_to_ata()
1441 kfree(info->srb.sense_buffer); in isd200_free_info_ptrs()
1463 info->srb.sense_buffer = kmalloc(SCSI_SENSE_BUFFERSIZE, GFP_KERNEL); in isd200_init_info()
1465 if (!info->id || !info->RegsBuf || !info->srb.sense_buffer) { in isd200_init_info()
1512 static void isd200_ata_command(struct scsi_cmnd *srb, struct us_data *us) in isd200_ata_command() argument
1521 srb->result = DID_ERROR << 16; in isd200_ata_command()
1525 scsi_set_resid(srb, 0); in isd200_ata_command()
1527 orig_bufflen = scsi_bufflen(srb); in isd200_ata_command()
1528 sendToTransport = isd200_scsi_to_ata(srb, us, &ataCdb); in isd200_ata_command()
1532 isd200_invoke_transport(us, srb, &ataCdb); in isd200_ata_command()
1534 isd200_srb_set_bufflen(srb, orig_bufflen); in isd200_ata_command()