亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧美日韩国产系列| 一区二区三区中文字幕电影| 正在播放亚洲一区| 3751色影院一区二区三区| 欧美吻胸吃奶大尺度电影| 欧美性猛交一区二区三区精品| 91免费视频网| 91精品办公室少妇高潮对白| 91国产福利在线| 在线观看日韩高清av| 91久久精品网| 欧美放荡的少妇| 91精品国产欧美一区二区成人| 777xxx欧美| 日韩一区二区高清| 精品黑人一区二区三区久久| 久久丝袜美腿综合| 国产欧美日本一区二区三区| 国产精品激情偷乱一区二区∴| 1000部国产精品成人观看| 亚洲免费在线看| 亚洲高清视频中文字幕| 日韩电影在线免费看| 麻豆成人综合网| 国产成人99久久亚洲综合精品| av电影在线观看一区| 欧美色成人综合| 精品欧美久久久| 久久精品人人做人人爽97| 国产精品久久一卡二卡| 一区二区在线电影| 午夜久久久久久久久| 国产一区二区三区黄视频| 成年人午夜久久久| 欧美色偷偷大香| 精品1区2区在线观看| 中文字幕一区二区三| 亚洲成a天堂v人片| 国产一区在线观看视频| 99精品视频一区| 欧美精品在欧美一区二区少妇| 精品国产一区二区在线观看| 国产精品久久久久aaaa| 性欧美疯狂xxxxbbbb| 国产精品香蕉一区二区三区| 色丁香久综合在线久综合在线观看| 91精品国产综合久久久久久久| 久久久777精品电影网影网 | 欧美国产综合色视频| 亚洲精品中文在线影院| 久久电影网站中文字幕| 99re视频这里只有精品| 日韩欧美中文字幕一区| 国产精品你懂的在线欣赏| 石原莉奈在线亚洲二区| 国产成+人+日韩+欧美+亚洲| 欧美亚洲一区三区| 久久久久久久免费视频了| 夜夜嗨av一区二区三区中文字幕| 精品亚洲成av人在线观看| 色欧美乱欧美15图片| 精品国产乱码久久久久久久久 | 成人永久看片免费视频天堂| 欧美日韩在线一区二区| 欧美国产日韩精品免费观看| 日日欢夜夜爽一区| 99国产精品久| 久久综合中文字幕| 午夜电影网亚洲视频| aaa亚洲精品| 久久久久亚洲综合| 日本va欧美va欧美va精品| 99在线精品观看| 久久久精品免费网站| 蜜桃久久久久久久| 欧美猛男男办公室激情| 综合av第一页| 高清不卡一二三区| 日韩精品在线看片z| 亚洲福利视频一区二区| 91影院在线免费观看| 国产视频在线观看一区二区三区| 奇米在线7777在线精品| 欧美日韩免费一区二区三区| 日韩码欧中文字| 成人av在线电影| 2022国产精品视频| 久久99精品视频| 日韩一级完整毛片| 日韩精品电影在线观看| 欧美性感一区二区三区| 樱桃视频在线观看一区| 91日韩精品一区| 最新不卡av在线| k8久久久一区二区三区| 中文字幕免费不卡| 国产mv日韩mv欧美| 国产片一区二区| 国产69精品久久777的优势| 2020国产成人综合网| 国精产品一区一区三区mba视频| 日韩欧美二区三区| 久久精品99国产精品| 欧美大黄免费观看| 国内精品免费**视频| 精品国产sm最大网站| 国内精品不卡在线| 久久综合久色欧美综合狠狠| 国产一二三精品| 欧美精品一区二| 国产精品羞羞答答xxdd| 国产婷婷色一区二区三区在线| 国产一区二区在线免费观看| 久久久久久久久久久黄色| 国产在线精品一区二区不卡了| 精品国产免费视频| 国产a区久久久| 亚洲国产精品二十页| 色综合天天综合在线视频| 亚洲一区在线免费观看| 777久久久精品| 欧美美女视频在线观看| 精品婷婷伊人一区三区三| 日韩av成人高清| 久久综合精品国产一区二区三区| 国产成人在线视频网站| 国产精品护士白丝一区av| 欧美色手机在线观看| 卡一卡二国产精品| 欧美国产一区视频在线观看| 91麻豆免费看片| 日本在线观看不卡视频| 久久久99精品久久| 色视频成人在线观看免| 日韩电影免费在线| 久久嫩草精品久久久精品一| 9l国产精品久久久久麻豆| 亚洲图片一区二区| 精品国产制服丝袜高跟| 99精品久久99久久久久| 亚洲已满18点击进入久久| 欧美一级二级在线观看| 粉嫩嫩av羞羞动漫久久久 | 一区二区在线电影| 欧美一区二区国产| 成人网在线免费视频| 亚洲高清免费在线| 国产日韩欧美高清在线| 欧美日韩中文精品| 国产盗摄一区二区| 亚洲成人一区二区| 欧美国产日本韩| 欧美久久久一区| 成人h动漫精品一区二区| 日本v片在线高清不卡在线观看| 国产三级精品三级| 91精品国产手机| 99re在线视频这里只有精品| 久久精品国产亚洲aⅴ| 一区在线观看免费| 日韩欧美一级二级三级| 95精品视频在线| 国产一区二三区| 午夜精品一区二区三区电影天堂 | 欧美精选一区二区| av在线一区二区| 久久99精品国产.久久久久久| 亚洲免费观看视频| 国产色综合久久| 欧美一区二区在线视频| 99国产麻豆精品| 国产麻豆9l精品三级站| 日韩福利视频网| 亚洲高清久久久| 亚洲美女在线国产| 国产精品久久久久影视| 欧美xxx久久| 678五月天丁香亚洲综合网| 北条麻妃国产九九精品视频| 国产一区二区三区日韩 | 欧美男女性生活在线直播观看| 国产激情精品久久久第一区二区| 日欧美一区二区| 亚洲一区二区四区蜜桃| 国产精品高潮久久久久无| 2021久久国产精品不只是精品| 欧美另类z0zxhd电影| 91麻豆成人久久精品二区三区| 国产精品一级片在线观看| 久久精品国产精品亚洲精品| 午夜一区二区三区视频| 一级中文字幕一区二区| 亚洲天堂中文字幕| 国产精品久久久久久久久免费桃花| 欧美成人女星排名| 日韩欧美在线一区二区三区| 制服丝袜国产精品| 欧美日韩一区二区三区四区 | 亚洲男帅同性gay1069| 国产精品国产自产拍在线|