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

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

?? 2440_ohci.c

?? 基于s3c2440A的wince5.0 USBHCD
?? C
?? 第 1 頁 / 共 2 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:  
    system.c
    
Abstract:  
    Device dependant part of the USB Universal Host Controller Driver (OHCD).

Notes: 
--*/
#include <windows.h>
#include <ceddk.h>
#include <ddkreg.h>
#include <hcdddsi.h>

#define REG_PHYSICAL_PAGE_SIZE TEXT("PhysicalPageSize")
// Amount of memory to use for HCD buffer
static const DWORD gcTotalAvailablePhysicalMemory = 65536; // 64K
static const DWORD gcHighPriorityPhysicalMemory = 0x4000; // 16K


typedef struct _SOhcdPdd
{
    LPVOID lpvMemoryObject;
    LPVOID lpvOhcdMddObject;
    PVOID pvVirtualAddress;                        // DMA buffers as seen by the CPU
    DWORD dwPhysicalMemSize;
    PHYSICAL_ADDRESS LogicalAddress;        // DMA buffers as seen by the DMA controller and bus interfaces
    DMA_ADAPTER_OBJECT AdapterObject;
    TCHAR szDriverRegKey[MAX_PATH];
    PUCHAR ioPortBase;
    DWORD dwSysIntr;
    CRITICAL_SECTION csPdd;                     // serializes access to the PDD object
    HANDLE IsrHandle;
    HANDLE hParentBusHandle;
} SOhcdPdd;

#define UnusedParameter(x)  x = x

/* HcdPdd_DllMain
 * 
 *  DLL Entry point.
 *
 * Return Value:
 */
extern BOOL HcdPdd_DllMain(HANDLE hinstDLL, DWORD dwReason, LPVOID lpvReserved)
{
    UnusedParameter(hinstDLL);
    UnusedParameter(dwReason);
    UnusedParameter(lpvReserved);

    return TRUE;
}

static BOOL
GetRegistryPhysicalMemSize(
    LPCWSTR RegKeyPath,         // IN - driver registry key path
    DWORD * lpdwPhyscialMemSize)       // OUT - base address
{
    HKEY hKey;
    DWORD dwData;
    DWORD dwSize;
    DWORD dwType;
    BOOL  fRet=FALSE;
    DWORD dwRet;
    // Open key
    dwRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,RegKeyPath,0,0,&hKey);
    if (dwRet != ERROR_SUCCESS) {
        DEBUGMSG(ZONE_ERROR,(TEXT("!UHCD:GetRegistryConfig RegOpenKeyEx(%s) failed %d\r\n"),
                             RegKeyPath, dwRet));
        return FALSE;
    }

    // Read base address, range from registry and determine IOSpace
    dwSize = sizeof(dwData);
    dwRet = RegQueryValueEx(hKey, REG_PHYSICAL_PAGE_SIZE, 0, &dwType, (PUCHAR)&dwData, &dwSize);
    if (dwRet == ERROR_SUCCESS) {
        if (lpdwPhyscialMemSize)
            *lpdwPhyscialMemSize = dwData;
        fRet=TRUE;
    }
    RegCloseKey(hKey);
    return fRet;
}


/* ConfigureOHCICard
 * 
 */
BOOL
ConfigureOHCICard(
    SOhcdPdd * pPddObject, // IN - contains PDD reference pointer.
    PUCHAR *pioPortBase,   // IN - contains physical address of register base
                           // OUT- contains virtual address of register base
    DWORD dwAddrLen,
    DWORD dwIOSpace,
    INTERFACE_TYPE IfcType,
    DWORD dwBusNumber
    )
{
    ULONG               inIoSpace = dwIOSpace;
    ULONG               portBase;
    PHYSICAL_ADDRESS    ioPhysicalBase = {0, 0};
    
    portBase = (ULONG)*pioPortBase;
    ioPhysicalBase.LowPart = portBase;

    if (!BusTransBusAddrToVirtual(pPddObject->hParentBusHandle, IfcType, dwBusNumber, ioPhysicalBase, dwAddrLen, &inIoSpace, (PPVOID)pioPortBase)) {
        DEBUGMSG(ZONE_ERROR, (L"OHCD: Failed TransBusAddrToVirtual\r\n"));
        return FALSE;
    }

    DEBUGMSG(ZONE_INIT, 
             (TEXT("OHCD: ioPhysicalBase 0x%X, IoSpace 0x%X\r\n"),
              ioPhysicalBase.LowPart, inIoSpace));
    DEBUGMSG(ZONE_INIT, 
             (TEXT("OHCD: ioPortBase 0x%X, portBase 0x%X\r\n"),
              *pioPortBase, portBase));

    return TRUE;
}


/* InitializeOHCI
 *
 *  Configure and initialize OHCI card
 *
 * Return Value:
 *  Return TRUE if card could be located and configured, otherwise FALSE
 */
static BOOL 
InitializeOHCI(
    SOhcdPdd * pPddObject,    // IN - Pointer to PDD structure
    LPCWSTR szDriverRegKey)   // IN - Pointer to active registry key string
{
    PUCHAR ioPortBase = NULL;
    DWORD dwAddrLen;
    DWORD dwIOSpace;
    BOOL InstallIsr = FALSE;
    BOOL fResult = FALSE;
    LPVOID pobMem = NULL;
    LPVOID pobOhcd = NULL;
    DWORD PhysAddr;
    DWORD dwHPPhysicalMemSize;
    HKEY hKey=NULL;

    DDKWINDOWINFO dwi;
    DDKISRINFO dii;

    if (RegOpenKeyEx(HKEY_LOCAL_MACHINE,szDriverRegKey,0,0,&hKey)!= ERROR_SUCCESS) {
        DEBUGMSG(ZONE_ERROR,(TEXT("InitializeOHCI:GetRegistryConfig RegOpenKeyEx(%s) failed\r\n"),
                             szDriverRegKey));
        return FALSE;
    }
    dwi.cbSize=sizeof(dwi);
    dii.cbSize=sizeof(dii);
    if ( DDKReg_GetWindowInfo(hKey, &dwi ) !=ERROR_SUCCESS || DDKReg_GetIsrInfo (hKey, &dii ) != ERROR_SUCCESS) {
        DEBUGMSG(ZONE_ERROR,(TEXT("InitializeOHCI:DDKReg_GetWindowInfo or  DDKReg_GetWindowInfo failed\r\n")));
        goto InitializeOHCI_Error;
    }
    if (dwi.dwNumMemWindows!=0) {
        PhysAddr = dwi.memWindows[0].dwBase;
        dwAddrLen= dwi.memWindows[0].dwLen;
        dwIOSpace = 0;
    }
    else if (dwi.dwNumIoWindows!=0) {
        PhysAddr= dwi.ioWindows[0].dwBase;
        dwAddrLen = dwi.ioWindows[0].dwLen;
        dwIOSpace = 1;
    }
    else
        goto InitializeOHCI_Error;
        
    DEBUGMSG(ZONE_INIT,(TEXT("OHCD: Read config from registry: Base Address: 0x%X, Length: 0x%X, I/O Port: %s, SysIntr: 0x%X, Interface Type: %u, Bus Number: %u\r\n"),
                    PhysAddr, dwAddrLen, dwIOSpace ? L"YES" : L"NO", dii.dwSysintr, dwi.dwInterfaceType, dwi.dwBusNumber));
    
    ioPortBase = (PBYTE) PhysAddr;
    
    if (!(fResult = ConfigureOHCICard(pPddObject, &ioPortBase, dwAddrLen, dwIOSpace,dwi.dwInterfaceType, dwi.dwBusNumber))) {
        goto InitializeOHCI_Error;
    }    
    if (dii.szIsrDll[0] != 0 && dii.szIsrHandler[0]!=0 && dii.dwIrq<0xff && dii.dwIrq>0 ) {
        // Install ISR handler
        pPddObject->IsrHandle = LoadIntChainHandler(dii.szIsrDll, dii.szIsrHandler, (BYTE)dii.dwIrq);

        if (!pPddObject->IsrHandle) {
            DEBUGMSG(ZONE_ERROR, (L"OHCD: Couldn't install ISR handler\r\n"));
        } else {
            GIISR_INFO Info;
            PHYSICAL_ADDRESS PortAddress = {PhysAddr, 0};
            
            DEBUGMSG(ZONE_INIT, (L"OHCD: Installed ISR handler, Dll = '%s', Handler = '%s', Irq = %d\r\n",
                dii.szIsrDll, dii.szIsrHandler, dii.dwIrq));
            
            if (!BusTransBusAddrToStatic(pPddObject->hParentBusHandle,dwi.dwInterfaceType, dwi.dwBusNumber, PortAddress, dwAddrLen, &dwIOSpace, &(PVOID)PhysAddr)) {
                DEBUGMSG(ZONE_ERROR, (L"OHCD: Failed TransBusAddrToStatic\r\n"));
                goto InitializeOHCI_Error;
            }
        
            // Set up ISR handler
            Info.SysIntr = dii.dwSysintr;
            Info.CheckPort = TRUE;
            Info.PortIsIO = (dwIOSpace) ? TRUE : FALSE;
            Info.UseMaskReg = TRUE;
            Info.PortAddr = PhysAddr + 0x0C;
            Info.PortSize = sizeof(DWORD);
            Info.MaskAddr = PhysAddr + 0x10;
            
            if (!KernelLibIoControl(pPddObject->IsrHandle, IOCTL_GIISR_INFO, &Info, sizeof(Info), NULL, 0, NULL)) {
                DEBUGMSG(ZONE_ERROR, (L"OHCD: KernelLibIoControl call failed.\r\n"));
            }
        }
    }
    // The PDD can supply a buffer of contiguous physical memory here, or can let the 
    // MDD try to allocate the memory from system RAM.  We will use the HalAllocateCommonBuffer()
    // API to allocate the memory and bus controller physical addresses and pass this information
    // into the MDD.
    if (GetRegistryPhysicalMemSize(szDriverRegKey,&pPddObject->dwPhysicalMemSize)) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日夜夜一区二区| 国产乱码一区二区三区| 免费成人在线视频观看| 成人a级免费电影| 9191国产精品| 亚洲欧美另类久久久精品| 久久91精品久久久久久秒播| 在线观看一区日韩| 国产精品第13页| 国内精品写真在线观看| 欧美精品三级在线观看| 国产精品国产馆在线真实露脸| 免费成人小视频| 欧美日韩精品一区二区三区| 综合久久国产九一剧情麻豆| 粉嫩av亚洲一区二区图片| 日韩视频不卡中文| 日韩成人午夜精品| 欧美日本一道本| 亚洲不卡一区二区三区| 色综合久久88色综合天天免费| 久久久.com| 国产精品一区二区三区网站| 日韩精品影音先锋| 免费观看久久久4p| 精品奇米国产一区二区三区| 丝袜美腿亚洲色图| 91麻豆精品国产| 奇米影视一区二区三区| 777色狠狠一区二区三区| 亚洲午夜三级在线| 欧美色偷偷大香| 亚洲成av人片在线| 91精品国产入口在线| 日韩国产在线观看| 欧美一区2区视频在线观看| 欧美aa在线视频| 欧美成人伊人久久综合网| 美女视频一区二区| 久久无码av三级| 国产成人在线影院| 国产亚洲人成网站| 91视频免费播放| 一区二区三区欧美久久| 欧美久久久影院| 裸体在线国模精品偷拍| 精品91自产拍在线观看一区| 国产丶欧美丶日本不卡视频| 国产亚洲美州欧州综合国| 成人精品国产福利| 一区二区三区在线观看网站| 欧美色综合久久| 久久国产精品99精品国产| 国产丝袜欧美中文另类| 色婷婷综合久久久久中文一区二区| 一区二区三区中文字幕在线观看| 欧美色大人视频| 国产一区二区三区电影在线观看 | 九色综合狠狠综合久久| 久久精品人人做人人爽人人| 波多野结衣91| 午夜私人影院久久久久| 久久蜜桃av一区二区天堂| 色综合色综合色综合色综合色综合 | 一二三区精品视频| 精品欧美一区二区三区精品久久| 国产高清久久久久| 亚洲一区二区三区国产| 精品99999| 欧美日韩国产另类不卡| 国产精品亚洲а∨天堂免在线| 亚洲裸体xxx| 日韩视频一区二区在线观看| 91在线视频播放| 久久国产精品99精品国产| 亚洲另类在线一区| 精品伦理精品一区| 欧美日韩和欧美的一区二区| 国产精品18久久久久| 午夜精品久久久久久| 中文字幕欧美三区| 日韩欧美激情在线| 在线观看一区日韩| www.亚洲在线| 国产在线看一区| 日韩av在线播放中文字幕| 亚洲欧美综合网| 久久久亚洲欧洲日产国码αv| 欧美视频一区在线| 95精品视频在线| 国产自产高清不卡| 免费高清在线视频一区·| 亚洲一区欧美一区| 综合久久国产九一剧情麻豆| 精品国产乱码久久| 日韩亚洲电影在线| 欧美一区二区三区免费大片| 欧美亚洲动漫另类| 99re热视频精品| 成人avav在线| 国产69精品久久777的优势| 精品中文av资源站在线观看| 日日夜夜免费精品视频| 午夜精品久久久| 亚洲成年人网站在线观看| 亚洲精品写真福利| 最新欧美精品一区二区三区| 久久一二三国产| 欧美mv日韩mv国产网站app| 69堂成人精品免费视频| 欧美日韩在线电影| 欧美日韩久久一区二区| 欧美性大战久久久久久久蜜臀 | 国产精品一线二线三线精华| 麻豆国产一区二区| 精品一区精品二区高清| 久久精品国产亚洲aⅴ | 亚洲va欧美va国产va天堂影院| 综合网在线视频| 亚洲精品国产品国语在线app| 亚洲日本韩国一区| 亚洲美女少妇撒尿| 偷窥国产亚洲免费视频| 日韩电影在线免费看| 免费的成人av| 国内精品在线播放| 成人av网址在线| 欧美性xxxxxxxx| 日韩一区二区免费在线观看| 欧美大片在线观看一区| 国产夜色精品一区二区av| 国产精品系列在线| 亚洲女同一区二区| 亚洲福利视频导航| 久久99国产精品麻豆| 成人激情午夜影院| 欧美视频三区在线播放| 精品电影一区二区三区| 中文字幕久久午夜不卡| 亚洲日本韩国一区| 久久国产麻豆精品| a级高清视频欧美日韩| 欧美剧情电影在线观看完整版免费励志电影| 欧美一级精品大片| 国产精品美女久久久久aⅴ | 韩国三级中文字幕hd久久精品| 国产精品亚洲视频| 欧美亚洲国产bt| 久久久国产精华| 亚洲18女电影在线观看| 久久99精品一区二区三区三区| 国产91在线看| 欧美三级一区二区| 欧美激情一区二区三区| 天堂成人免费av电影一区| 粉嫩嫩av羞羞动漫久久久| av综合在线播放| 91国内精品野花午夜精品| 欧美一区二区三区人| 亚洲视频一二区| 韩国欧美国产一区| 91福利视频网站| 国产亚洲欧美中文| 日本系列欧美系列| 91精品办公室少妇高潮对白| 精品成人a区在线观看| 亚洲国产一区二区视频| 国产成人丝袜美腿| 欧美成人在线直播| 性做久久久久久免费观看| 成人黄色国产精品网站大全在线免费观看| 欧美色欧美亚洲另类二区| 国产精品国产精品国产专区不蜜| 全国精品久久少妇| 欧美性猛交一区二区三区精品| 国产欧美日韩卡一| 国内久久婷婷综合| 日韩欧美一区在线观看| 香蕉久久一区二区不卡无毒影院| 成人国产电影网| 国产亚洲欧美色| 国产乱理伦片在线观看夜一区| 91精品国产综合久久久久久漫画| 亚洲精品国久久99热| 97精品国产露脸对白| 欧美国产精品劲爆| 高清不卡在线观看| 久久久久久毛片| 国产一区二区日韩精品| 欧美成人女星排名| 日韩影院免费视频| 91精品国产91综合久久蜜臀| 亚洲国产视频直播| 欧美日韩久久久一区| 亚洲v中文字幕| 欧美一区日本一区韩国一区| 天堂一区二区在线| 日韩一区二区免费在线电影| 日韩成人dvd| 欧美大尺度电影在线|