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

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

?? isrdpc.c

?? plx9054的WDM驅動程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++

Copyright (c) Microsoft Corporation.  All rights reserved.

    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:

    ISRDPC.C

Abstract:

    Contains routine to handle interrupts, interrupt DPCs and WatchDogTimer DPC

Environment:

    Kernel mode


Revision History:

    Eliyas Yakub Feb 13, 2003

--*/

#include "precomp.h"

#if defined(EVENT_TRACING)
#include "ISRDPC.tmh"
#endif

BOOLEAN 
NICInterruptHandler(
    IN PKINTERRUPT  Interupt, 
    IN PVOID        ServiceContext
    )
/*++
Routine Description:

    Interrupt handler for the device.

Arguments:

    Interupt - Address of the KINTERRUPT Object for our device.
    ServiceContext - Pointer to our adapter

Return Value:

     TRUE if our device is interrupting, FALSE otherwise.                                                    

--*/    
{
    BOOLEAN     InterruptRecognized = FALSE;
    PFDO_DATA   FdoData = (PFDO_DATA)ServiceContext;
    USHORT      IntStatus;

    DebugPrint(TRACE, DBG_INTERRUPT, "--> NICInterruptHandler\n");
    
    do 
    {
        //
        // If the adapter is in low power state, then it should not 
        // recognize any interrupt
        // 
        if (FdoData->DevicePowerState > PowerDeviceD0)
        {
            break;
        }
        //
        // We process the interrupt if it's not disabled and it's active                  
        //
        if (!NIC_INTERRUPT_DISABLED(FdoData) && NIC_INTERRUPT_ACTIVE(FdoData))
        {
            InterruptRecognized = TRUE;
        
            //
            // Disable the interrupt (will be re-enabled in NICDpcForIsr
            //
            NICDisableInterrupt(FdoData);
                
            //
            // Acknowledge the interrupt(s) and get the interrupt status
            //

            NIC_ACK_INTERRUPT(FdoData, IntStatus);

            DebugPrint(TRACE, DBG_INTERRUPT, "Requesting DPC\n");

            IoRequestDpc(FdoData->Self, NULL, FdoData);
            
        }
    }while (FALSE);    

    DebugPrint(TRACE, DBG_INTERRUPT, "<-- NICInterruptHandler\n");

    return InterruptRecognized;
}

VOID 
NICDpcForIsr(
    IN PKDPC            Dpc,
    IN PDEVICE_OBJECT   DeviceObject,
    IN PIRP             Irp, //Unused
    IN PVOID            Context
    )

/*++

Routine Description:

    DPC callback for ISR. 

Arguments:

    DeviceObject - Pointer to the device object.

    Context - MiniportAdapterContext.

    Irp - Unused.

    Context - Pointer to FDO_DATA.

Return Value:

--*/
{
    PFDO_DATA fdoData = (PFDO_DATA) Context;

    DebugPrint(TRACE, DBG_DPC, "--> NICDpcForIsr\n");

    KeAcquireSpinLockAtDpcLevel(&fdoData->RcvLock);

    NICHandleRecvInterrupt(fdoData);

    KeReleaseSpinLockFromDpcLevel(&fdoData->RcvLock);

    //
    // Handle send interrupt    
    //
    KeAcquireSpinLockAtDpcLevel(&fdoData->SendLock);

    (VOID)NICHandleSendInterrupt(fdoData);

    KeReleaseSpinLockFromDpcLevel(&fdoData->SendLock);

    //
    // Start the receive unit if it had stopped
    //
    KeAcquireSpinLockAtDpcLevel(&fdoData->RcvLock);

    (VOID)NICStartRecv(fdoData);

    KeReleaseSpinLockFromDpcLevel(&fdoData->RcvLock);
    
    //
    // Re-enable the interrupt (disabled in MPIsr)
    //
    KeSynchronizeExecution(
        fdoData->Interrupt,
        (PKSYNCHRONIZE_ROUTINE)NICEnableInterrupt,
        fdoData);

    DebugPrint(TRACE, DBG_DPC, "<-- NICDpcForIsr\n");

}


VOID 
NICWatchDogTimerDpc(
    IN  PVOID	    SystemSpecific1,
    IN  PVOID	    FunctionContext,
    IN  PVOID	    SystemSpecific2, 
    IN  PVOID	    SystemSpecific3
    )
/*++

Routine Description:
    
    This DPC is used to do both link detection during hardware init and
    after that for hardware hang detection.
    
Arguments:

    SystemSpecific1     Not used
    FunctionContext     Pointer to our FdoData
    SystemSpecific2     Not used
    SystemSpecific3     Not used

Return Value:

    None
    
--*/
{
    PFDO_DATA           FdoData = (PFDO_DATA)FunctionContext;
    LARGE_INTEGER       DueTime;
    NTSTATUS            status = STATUS_SUCCESS;
    
    UNREFERENCED_PARAMETER(SystemSpecific1);
    UNREFERENCED_PARAMETER(SystemSpecific2);
    UNREFERENCED_PARAMETER(SystemSpecific3);

    DueTime.QuadPart = NIC_CHECK_FOR_HANG_DELAY;

    PciDrvIoIncrement(FdoData);

    if(MP_TEST_FLAG(FdoData, fMP_ADAPTER_HALT_IN_PROGRESS)){
        status = STATUS_DEVICE_REMOVED;
        goto Exit;
    }

    //
    // If the device has been power down, we will return without
    // touching the hardware. The timer will be restarted when
    // the device powers up.
    //
    if(FdoData->DevicePowerState == PowerDeviceD0)
    {
        if(!FdoData->CheckForHang){
            //
            // We are still doing link detection
            //            
            status = NICLinkDetection(FdoData);
            if(status == STATUS_PENDING) {
                // Wait for 100 ms   
                FdoData->bLinkDetectionWait = TRUE;
                DueTime.QuadPart = NIC_LINK_DETECTION_DELAY;
            }else {
                FdoData->CheckForHang = TRUE;
            }        
        }else {
            //
            // Link detection is over, let us check to see
            // if the hardware is hung.
            //
            if(NICCheckForHang(FdoData)){
                
                status = NICReset(FdoData);
                if(!NT_SUCCESS(status)){                    
                    goto Exit;
                }
            }
        }

        KeSetTimer( &FdoData->WatchDogTimer,   // Timer
                            DueTime,         // DueTime
                            &FdoData->WatchDogTimerDpc      // Dpc  
                            );           
     } else{
        goto Exit;
     }

     
     PciDrvIoDecrement(FdoData);
     return;
    
Exit:
    PciDrvIoDecrement(FdoData);  
    KeSetEvent(&FdoData->WatchDogTimerEvent, IO_NO_INCREMENT, FALSE);    
    DebugPrint(INFO, DBG_DPC, "WatchDogTimer is exiting %x\n", status);    
    return;
    
}


BOOLEAN 
NICCheckForHang(
    IN  PFDO_DATA     FdoData
    )
/*++

Routine Description:
    
    CheckForHang handler is called in the context of a timer DPC. 
    take advantage of this fact when acquiring/releasing spinlocks
    
Arguments:

    FdoData  Pointer to our adapter

Return Value:

    TRUE    This NIC needs a reset
    FALSE   Everything is fine

--*/
{
    PMP_TCB             pMpTcb;
    
    //
    // Just skip this part if the adapter is doing link detection
    //
    if (MP_TEST_FLAG(FdoData, fMP_ADAPTER_LINK_DETECTION))
    {
        return(FALSE);   
    }

    //
    // any nonrecoverable hardware error?
    //
    if (MP_TEST_FLAG(FdoData, fMP_ADAPTER_NON_RECOVER_ERROR))
    {
        DebugPrint(WARNING, DBG_DPC, "Non recoverable error - remove\n");
        return (TRUE);
    }
            
    //
    // hardware failure?
    //
    if (MP_TEST_FLAG(FdoData, fMP_ADAPTER_HARDWARE_ERROR))
    {
        DebugPrint(WARNING, DBG_DPC, "hardware error - reset\n");
        return(TRUE);
    }
          
    //
    // Is send stuck?                  
    //
    
    KeAcquireSpinLockAtDpcLevel(&FdoData->SendLock);

    if (FdoData->nBusySend > 0)
    {
        pMpTcb = FdoData->CurrSendHead;
        pMpTcb->Count++;
        if (pMpTcb->Count > NIC_SEND_HANG_THRESHOLD)
        {
            KeReleaseSpinLockFromDpcLevel(&FdoData->SendLock);
            DebugPrint(WARNING, DBG_DPC, "Send is stuck - reset\n");
            return(TRUE);
        }
    }
    
    KeReleaseSpinLockFromDpcLevel(&FdoData->SendLock);

    KeAcquireSpinLockAtDpcLevel(&FdoData->RcvLock);

    //
    // Update the RFD shrink count                                          
    //
    if (FdoData->CurrNumRfd > FdoData->NumRfd)
    {
        FdoData->RfdShrinkCount++;          
    }

    KeReleaseSpinLockFromDpcLevel(&FdoData->RcvLock);

    NICIndicateMediaState(FdoData);
    
    return(FALSE);
}

NTSTATUS 
NICReset(
    IN PFDO_DATA FdoData
    )
/*++

Routine Description:
    
    Function to reset the device.
    
Arguments:

    FdoData  Pointer to our adapter


Return Value:

    NT Status code.
    
Note:
    NICReset is called at DPC. Take advantage of this fact 
    when acquiring or releasing spinlocks
    
--*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人欧美一区二区三区在线播放| 欧美日精品一区视频| 北条麻妃一区二区三区| 欧美性色综合网| 精品电影一区二区| **欧美大码日韩| 爽爽淫人综合网网站| 国产精品亚洲视频| 欧美亚洲丝袜传媒另类| 亚洲精品一线二线三线| 一区二区三区日韩精品视频| 伦理电影国产精品| 99久久久久免费精品国产| 777a∨成人精品桃花网| 国产精品三级久久久久三级| 亚洲一区av在线| 国内精品久久久久影院一蜜桃| 91热门视频在线观看| 欧美一级搡bbbb搡bbbb| 亚洲欧美自拍偷拍色图| 久久精品国产第一区二区三区| a在线播放不卡| 精品sm在线观看| 亚洲影视在线观看| 国产高清精品久久久久| 精品视频免费在线| 中文字幕国产一区| 麻豆精品新av中文字幕| 在线日韩国产精品| 国产欧美精品一区| 美美哒免费高清在线观看视频一区二区 | 亚洲专区一二三| 国产成人精品免费视频网站| 在线不卡一区二区| 亚洲一级二级三级在线免费观看| 国产精品一二三| 日韩女优视频免费观看| 亚洲一区日韩精品中文字幕| 成人a级免费电影| 精品处破学生在线二十三| 亚洲一区二区三区不卡国产欧美| 丁香婷婷综合激情五月色| 日韩一区二区在线看| 一区二区三区在线不卡| bt7086福利一区国产| 久久久久国色av免费看影院| 日本女人一区二区三区| 欧美四级电影在线观看| 亚洲欧美一区二区不卡| 国产成人8x视频一区二区| 欧美精品一区男女天堂| 青青青伊人色综合久久| 7777精品伊人久久久大香线蕉| 一区二区三区在线影院| 99久久综合精品| 国产精品久久久久一区| 国产高清不卡一区二区| 日韩精品一区二区三区视频在线观看 | 国产一区二区美女诱惑| 欧美一激情一区二区三区| 亚洲综合自拍偷拍| 91久久免费观看| 夜夜操天天操亚洲| 在线观看日韩电影| 一区二区三区加勒比av| 色综合久久88色综合天天| 中文字幕亚洲一区二区av在线 | 中文字幕一区二区在线播放| 国产成人精品免费| 欧美国产日韩在线观看| 国产成人av电影在线| 日本一区二区三区免费乱视频| 国产一区二区三区久久久| 久久久久久久久久久久久女国产乱| 国产毛片一区二区| 亚洲国产电影在线观看| 99久久精品免费观看| 亚洲乱码日产精品bd| 在线视频观看一区| 视频一区视频二区中文字幕| 538在线一区二区精品国产| 美女www一区二区| 国产无一区二区| 丁香天五香天堂综合| 日韩一区在线免费观看| 在线观看亚洲一区| 视频一区欧美日韩| 亚洲精品一区二区三区四区高清| 国产乱子伦一区二区三区国色天香 | 亚洲一区二区三区四区的| 欧美日韩国产不卡| 久久aⅴ国产欧美74aaa| 国产女人18毛片水真多成人如厕| 成人黄色777网| 亚洲一级二级三级在线免费观看| 欧美电影在线免费观看| 久久国产精品72免费观看| 国产一区二区在线影院| 1000精品久久久久久久久| 欧美午夜精品久久久久久超碰| 五月激情六月综合| 欧美精品一区二区三区视频| 国产99久久久精品| 亚洲人妖av一区二区| 欧美猛男gaygay网站| 国产一区二区在线视频| 国产精品 欧美精品| 国产精品久久久久久久久动漫| 在线观看日韩毛片| 黄色日韩网站视频| ...中文天堂在线一区| 91精品国产综合久久蜜臀| 国产九色sp调教91| 亚洲欧美日本在线| 日韩一级二级三级| 99精品欧美一区二区蜜桃免费| 香蕉成人啪国产精品视频综合网| 26uuu亚洲综合色| 在线影视一区二区三区| 国产一区二区调教| 亚洲欧美国产77777| 欧美mv和日韩mv国产网站| 99精品热视频| 精品在线视频一区| 一区二区三区在线观看动漫 | 国产一区二区福利视频| 亚洲精品视频一区| 26uuu欧美| 欧洲精品视频在线观看| 成人黄色电影在线| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 看国产成人h片视频| 亚洲人成影院在线观看| 精品久久久久99| 欧美伊人久久久久久久久影院| 国产精品一区久久久久| 无吗不卡中文字幕| 国产精品第五页| 2020国产精品自拍| 欧美日韩国产精品成人| aaa欧美色吧激情视频| 久久66热re国产| 性久久久久久久| 亚洲三级在线看| 久久久久久久网| 日韩一区二区高清| 欧美性色黄大片| 91在线观看视频| 国产91清纯白嫩初高中在线观看| 日本不卡一区二区三区高清视频| 亚洲色图一区二区三区| 国产欧美精品区一区二区三区| 欧美zozo另类异族| 91精品国产福利| 欧美日韩一卡二卡| 欧美在线观看一区二区| 不卡av在线免费观看| 国产麻豆9l精品三级站| 九九在线精品视频| 裸体一区二区三区| 日韩国产精品91| 婷婷综合久久一区二区三区| 亚洲黄色在线视频| 樱花影视一区二区| 亚洲欧美韩国综合色| 国产精品超碰97尤物18| 国产精品少妇自拍| 国产欧美一区二区精品久导航| 精品国产sm最大网站免费看| 欧美一区二区福利在线| 欧美一区二区三区人| 91精品国产综合久久小美女| 欧美久久久久久蜜桃| 欧美日本一区二区在线观看| 欧美日韩一级黄| 欧美日韩精品一区二区在线播放| 欧美主播一区二区三区美女| 色狠狠色狠狠综合| 欧美性色黄大片手机版| 欧美亚洲一区二区三区四区| 欧美性xxxxxxxx| 欧美久久久久久久久中文字幕| 欧美日韩久久久一区| 在线电影院国产精品| 在线电影国产精品| 日韩精品中文字幕一区| 欧美精品一区二区三区在线| 久久一二三国产| 国产精品沙发午睡系列990531| 国产精品乱码一区二三区小蝌蚪| 中文字幕乱码亚洲精品一区| 中文字幕一区二区三区不卡| 亚洲欧美激情插| 亚洲国产精品一区二区www在线| 亚洲成人自拍偷拍| 麻豆成人久久精品二区三区红| 九九精品一区二区| 福利一区二区在线观看| 99久久国产综合精品女不卡 | 亚洲一区二区欧美日韩|