关于C++ 使用ASPI 向光驱发送SCSI命令遇到的有关问题
关于C++ 使用ASPI 向光驱发送SCSI命令遇到的问题
先贴代码
这段代码是获取硬件类型为CDROM的硬件名称,
再看下面的代码,这段代码是获取类型为CDROM硬件的转速
先贴代码
这段代码是获取硬件类型为CDROM的硬件名称,
BYTE __fastcall getDriveName( BYTE hostadapter, BYTE target, char* stringbuffer )
{
SRB_ExecSCSICmd s;
BYTE buf[100];
memset( &s, 0, sizeof( s ) );
memset( buf, 0, 100 );
s.SRB_Cmd = SC_EXEC_SCSI_CMD;
s.SRB_HaId = hostadapter;
s.SRB_Target = target;
s.SRB_Lun = 0;
s.SRB_Flags = SRB_DIR_IN | SRB_EVENT_NOTIFY;
s.SRB_BufLen = 100;
s.SRB_BufPointer = buf;
s.SRB_SenseLen = SENSE_LEN;
s.SRB_CDBLen = 6;
s.CDBByte[0] = SCSI_INQUIRY;
s.CDBByte[1] = 0;
s.CDBByte[2] = 0;
s.CDBByte[3] = 0;
s.CDBByte[4] = 100;
s.CDBByte[5] = 0;
BYTE byStatus = ExecSCSICommand(&s); //ExecSCSICommand封装SendASPI32Command即为发送方法
if( byStatus != SS_COMP )
{
//cout << "getDriveName returned status:" << LookupASPIStatus(byStatus).c_str() << endl;
}
if( byStatus == SS_ERR && s.SRB_TargStat == STATUS_CHKCOND )
{
BYTE SenseKey = s.SenseArea[2] & (BYTE)15;
BYTE ASC = s.SenseArea[12];
BYTE ASCQ = s.SenseArea[13];
}
//if the command was successful
if( byStatus == SS_COMP )
{
//extract the whole string identifying the drive
for( int i = 8; i < 36; i++ )
{
stringbuffer[i-8] = buf[i];
}
//the part I wish to extract is 28 characters long
stringbuffer[28] = NULL;
}
return byStatus;
}
再看下面的代码,这段代码是获取类型为CDROM硬件的转速
int __fastcall getCDSpeed(BYTE hostadapter, BYTE target)
{
SRB_ExecSCSICmd s;
unsigned char b[256];
memset( &s, 0, sizeof( s ) );
memset( b, 0xFF, 256 );
s.SRB_Cmd = SC_EXEC_SCSI_CMD;