Lines Matching refs:srb
341 struct scsi_cmnd srb; member
410 static void isd200_build_sense(struct us_data *us, struct scsi_cmnd *srb) in isd200_build_sense() argument
413 struct sense_data *buf = (struct sense_data *) &srb->sense_buffer[0]; in isd200_build_sense()
463 struct scsi_cmnd *srb = &info->srb; in isd200_set_srb() local
468 srb->sc_data_direction = dir; in isd200_set_srb()
469 srb->sdb.table.sgl = buff ? &info->sg : NULL; in isd200_set_srb()
470 srb->sdb.length = bufflen; in isd200_set_srb()
471 srb->sdb.table.nents = buff ? 1 : 0; in isd200_set_srb()
474 static void isd200_srb_set_bufflen(struct scsi_cmnd *srb, unsigned bufflen) in isd200_srb_set_bufflen() argument
476 srb->sdb.length = bufflen; in isd200_srb_set_bufflen()
495 struct scsi_cmnd *srb = &info->srb; in isd200_action() local
499 srb->cmnd = info->cmnd; in isd200_action()
500 srb->device = &srb_dev; in isd200_action()
566 memcpy(srb->cmnd, &ata, sizeof(ata.generic)); in isd200_action()
567 srb->cmd_len = sizeof(ata.generic); in isd200_action()
568 status = usb_stor_Bulk_transport(srb, us); in isd200_action()
619 struct scsi_cmnd *srb, in isd200_invoke_transport() argument
627 memcpy(srb->cmnd, ataCdb, sizeof(ataCdb->generic)); in isd200_invoke_transport()
628 srb->cmd_len = sizeof(ataCdb->generic); in isd200_invoke_transport()
629 transferStatus = usb_stor_Bulk_transport(srb, us); in isd200_invoke_transport()
643 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
648 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
658 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
664 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
669 if ((scsi_get_resid(srb) > 0) && in isd200_invoke_transport()
670 !((srb->cmnd[0] == REQUEST_SENSE) || in isd200_invoke_transport()
671 (srb->cmnd[0] == INQUIRY) || in isd200_invoke_transport()
672 (srb->cmnd[0] == MODE_SENSE) || in isd200_invoke_transport()
673 (srb->cmnd[0] == LOG_SENSE) || in isd200_invoke_transport()
674 (srb->cmnd[0] == MODE_SENSE_10))) { in isd200_invoke_transport()
686 isd200_build_sense(us, srb); in isd200_invoke_transport()
687 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
690 if ((srb->sense_buffer[2] & 0xf) == 0x0) in isd200_invoke_transport()
691 srb->result = SAM_STAT_GOOD; in isd200_invoke_transport()
693 srb->result = DID_ERROR << 16; in isd200_invoke_transport()
702 srb->result = SAM_STAT_CHECK_CONDITION; in isd200_invoke_transport()
708 srb->result = DID_ABORT << 16; in isd200_invoke_transport()
1222 static int isd200_scsi_to_ata(struct scsi_cmnd *srb, struct us_data *us, in isd200_scsi_to_ata() argument
1237 switch (srb->cmnd[0]) { in isd200_scsi_to_ata()
1243 sizeof(info->InquiryData), srb); in isd200_scsi_to_ata()
1244 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1252 usb_stor_set_xfer_buf(senseData, sizeof(senseData), srb); in isd200_scsi_to_ata()
1261 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1264 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1279 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1282 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1304 sizeof(readCapacityData), srb); in isd200_scsi_to_ata()
1305 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1313 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1314 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1345 lba = be32_to_cpu(*(__be32 *)&srb->cmnd[2]); in isd200_scsi_to_ata()
1346 blockCount = (unsigned long)srb->cmnd[7]<<8 | (unsigned long)srb->cmnd[8]; in isd200_scsi_to_ata()
1379 srb->cmnd[4]); in isd200_scsi_to_ata()
1385 ataCdb->write.CommandByte = (srb->cmnd[4] & 0x1) ? in isd200_scsi_to_ata()
1387 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1390 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1397 usb_stor_dbg(us, " srb->cmnd[4] = 0x%X\n", srb->cmnd[4]); in isd200_scsi_to_ata()
1399 if ((srb->cmnd[4] & 0x3) == 0x2) { in isd200_scsi_to_ata()
1406 } else if ((srb->cmnd[4] & 0x3) == 0x1) { in isd200_scsi_to_ata()
1413 isd200_srb_set_bufflen(srb, 0); in isd200_scsi_to_ata()
1416 srb->result = SAM_STAT_GOOD; in isd200_scsi_to_ata()
1423 srb->cmnd[0]); in isd200_scsi_to_ata()
1424 srb->result = DID_ERROR << 16; in isd200_scsi_to_ata()
1445 kfree(info->srb.sense_buffer); in isd200_free_info_ptrs()
1467 info->srb.sense_buffer = kmalloc(SCSI_SENSE_BUFFERSIZE, GFP_KERNEL); in isd200_init_info()
1469 if (!info->id || !info->RegsBuf || !info->srb.sense_buffer) { in isd200_init_info()
1516 static void isd200_ata_command(struct scsi_cmnd *srb, struct us_data *us) in isd200_ata_command() argument
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()