我想通过使用MSDN上描述的OVERLAPPED结构来异步调用DeviceIO函数。 我正在使用FSCTL_ENUM_USN_DATA控制代码来枚举NTFS驱动器的MFT,但我无法异步运行它。文件句柄是使用FILE_FLAG_OVERLAPPED创建的,但是我是否将重叠结构与FILE_FLAG_OVERLAPPED一起使用没有区别。该函数不会立即返回。似乎在这两种情况下都是同步的。 下面的示例显示了C:\驱动器上第一个100.000 MFT条目的枚举。 由于我不太熟悉重叠结构的用法,可能我做了错误的事情。我的问题:如何异步执行DeviceIoControl(hDevice,FSCTL_ENUM_USN_DATA,...)?感谢您的帮助。如何异步调用DeviceIOControl代码?
#include "stdafx.h"
#include <Windows.h>
typedef struct {
DWORDLONG nextusn;
USN_RECORD FirstUsnRecord;
BYTE Buffer[500];
}TDeviceIoControlOutputBuffer, *PTDeviceIoControlOutputBuffer;
int _tmain(int argc, _TCHAR* argv[])
{
MFT_ENUM_DATA lInputMftData;
lInputMftData.StartFileReferenceNumber = 0;
lInputMftData.MinMajorVersion = 2;
lInputMftData.MaxMajorVersion = 3;
lInputMftData.LowUsn = 0;
lInputMftData.HighUsn = 0;
TDeviceIoControlOutputBuffer lOutputMftData;
DWORD lOutBytesReturned = 0;
HANDLE hEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
OVERLAPPED lOverlapped = { 0 };
lOverlapped.hEvent = hEvent;
LPCWSTR path = L"\\\\.\\C:";
HANDLE hDevice = CreateFile(path, GENERIC_READ, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, NULL);
if (hDevice != INVALID_HANDLE_VALUE) {
lOutputMftData.nextusn = 0;
while (lOutputMftData.nextusn < 100000) {
lInputMftData.StartFileReferenceNumber = lOutputMftData.nextusn;
BOOL result = DeviceIoControl(hDevice, FSCTL_ENUM_USN_DATA, &lInputMftData, sizeof(lInputMftData), &lOutputMftData, sizeof(lOutputMftData), &lOutBytesReturned, &lOverlapped);
}
}
}
如果驱动程序不支持异步I/O一般或有一定的要求,它处理I/O请求同步,忽略重叠参数。不过,我不知道这个驱动程序是否支持异步I/O模式下的这个特定请求。 –
感谢您的回复。根据微软的FSCTL_ENUM_USN_DATA可以调用async:http://msdn.microsoft.com/en-us/library/windows/desktop/aa364563%28v=vs.85%29.aspx – user3816574
那么,再看看你的代码,我没有看到你填写'lOverlapped'变量的'hEvent'成员。这可能是同步执行此请求的一个很好的理由。 –