Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

143 lines
3.8 KiB

// Private nt headers.
//
#include <nt.h>
#include <ntrtl.h>
#include <nturtl.h>
#include <objbase.h> // CLSIDFromString
#include <setupapi.h>
#include <conio.h> // _kbhit
#include <stdio.h> // printf
BOOL
FGetClassGuidFromCmdLineParam (
PCWSTR pszParam,
GUID* pguidClass)
{
static const struct
{
GUID guidClass;
PCWSTR pszName;
} MapClassGuidToName [] =
{
{ {0xad498944, 0x762f, 0x11d0, 0x8d, 0xcb, 0x00, 0xc0, 0x4f, 0xc3, 0x35, 0x8c},
L"ndislan" },
};
if (TEXT('{' == *pszParam))
{
return SUCCEEDED(CLSIDFromString ((LPOLESTR)pszParam, pguidClass));
}
else
{
INT i;
for (i = 0;
i < sizeof(MapClassGuidToName) / sizeof(MapClassGuidToName[0]);
i++)
{
if (0 == lstrcmpiW (pszParam, MapClassGuidToName[i].pszName))
{
*pguidClass = MapClassGuidToName[i].guidClass;
return TRUE;
}
}
}
return FALSE;
}
void
__cdecl
wmain (
int argc,
PCWSTR argv[])
{
GUID guidClass;
HDEVINFO hdi;
// Argument check
//
if (2 != argc)
{
printf ("%S {class guid}\n", argv[0]);
return;
}
// Conver the string argument for the guid into a GUID.
//
if (!FGetClassGuidFromCmdLineParam (argv[1], &guidClass))
{
printf ("error: invalid class guid.\n");
}
// Get the devices in this class.
//
hdi = SetupDiGetClassDevs (&guidClass, NULL, NULL,
DIGCF_PRESENT | DIGCF_DEVICEINTERFACE);
if (hdi)
{
BYTE abBuffer [ sizeof(SP_DEVICE_INTERFACE_DETAIL_DATA) +
(MAX_PATH * sizeof(WCHAR)) ];
SP_DEVICE_INTERFACE_DATA did;
PSP_DEVICE_INTERFACE_DETAIL_DATA pDetail;
DWORD i;
ZeroMemory (&did, sizeof(did));
did.cbSize = sizeof(did);
pDetail = (PSP_DEVICE_INTERFACE_DETAIL_DATA)abBuffer;
// Enumerate the device interfaces of the class.
//
for (i = 0;
SetupDiEnumDeviceInterfaces (hdi, NULL, &guidClass, i, &did);
i++)
{
pDetail->cbSize = sizeof(*pDetail);
if (SetupDiGetDeviceInterfaceDetail (hdi, &did,
pDetail, sizeof(abBuffer), NULL, NULL))
{
HANDLE hFile;
printf ("opening %S\n", pDetail->DevicePath);
hFile = CreateFile (pDetail->DevicePath,
GENERIC_READ | GENERIC_WRITE,
0, NULL, OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED,
NULL);
if (hFile && (INVALID_HANDLE_VALUE != hFile))
{
printf ("press any key to close device...");
while (!_kbhit())
{
Sleep (20);
}
_getch ();
printf ("\n\n");
CloseHandle (hFile);
}
else
{
printf ("error: CreateFile failed. (%d)\n\n",
GetLastError ());
}
}
else
{
printf ("error: SetupDiGetDeviceInterfaceDetail failed "
"for item %d. (%d)\n", i, GetLastError ());
}
}
SetupDiDestroyDeviceInfoList (hdi);
}
else
{
printf ("error: SetupDiGetClassDevs returned %d", GetLastError ());
}
}