admin管理员组

文章数量:1530862

SCSI的设备间通信:
涉及到一个主要的windows函数,DeviceIoControl()。
在获取到设备句柄之后,就可以通过下面的函数和设备通讯了。
DeviceIoControl(
m_hControlDrv,
IOCTL_SCSI_PASS_THROUGH,
&sptwb,
u32Length,
&sptwb,
u32Length,
&u32Return,
FALSE);

第一个参数为句柄。
第二个参数代表此次的控制码, IOCTL_SCSI_PASS_THROUGH代表向设备发送一个带有scsi命令的结构体,结构体地址在第三个参数中传入。
typedef struct _SCSI_PASS_THROUGH {
USHORT Length;
UCHAR ScsiStatus;
UCHAR PathId;
UCHAR TargetId;
UCHAR Lun;
UCHAR CdbLength;
UCHAR SenseInfoLength;
UCHAR DataIn;
ULONG DataTransferLength;
ULONG TimeOutValue;
ULONG_PTR DataBufferOffset;
ULONG SenseInfoOffset;
UCHAR Cdb[16];
}SCSI_PASS_THROUGH;
CDB[16]结构:一般是第一个字节放opcode,剩下的字节为参数字节,不同情况下的结构不一样。
SCSI的opcode如下(未放全):
Code Command
00 TEST UNIT READY
01 REWIND
03 REQUEST SENSE
04 FORMAT
05 READ BLOCK LIMITS
07 REASSIGN BLOCKS
07 INITIALIZE ELEMENT STATUS
08 READ(6)
0A WRITE(6)
0B SEEK(6)
0F READ REVERSE(6)
10 WRITE FILEMARKS(6)
11 SPACE(6)
12 INQUIRY
13 VERIFY(6)
14 RECOVER BUFFERED DATA
15 MODE SELECT(6)
16 RESERVE(6)
17 RELEASE(6)
18 COPY
19 ERASE (6)
1A MODE SENSE (6)
1B START STOP UNIT
1B LOAD UNLOAD
1C RECEIVE DIAGNOSTIC RESULTS
1D SEND DIAGNOSTIC
1E PREVENT ALLOW MEDIUM REMOVAL
23 READ FORMAT CAPACITIES
25 READ CAPACITY(10)
28 READ(10)
29 READ GENERATION
2A WRITE(10)

本文标签: DeviceIoControlSCSICDBSCSIPASSTHROUGH