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

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

?? card.c

?? 使用網絡驅動器接口標準開發的ne2000網卡的NT驅動.
?? C
?? 第 1 頁 / 共 5 頁
字號:

/*++

Copyright (c) 1990-1998 Microsoft Corporation, All Rights Reserved.

Module Name:

    card.c

Abstract:

    Card-specific functions for the NDIS 3.0 Novell 2000 driver.

Author:

    Sean Selitrennikoff

Environment:

    Kernel mode, FSD

Revision History:

--*/

#include "precomp.h"

BOOLEAN
CardSlotTest(
    IN PNE2000_ADAPTER Adapter
    );

BOOLEAN
CardRamTest(
    IN PNE2000_ADAPTER Adapter
    );


#pragma NDIS_PAGEABLE_FUNCTION(CardCheckParameters)

BOOLEAN CardCheckParameters(
    IN PNE2000_ADAPTER Adapter
)

/*++

Routine Description:

    Checks that the I/O base address is correct.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    TRUE, if IoBaseAddress appears correct.

--*/

{
    UCHAR Tmp;

    //
    // If adapter responds to a stop command correctly -- assume it is there.
    //

    //
    // Turn off interrupts first.
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_INTR_MASK, 0);

    //
    // Stop the card.
    //
    SyncCardStop(Adapter);

    //
    // Pause
    //
    NdisStallExecution(2000);

    //
    // Read response
    //
    NdisRawReadPortUchar(Adapter->IoPAddr + NIC_COMMAND, &Tmp);

    if ((Tmp == (CR_NO_DMA | CR_STOP)) ||
        (Tmp == (CR_NO_DMA | CR_STOP | CR_START))
    )
    {
        return(TRUE);
    }
    else
    {
        return(FALSE);
    }
}
#ifdef NE2000

#pragma NDIS_PAGEABLE_FUNCTION(CardSlotTest)


BOOLEAN CardSlotTest(
    IN PNE2000_ADAPTER Adapter
)

/*++

Routine Description:

    Checks if the card is in an 8 or 16 bit slot and sets a flag in the
    adapter structure.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    TRUE, if all goes well, else FALSE.

--*/

{
    UCHAR Tmp;
    UCHAR RomCopy[32];
    UCHAR i;
	BOOLEAN found;

    //
    // Reset the chip
    //
    NdisRawReadPortUchar(Adapter->IoPAddr + NIC_RESET, &Tmp);
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RESET, 0xFF);

    //
    // Go to page 0 and stop
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_COMMAND, CR_STOP | CR_NO_DMA);

    //
    // Pause
    //
    NdisStallExecution(2000);

    //
    // Check that it is stopped
    //
    NdisRawReadPortUchar(Adapter->IoPAddr + NIC_COMMAND, &Tmp);
    if (Tmp != (CR_NO_DMA | CR_STOP))
    {
        IF_LOUD(DbgPrint("Could not stop the card\n");)

        return(FALSE);
    }

    //
    // Setup to read from ROM
    //
    NdisRawWritePortUchar(
        Adapter->IoPAddr + NIC_DATA_CONFIG,
        DCR_BYTE_WIDE | DCR_FIFO_8_BYTE | DCR_NORMAL
    );

    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_INTR_MASK, 0x0);

    //
    // Ack any interrupts that may be hanging around
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_INTR_STATUS, 0xFF);

    //
    // Setup to read in the ROM, the address and byte count.
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RMT_ADDR_LSB, 0x0);

    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RMT_ADDR_MSB, 0x0);

    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RMT_COUNT_LSB, 32);

    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RMT_COUNT_MSB, 0x0);

    NdisRawWritePortUchar(
        Adapter->IoPAddr + NIC_COMMAND,
        CR_DMA_READ | CR_START
    );

    //
    // Read first 32 bytes in 16 bit mode
    //
	for (i = 0; i < 32; i++)
	{
		NdisRawReadPortUchar(Adapter->IoPAddr + NIC_RACK_NIC, RomCopy + i);
	}

    IF_VERY_LOUD( DbgPrint("Resetting the chip\n"); )

    //
    // Reset the chip
    //
    NdisRawReadPortUchar(Adapter->IoPAddr + NIC_RESET, &Tmp);
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RESET, 0xFF);

    //
    // Check ROM for 'B' (byte) or 'W' (word)
    // NOTE: If the buffer has bot BB and WW then use WW instead of BB
    IF_VERY_LOUD( DbgPrint("Checking slot type\n"); )

	found = FALSE;
	for (i = 16; i < 31; i++)
	{
		if (((RomCopy[i] == 'B') && (RomCopy[i+1] == 'B')) ||
			((RomCopy[i] == 'W') && (RomCopy[i+1] == 'W'))
		)
		{
			if (RomCopy[i] == 'B')
			{
				Adapter->EightBitSlot = TRUE;
				found = TRUE;
			}
			else
			{
				Adapter->EightBitSlot = FALSE;
				found = TRUE;
				break;		// Go no farther
			}
		}
	}

	if (found)
	{
		IF_VERY_LOUD( (Adapter->EightBitSlot?DbgPrint("8 bit slot\n"):
							  DbgPrint("16 bit slot\n")); )
	}
	else
	{
		//
		// If neither found -- then not an NE2000
		//
		IF_VERY_LOUD( DbgPrint("Failed slot type\n"); )
	}

    return(found);
}

#endif // NE2000




#pragma NDIS_PAGEABLE_FUNCTION(CardRamTest)

BOOLEAN
CardRamTest(
    IN PNE2000_ADAPTER Adapter
    )

/*++

Routine Description:

    Finds out how much RAM the adapter has.  It starts at 1K and checks thru
    60K.  It will set Adapter->RamSize to the appropriate value iff this
    function returns TRUE.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    TRUE, if all goes well, else FALSE.

--*/

{
    PUCHAR RamBase, RamPointer;
    PUCHAR RamEnd;

	UCHAR TestPattern[]={ 0xAA, 0x55, 0xFF, 0x00 };
	PULONG pTestPattern = (PULONG)TestPattern;
	UCHAR ReadPattern[4];
	PULONG pReadPattern = (PULONG)ReadPattern;

    for (RamBase = (PUCHAR)0x400; RamBase < (PUCHAR)0x10000; RamBase += 0x400) {

        //
        // Write Test pattern
        //

        if (!CardCopyDown(Adapter, RamBase, TestPattern, 4)) {

            continue;

        }

        //
        // Read pattern
        //

        if (!CardCopyUp(Adapter, ReadPattern, RamBase, 4)) {

            continue;

        }

        IF_VERY_LOUD( DbgPrint("Addr 0x%x: 0x%x, 0x%x, 0x%x, 0x%x\n",
                               RamBase,
                               ReadPattern[0],
                               ReadPattern[1],
                               ReadPattern[2],
                               ReadPattern[3]
                              );
                    )


        //
        // If they are the same, find the end
        //

        if (*pReadPattern == *pTestPattern) {

            for (RamEnd = RamBase; !(PtrToUlong(RamEnd) & 0xFFFF0000); RamEnd += 0x400) {

                //
                // Write test pattern
                //

                if (!CardCopyDown(Adapter, RamEnd, TestPattern, 4)) {

                    break;

                }

                //
                // Read pattern
                //

                if (!CardCopyUp(Adapter, ReadPattern, RamEnd, 4)) {

                    break;

                }

                if (*pReadPattern != *pTestPattern) {

                    break;

                }

            }

            break;

        }

    }

    IF_LOUD( DbgPrint("RamBase 0x%x, RamEnd 0x%x\n", RamBase, RamEnd); )

    //
    // If not found, error out
    //

    if ((RamBase >= (PUCHAR)0x10000) || (RamBase == RamEnd)) {

        return(FALSE);

    }

    //
    // Watch for boundary case when RamEnd is maximum value
    //

    if ((ULONG_PTR)RamEnd & 0xFFFF0000) {

        RamEnd -= 0x100;

    }

    //
    // Check all of ram
    //

    for (RamPointer = RamBase; RamPointer < RamEnd; RamPointer += 4) {

        //
        // Write test pattern
        //

        if (!CardCopyDown(Adapter, RamPointer, TestPattern, 4)) {

            return(FALSE);

        }

        //
        // Read pattern
        //

        if (!CardCopyUp(Adapter, ReadPattern, RamBase, 4)) {

            return(FALSE);

        }

        if (*pReadPattern != *pTestPattern) {

            return(FALSE);

        }

    }

    //
    // Store Results
    //

    Adapter->RamBase = RamBase;
    Adapter->RamSize = (ULONG)(RamEnd - RamBase);

    return(TRUE);

}

#pragma NDIS_PAGEABLE_FUNCTION(CardInitialize)

BOOLEAN
CardInitialize(
    IN PNE2000_ADAPTER Adapter
    )

/*++

Routine Description:

    Initializes the card into a running state.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    TRUE, if all goes well, else FALSE.

--*/

{
    UCHAR Tmp;
    USHORT i;

    //
    // Stop the card.
    //
    SyncCardStop(Adapter);

    //
    // Initialize the Data Configuration register.
    //
    NdisRawWritePortUchar(
        Adapter->IoPAddr + NIC_DATA_CONFIG,
        DCR_AUTO_INIT | DCR_FIFO_8_BYTE
    );

    //
    // Set Xmit start location
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_XMIT_START, 0xA0);

    //
    // Set Xmit configuration
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_XMIT_CONFIG, 0x0);

    //
    // Set Receive configuration
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RCV_CONFIG, RCR_MONITOR);

    //
    // Set Receive start
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_PAGE_START, 0x4);

    //
    // Set Receive end
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_PAGE_STOP, 0xFF);

    //
    // Set Receive boundary
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_BOUNDARY, 0x4);

    //
    // Set Xmit bytes
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_XMIT_COUNT_LSB, 0x3C);
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_XMIT_COUNT_MSB, 0x0);

    //
    // Pause
    //
    NdisStallExecution(2000);

    //
    // Ack all interrupts that we might have produced
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_INTR_STATUS, 0xFF);

    //
    // Change to page 1
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_COMMAND, CR_PAGE1 | CR_STOP);

    //
    // Set current
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_CURRENT, 0x4);

    //
    // Back to page 0
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_COMMAND, CR_PAGE0 | CR_STOP);

    //
    // Pause
    //
    NdisStallExecution(2000);

    //
    // Check that Command register reflects this last command
    //
    NdisRawReadPortUchar(Adapter->IoPAddr + NIC_COMMAND, &Tmp);
    if (!(Tmp & CR_STOP))
    {
        IF_LOUD(DbgPrint("Invalid command register\n");)

        return(FALSE);
    }

    //
    // Do initialization errata
    //
    NdisRawWritePortUchar(Adapter->IoPAddr + NIC_RMT_COUNT_LSB, 55);

    //
    // Setup for a read
    //
    NdisRawWritePortUchar(
        Adapter->IoPAddr + NIC_COMMAND,
        CR_DMA_READ | CR_START
    );

#ifdef NE2000

    //
    // Check if the slot is 8 or 16 bit (affects data transfer rate).
    //

    if ((Adapter->BusType == NdisInterfaceMca) ||
		(NE2000_PCMCIA == Adapter->CardType))
    {
        Adapter->EightBitSlot = FALSE;
    }
    else
    {
        IF_VERY_LOUD(DbgPrint("CardSlotTest\n");)

        if (CardSlotTest(Adapter) == FALSE)
        {
            //
            // Stop chip
            //
            SyncCardStop(Adapter);

            IF_LOUD(DbgPrint("  -- Failed\n");)
            return(FALSE);
        }

    }

#else // NE2000

    Adapter->EightBitSlot = TRUE;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品美女久久久久久| 日本精品一级二级| 日本成人中文字幕在线视频| 亚洲精品中文字幕在线观看| 中文字幕一区视频| 国产精品国产三级国产有无不卡 | 欧美久久一二三四区| 在线看一区二区| 91黄色小视频| 欧美丝袜自拍制服另类| 欧美在线高清视频| 欧美高清视频一二三区| 日韩免费高清av| 久久久亚洲综合| 中文字幕精品三区| 椎名由奈av一区二区三区| 日韩电影免费一区| 久久精品国产精品亚洲精品| 精品一区精品二区高清| 福利一区福利二区| 欧美性猛交一区二区三区精品| 欧美精品vⅰdeose4hd| 亚洲精品一区二区三区蜜桃下载| 亚洲精品一区二区三区在线观看 | 日韩免费看网站| 国产精品视频九色porn| 亚洲欧洲日韩女同| 亚洲成人免费看| 国产老女人精品毛片久久| 色综合久久99| 欧美精品一区二区三区视频 | 884aa四虎影成人精品一区| 日韩女同互慰一区二区| 亚洲欧洲国产日韩| 日韩va亚洲va欧美va久久| 顶级嫩模精品视频在线看| 欧美日韩美少妇| 国产精品女人毛片| 免费欧美在线视频| av一区二区三区黑人| 日韩三级视频在线看| 国产精品久久久久7777按摩| 天堂av在线一区| 99re热视频精品| 欧美精品一区二区三区视频| 亚洲最色的网站| 成人教育av在线| 久久久久成人黄色影片| 香蕉av福利精品导航| 成人av高清在线| 日韩欧美国产高清| 亚洲精选视频免费看| 国产久卡久卡久卡久卡视频精品| 欧美日韩在线精品一区二区三区激情| 久久精品视频一区二区| 麻豆成人久久精品二区三区红| 91麻豆精品一区二区三区| 久久精品欧美日韩| 激情综合五月婷婷| 欧美精品丝袜中出| 国产真实乱偷精品视频免| 欧美精选午夜久久久乱码6080| 亚洲品质自拍视频网站| 国产成人自拍在线| 久久免费国产精品 | 成人网页在线观看| 日韩精品一区二区三区视频播放 | 99精品偷自拍| 欧美一区二区成人| 亚洲精品久久嫩草网站秘色| 国产一区二区视频在线| av不卡一区二区三区| 中文字幕一区二区三区在线播放| 成人一区二区视频| 中文字幕巨乱亚洲| 波多野结衣欧美| 国产精品久久久久一区二区三区| 国内精品在线播放| 国产激情偷乱视频一区二区三区| 久久美女高清视频| 国产精品一区二区三区99| 精品国产1区二区| 国产精品自拍在线| 国产精品美女一区二区三区 | 欧美成人三级电影在线| 日韩高清在线不卡| 91精品国产色综合久久| 老司机精品视频导航| 精品电影一区二区| 国产91精品在线观看| 国产精品美女一区二区三区 | 欧美男生操女生| 亚洲一区二区精品3399| 欧美一区二区视频观看视频| 日韩精品一级二级| 精品福利二区三区| 大胆欧美人体老妇| 亚洲精品视频在线看| 5566中文字幕一区二区电影| 国产又黄又大久久| 亚洲欧洲精品天堂一级| 在线免费观看日本欧美| 久久99热狠狠色一区二区| 亚洲国产高清在线观看视频| 91国在线观看| 久久99国产精品免费| 亚洲色图制服诱惑| 欧美一区二区女人| 成人毛片视频在线观看| 爽好久久久欧美精品| 26uuu精品一区二区三区四区在线| 不卡区在线中文字幕| 天天av天天翘天天综合网| 国产三级久久久| 欧美日韩精品一区二区三区 | 亚洲男人的天堂一区二区| 91精品国产麻豆| 成人黄色软件下载| 石原莉奈在线亚洲三区| 国产精品视频线看| 日韩视频永久免费| 色综合久久中文字幕综合网| 国内精品国产三级国产a久久| 亚洲婷婷在线视频| 久久婷婷国产综合精品青草| 91激情五月电影| 成人av午夜影院| 美女视频黄 久久| 午夜一区二区三区在线观看| 中文字幕一区二区三区在线观看 | 日韩你懂的电影在线观看| 一本色道**综合亚洲精品蜜桃冫| 久久99国产精品成人| 中文字幕一区二区三区四区 | 91精品国产一区二区人妖| 在线观看一区二区视频| 成人手机在线视频| 国产九色sp调教91| 精品在线播放免费| 蜜桃精品视频在线| 午夜久久久影院| 亚洲已满18点击进入久久| 国产精品美女久久久久aⅴ| 久久日韩粉嫩一区二区三区 | 激情文学综合丁香| 日本一不卡视频| 天堂成人免费av电影一区| 亚洲成人黄色小说| 午夜精品在线视频一区| 亚洲一区二区三区视频在线 | 亚洲午夜久久久久久久久电影网| 国产精品美日韩| 国产精品激情偷乱一区二区∴| 久久先锋资源网| 国产日本亚洲高清| 国产精品传媒在线| 亚洲欧洲色图综合| 国产欧美日韩一区二区三区在线观看 | 欧美v日韩v国产v| 欧美性受xxxx| 91精品国产乱码| 欧美精品一区二区三区蜜桃| 26uuu亚洲婷婷狠狠天堂| 久久久久99精品国产片| 欧美激情艳妇裸体舞| 国产精品福利一区二区| 久久成人久久鬼色| 国产一区二区美女诱惑| 成人免费视频播放| 色88888久久久久久影院野外| 在线免费不卡电影| 欧美一区二区久久久| 久久久久久久久久久久久女国产乱| 国产欧美一区二区三区在线老狼| 国产精品视频在线看| 亚洲国产精品一区二区久久恐怖片| 日韩精品免费专区| 国产成人a级片| 欧美三级资源在线| 日韩欧美中文一区| 国产精品免费久久久久| 亚洲影视在线播放| 天天综合色天天综合| 国产一区二区精品久久| 91国产免费看| 久久美女艺术照精彩视频福利播放| 日本一区二区三区免费乱视频| 亚洲一区视频在线观看视频| 久久国产尿小便嘘嘘尿| 一本久久综合亚洲鲁鲁五月天| 666欧美在线视频| 中文字幕在线一区免费| 青青草一区二区三区| 99r国产精品| 欧美sm极限捆绑bd| 一级中文字幕一区二区| 国产一区二区免费视频| 欧美猛男gaygay网站| 亚洲国产精品国自产拍av| 奇米在线7777在线精品|