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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? plxinterrupt.c

?? PCI接口產(chǎn)品中橋芯片PLX6000、PLX8000、PLX9000和PLXsrv驅(qū)動模塊源碼
?? C
字號:
/*******************************************************************************
 * Copyright (c) 2007 PLX Technology, Inc.
 *
 * PLX Technology Inc. licenses this software under specific terms and
 * conditions.  Use of any of the software or derviatives thereof in any
 * product without a PLX Technology chip is strictly prohibited.
 *
 * PLX Technology, Inc. provides this software AS IS, WITHOUT ANY WARRANTY,
 * EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY WARRANTY OF
 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  PLX makes no guarantee
 * or representations regarding the use of, or the results of the use of,
 * the software and documentation in terms of correctness, accuracy,
 * reliability, currentness, or otherwise; and you rely on the software,
 * documentation and results solely at your own risk.
 *
 * IN NO EVENT SHALL PLX BE LIABLE FOR ANY LOSS OF USE, LOSS OF BUSINESS,
 * LOSS OF PROFITS, INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES
 * OF ANY KIND.  IN NO EVENT SHALL PLX'S TOTAL LIABILITY EXCEED THE SUM
 * PAID TO PLX FOR THE PRODUCT LICENSED HEREUNDER.
 *
 ******************************************************************************/

/******************************************************************************
 *
 * File Name:
 *
 *      PlxInterrupt.c
 *
 * Description:
 *
 *      This file handles interrupts for the PLX device
 *
 * Revision History:
 *
 *      01-01-07 : PLX SDK v5.00
 *
 ******************************************************************************/


#include "PlxChipFn.h"
#include "PlxInterrupt.h"
#include "SupportFunc.h"




/******************************************************************************
 *
 * Function   :  OnInterrupt
 *
 * Description:  The Interrupt Service Routine for the PLX device
 *
 ******************************************************************************/
BOOLEAN
OnInterrupt(
    PKINTERRUPT pInterrupt,
    PVOID       ServiceContext
    )
{
    U32               RegPciInt;
    U32               InterruptSource;
    DEVICE_EXTENSION *pdx;


    // Get the device extension
    pdx = (DEVICE_EXTENSION *)ServiceContext;

    // Read interrupt status register
    RegPciInt =
        PLX_9000_REG_READ(
            pdx,
            PCI9030_INT_CTRL_STAT
            );

    /****************************************************
     * If the chip is in a low power state, then local
     * register reads are disabled and will always return
     * 0xFFFFFFFF.  If the PLX chip's interrupt is shared
     * with another PCI device, the PXL ISR may continue
     * to be called.  This case is handled to avoid
     * erroneous reporting of an active interrupt.
     ***************************************************/
    if (RegPciInt == 0xFFFFFFFF)
        return FALSE;

    // Check for master PCI interrupt enable
    if ((RegPciInt & (1 << 6)) == 0)
        return FALSE;

    // Verify that an interrupt is truly active

    // Clear the interrupt type flag
    InterruptSource = INTR_TYPE_NONE;

    // Check if Local Interrupt 1 is active and not masked
    if ((RegPciInt & (1 << 2)) && (RegPciInt & (1 << 0)))
    {
        InterruptSource |= INTR_TYPE_LOCAL_1;
    }

    // Check if Local Interrupt 2 is active and not masked
    if ((RegPciInt & (1 << 5)) && (RegPciInt & (1 << 3)))
    {
        InterruptSource |= INTR_TYPE_LOCAL_2;
    }

    // Software Interrupt
    if (RegPciInt & (1 << 7))
    {
        InterruptSource |= INTR_TYPE_SOFTWARE;
    }

    // Return if no interrupts are active
    if (InterruptSource == INTR_TYPE_NONE)
        return FALSE;

    // At this point, the device interrupt is verified

    // Mask the PCI Interrupt
    PLX_9000_REG_WRITE(
        pdx,
        PCI9030_INT_CTRL_STAT,
        RegPciInt & ~(1 << 6)
        );

    //
    // Schedule deferred procedure (DPC) to complete interrupt processing
    //

    KeInsertQueueDpc(
        &(pdx->DpcForIsr),
        (VOID *)(PLX_UINT_PTR)InterruptSource,
        NULL
        );

    return TRUE;
}




/******************************************************************************
 *
 * Function   :  DpcForIsr
 *
 * Description:  This routine will be triggered by the ISR to service an interrupt
 *
 ******************************************************************************/
VOID
DpcForIsr(
    PKDPC pDpc,
    PVOID pContext,
    PVOID pArg1,
    PVOID pArg2
    )
{
    U32                 RegValue;
    PLX_REG_DATA        RegData;
    DEVICE_EXTENSION   *pdx;
    PLX_INTERRUPT_DATA  IntData;


    // Get the device extension
    pdx = (DEVICE_EXTENSION *)pContext;

    // Get interrupt source
    IntData.Source_Ints     = PtrToUlong(pArg1);
    IntData.Source_Doorbell = 0;

    KeAcquireSpinLockAtDpcLevel(
        &(pdx->Lock_HwAccess)
        );

    // Local Interrupt 1
    if (IntData.Source_Ints & INTR_TYPE_LOCAL_1)
    {
        // Setup to synchronize access to Interrupt Control/Status Register
        RegData.pdx         = pdx;
        RegData.offset      = PCI9030_INT_CTRL_STAT;
        RegData.BitsToSet   = 0;
        RegData.BitsToClear = 0;

        // Check if this is an edge-triggered interrupt
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9030_INT_CTRL_STAT
                );

        if ((RegValue & (1 << 1)) && (RegValue & (1 << 8)))
        {
            // Clear edge-triggered interrupt
            RegData.BitsToSet = (1 << 10);

            KeSynchronizeExecution(
                pdx->pInterruptObject,
                PlxSynchronizedRegisterModify,
                (VOID *)&RegData
                );
        }
        else
        {
            // Mask Local Interrupt 1
            RegData.BitsToClear = (1 << 0);

            KeSynchronizeExecution(
                pdx->pInterruptObject,
                PlxSynchronizedRegisterModify,
                (VOID *)&RegData
                );
        }
    }

    // Local Interrupt 2
    if (IntData.Source_Ints & INTR_TYPE_LOCAL_2)
    {
        // Setup to synchronize access to Interrupt Control/Status Register
        RegData.pdx         = pdx;
        RegData.offset      = PCI9030_INT_CTRL_STAT;
        RegData.BitsToSet   = 0;
        RegData.BitsToClear = 0;

        // Check if this is an edge-triggered interrupt
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9030_INT_CTRL_STAT
                );

        if ((RegValue & (1 << 4)) && (RegValue & (1 << 9)))
        {
            // Clear edge-triggered interrupt
            RegData.BitsToSet = (1 << 11);

            KeSynchronizeExecution(
                pdx->pInterruptObject,
                PlxSynchronizedRegisterModify,
                (VOID *)&RegData
                );
        }
        else
        {
            // Mask Local Interrupt 2
            RegData.BitsToClear = (1 << 3);

            KeSynchronizeExecution(
                pdx->pInterruptObject,
                PlxSynchronizedRegisterModify,
                (VOID *)&RegData
                );
        }
    }

    // Software Interrupt
    if (IntData.Source_Ints & INTR_TYPE_SOFTWARE)
    {
        // Setup to synchronize access to Interrupt Control/Status Register
        RegData.pdx       = pdx;
        RegData.offset    = PCI9030_INT_CTRL_STAT;
        RegData.BitsToSet = 0;

        // Clear the software interrupt
        RegData.BitsToClear = (1 << 7);

        KeSynchronizeExecution(
            pdx->pInterruptObject,
            PlxSynchronizedRegisterModify,
            (VOID *)&RegData
            );
    }

    KeReleaseSpinLockFromDpcLevel(
        &(pdx->Lock_HwAccess)
        );

    // Signal any objects waiting for notification
    PlxSignalNotifications(
        pdx,
        &IntData
        );

    // Re-enable interrupts
    KeSynchronizeExecution(
        pdx->pInterruptObject,
        PlxChipInterruptsEnable,
        pdx
        );
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2023国产精华国产精品| 欧洲一区二区三区在线| 亚洲电影激情视频网站| 亚洲天堂av一区| 18欧美乱大交hd1984| 亚洲国产精华液网站w| 欧美激情一区二区在线| 国产精品国产三级国产aⅴ入口| 久久综合国产精品| 久久久久国产精品麻豆ai换脸| 欧美精品一区二区在线观看| 国产婷婷精品av在线| 国产精品丝袜一区| 亚洲尤物视频在线| 日韩综合小视频| 麻豆视频一区二区| 蜜臀av一区二区| 国产69精品久久久久777| 风间由美一区二区av101| 91免费视频网| 欧美一级黄色录像| 欧美激情一区二区三区在线| 樱桃视频在线观看一区| 热久久国产精品| 国产麻豆精品久久一二三| 成人免费av网站| 欧美丝袜丝nylons| 欧美大片日本大片免费观看| 国产精品久久久久aaaa| 午夜精品123| 国产成人精品免费网站| 精品视频一区二区不卡| 久久综合成人精品亚洲另类欧美 | 日韩一区二区电影网| 欧美刺激午夜性久久久久久久| 欧美剧情片在线观看| 久久久一区二区三区捆绑**| 中文欧美字幕免费| 亚洲精品久久久久久国产精华液| 日韩精品一二三四| 波多野结衣中文字幕一区| 欧美肥妇bbw| 日韩一区在线看| 免费不卡在线观看| 色婷婷香蕉在线一区二区| 久久久亚洲精华液精华液精华液| 一区二区久久久久| 国产精品99久久久久久宅男| 欧美精品tushy高清| 亚洲丝袜精品丝袜在线| 激情深爱一区二区| 欧美福利电影网| 一二三四社区欧美黄| 国产精品1区2区| 欧美变态tickling挠脚心| 亚洲小说欧美激情另类| 91丨九色丨国产丨porny| 精品国产三级电影在线观看| 偷拍日韩校园综合在线| 99久久99久久久精品齐齐| 国产女主播视频一区二区| 蜜臀av性久久久久av蜜臀妖精| 欧美日韩一区不卡| 亚洲一区二区三区在线播放| 成人精品一区二区三区中文字幕 | 国产欧美日韩麻豆91| 麻豆免费看一区二区三区| 欧美精品丝袜久久久中文字幕| 亚洲男人的天堂网| 91麻豆国产精品久久| 国产精品久久一级| caoporen国产精品视频| 国产亚洲精品bt天堂精选| 国产精品资源网站| 久久久久久免费毛片精品| 日韩成人伦理电影在线观看| 91黄视频在线观看| 亚洲尤物视频在线| 欧美日韩国产高清一区二区三区 | 老司机午夜精品99久久| 欧美美女一区二区在线观看| 午夜激情久久久| 制服丝袜亚洲精品中文字幕| 午夜成人免费视频| 日韩欧美一区二区不卡| 激情综合色播激情啊| 国产视频一区不卡| 91小视频在线| 天堂一区二区在线| 678五月天丁香亚洲综合网| 日本特黄久久久高潮| 久久婷婷综合激情| 成人午夜在线视频| 亚洲欧美日韩一区二区三区在线观看| 91浏览器在线视频| 亚洲成人动漫一区| 精品国产91久久久久久久妲己| 久久99久久精品| 国产精品大尺度| 欧美三级中文字幕在线观看| 青青草国产成人99久久| 国产午夜精品一区二区三区视频| 不卡影院免费观看| 石原莉奈一区二区三区在线观看| 久久无码av三级| 欧美中文字幕一二三区视频| 精品一区二区三区免费毛片爱 | 7777精品久久久大香线蕉 | 亚洲男同1069视频| 欧美一级精品在线| jizzjizzjizz欧美| 日本不卡1234视频| 亚洲情趣在线观看| 欧美不卡视频一区| 在线观看国产日韩| 国产伦精品一区二区三区免费迷| 一区二区三区免费看视频| 3751色影院一区二区三区| 成人性生交大片免费看中文 | 国产精品萝li| 日韩欧美国产一区二区三区| 99vv1com这只有精品| 久久不见久久见免费视频1| 一卡二卡欧美日韩| 久久久www免费人成精品| 欧美日韩高清一区| 91在线观看下载| 国产激情视频一区二区三区欧美 | 国产精品综合一区二区| 亚洲一区中文在线| 国产精品欧美久久久久一区二区| 91精品国产乱| 欧美亚洲国产一区在线观看网站| 岛国精品一区二区| 国内精品伊人久久久久影院对白| 婷婷成人激情在线网| 亚洲欧美激情一区二区| 久久久亚洲高清| 日韩欧美久久久| 日韩丝袜美女视频| 91精品麻豆日日躁夜夜躁| 在线一区二区观看| 色综合中文字幕国产 | 中文字幕在线一区免费| 26uuu亚洲| 精品国产sm最大网站免费看| 91精品国产综合久久香蕉麻豆 | 337p粉嫩大胆噜噜噜噜噜91av| 欧美日韩精品一区二区三区蜜桃 | 久久97超碰色| 麻豆精品一二三| 久久精品免费看| 青青草97国产精品免费观看无弹窗版| 亚洲国产精品一区二区久久恐怖片| 亚洲欧洲av在线| 亚洲精品国产无套在线观| 亚洲欧美日韩国产中文在线| 亚洲天堂福利av| 亚洲国产日日夜夜| 亚洲成人免费视频| 天堂久久一区二区三区| 日韩电影一区二区三区| 蜜桃视频一区二区三区 | 中文字幕成人在线观看| 国产精品乱码妇女bbbb| 亚洲日韩欧美一区二区在线| 亚洲一区二区三区影院| 亚洲成人动漫在线免费观看| 蜜桃久久久久久| 国产成人综合亚洲网站| 成人毛片视频在线观看| 色综合久久六月婷婷中文字幕| 欧美午夜精品一区二区三区| 欧美日韩亚洲另类| 欧美电影免费提供在线观看| 日本一区二区综合亚洲| 一区二区三区日韩欧美精品| 日韩影院在线观看| 国产黄色成人av| 欧美伊人精品成人久久综合97| 日韩欧美一二三区| 自拍视频在线观看一区二区| 亚洲 欧美综合在线网络| 国产一区二区在线影院| 色综合久久久久久久久| 日韩美女视频在线| 欧美激情在线看| 性久久久久久久久久久久| 国产成人精品免费看| 欧美高清www午色夜在线视频| 国产精品无人区| 日韩精品国产精品| 99免费精品视频| 精品久久久三级丝袜| 亚洲一区二区成人在线观看| 国产乱码精品一品二品| 欧美日韩国产成人在线91| 中文字幕在线一区免费| 国产乱色国产精品免费视频| 欧美吻胸吃奶大尺度电影|