Lines Matching refs:srb
339 struct scsi_cmnd srb; member
408 static void isd200_build_sense(struct us_data *us, struct scsi_cmnd *srb) in isd200_build_sense() argument
411 struct sense_data *buf = (struct sense_data *) &srb->sense_buffer[0]; in isd200_build_sense()
461 struct scsi_cmnd *srb = &info->srb; in isd200_set_srb() local
466 srb->sc_data_direction = dir; in isd200_set_srb()
467 srb->sdb.table.sgl = buff ? &info->sg : NULL; in isd200_set_srb()
468 srb->sdb.length = bufflen; in isd200_set_srb()
469 srb->sdb.table.nents = buff ? 1 : 0; in isd200_set_srb()
472 static void isd200_srb_set_bufflen(struct scsi_cmnd *srb, unsigned bufflen) in isd200_srb_set_bufflen() argument
474 srb->sdb.length = bufflen; in isd200_srb_set_bufflen()
493 struct scsi_cmnd *srb = &info->srb; in isd200_action() local
497 srb->cmnd = info->cmnd; in isd200_action()
498 srb->device = &srb_dev; in isd200_action()
564 memcpy(srb->cmnd, &ata, sizeof(ata.generic)); in isd200_action()
565 srb->cmd_len = sizeof(ata.generic); in isd200_action()
566 status = usb_stor_Bulk_transport(srb, us); in isd200_action()
617 struct scsi_cmnd *srb, in isd200_invoke_transport() argument
625 memcpy(srb->cmnd, ataCdb, sizeof(ataCdb->generic)); in isd200_invoke_transport()
626 srb->cmd_len = sizeof(ataCdb->generic); in isd200_invoke_transport()
627 transferStatus = usb_stor_Bulk_transport(srb, us); in isd200_invoke_transport()
641 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
646 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
656 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
662 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
667 if ((scsi_get_resid(srb) > 0) && in isd200_invoke_transport()
668 !((srb->cmnd[0] == REQUEST_SENSE) || in isd200_invoke_transport()
669 (srb->cmnd[0] == INQUIRY) || in isd200_invoke_transport()
670 (srb->cmnd[0] == MODE_SENSE) || in isd200_invoke_transport()
671 (srb->cmnd[0] == LOG_SENSE) || in isd200_invoke_transport()
672 (srb->cmnd[0] == MODE_SENSE_10))) { in isd200_invoke_transport()
684 isd200_build_sense(us, srb); in isd200_invoke_transport()
685 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
688 if ((srb->sense_buffer[2] & 0xf) == 0x0) in isd200_invoke_transport()
689 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
691 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
700 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
706 srb->result = DID_ABORT << 16; in isd200_invoke_transport()
1220 static int isd200_scsi_to_ata(struct scsi_cmnd *srb, struct us_data *us, in isd200_scsi_to_ata() argument
1235 switch (srb->cmnd[0]) { in isd200_scsi_to_ata()
1241 sizeof(info->InquiryData), srb); in isd200_scsi_to_ata()
1242 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1250 usb_stor_set_xfer_buf(senseData, sizeof(senseData), srb); in isd200_scsi_to_ata()
1259 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1262 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1277 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1280 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1302 sizeof(readCapacityData), srb); in isd200_scsi_to_ata()
1303 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1311 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1312 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1343 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1344 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1377 srb->cmnd[4]); in isd200_scsi_to_ata()
1383 ataCdb->write.CommandByte = (srb->cmnd[4] & 0x1) ? in isd200_scsi_to_ata()
1385 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1388 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1395 usb_stor_dbg(us, " srb->cmnd[4] = 0x%X\n", srb->cmnd[4]); in isd200_scsi_to_ata()
1397 if ((srb->cmnd[4] & 0x3) == 0x2) { in isd200_scsi_to_ata()
1404 } else if ((srb->cmnd[4] & 0x3) == 0x1) { in isd200_scsi_to_ata()
1411 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1414 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1421 srb->cmnd[0]); in isd200_scsi_to_ata()
1422 srb->result = DID_ERROR << 16; in isd200_scsi_to_ata()
1443 kfree(info->srb.sense_buffer); in isd200_free_info_ptrs()
1466 info->srb.sense_buffer = in isd200_init_info()
1468 if (!info->id || !info->RegsBuf || !info->srb.sense_buffer) { in isd200_init_info()
1518 static void isd200_ata_command(struct scsi_cmnd *srb, struct us_data *us) in isd200_ata_command() argument
1528 scsi_set_resid(srb, 0); in isd200_ata_command()
1530 orig_bufflen = scsi_bufflen(srb); in isd200_ata_command()
1531 sendToTransport = isd200_scsi_to_ata(srb, us, &ataCdb); in isd200_ata_command()
1535 isd200_invoke_transport(us, srb, &ataCdb); in isd200_ata_command()
1537 isd200_srb_set_bufflen(srb, orig_bufflen); in isd200_ata_command()