Lines Matching refs:srb
330 struct scsi_cmnd srb; member
399 static void isd200_build_sense(struct us_data *us, struct scsi_cmnd *srb) in isd200_build_sense() argument
402 struct sense_data *buf = (struct sense_data *) &srb->sense_buffer[0]; in isd200_build_sense()
452 struct scsi_cmnd *srb = &info->srb; in isd200_set_srb() local
457 srb->sc_data_direction = dir; in isd200_set_srb()
458 srb->sdb.table.sgl = buff ? &info->sg : NULL; in isd200_set_srb()
459 srb->sdb.length = bufflen; in isd200_set_srb()
460 srb->sdb.table.nents = buff ? 1 : 0; in isd200_set_srb()
463 static void isd200_srb_set_bufflen(struct scsi_cmnd *srb, unsigned bufflen) in isd200_srb_set_bufflen() argument
465 srb->sdb.length = bufflen; in isd200_srb_set_bufflen()
484 struct scsi_cmnd *srb = &info->srb; in isd200_action() local
488 srb->cmnd = info->cmnd; in isd200_action()
489 srb->device = &srb_dev; in isd200_action()
555 memcpy(srb->cmnd, &ata, sizeof(ata.generic)); in isd200_action()
556 srb->cmd_len = sizeof(ata.generic); in isd200_action()
557 status = usb_stor_Bulk_transport(srb, us); in isd200_action()
608 struct scsi_cmnd *srb, in isd200_invoke_transport() argument
616 memcpy(srb->cmnd, ataCdb, sizeof(ataCdb->generic)); in isd200_invoke_transport()
617 srb->cmd_len = sizeof(ataCdb->generic); in isd200_invoke_transport()
618 transferStatus = usb_stor_Bulk_transport(srb, us); in isd200_invoke_transport()
633 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
638 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
648 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
654 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
659 if ((scsi_get_resid(srb) > 0) && in isd200_invoke_transport()
660 !((srb->cmnd[0] == REQUEST_SENSE) || in isd200_invoke_transport()
661 (srb->cmnd[0] == INQUIRY) || in isd200_invoke_transport()
662 (srb->cmnd[0] == MODE_SENSE) || in isd200_invoke_transport()
663 (srb->cmnd[0] == LOG_SENSE) || in isd200_invoke_transport()
664 (srb->cmnd[0] == MODE_SENSE_10))) { in isd200_invoke_transport()
676 isd200_build_sense(us, srb); in isd200_invoke_transport()
677 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
680 if ((srb->sense_buffer[2] & 0xf) == 0x0) in isd200_invoke_transport()
681 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
683 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
693 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
701 srb->result = DID_ABORT << 16; in isd200_invoke_transport()
1219 static int isd200_scsi_to_ata(struct scsi_cmnd *srb, struct us_data *us, in isd200_scsi_to_ata() argument
1234 switch (srb->cmnd[0]) { in isd200_scsi_to_ata()
1240 sizeof(info->InquiryData), srb); in isd200_scsi_to_ata()
1241 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1249 usb_stor_set_xfer_buf(senseData, sizeof(senseData), srb); in isd200_scsi_to_ata()
1258 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1261 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1276 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1279 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1301 sizeof(readCapacityData), srb); in isd200_scsi_to_ata()
1302 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1310 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1311 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1342 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1343 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1376 srb->cmnd[4]); in isd200_scsi_to_ata()
1382 ataCdb->write.CommandByte = (srb->cmnd[4] & 0x1) ? in isd200_scsi_to_ata()
1384 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1387 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1394 usb_stor_dbg(us, " srb->cmnd[4] = 0x%X\n", srb->cmnd[4]); in isd200_scsi_to_ata()
1396 if ((srb->cmnd[4] & 0x3) == 0x2) { in isd200_scsi_to_ata()
1403 } else if ((srb->cmnd[4] & 0x3) == 0x1) { in isd200_scsi_to_ata()
1410 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1413 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1420 srb->cmnd[0]); in isd200_scsi_to_ata()
1421 srb->result = DID_ERROR << 16; in isd200_scsi_to_ata()
1442 kfree(info->srb.sense_buffer); in isd200_free_info_ptrs()
1464 info->srb.sense_buffer = kmalloc(SCSI_SENSE_BUFFERSIZE, GFP_KERNEL); in isd200_init_info()
1466 if (!info->id || !info->RegsBuf || !info->srb.sense_buffer) { in isd200_init_info()
1513 static void isd200_ata_command(struct scsi_cmnd *srb, struct us_data *us) in isd200_ata_command() argument
1522 srb->result = DID_ERROR << 16; in isd200_ata_command()
1526 scsi_set_resid(srb, 0); in isd200_ata_command()
1528 orig_bufflen = scsi_bufflen(srb); in isd200_ata_command()
1529 sendToTransport = isd200_scsi_to_ata(srb, us, &ataCdb); in isd200_ata_command()
1533 isd200_invoke_transport(us, srb, &ataCdb); in isd200_ata_command()
1535 isd200_srb_set_bufflen(srb, orig_bufflen); in isd200_ata_command()