DeviceIoControl 호출
애플리케이션은 DeviceIoControl 함수를 사용하여 플로피 디스크 드라이브, 하드 디스크 드라이브, 테이프 드라이브 또는 CD-ROM 드라이브에 대한 직접 입력 및 출력 작업을 수행하거나 정보를 검색할 수 있습니다. SDK 설명서에 포함된 표준 제어 코드 목록은 DeviceIoControl의 설명 섹션을 참조하세요.
다음 예제에서는 시스템의 첫 번째 실제 드라이브에 대 한 정보를 검색 하는 방법을 보여 줍니다. CreateFile 함수를 사용하여 첫 번째 실제 드라이브에 대한 디바이스 핸들을 검색한 다음, IOCTL_DISK_GET_DRIVE_GEOMETRY 제어 코드와 함께 DeviceIoControl을 사용하여 드라이브에 대한 정보로 DISK_GEOMETRY 구조를 채웁니다.
#define UNICODE 1
#define _UNICODE 1
/* The code of interest is in the subroutine GetDriveGeometry. The
code in main shows how to interpret the results of the call. */
#include <windows.h>
#include <winioctl.h>
#include <stdio.h>
#define wszDrive L"\\\\.\\PhysicalDrive0"
BOOL GetDriveGeometry(LPWSTR wszPath, DISK_GEOMETRY *pdg)
{
HANDLE hDevice = INVALID_HANDLE_VALUE; // handle to the drive to be examined
BOOL bResult = FALSE; // results flag
DWORD junk = 0; // discard results
hDevice = CreateFileW(wszPath, // drive to open
0, // no access to the drive
FILE_SHARE_READ | // share mode
FILE_SHARE_WRITE,
NULL, // default security attributes
OPEN_EXISTING, // disposition
0, // file attributes
NULL); // do not copy file attributes
if (hDevice == INVALID_HANDLE_VALUE) // cannot open the drive
{
return (FALSE);
}
bResult = DeviceIoControl(hDevice, // device to be queried
IOCTL_DISK_GET_DRIVE_GEOMETRY, // operation to perform
NULL, 0, // no input buffer
pdg, sizeof(*pdg), // output buffer
&junk, // # bytes returned
(LPOVERLAPPED) NULL); // synchronous I/O
CloseHandle(hDevice);
return (bResult);
}
int wmain(int argc, wchar_t *argv[])
{
DISK_GEOMETRY pdg = { 0 }; // disk drive geometry structure
BOOL bResult = FALSE; // generic results flag
ULONGLONG DiskSize = 0; // size of the drive, in bytes
bResult = GetDriveGeometry (wszDrive, &pdg);
if (bResult)
{
wprintf(L"Drive path = %ws\n", wszDrive);
wprintf(L"Cylinders = %I64d\n", pdg.Cylinders);
wprintf(L"Tracks/cylinder = %ld\n", (ULONG) pdg.TracksPerCylinder);
wprintf(L"Sectors/track = %ld\n", (ULONG) pdg.SectorsPerTrack);
wprintf(L"Bytes/sector = %ld\n", (ULONG) pdg.BytesPerSector);
DiskSize = pdg.Cylinders.QuadPart * (ULONG)pdg.TracksPerCylinder *
(ULONG)pdg.SectorsPerTrack * (ULONG)pdg.BytesPerSector;
wprintf(L"Disk size = %I64d (Bytes)\n"
L" = %.2f (Gb)\n",
DiskSize, (double) DiskSize / (1024 * 1024 * 1024));
}
else
{
wprintf (L"GetDriveGeometry failed. Error %ld.\n", GetLastError ());
}
return ((int)bResult);
}