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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? plxchipapi.c

?? PCI接口產(chǎn)品中橋芯片PLX6000、PLX8000、PLX9000和PLXsrv驅(qū)動(dòng)模塊源碼
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*******************************************************************************
 * 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:
 *
 *      PlxChipApi.c
 *
 * Description:
 *
 *      Implements chip-specific API functions
 *
 * Revision History:
 *
 *      06-01-07 : PLX SDK v5.10
 *
 ******************************************************************************/


#include "Eep_9000.h"
#include "PciSupport.h"
#include "PlxChipApi.h"
#include "SupportFunc.h"




/******************************************************************************
 *
 * Function   :  PlxChip_BoardReset
 *
 * Description:  Resets a device using software reset feature of PLX chip
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_BoardReset(
    DEVICE_EXTENSION *pdx
    )
{
    U8  MU_Enabled;
    U8  EepromPresent;
    U32 RegValue;
    U32 RegInterrupt;
    U32 RegHotSwap;
    U32 RegPowerMgmnt;


    // Clear any PCI errors
    PLX_PCI_REG_READ(
        pdx,
        CFG_COMMAND,
        &RegValue
        );

    if (RegValue & (0xf8 << 24))
    {
        // Write value back to clear aborts
        PLX_PCI_REG_WRITE(
            pdx,
            CFG_COMMAND,
            RegValue
            );
    }

    // Save state of I2O Decode Enable
    RegValue =
        PLX_9000_REG_READ(
            pdx,
            PCI9056_FIFO_CTRL_STAT
            );

    MU_Enabled = (U8)(RegValue & (1 << 0));

    // Determine if an EEPROM is present
    RegValue =
        PLX_9000_REG_READ(
            pdx,
            PCI9056_EEPROM_CTRL_STAT
            );

    // Make sure S/W Reset & EEPROM reload bits are clear
    RegValue &= ~((1 << 30) | (1 << 29));

    // Remember if EEPROM is present
    EepromPresent = (U8)((RegValue >> 28) & (1 << 0));

    // Save interrupt line
    PLX_PCI_REG_READ(
        pdx,
        CFG_INT_LINE,
        &RegInterrupt
        );

    // Save some registers if EEPROM present
    if (EepromPresent)
    {
        PLX_PCI_REG_READ(
            pdx,
            PCI9056_HS_CAP_ID,
            &RegHotSwap
            );

        PLX_PCI_REG_READ(
            pdx,
            PCI9056_PM_CSR,
            &RegPowerMgmnt
            );
    }

    // Issue Software Reset to hold PLX chip in reset
    PLX_9000_REG_WRITE(
        pdx,
        PCI9056_EEPROM_CTRL_STAT,
        RegValue | (1 << 30)
        );

    // Delay for a bit
    Plx_sleep(100);

    // Bring chip out of reset
    PLX_9000_REG_WRITE(
        pdx,
        PCI9056_EEPROM_CTRL_STAT,
        RegValue
        );

    // Issue EEPROM reload in case now programmed
    PLX_9000_REG_WRITE(
        pdx,
        PCI9056_EEPROM_CTRL_STAT,
        RegValue | (1 << 29)
        );

    // Delay for a bit
    Plx_sleep(10);

    // Clear EEPROM reload
    PLX_9000_REG_WRITE(
        pdx,
        PCI9056_EEPROM_CTRL_STAT,
        RegValue
        );

    // Restore I2O Decode Enable state
    if (MU_Enabled)
    {
        // Save state of I2O Decode Enable
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9056_FIFO_CTRL_STAT
                );

        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_FIFO_CTRL_STAT,
            RegValue | (1 << 0)
            );
    }

    // Restore interrupt line
    PLX_PCI_REG_WRITE(
        pdx,
        CFG_INT_LINE,
        RegInterrupt
        );

    // If EEPROM was present, restore registers
    if (EepromPresent)
    {
        // Mask out HS bits that can be cleared
        RegHotSwap &= ~((1 << 23) | (1 << 22) | (1 << 17));

        PLX_PCI_REG_WRITE(
            pdx,
            PCI9056_HS_CAP_ID,
            RegHotSwap
            );

        // Mask out PM bits that can be cleared
        RegPowerMgmnt &= ~(1 << 15);

        PLX_PCI_REG_READ(
            pdx,
            PCI9056_PM_CSR,
            &RegPowerMgmnt
            );
    }

    return ApiSuccess;
}




/******************************************************************************
 *
 * Function   :  PlxChip_InterruptEnable
 *
 * Description:  Enables specific interupts of the PLX Chip
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_InterruptEnable(
    DEVICE_EXTENSION *pdx,
    PLX_INTERRUPT    *pPlxIntr
    )
{
    U32          QueueCsr;
    U32          QueueCsr_Original;
    U32          RegValue;
    PLX_REG_DATA RegData;


    // Setup to synchronize access to Interrupt Control/Status Register
    RegData.pdx         = pdx;
    RegData.offset      = PCI9056_INT_CTRL_STAT;
    RegData.BitsToSet   = 0;
    RegData.BitsToClear = 0;

    if (pPlxIntr->PciMain)
        RegData.BitsToSet |= (1 << 8);

    if (pPlxIntr->PciAbort)
        RegData.BitsToSet |= (1 << 10);

    if (pPlxIntr->TargetRetryAbort)
        RegData.BitsToSet |= (1 << 12);

    if (pPlxIntr->LocalToPci_1)
        RegData.BitsToSet |= (1 << 11);

    if (pPlxIntr->Doorbell)
        RegData.BitsToSet |= (1 << 9);

    if (pPlxIntr->PowerManagement)
        RegData.BitsToSet |= (1 << 4);

    if (pPlxIntr->DmaChannel_0)
    {
        RegData.BitsToSet |= (1 << 18);

        // Make sure DMA done interrupt is enabled & routed to PCI
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9056_DMA0_MODE
                );

        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_DMA0_MODE,
            RegValue | (1 << 17) | (1 << 10)
            );
    }

    if (pPlxIntr->DmaChannel_1)
    {
        RegData.BitsToSet |= (1 << 19);

        // Make sure DMA done interrupt is enabled & routed to PCI
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9056_DMA1_MODE
                );

        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_DMA1_MODE,
            RegValue | (1 << 17) | (1 << 10)
            );
    }

    // Inbound Post Queue Interrupt Control/Status Register
    QueueCsr_Original =
        PLX_9000_REG_READ(
            pdx,
            PCI9056_FIFO_CTRL_STAT
            );

    QueueCsr = QueueCsr_Original;

    if (pPlxIntr->MuOutboundPost)
    {
        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_OUTPOST_INT_MASK,
            0
            );
    }

    if (pPlxIntr->MuInboundPost)
        QueueCsr &= ~(1 << 4);

    if (pPlxIntr->MuOutboundOverflow)
    {
        RegData.BitsToSet |=  (1 << 1);
        QueueCsr          &= ~(1 << 6);
    }

    // Write register values if they have changed
    if (RegData.BitsToSet != 0)
    {
        // Synchronize write of Interrupt Control/Status Register
        KeSynchronizeExecution(
            pdx->pInterruptObject,
            PlxSynchronizedRegisterModify,
            &RegData
            );
    }

    if (QueueCsr != QueueCsr_Original)
    {
        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_FIFO_CTRL_STAT,
            QueueCsr
            );
    }

    return ApiSuccess;
}




/******************************************************************************
 *
 * Function   :  PlxChip_InterruptDisable
 *
 * Description:  Disables specific interrupts of the PLX Chip
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_InterruptDisable(
    DEVICE_EXTENSION *pdx,
    PLX_INTERRUPT    *pPlxIntr
    )
{
    U32          QueueCsr;
    U32          QueueCsr_Original;
    U32          RegValue;
    PLX_REG_DATA RegData;


    // Setup to synchronize access to Interrupt Control/Status Register
    RegData.pdx         = pdx;
    RegData.offset      = PCI9056_INT_CTRL_STAT;
    RegData.BitsToSet   = 0;
    RegData.BitsToClear = 0;

    if (pPlxIntr->PciMain)
        RegData.BitsToClear |= (1 << 8);

    if (pPlxIntr->PciAbort)
        RegData.BitsToClear |= (1 << 10);

    if (pPlxIntr->TargetRetryAbort)
        RegData.BitsToClear |= (1 << 12);

    if (pPlxIntr->LocalToPci_1)
        RegData.BitsToClear |= (1 << 11);

    if (pPlxIntr->Doorbell)
        RegData.BitsToClear |= (1 << 9);

    if (pPlxIntr->PowerManagement)
        RegData.BitsToClear |= (1 << 4);

    if (pPlxIntr->DmaChannel_0)
    {
        // Check if DMA interrupt is routed to PCI
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9056_DMA0_MODE
                );

        if (RegValue & (1 << 17))
        {
            RegData.BitsToClear |= (1 << 18);

            // Disable DMA interrupt enable
            PLX_9000_REG_WRITE(
                pdx,
                PCI9056_DMA0_MODE,
                RegValue & ~(1 << 10)
                );
        }
    }

    if (pPlxIntr->DmaChannel_1)
    {
        // Check if DMA interrupt is routed to PCI
        RegValue =
            PLX_9000_REG_READ(
                pdx,
                PCI9056_DMA1_MODE
                );

        if (RegValue & (1 << 17))
        {
            RegData.BitsToClear |= (1 << 19);

            // Disable DMA interrupt enable
            PLX_9000_REG_WRITE(
                pdx,
                PCI9056_DMA1_MODE,
                RegValue & ~(1 << 10)
                );
        }
    }

    // Inbound Post Queue Interrupt Control/Status Register
    QueueCsr_Original =
        PLX_9000_REG_READ(
            pdx,
            PCI9056_FIFO_CTRL_STAT
            );

    QueueCsr = QueueCsr_Original;

    if (pPlxIntr->MuOutboundPost)
    {
        PLX_9000_REG_WRITE(
            pdx,
            PCI9056_OUTPOST_INT_MASK,
            (1 << 3)
            );
    }

    if (pPlxIntr->MuInboundPost)
        QueueCsr |= (1 << 4);

    if (pPlxIntr->MuOutboundOverflow)
        QueueCsr |= (1 << 6);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 久久影音资源网| 欧美三级在线播放| 色999日韩国产欧美一区二区| aaa国产一区| 成人h版在线观看| 成人久久视频在线观看| 成人小视频免费在线观看| 国产夫妻精品视频| 国产精品 欧美精品| 国产精品综合一区二区三区| 国产经典欧美精品| 99精品视频免费在线观看| bt欧美亚洲午夜电影天堂| 99久久综合色| 色av一区二区| 欧美精品在线观看播放| 欧美一级二级三级乱码| 日韩欧美视频在线 | 日本美女一区二区三区视频| 五月天一区二区| 免费成人结看片| 国产乱码精品一品二品| 成人精品电影在线观看| 色琪琪一区二区三区亚洲区| 884aa四虎影成人精品一区| 日韩欧美国产综合一区| 久久精品人人做人人爽97| 国产精品国产三级国产普通话蜜臀| 亚洲欧洲在线观看av| 亚洲一区二区三区四区五区黄| 午夜国产精品一区| 国产精品一区专区| 91蜜桃视频在线| 91精品国产综合久久久久久久 | 国产91精品精华液一区二区三区| 成人午夜精品在线| 欧美亚洲国产一区二区三区| 日韩亚洲欧美综合| 国产欧美日韩在线观看| 亚洲国产综合人成综合网站| 日本大胆欧美人术艺术动态 | 日韩一区二区不卡| 国产精品系列在线| 香港成人在线视频| 国产激情91久久精品导航| 在线欧美一区二区| 久久新电视剧免费观看| 一区二区不卡在线播放| 久久国产夜色精品鲁鲁99| av不卡免费在线观看| 日韩免费电影一区| 亚洲天堂福利av| 国产综合色在线| 在线看国产一区| 国产人妖乱国产精品人妖| 亚洲国产成人高清精品| 国产 日韩 欧美大片| 欧美日韩国产影片| 国产精品久久久久影院老司| 日韩成人av影视| 91女人视频在线观看| 精品美女被调教视频大全网站| 亚洲视频资源在线| 国产综合色精品一区二区三区| 欧美中文字幕不卡| 国产精品久久精品日日| 美女尤物国产一区| 91麻豆福利精品推荐| 精品福利在线导航| 婷婷夜色潮精品综合在线| 成人一级片网址| 日韩视频在线你懂得| 亚洲国产一区二区三区 | 欧美日韩情趣电影| 亚洲欧美一区二区不卡| 国产自产高清不卡| 4438x成人网最大色成网站| 亚洲欧美另类久久久精品 | 欧美二区乱c少妇| 亚洲女同一区二区| 风间由美一区二区三区在线观看| 日韩一本二本av| 日韩精彩视频在线观看| 欧美视频日韩视频| 樱花影视一区二区| www.亚洲人| 欧美国产成人在线| 狠狠狠色丁香婷婷综合激情| 91精品视频网| 亚洲大尺度视频在线观看| 色婷婷亚洲综合| 国产精品不卡视频| 波多野洁衣一区| 欧美高清在线一区| av在线不卡电影| 国产精品素人一区二区| 粉嫩高潮美女一区二区三区 | 国产精一品亚洲二区在线视频| 精品欧美一区二区在线观看 | 日韩欧美综合一区| 丝袜诱惑制服诱惑色一区在线观看| 在线免费观看不卡av| 夜夜嗨av一区二区三区| 在线观看91精品国产入口| 亚洲色欲色欲www在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 中文字幕中文乱码欧美一区二区| 国产91精品入口| 中文字幕在线不卡一区 | 精品粉嫩超白一线天av| 久久精品国产99| 欧美va亚洲va| 国产一区在线看| 久久青草欧美一区二区三区| 国产成人亚洲精品青草天美| 中文字幕欧美国产| 成人av在线电影| 亚洲另类色综合网站| 在线视频综合导航| 日本欧美大码aⅴ在线播放| 精品黑人一区二区三区久久| 国产99久久久国产精品潘金| 国产精品成人免费| 欧美日韩精品一区二区三区蜜桃 | 夜夜嗨av一区二区三区中文字幕 | 欧美日本在线一区| 免费在线看成人av| 久久久久国产精品人| 99精品视频中文字幕| 亚洲一区在线免费观看| 欧美放荡的少妇| 国产风韵犹存在线视精品| 亚洲欧美一区二区在线观看| 欧美性极品少妇| 精品亚洲国内自在自线福利| 欧美国产国产综合| 欧美性生活大片视频| 理论片日本一区| 中文一区在线播放| 欧美日韩卡一卡二| 国产乱码一区二区三区| 一区二区三区在线视频播放| 91精品国产福利在线观看 | 欧美精选午夜久久久乱码6080| 麻豆91在线观看| 中文字幕一区二区三区av| 欧美日本高清视频在线观看| 国产一区二区三区免费播放| 最近日韩中文字幕| 欧美大片一区二区| 91丨九色丨尤物| 久草这里只有精品视频| 亚洲色图欧美在线| 精品国产一区二区三区忘忧草| av男人天堂一区| 久久国产精品色| 亚洲图片欧美视频| 中文字幕成人网| 欧美一区二区免费视频| www.在线欧美| 国精产品一区一区三区mba桃花| 亚洲女人小视频在线观看| 欧美v亚洲v综合ⅴ国产v| 在线视频观看一区| 国产精品911| 日本成人在线一区| 亚洲色图在线看| 国产亚洲欧美中文| 91麻豆精品91久久久久同性| av在线不卡网| 国产很黄免费观看久久| 日本欧美大码aⅴ在线播放| 亚洲美女视频一区| 国产三级一区二区| 欧美一区二区二区| 欧美影院一区二区| 成人免费三级在线| 韩国v欧美v亚洲v日本v| 午夜av电影一区| 亚洲激情欧美激情| 国产精品免费久久| 久久女同互慰一区二区三区| 欧美美女激情18p| 色狠狠av一区二区三区| 99久久er热在这里只有精品15 | 国产麻豆视频精品| 日韩精品电影在线| 亚洲丶国产丶欧美一区二区三区| 中文字幕精品综合| 久久久亚洲欧洲日产国码αv| 日韩一区国产二区欧美三区| 欧美三级日韩三级国产三级| va亚洲va日韩不卡在线观看| 国产精品自产自拍| 久久精品99久久久| 青青草一区二区三区| 免费看日韩a级影片| 日本亚洲视频在线| 日韩福利电影在线|