亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? enummain.cpp

?? USB HASP key emulator, based on USB bus driver
?? CPP
字號:
/*++

Copyright (c) 2004 Chingachguk & Denger2k All rights reserved.

Module Name:

    Enum.c

Environment:

    usermode console application

Revision History:


--*/

#include <basetyps.h>
#include <rpc.h>
#include <rpcndr.h>
#include <stdlib.h>
#include <wtypes.h>
#include <setupapi.h>
#include <initguid.h>
#include <stdio.h>
#include <string.h>
#include <winioctl.h>
#include "..\Bus\Include\public.h"

DEFINE_GUID (GUID_DEVINTERFACE_VUSB1,
	0x45e0f259, 0x9cbf, 0x456e, 0x9d, 0xa5, 0x82, 0x1a, 0xa4, 0x2c, 0x4a, 0x1);
// {45E0F259-9CBF-456e-9DA5-821AA42C4A01}

//
// Prototypes
//

BOOLEAN
OpenBusInterface (
    IN       HDEVINFO                    HardwareDeviceInfo,
    IN       PSP_DEVICE_INTERFACE_DATA   DeviceInterfaceData
    );



#define USAGE  \
"Usage: Enum [-p SerialNo] [Password] Plugs in a device. SerialNo must be greater than zero.\n\
             [-u SerialNo or 0] Unplugs device(s) - specify 0 to unplug all \
                                the devices enumerated so far.\n\
             [-e SerialNo or 0] Ejects device(s) - specify 0 to eject all \
                                the devices enumerated so far.\n"

BOOLEAN     bPlugIn, bUnplug, bEject;
ULONG       SerialNo, Password;

int _cdecl main (int argc, char *argv[])
{
    HDEVINFO                    hardwareDeviceInfo;
    SP_DEVICE_INTERFACE_DATA    deviceInterfaceData;

    bPlugIn = bUnplug = FALSE;

    if(argc <3) {
        goto usage;
    }

    if(argv[1][0] == '-') {
        if(tolower(argv[1][1]) == 'p') {
            if(argv[2])
                SerialNo = (ULONG)atol(argv[2]);
                if(argv[3])
                    Password = (ULONG)atol(argv[3]);
        bPlugIn = TRUE;
        }
        else if(tolower(argv[1][1]) == 'u') {
            if(argv[2])
                SerialNo = (ULONG)atol(argv[2]);
            bUnplug = TRUE;
        }
        else if(tolower(argv[1][1]) == 'e') {
            if(argv[2])
                SerialNo = (ULONG)atol(argv[2]); 
            bEject = TRUE;
        }
        else {
            goto usage;
        }
    }
    else
        goto usage;

    if(bPlugIn && 0 == SerialNo)
        goto usage;
    //
    // Open a handle to the device interface information set of all 
    // present USB bus enumerator interfaces.
    //

    hardwareDeviceInfo = SetupDiGetClassDevs (
                       (LPGUID)&GUID_DEVINTERFACE_VUSB1,
                       NULL, // Define no enumerator (global)
                       NULL, // Define no
                       (DIGCF_PRESENT | // Only Devices present
                       DIGCF_DEVICEINTERFACE)); // Function class devices.

    if(INVALID_HANDLE_VALUE == hardwareDeviceInfo)
    {
        printf("SetupDiGetClassDevs failed: %x\n", GetLastError());
        return 0;
    }

    deviceInterfaceData.cbSize = sizeof (SP_DEVICE_INTERFACE_DATA);

    if (SetupDiEnumDeviceInterfaces (hardwareDeviceInfo,
                                 0, // No care about specific PDOs
                                 (LPGUID)&GUID_DEVINTERFACE_VUSB,
                                 0, //
                                 &deviceInterfaceData)) {

        OpenBusInterface(hardwareDeviceInfo, &deviceInterfaceData);
    } else if (ERROR_NO_MORE_ITEMS == GetLastError()) {
    
        printf(
        "Error:Interface GUID_DEVINTERFACE_VUSB is not registered\n");
    }

    SetupDiDestroyDeviceInfoList (hardwareDeviceInfo);
    return 0;
usage: 
    printf(USAGE);
    exit(0);
}

BOOLEAN
OpenBusInterface (
    IN       HDEVINFO                    HardwareDeviceInfo,
    IN       PSP_DEVICE_INTERFACE_DATA   DeviceInterfaceData
    )
{
    HANDLE                              file;
    PSP_DEVICE_INTERFACE_DETAIL_DATA    deviceInterfaceDetailData = NULL;
    ULONG                               predictedLength = 0;
    ULONG                               requiredLength = 0;
    ULONG                               bytes;
    VUSB_UNPLUG_HARDWARE             unplug;
    VUSB_EJECT_HARDWARE              eject;
    PVUSB_PLUGIN_HARDWARE            hardware;
    BOOLEAN                             bSuccess;

    //
    // Allocate a function class device data structure to receive the
    // information about this particular device.
    //
    
    SetupDiGetDeviceInterfaceDetail (
            HardwareDeviceInfo,
            DeviceInterfaceData,
            NULL, // probing so no output buffer yet
            0, // probing so output buffer length of zero
            &requiredLength,
            NULL); // not interested in the specific dev-node


    predictedLength = requiredLength;

    deviceInterfaceDetailData = (PSP_DEVICE_INTERFACE_DETAIL_DATA) malloc (predictedLength);

    if(deviceInterfaceDetailData) {
        deviceInterfaceDetailData->cbSize = 
                      sizeof (SP_DEVICE_INTERFACE_DETAIL_DATA);
    } else {
        printf("Couldn't allocate %d bytes for device interface details.\n", predictedLength);
        return FALSE;
    }

    
    if (! SetupDiGetDeviceInterfaceDetail (
               HardwareDeviceInfo,
               DeviceInterfaceData,
               deviceInterfaceDetailData,
               predictedLength,
               &requiredLength,
               NULL)) {
        printf("Error in SetupDiGetDeviceInterfaceDetail\n");
        free (deviceInterfaceDetailData);
        return FALSE;
    }

    printf("Opening %s\n", deviceInterfaceDetailData->DevicePath);

    file = CreateFile ( deviceInterfaceDetailData->DevicePath,
                        GENERIC_READ | GENERIC_WRITE,
                        0, // FILE_SHARE_READ | FILE_SHARE_WRITE
                        NULL, // no SECURITY_ATTRIBUTES structure
                        OPEN_EXISTING, // No special create flags
                        0, // No special attributes
                        NULL); // No template file

    if (INVALID_HANDLE_VALUE == file) {
        printf("Device not ready: %x", GetLastError());
        free (deviceInterfaceDetailData);
        return FALSE;
    }
    
    printf("Bus interface opened!!!\n");

    //
    // From this point on, we need to jump to the end of the routine for
    // common clean-up.  Keep track of whether we succeeded or failed, so
    // we'll know what to return to the caller.
    //
    bSuccess = FALSE;

    //
    // Enumerate Devices
    //

    if(bPlugIn) {

        printf("SerialNo./Password of the device to be enumerated: %d/%08X\n", SerialNo, Password);

        hardware =(PVUSB_PLUGIN_HARDWARE) malloc (bytes = (sizeof (VUSB_PLUGIN_HARDWARE) +
                                              BUS_HARDWARE_IDS_LENGTH));

        if(hardware) {
            hardware->Size = sizeof (VUSB_PLUGIN_HARDWARE);
            hardware->SerialNo = SerialNo;
            hardware->Password = Password;
        } else {
            printf("Couldn't allocate %d bytes for VUSB plugin hardware structure.\n", bytes);
            goto End;
        }

        //
        // Allocate storage for the Device ID
        //
        /*wchar_t *deviceHardwareID=L"USB\\VID_0529&PID_0001\0";
        wcscpy (hardware->HardwareIDs,
            deviceHardwareID);*/
        memcpy (hardware->HardwareIDs,
                BUS_HARDWARE_IDS,
                BUS_HARDWARE_IDS_LENGTH);

        if (!DeviceIoControl (file,
                              IOCTL_VUSB_PLUGIN_HARDWARE ,
                              hardware, bytes,
                              hardware, bytes,
                              &bytes, NULL)) {
              free (hardware);
              printf("PlugIn failed:0x%x\n", GetLastError());
              goto End;
        }

        free (hardware);
    }

    //
    // Removes a device if given the specific Id of the device. Otherwise this
    // ioctls removes all the devices that are enumerated so far.
    //
    
    if(bUnplug) {
        printf("Unplugging device(s)....\n");

        unplug.Size = bytes = sizeof (unplug);
        unplug.SerialNo = SerialNo;
        if (!DeviceIoControl (file,
                              IOCTL_VUSB_UNPLUG_HARDWARE,
                              &unplug, bytes,
                              &unplug, bytes,
                              &bytes, NULL)) {
            printf("Unplug failed: 0x%x\n", GetLastError());
            goto End;
        }
    }

    //
    // Ejects a device if given the specific Id of the device. Otherwise this
    // ioctls ejects all the devices that are enumerated so far.
    //

    if(bEject)
    {
        printf("Ejecting Device(s)\n");

        eject.Size = bytes = sizeof (eject);
        eject.SerialNo = SerialNo;
        if (!DeviceIoControl (file,
                              IOCTL_VUSB_EJECT_HARDWARE,
                              &eject, bytes,
                              &eject, bytes,
                              &bytes, NULL)) {
            printf("Eject failed: 0x%x\n", GetLastError());
            goto End;
        }
    }

    printf("Success!!!\n");
    bSuccess = TRUE;

End:
    CloseHandle(file);
    free (deviceInterfaceDetailData);
    return bSuccess;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产高清一区二区三区| 国产精品99久久久久| 久久精品网站免费观看| 日韩欧美一区中文| 日韩美女视频在线| 精品国产sm最大网站免费看| 欧美刺激脚交jootjob| 精品国产污污免费网站入口| 精品国内片67194| 国产欧美精品一区二区三区四区| 久久久精品中文字幕麻豆发布| 2021中文字幕一区亚洲| 久久精品视频在线免费观看| 中文字幕第一区第二区| 一区二区三区四区五区视频在线观看| 国产精品乱码妇女bbbb| 亚洲蜜桃精久久久久久久| 亚洲一区中文在线| 免费成人av在线播放| 国产精品正在播放| 91蝌蚪国产九色| 51精品久久久久久久蜜臀| 欧美变态tickle挠乳网站| 久久夜色精品国产噜噜av| 中文字幕在线观看一区二区| 亚洲精品成a人| 麻豆精品视频在线观看视频| 丰满白嫩尤物一区二区| 91黄色免费版| 精品国产成人系列| 亚洲欧洲制服丝袜| 久久精品国产第一区二区三区| 国产麻豆9l精品三级站| 欧美在线观看一区| 久久综合九色综合欧美就去吻| 国产精品第四页| 免费观看一级欧美片| 97精品电影院| 精品国产免费久久| 亚洲一区二区不卡免费| 国内久久婷婷综合| 欧美亚日韩国产aⅴ精品中极品| 精品久久久影院| 亚洲成a人v欧美综合天堂| 国产精品一区二区久久不卡 | 久久综合久久综合久久综合| 亚洲欧美偷拍卡通变态| 秋霞电影网一区二区| 国产99久久久精品| 日韩一区二区三区在线| 亚洲精品成人天堂一二三| 国产福利精品一区| 777欧美精品| 夜夜亚洲天天久久| 精品在线免费视频| 欧美日韩国产123区| 中文字幕一区二区三区在线观看| 精品在线播放午夜| 欧美男人的天堂一二区| 依依成人精品视频| 成人黄色a**站在线观看| 欧美精品一区二区三区四区 | 国产福利一区二区| 欧美成人福利视频| 日韩av高清在线观看| 欧美在线一区二区三区| 国产精品久久夜| 高清不卡一二三区| 国产亚洲欧美色| 国产精品一区二区不卡| 国产亚洲欧洲一区高清在线观看| 久久国产成人午夜av影院| 欧美一卡二卡在线| 日韩成人一级大片| 欧美一卡二卡三卡四卡| 久久99这里只有精品| 日韩亚洲欧美在线| 青青草97国产精品免费观看| 91精品国产品国语在线不卡| 日韩成人伦理电影在线观看| 欧美精品高清视频| 免播放器亚洲一区| 精品sm在线观看| 成人一级片网址| 日韩一区在线免费观看| 在线一区二区观看| 香蕉久久一区二区不卡无毒影院| 欧美日韩免费观看一区三区| 国产综合色产在线精品| 精品国产在天天线2019| 国产99一区视频免费| 国产精品传媒在线| 欧美精品欧美精品系列| 国产一区二区三区在线观看精品 | 亚洲色大成网站www久久九九| www.日本不卡| 亚洲va天堂va国产va久| 日韩一区和二区| 国产米奇在线777精品观看| 国产精品久久久久久久久免费相片| 91免费观看在线| 青草国产精品久久久久久| 国产人久久人人人人爽| 欧洲日韩一区二区三区| 蜜臀国产一区二区三区在线播放 | 欧美精品久久久久久久多人混战 | 亚洲欧美精品午睡沙发| 欧美二区在线观看| 粉嫩一区二区三区在线看| 伊人开心综合网| 亚洲精品一区二区精华| 色素色在线综合| 国产一区二区在线视频| 日韩影院免费视频| 国产日韩亚洲欧美综合| 91美女精品福利| 激情久久久久久久久久久久久久久久| 国产精品乱人伦中文| 欧美一卡二卡在线观看| 99视频精品在线| 久久99国产精品免费网站| 亚洲另类在线一区| 久久久蜜桃精品| 制服丝袜在线91| 91浏览器入口在线观看| 国产精品一区二区三区乱码| 亚州成人在线电影| 中文字幕一区二区三区精华液| 日韩一级视频免费观看在线| 色哟哟欧美精品| 成人网在线免费视频| 免费在线观看视频一区| 亚洲在线视频网站| 亚洲视频每日更新| 国产精品高潮呻吟久久| 2021国产精品久久精品| 日韩欧美第一区| 欧美男男青年gay1069videost| 91丝袜高跟美女视频| 波多野结衣在线一区| 韩国v欧美v亚洲v日本v| 麻豆成人综合网| 秋霞av亚洲一区二区三| 亚洲成人免费av| 亚洲激情一二三区| 亚洲男人的天堂av| 国产精品久久久久久亚洲毛片 | 亚洲午夜久久久久久久久久久| 国产精品网站导航| 久久久久一区二区三区四区| 精品国产污网站| 精品国产不卡一区二区三区| 日韩精品在线一区二区| 5858s免费视频成人| 日韩午夜小视频| 亚洲精品一区二区三区蜜桃下载| 精品久久久影院| 国产欧美一区二区三区在线老狼| 久久网站最新地址| 欧美国产日韩一二三区| 国产精品久久久久久一区二区三区 | 欧美国产97人人爽人人喊| 国产网站一区二区| 国产精品国产三级国产| 亚洲乱码国产乱码精品精的特点 | 久久精品噜噜噜成人88aⅴ| 日韩精品每日更新| 麻豆精品一区二区av白丝在线| 久热成人在线视频| 粉嫩嫩av羞羞动漫久久久| 成人午夜碰碰视频| 欧美影片第一页| 欧美一级欧美三级| 国产视频视频一区| 亚洲精品五月天| 天天综合天天做天天综合| 精品一区二区三区在线视频| 成人午夜伦理影院| 色妞www精品视频| 欧美一区二区三区小说| 中文天堂在线一区| 亚洲网友自拍偷拍| 激情综合色播激情啊| 99久久精品99国产精品 | 热久久久久久久| 国产福利精品一区| 欧美在线一区二区| 国产亚洲婷婷免费| 性欧美大战久久久久久久久| 国内久久精品视频| 日本道免费精品一区二区三区| 欧美一级黄色片| 中文字幕 久热精品 视频在线| 亚洲丶国产丶欧美一区二区三区| 黑人巨大精品欧美黑白配亚洲| 91日韩在线专区| 久久精品视频网| 日本中文在线一区| 欧美一区二区三区不卡| 1区2区3区国产精品|