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

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

?? plxchipapi.c

?? PCI接口產品中橋芯片PLX6000、PLX8000、PLX9000和PLXsrv驅動模塊源碼
?? 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:
 *
 *      PlxChipApi.c
 *
 * Description:
 *
 *      Implements chip-specific API functions
 *
 * Revision History:
 *
 *      02-01-07 : PLX SDK v5.00
 *
 ******************************************************************************/


#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  EepromPresent;
    U32 RegValue;
    U32 RegInterrupt;
    U32 RegHotSwap;
    U32 RegPowerMgmnt;
    U32 RegIntCtrlStatus;


    // Added to avoid compiler warnings
    RegIntCtrlStatus = 0;

    // 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
            );
    }

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

    // 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)
    {
        RegIntCtrlStatus =
            PLX_9000_REG_READ(
                pdx,
                PCI9030_INT_CTRL_STAT
                );

        PLX_PCI_REG_READ(
            pdx,
            PCI9030_HS_CAP_ID,
            &RegHotSwap
            );

        PLX_PCI_REG_READ(
            pdx,
            PCI9030_PM_CSR,
            &RegPowerMgmnt
            );
    }

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

    // Delay for a bit
    Plx_sleep(100);

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

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

    // Delay for a bit
    Plx_sleep(10);

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

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

    // If EEPROM was present, restore registers
    if (EepromPresent)
    {
        // Mask interrupt clear bits
        RegIntCtrlStatus &= ~((1 << 11) | (1 << 10));

        PLX_9000_REG_WRITE(
            pdx,
            PCI9030_INT_CTRL_STAT,
            RegIntCtrlStatus
            );

        // Mask out HS bits that can be cleared
        RegHotSwap &= ~((1 << 23) | (1 << 22) | (1 << 17));

        PLX_PCI_REG_WRITE(
            pdx,
            PCI9030_HS_CAP_ID,
            RegHotSwap
            );

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

        PLX_PCI_REG_READ(
            pdx,
            PCI9030_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
    )
{
    PLX_REG_DATA RegData;


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

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

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

    if (pPlxIntr->LocalToPci_2)
        RegData.BitsToSet |= (1 << 3);

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

    return ApiSuccess;
}




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


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

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

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

    if (pPlxIntr->LocalToPci_2)
        RegData.BitsToClear |= (1 << 3);

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

    return ApiSuccess;
}




/******************************************************************************
 *
 * Function   :  PlxChip_EepromReadByOffset
 *
 * Description:  Read a 32-bit value from the EEPROM at a specified offset
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_EepromReadByOffset(
    DEVICE_EXTENSION *pdx,
    U16               offset,
    U32              *pValue
    )
{
    // Verify the offset
    if ((offset & 0x3) || (offset > 0x200))
    {
        DebugPrintf(("ERROR - Invalid EEPROM offset\n"));
        return ApiInvalidOffset;
    }

    // Read EEPROM
    Plx9000_EepromReadByOffset(
        pdx,
        Eeprom93CS56,
        offset,
        pValue
        );

    return ApiSuccess;
}




/******************************************************************************
 *
 * Function   :  PlxChip_EepromWriteByOffset
 *
 * Description:  Write a 32-bit value to the EEPROM at a specified offset
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_EepromWriteByOffset(
    DEVICE_EXTENSION *pdx,
    U16               offset,
    U32               value
    )
{
    U32 RegisterSave;


    // Verify the offset
    if ((offset & 0x3) || (offset > 0x200))
    {
        DebugPrintf(("ERROR - Invalid EEPROM offset\n"));
        return ApiInvalidOffset;
    }

    // Unprotect the EEPROM for write access
    RegisterSave =
        PLX_9000_REG_READ(
            pdx,
            PCI9030_INT_CTRL_STAT
            );

    PLX_9000_REG_WRITE(
        pdx,
        PCI9030_INT_CTRL_STAT,
        RegisterSave & ~(0xFF << 16)
        );

    // Write to EEPROM
    Plx9000_EepromWriteByOffset(
        pdx,
        Eeprom93CS56,
        offset,
        value
        );

    // Restore EEPROM Write-Protected Address Boundary
    PLX_9000_REG_WRITE(
        pdx,
        PCI9030_INT_CTRL_STAT,
        RegisterSave
        );

    return ApiSuccess;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaControl
 *
 * Description:  Control the DMA engine
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaControl(
    DEVICE_EXTENSION *pdx,
    U8                channel,
    PLX_DMA_COMMAND   command
    )
{
    return ApiUnsupportedFunction;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaStatus
 *
 * Description:  Get status of a DMA channel
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaStatus(
    DEVICE_EXTENSION *pdx,
    U8                channel
    )
{
    return ApiUnsupportedFunction;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaChannelOpen
 *
 * Description:  Open a DMA channel
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaChannelOpen(
    DEVICE_EXTENSION *pdx,
    U8                channel,
    PLX_DMA_PROP     *pProp,
    VOID             *pOwner
    )
{
    return ApiUnsupportedFunction;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaTransferBlock
 *
 * Description:  Performs DMA block transfer
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaTransferBlock(
    DEVICE_EXTENSION *pdx,
    U8                channel,
    PLX_DMA_PARAMS   *pParams
    )
{
    return ApiUnsupportedFunction;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaTransferUserBuffer
 *
 * Description:  Transfers a user-mode buffer using SGL DMA
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaTransferUserBuffer(
    DEVICE_EXTENSION *pdx,
    U8                channel,
    PLX_DMA_PARAMS   *pParams
    )
{
    return ApiUnsupportedFunction;
}




/******************************************************************************
 *
 * Function   :  PlxChip_DmaChannelClose
 *
 * Description:  Close a previously opened channel
 *
 ******************************************************************************/
RETURN_CODE
PlxChip_DmaChannelClose(
    DEVICE_EXTENSION *pdx,
    U8                channel,
    BOOLEAN           bCheckInProgress
    )
{
    return ApiUnsupportedFunction;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美mv和日韩mv国产网站| 91影院在线免费观看| 成人黄色在线视频| 精品精品欲导航| 天天色图综合网| 91黄色激情网站| 亚洲精品大片www| 99久久夜色精品国产网站| 久久在线观看免费| 久久精品久久99精品久久| 91精品国产麻豆国产自产在线| 亚洲综合色视频| 色婷婷av一区二区三区软件| 欧美大片免费久久精品三p| 五月婷婷久久综合| 国产精品一区二区不卡| 久久久久一区二区三区四区| 精品一区二区久久久| 欧美不卡激情三级在线观看| 精品一区二区三区蜜桃| 亚洲精品在线网站| 国产伦精品一区二区三区在线观看| 精品入口麻豆88视频| 久久国产精品色| 国产天堂亚洲国产碰碰| 国产成人久久精品77777最新版本| 久久久久一区二区三区四区| 成人禁用看黄a在线| 亚洲精品亚洲人成人网在线播放| 在线日韩一区二区| 午夜av一区二区三区| 精品日韩欧美在线| 国内精品在线播放| 中文字幕日韩一区| 欧美日韩成人在线一区| 久久91精品国产91久久小草| 欧美国产日产图区| 欧美视频一区二区三区四区| 奇米影视在线99精品| 久久久不卡网国产精品二区| 91视频www| 男男视频亚洲欧美| 亚洲国产精品ⅴa在线观看| av不卡免费电影| 亚洲1区2区3区4区| 精品少妇一区二区三区日产乱码 | 日本一区二区免费在线| 91亚洲精品乱码久久久久久蜜桃| 亚洲午夜免费视频| 欧美精品一区二区三区视频| 国产高清在线精品| 中文字幕免费不卡| 欧美日韩精品三区| 成人福利视频在线| 亚洲chinese男男1069| 欧美激情一区在线观看| 欧美福利视频一区| 成人免费va视频| 日韩不卡一区二区三区| 亚洲婷婷国产精品电影人久久| 在线不卡一区二区| 成人av电影在线| 麻豆一区二区99久久久久| 亚洲少妇最新在线视频| 久久青草国产手机看片福利盒子| 欧美天天综合网| 岛国一区二区在线观看| 日本aⅴ精品一区二区三区| 亚洲日穴在线视频| 久久久久综合网| 日韩一级免费观看| 欧美无砖专区一中文字| 99热在这里有精品免费| 亚洲图片欧美一区| 中文字幕第一区| 日韩一本二本av| 欧美日韩国产中文| 在线视频欧美区| 国产一区在线不卡| 97精品久久久午夜一区二区三区 | 一区2区3区在线看| 中文字幕二三区不卡| 精品国产网站在线观看| 91麻豆精品国产无毒不卡在线观看| 99热99精品| 激情小说亚洲一区| 亚洲精品日韩一| 中文字幕一区二区日韩精品绯色| 久久久久久影视| 2023国产精华国产精品| 制服丝袜亚洲色图| 欧美日韩国产经典色站一区二区三区| 91国产丝袜在线播放| 色综合色狠狠综合色| 成人影视亚洲图片在线| 福利电影一区二区| 国产福利精品导航| 高清免费成人av| 成人免费视频播放| 成人高清视频免费观看| 成人av在线资源网站| 不卡影院免费观看| 韩国女主播一区| 国产一区在线精品| 成人在线视频首页| 91视频免费看| 亚洲国产色一区| 午夜天堂影视香蕉久久| 午夜精品视频一区| 亚洲国产精品人人做人人爽| 亚洲一区二区av电影| 天涯成人国产亚洲精品一区av| 亚洲一区二区中文在线| 天堂一区二区在线| 亚洲国产精品久久久久婷婷884| 亚洲制服丝袜一区| 麻豆精品视频在线观看免费| 精品一区二区综合| 成人久久18免费网站麻豆 | 久久久久久9999| 中文字幕巨乱亚洲| 一区二区三区日韩欧美| 一区二区三区毛片| 日韩成人精品视频| 国产精品一区二区x88av| 国产成人精品aa毛片| 日本精品视频一区二区| 91精品一区二区三区久久久久久 | 成人美女视频在线看| 91亚洲精品一区二区乱码| 欧美日韩精品一区视频| 久久久久久免费毛片精品| 亚洲欧洲精品成人久久奇米网| 136国产福利精品导航| 亚洲男人的天堂av| 青青草原综合久久大伊人精品优势| 国产精品69久久久久水密桃| 91视频在线观看免费| 日韩午夜激情电影| 亚洲精品成人天堂一二三| 免费久久99精品国产| www.成人网.com| 3d动漫精品啪啪1区2区免费| 国产日韩影视精品| 亚洲18女电影在线观看| 国产精品主播直播| 91免费看视频| 精品国偷自产国产一区| 亚洲精品五月天| 久久机这里只有精品| 99re这里只有精品视频首页| 日韩欧美一区二区视频| 亚洲伦理在线免费看| 国产自产高清不卡| 欧美日韩免费观看一区二区三区| 久久久久国产一区二区三区四区 | 日韩中文字幕1| eeuss影院一区二区三区| 欧洲亚洲国产日韩| 中文无字幕一区二区三区| 日欧美一区二区| 色婷婷综合久久久中文字幕| 久久精品欧美一区二区三区麻豆| 亚洲va国产va欧美va观看| 国产成人亚洲精品青草天美| 91精品一区二区三区在线观看| 亚洲精品日韩一| 国产乱国产乱300精品| 欧美一区二区视频观看视频 | 国产成人av一区二区| 91麻豆精品国产91久久久久久久久 | 亚洲一区二区三区美女| av不卡在线观看| 国产精品乱码一区二区三区软件 | 欧美电影在哪看比较好| 一个色在线综合| 欧美视频一区在线| 偷拍日韩校园综合在线| 欧美日韩免费观看一区二区三区| 亚洲国产中文字幕| 欧美日韩电影一区| 另类人妖一区二区av| 久久综合狠狠综合| 丁香五精品蜜臀久久久久99网站| 亚洲国产成人一区二区三区| 99精品欧美一区二区三区小说 | 久久婷婷一区二区三区| 国产精品2024| 亚洲天堂av老司机| 欧美日韩国产精品自在自线| 麻豆精品国产传媒mv男同| 337p粉嫩大胆噜噜噜噜噜91av | 久久精品国产亚洲一区二区三区| 成人午夜视频免费看| 亚洲一区在线看| 欧美日韩国产综合视频在线观看| 日韩和欧美一区二区三区| 欧美一卡二卡在线观看| 国产黄色成人av| 亚洲欧美日韩成人高清在线一区|