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

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

?? pcmcia.c

?? windows ce 3.00 嵌入式操作系統源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* File:    pcmcia.c
 *
 * Purpose: WinCE device loader for PCMCIA devices
 *
 * Copyright (c) 1995-2000 Microsoft Corporation.  All rights reserved.
 */
#include <windows.h>
#include <types.h>
#include <tchar.h>
#include <winreg.h>
#include <cardserv.h>
#include <tuple.h>
#include <devload.h>
#include <devloadp.h>
#include <dbt.h>
#include <notify.h>
#include <extfile.h>
#include <netui.h>

#ifdef TARGET_NT
#include <devemul.h>
#include <device.h>
#include <proxy.h>
#endif // TARGET_NT

#ifdef INSTRUM_DEV
#include <instrumd.h>
#endif // INSTRUM_DEV

//
// This module contains these functions:
//  QueryDriverNameThread
//  QueryDriverName
//  InitTapiDeviceChange
//  RunDetectors
//  LoadPCCardDriver
//  FindPCCardDriver
//  FindActiveBySocket
//  I_DeactivateDevice
//  IsCardInserted
//  PcmciaCallBack
//  InitPCMCIA
//  InitTAPIDevices

//
// Functions from device.c
//
void NotifyFSDs(void);
void WaitForFSDs(void);

//
// Functions from devload.c
//
extern BOOL StartDriver(LPTSTR RegPath, LPTSTR PnpId, DWORD LoadOrder, CARD_SOCKET_HANDLE hSock);
extern BOOL CallTapiDeviceChange(HKEY hActiveKey, LPCTSTR DevName, BOOL bDelete);
extern VOID StartDeviceNotify(LPTSTR DevName, BOOL bNew);
extern HMODULE v_hTapiDLL;

CARD_CLIENT_HANDLE v_hPcmcia;
HANDLE          v_hPcmciaDll;
REGISTERCLIENT  pfnRegisterClient;
GETFIRSTTUPLE   pfnGetFirstTuple;
GETNEXTTUPLE    pfnGetNextTuple;
GETTUPLEDATA    pfnGetTupleData;
GETSTATUS       pfnGetStatus;
SYSTEMPOWER     pfnSystemPower;

BOOL IsCardInserted(CARD_SOCKET_HANDLE hSock);

typedef struct _QUERY_NAME_CONTEXT {
    LPTSTR PnpId;
    UCHAR DevType;
    CARD_SOCKET_HANDLE  hSock;
} QUERY_NAME_CONTEXT, * PQUERY_NAME_CONTEXT;

typedef LPTSTR (*PFN_INSTALL_DRIVER)(LPTSTR, LPTSTR, DWORD);

//
// Thread to query the user for the name of the driver for
// an unrecognized pccard, call its Install_Driver function and
// start it.
// 
DWORD
QueryDriverNameThread(
    IN PVOID ThreadContext
    )
{
    PQUERY_NAME_CONTEXT pContext = (PQUERY_NAME_CONTEXT)ThreadContext;
    HMODULE hInstallDll;
    PFN_INSTALL_DRIVER pfnInstall;
    LPTSTR RegPath = NULL;
    GETDRIVERNAMEPARMS GDNP;

    if (!IsCardInserted(pContext->hSock)) {
        goto qdnt_exit;
    }

    GDNP.PCCardType = (DWORD)pContext->DevType;
    GDNP.Socket = (DWORD)pContext->hSock.uSocket;

    //
    // Get this unrecognized card's device driver name.
    //
    if (!CallGetDriverName(NULL, &GDNP)) {
        DEBUGMSG(ZONE_PCMCIA, (TEXT("DEVICE: CallGetDriverName failed %d\r\n"),
            GetLastError()));
        goto qdnt_exit;
    }

    DEBUGMSG(ZONE_PCMCIA,
        (TEXT("DEVICE: CallGetDriverName returned %s\r\n"), GDNP.DriverName));

    hInstallDll = LoadDriver(GDNP.DriverName);
    if (hInstallDll == NULL) {
        DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
            (TEXT("DEVICE: LoadDriver(%s) failed %d\r\n"),
            GDNP.DriverName, GetLastError()));
        goto qdnt_exit;
    }

    pfnInstall = (PFN_INSTALL_DRIVER)GetProcAddress(hInstallDll,
                     TEXT("Install_Driver"));
    //
    // Tell it to install itself
    //
    if (pfnInstall) {
        RegPath = pfnInstall(
                     pContext->PnpId,
                     GDNP.DriverName,
                     sizeof(GDNP.DriverName));
    }

    //
    // Start it
    //
    if (RegPath) {
        StartDriver(
            RegPath,
            pContext->PnpId,
            MAX_LOAD_ORDER+1,
            pContext->hSock);
    }

    FreeLibrary(hInstallDll);

qdnt_exit:
    LocalFree(pContext->PnpId);
    LocalFree(pContext);
    return 0;
}   // QueryDriverNameThread

//
// Function to start a thread to query the user for the name of the driver for
// an unrecognized pccard.
//
VOID
QueryDriverName(
    LPTSTR PnpId,
    UCHAR DevType,
    CARD_SOCKET_HANDLE hSock
    )
{
    HANDLE hThd;
    LPTSTR pPnpId;
    PQUERY_NAME_CONTEXT pContext;
    DWORD cExtra;

    pContext = LocalAlloc(LPTR, sizeof(QUERY_NAME_CONTEXT));
    if (pContext == NULL) {
        return;
    }

    cExtra = (hSock.uFunction > 0) ? 3 : 1;
    pPnpId = LocalAlloc(LPTR, (_tcslen(PnpId) + cExtra) * sizeof(TCHAR));
    if (pPnpId == NULL) {
        LocalFree(pContext);
        return;
    }

    _tcscpy(pPnpId, PnpId);
    //
    // Additional functions will have a "-n" appended to their PnpId where
    // 'n' is the function number. This is so we can have a PnpId registry
    // entry for each function.
    //
    if (hSock.uFunction > 0) {
        cExtra = _tcslen(pPnpId);
        pPnpId[cExtra]   = (TCHAR) '-';
        pPnpId[cExtra+1] = (TCHAR) '0' + (TCHAR) hSock.uFunction;
        pPnpId[cExtra+2] = (TCHAR) 0;
    }

    pContext->PnpId = pPnpId;
    pContext->DevType = DevType;
    pContext->hSock = hSock;
    hThd = CreateThread(NULL, 0,
                     (LPTHREAD_START_ROUTINE)&QueryDriverNameThread,
                     (LPVOID) pContext, 0, NULL);
    if (hThd != NULL) {
        CloseHandle(hThd);
    } else {
        LocalFree(pPnpId);
        LocalFree(pContext);
    }
}   // QueryDriverName


//
// RunDetectors - Function to call the detection modules under the key 
// HLM\Drivers\PCMCIA\Detect and return the key name under HLM\Drivers\PCMCIA
// for the device driver to load (will be passed to LoadPCCardDriver), or return
// NULL if none of the detection modules recognizes the card.
// The names of the keys under HLM\Drivers\PCMCIA\Detect are actually numbers to
// allow a definite ordering of the detection modules.
//
LPTSTR
RunDetectors(
    CARD_SOCKET_HANDLE hSock,
    UCHAR DevType,
    LPTSTR StrBuf,
    DWORD StrLen
    )
{
    HKEY hDetectKey;
    HKEY hDetectMod;
    PFN_DETECT_ENTRY pfnDetectEntry;
    TCHAR DetectDll[DEVDLL_LEN];
    TCHAR DetectEntry[DEVENTRY_LEN];
    LPTSTR DeviceKey;
    DWORD status;
    DWORD ValLen;
    DWORD ValType;
    DWORD NumDetectKeys;
    DWORD RegEnum;
    DWORD DetectOrder;
    HMODULE hDetectDll;

    status = RegOpenKeyEx(
                HKEY_LOCAL_MACHINE,
                DEVLOAD_DETECT_KEY,
                0,
                0,
                &hDetectKey);
    if (status != ERROR_SUCCESS) {
        DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
            (TEXT("DEVICE!RunDetectors: RegOpenKeyEx(%s) returned %d\r\n"),
            DEVLOAD_DETECT_KEY, status));
        return FALSE;
    }

    //
    // See how many detection modules there are
    //
    RegEnum = sizeof(DetectDll);
    status = RegQueryInfoKey(
                    hDetectKey,
                    DetectDll,      // class name buffer (lpszClass)
                    &RegEnum,       // ptr to length of class name buffer (lpcchClass)
                    NULL,           // reserved
                    &NumDetectKeys, // ptr to number of subkeys (lpcSubKeys)
                    &ValType,       // ptr to longest subkey name length (lpcchMaxSubKeyLen)
                    &ValLen,        // ptr to longest class string length (lpcchMaxClassLen)
                    &DetectOrder,   // ptr to number of value entries (lpcValues)
                    &DetectOrder,   // ptr to longest value name length (lpcchMaxValueNameLen)
                    &ValLen,        // ptr to longest value data length (lpcbMaxValueData)
                    NULL,           // ptr to security descriptor length
                    NULL);          // ptr to last write time
    if (status != ERROR_SUCCESS) {
        DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
            (TEXT("DEVICE!RunDetectors: RegQueryInfoKey() returned %d.\r\n"),
            status));
        goto rd_end;
    }
    DEBUGMSG(ZONE_PCMCIA,
        (TEXT("DEVICE!RunDetectors: %d detection modules\r\n"), NumDetectKeys));


    //
    // Call the detection modules in numeric order.  (The key names are numbers).
    //
    DetectOrder = 0;
    while (NumDetectKeys) {
        //
        // First check if the user yanked the card.
        //
        if (IsCardInserted(hSock) == FALSE) {
            goto rd_end;
        }

        //
        // Find the next detection module
        //
        wsprintf(DetectDll, TEXT("%02d"), DetectOrder); // format key name
        status = RegOpenKeyEx(hDetectKey, DetectDll, 0, 0, &hDetectMod);
        if (status) {
            goto rd_next_detector1;
        }
        NumDetectKeys--;

        //
        // Get the detection module's DLL name
        //
        ValLen = sizeof(DetectDll);
        status = RegQueryValueEx(
                    hDetectMod,
                    DEVLOAD_DLLNAME_VALNAME,
                    NULL,
                    &ValType,
                    (PUCHAR)&DetectDll,
                    &ValLen);
        if (status != ERROR_SUCCESS) {
            DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
                (TEXT("DEVICE!RunDetectors: RegQueryValueEx(%d\\DetectDll) returned %d\r\n"),
                DetectOrder, status));
            goto rd_next_detector;
        }

        //
        // Get the detection module's entrypoint
        //
        ValLen = sizeof(DetectEntry);
        status = RegQueryValueEx(
                    hDetectMod,
                    DEVLOAD_ENTRYPOINT_VALNAME,
                    NULL,
                    &ValType,
                    (PUCHAR)DetectEntry,
                    &ValLen);
        if (status != ERROR_SUCCESS) {
            DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
                (TEXT("DEVICE!RunDetectors: RegQueryValueEx(%d\\DetectEntry) returned %d\r\n"),
                DetectOrder, status));
            goto rd_next_detector;
        }

        //
        // Load the detection module and get the address of its entrypoint
        //
        hDetectDll = LoadDriver(DetectDll);
        if (hDetectDll == NULL) {
            DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
                (TEXT("DEVICE!RunDetectors: LoadLibrary(%s) failed %d\r\n"),
                DetectDll, GetLastError()));
            goto rd_next_detector;
        }

        pfnDetectEntry = (PFN_DETECT_ENTRY) GetProcAddress(hDetectDll, DetectEntry);
        if (pfnDetectEntry == NULL) {
            DEBUGMSG(ZONE_PCMCIA|ZONE_ERROR,
                (TEXT("DEVICE!RunDetectors: GetProcAddr(%s, %s) failed %d\r\n"),
                DetectDll, DetectEntry, GetLastError()));
            FreeLibrary(hDetectDll);
            goto rd_next_detector;
        }

        //
        // Finally, call the detection module's entrypoint
        //
        DEBUGMSG(ZONE_PCMCIA,
            (TEXT("DEVICE!RunDetectors: calling %d:%s:%s\r\n"),
            DetectOrder, DetectDll, DetectEntry));
        __try {
            DeviceKey = (pfnDetectEntry)(hSock, DevType, StrBuf, StrLen);
        } __except (EXCEPTION_EXECUTE_HANDLER) {
            DEBUGMSG(ZONE_PCMCIA,
                (TEXT("DEVICE!RunDetectors: faulted in %s:%s, continuing\r\n"),
                DetectDll, DetectEntry));
            DeviceKey = NULL;
        }
        FreeLibrary(hDetectDll);
        if (DeviceKey) {
            DEBUGMSG(ZONE_PCMCIA,
                (TEXT("DEVICE!RunDetectors: %d:%s:%s returned %s\r\n"),
                DetectOrder, DetectDll, DetectEntry, DeviceKey));
            RegCloseKey(hDetectKey);
            RegCloseKey(hDetectMod);
            return DeviceKey;
        }

rd_next_detector:
        RegCloseKey(hDetectMod);
rd_next_detector1:
        DetectOrder++;
    }

rd_end:
    RegCloseKey(hDetectKey);
    return NULL;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久久久久| 亚洲国产精品久久一线不卡| 久久精品国产99| 欧美一级久久久久久久大片| 亚洲成人免费看| 欧美一级黄色大片| 久99久精品视频免费观看| 精品黑人一区二区三区久久| 国产在线不卡一区| 国产精品人人做人人爽人人添| 成人高清视频在线| 亚洲在线视频免费观看| 欧美美女一区二区三区| 久久99精品国产.久久久久 | 久久精品国产秦先生| 日韩视频免费观看高清在线视频| 国产一区在线精品| 国产精品人妖ts系列视频| 欧美亚洲尤物久久| 久久99国产精品尤物| 欧美国产视频在线| 欧美午夜精品一区二区蜜桃| 美女视频网站黄色亚洲| 欧美激情综合在线| 欧美三级在线播放| 国产精品香蕉一区二区三区| 亚洲色图制服诱惑| 日韩欧美中文字幕精品| 99热99精品| 首页国产丝袜综合| 国产精品久久久久久久久久免费看| 欧洲日韩一区二区三区| 国产一区二区久久| 亚洲国产日韩a在线播放| 久久久久九九视频| 欧美人xxxx| 99久久久无码国产精品| 不卡一区在线观看| 久久精品国产成人一区二区三区| 国产精品免费视频一区| 91精品国模一区二区三区| 暴力调教一区二区三区| 看电影不卡的网站| 亚洲精品国久久99热| 26uuuu精品一区二区| 欧美一a一片一级一片| 国产不卡视频一区| 美女在线观看视频一区二区| 一区二区三区在线视频免费| 国产婷婷一区二区| 日韩精品一区二区三区四区 | 欧美aaaaa成人免费观看视频| 综合中文字幕亚洲| 久久精品免视看| 日韩欧美一二三四区| 欧美午夜精品久久久久久超碰 | 成人国产精品视频| 国产精品自拍毛片| 久久不见久久见免费视频1| 午夜精品国产更新| 亚洲综合在线第一页| 亚洲人成人一区二区在线观看| 国产亚洲午夜高清国产拍精品| 91精品欧美综合在线观看最新 | 成人免费视频一区| 国产在线不卡一卡二卡三卡四卡| 香蕉影视欧美成人| 亚洲国产成人av网| 夜夜嗨av一区二区三区中文字幕| 国产精品久久久久久妇女6080| 久久亚洲免费视频| 欧美xxxxxxxx| 日韩欧美国产电影| 日韩一区二区三| 欧美一卡二卡在线观看| 欧美一区二区成人| 日韩精品中午字幕| 精品欧美乱码久久久久久1区2区| 欧美浪妇xxxx高跟鞋交| 91精品国产福利| 日韩欧美色综合| 欧美精品一区二区蜜臀亚洲| 欧美一区二区成人| 久久男人中文字幕资源站| 久久综合九色综合97婷婷女人| 精品国产一区二区亚洲人成毛片| 精品福利一区二区三区| 日本一区二区三区电影| 国产精品久久久久久久久免费樱桃| 国产精品色噜噜| 亚洲人成伊人成综合网小说| 一区二区三区小说| 日韩福利电影在线| 国产综合久久久久久鬼色 | 91精品国产综合久久久久久久久久| 欧美综合在线视频| 欧美高清视频在线高清观看mv色露露十八 | 国产iv一区二区三区| 波多野结衣在线aⅴ中文字幕不卡| 成人开心网精品视频| 色偷偷一区二区三区| 欧美一区午夜精品| 中文字幕免费观看一区| 亚洲精品自拍动漫在线| 视频一区二区三区在线| 国产成人亚洲综合a∨婷婷图片| a级精品国产片在线观看| 欧美午夜精品久久久久久孕妇| 日韩丝袜情趣美女图片| 中文字幕av资源一区| 亚洲综合999| 极品少妇一区二区三区精品视频| 成人av在线影院| 欧美日韩亚洲丝袜制服| 国产亚洲制服色| 亚洲国产视频一区二区| 国产传媒久久文化传媒| 色88888久久久久久影院野外 | 精品剧情在线观看| 国产精品卡一卡二| 免费欧美高清视频| 色美美综合视频| 26uuu国产电影一区二区| 一区二区三区免费网站| 国产原创一区二区三区| 欧美在线观看视频一区二区| 26uuu亚洲综合色| 亚洲一区二区在线播放相泽| 国产麻豆视频一区二区| 欧美日韩国产三级| 国产精品免费免费| 伦理电影国产精品| 在线视频亚洲一区| 国产欧美日韩视频一区二区| 亚洲v日本v欧美v久久精品| 国产激情一区二区三区四区| 欧美二区三区91| 亚洲丝袜另类动漫二区| 国精产品一区一区三区mba桃花| 精品视频在线看| 亚洲三级电影网站| 国产99久久久国产精品潘金 | 亚洲成人第一页| av电影在线观看一区| 精品国免费一区二区三区| 一区二区高清在线| 99久久国产综合色|国产精品| 久久色在线观看| 蜜桃精品视频在线| 欧美日韩成人一区二区| 一区二区三区精品在线| aaa亚洲精品| 国产精品美女www爽爽爽| 国产精品一区不卡| 亚洲精品在线一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 美女视频网站黄色亚洲| 欧美日韩黄视频| 亚洲尤物视频在线| 91国内精品野花午夜精品| 亚洲欧美日韩国产综合在线| aaa国产一区| 成人免费小视频| 91蜜桃婷婷狠狠久久综合9色| 欧美精彩视频一区二区三区| 精品一区二区三区不卡| 日韩一区二区在线观看视频| 人妖欧美一区二区| 欧美电影免费观看完整版| 全国精品久久少妇| 欧美电视剧在线观看完整版| 免费欧美在线视频| 精品国产一区二区精华| 久久99国产乱子伦精品免费| 精品国产网站在线观看| 狠狠色丁香婷综合久久| 久久久久国产精品人| 成人免费av在线| 亚洲综合色区另类av| 欧美嫩在线观看| 激情综合色播激情啊| 国产欧美中文在线| 91在线小视频| 亚洲va欧美va人人爽| 欧美电视剧免费全集观看| 国产剧情在线观看一区二区| 国产精品高潮呻吟| 91福利视频在线| 麻豆精品一区二区av白丝在线| 精品久久久久久久一区二区蜜臀| 豆国产96在线|亚洲| 一区二区日韩av| 日韩欧美中文一区二区| 国产suv精品一区二区883| 亚洲免费观看高清完整版在线| 欧美日韩黄色一区二区| 激情五月婷婷综合| 亚洲丝袜另类动漫二区| 5月丁香婷婷综合| 丁香一区二区三区|