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

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

?? card.c

?? 虛擬網絡驅動程序ndis for 數字電視 ip 數據接收
?? C
字號:
/*++

  
    Copyright (c) 1999 SDMC Co., Ltd.
    
    Module Name:
        Card.c
    Abstract:
        This is the main file for the DVB-S fast modem NIC.
        This driver conforms to the NDIS 5.0 miniport interface.
            
        The overall structure and much of the code is taken from
        the NE2000 driver included in Microsoft NT3.5 DDK.

    Environment:
                  
        Kernel mode, FSD

        Revision History:
                      
        28/04/2005 ----- hanney
                        
--*/

#include <ndis.h>
#include "RTSNT_SW.H"
#include "bit.h"
//#include "halMAC.h"

#define NdisMSleep(x)	KeStallExecutionProcessor(x)

extern DRIVER_BLOCK RTFast_MiniportBlock;


// Removed by hanney on Apr 28th 2005
/*
#pragma NDIS_PAGEABLE_FUNCTION(ReadCardVersion)

*/  
    
#pragma NDIS_PAGEABLE_FUNCTION(CardInitialize)
    
/*++
    
    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.
                
--*/
BOOLEAN
CardInitialize(
               IN PRTFAST_ADAPTER Adapter
               )
{
    return(TRUE);
}




#pragma NDIS_PAGEABLE_FUNCTION(CardReadEthernetAddress)


/*++

Routine Description:

    Reads in the Ethernet address from the Novell 2000.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    The address is stored in Adapter->PermanentAddress, and StationAddress if it
    is currently zero.

--*/

VOID
CardReadEthernetAddress(
    IN PRTFAST_ADAPTER Adapter
    )
{
	// << Prashanth
    UNICODE_STRING		CastKeyName;
    UNICODE_STRING		CastValueName[6];
    UNICODE_STRING		CastValueData;
    HANDLE				CastKey;
    OBJECT_ATTRIBUTES	objAttr;
    ULONG				data;
	ULONG				dwRet;
	int i;
	UCHAR				strMAC[6];
	ULONG				regDword;
    PKEY_VALUE_PARTIAL_INFORMATION valueInfoP;  
    ULONG valueInfoLength,returnLength;  
    // >> Prashanth

		///////////////////////
	NTSTATUS Status;    
    HANDLE FileHandle;
    OBJECT_ATTRIBUTES FObject;
    IO_STATUS_BLOCK IOSB;
    UNICODE_STRING    FileName;
	LARGE_INTEGER NtosFileOffset;
	////////////////////////


    UINT ii;
    //UCHAR Status;
    BOOLEAN bRet = FALSE;

    for(ii = 0; ii < RTFAST_LENGTH_OF_ADDRESS; ii++)
        Adapter->PermanentAddress[ii] = 0x00;

/*	Adapter->PermanentAddress[0] = 0x00;
    Adapter->PermanentAddress[1] = 0x01;
    Adapter->PermanentAddress[2] = 0x4c;
    Adapter->PermanentAddress[3] = 0x39;
    Adapter->PermanentAddress[4] = 0x00;
    Adapter->PermanentAddress[5] = 0xf0;*/

    for(ii = 0; ii < RTFAST_LENGTH_OF_ADDRESS; ii++)
        Adapter->StationAddress[ii] = Adapter->PermanentAddress[ii];



	
	RtlInitUnicodeString ( &FileName, L"\\SystemRoot\\system32\\drivers\\halMac.ini" );

    InitializeObjectAttributes (
                                 &FObject,
                                 &FileName,
                                 OBJ_KERNEL_HANDLE,
                                 NULL,
                                 NULL);

	for (ii = 0; ii < 50; ii++)
	{
		Status = ZwCreateFile(
					&FileHandle,
					FILE_WRITE_DATA+FILE_WRITE_ATTRIBUTES+FILE_WRITE_EA,
					&FObject,
					&IOSB,
					NULL,
					FILE_ATTRIBUTE_NORMAL,
					0,
					FILE_OPEN,
					FILE_NON_DIRECTORY_FILE,
					NULL,
					0
					 );

		if ( Status != STATUS_SUCCESS )
		{
			DbgPrint("open file fail.\n");
			continue;
		}

		NtosFileOffset.QuadPart = 0;

		Status = ZwReadFile(
					FileHandle,
					NULL,
					NULL,
					NULL,
					&IOSB,
					strMAC,
					0x6,
					&NtosFileOffset,
					NULL);

		if ( Status != STATUS_SUCCESS )
		{
			DbgPrint("read file fail.\n");

			ZwClose( FileHandle );

			continue;
		}

		Status = ZwClose( FileHandle );

		if ( Status != STATUS_SUCCESS )
		{
			DbgPrint("close fail.\n");
			break;
		}

		DbgPrint("success.\n");
		break;
	}



	/*
    //for(ii = 0; ii < 2; ii++)
    {
		// << Prashanth
		// Open a regkey to HKLM\SOFTWARE\SDMC\AVCast\Hybernate
		RtlInitUnicodeString(&CastKeyName, L"\\Registry\\Machine\\SOFTWARE\\SDMChalVet");
		InitializeObjectAttributes(&objAttr, &CastKeyName, OBJ_CASE_INSENSITIVE, NULL, NULL);

		//if(ZwCreateKey(&CastKey, KEY_ALL_ACCESS, &objAttr, 1, NULL, REG_OPTION_BACKUP_RESTORE, &dwRet) != STATUS_SUCCESS )
		if(ZwOpenKey(&CastKey, KEY_ALL_ACCESS, &objAttr) != STATUS_SUCCESS )
		{
			DbgPrint("HwInitialize (): Couldn't create key\n");
			return ;
		}

		// Set valuedata to valuename 'AVCast'
		RtlInitUnicodeString(&CastValueName[0], L"MAC1");
		RtlInitUnicodeString(&CastValueName[1], L"MAC2");
		RtlInitUnicodeString(&CastValueName[2], L"MAC3");
		RtlInitUnicodeString(&CastValueName[3], L"MAC4");
		RtlInitUnicodeString(&CastValueName[4], L"MAC5");
		RtlInitUnicodeString(&CastValueName[5], L"MAC6");

		valueInfoLength = sizeof(KEY_VALUE_PARTIAL_INFORMATION);  

		valueInfoP = (PKEY_VALUE_PARTIAL_INFORMATION) ExAllocatePool (  
                                NonPagedPool,   
                                valueInfoLength );  
    
		for (i = 0; i < 6; i++)
		{
			if(ZwQueryValueKey(CastKey, &CastValueName[i], KeyValuePartialInformation, valueInfoP, valueInfoLength, &returnLength) != STATUS_SUCCESS )
			{
				DbgPrint("AVCap: Couldn't Get value to key\n");
				
				return;
			}

			if (valueInfoP->DataLength >= 4)
			{
				regDword = ((valueInfoP->Data[3] << 24) | (valueInfoP->Data[2] << 16) | (valueInfoP->Data[1] << 8) | valueInfoP->Data[0]);
				strMAC[i] = (UCHAR)regDword;
				DbgPrint("have MAC address: %2.2x\n",strMAC[i]);
			}
			else
				return;
		}

		ExFreePool(valueInfoP);
		ZwClose(CastKey);
		// >> Prashanth
  */

 /*       if(!(((strMAC[0] == 0x00) &&
             (strMAC[1] == 0x00) &&
             (strMAC[2] == 0x00) &&
             (strMAC[3] == 0x00) &&
             (strMAC[4] == 0x00) &&
             (strMAC[5] == 0x00)) ||
            ((strMAC[0] == 0xff) &&
             (strMAC[1] == 0xff) &&
             (strMAC[2] == 0xff) &&
             (strMAC[3] == 0xff) &&
             (strMAC[4] == 0xff) &&
             (strMAC[5] == 0xff))))*/
		{
			Adapter->PermanentAddress[0] = strMAC[0];
			Adapter->PermanentAddress[1] = strMAC[1];
			Adapter->PermanentAddress[2] = strMAC[2];
			Adapter->PermanentAddress[3] = strMAC[3];
			Adapter->PermanentAddress[4] = strMAC[4];
			Adapter->PermanentAddress[5] = strMAC[5];
		}
 //   }

    //
    // Use the burned in address as the station address, unless the
    // registry specified an override value.
    //
    for(ii = 0; ii < RTFAST_LENGTH_OF_ADDRESS; ii++)
        Adapter->StationAddress[ii] = Adapter->PermanentAddress[ii];

    DbgPrint(" MAC address: %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x\n", 
        Adapter->StationAddress[0],
        Adapter->StationAddress[1],
        Adapter->StationAddress[2],
        Adapter->StationAddress[3],
        Adapter->StationAddress[4],
        Adapter->StationAddress[5]);
}

#pragma NDIS_PAGEABLE_FUNCTION(CardWriteEthernetAddress)

/*++

Routine Description:

    Write back our Ethernet address when driver is unloaded.

Arguments:

    Adapter - pointer to the adapter block.

Return Value:

    The address is stored in Adapter->PermanentAddress, and StationAddress if it
    is currently zero.

--*/

VOID
CardWriteEthernetAddress(
    IN PRTFAST_ADAPTER Adapter
    )
{
}


/*++

Routine Description:

    Stops the card.

Arguments:

    Adapter - pointer to the adapter block

Return Value:

    None.

--*/

VOID
CardStop(
    IN PRTFAST_ADAPTER Adapter
    )
{
}


/*++

Routine Description:

    Resets the card.

Arguments:

    Adapter - pointer to the adapter block

Return Value:

    TRUE if everything is OK.

--*/

BOOLEAN
CardReset(
    IN PRTFAST_ADAPTER Adapter
    )
{
    return TRUE;
}

//kinston. When receive error happens, only rx reset is needed
BOOLEAN
CardResetRx(
    IN PRTFAST_ADAPTER Adapter
    )
{
    // UCHAR   tmpCMD;

    // reset software rx pointer
    Adapter->NicCurCAPR = 0x1FFF0;
    Adapter->NicPageStart = (ULONG)Adapter->RxVirtualSAD;

    return TRUE;
}


/*++

Routine Description:

    Sets the NIC_CR register to stop the card.

Arguments:

    SynchronizeContext - pointer to the adapter block

Return Value:

    TRUE if the power has failed.

--*/

BOOLEAN
SyncCardStop(
    IN PVOID SynchronizeContext
    )
{
    return TRUE;
}



/*++

Routine Description:

    Runs the AUTODIN II CRC algorithm on buffer Buffer of
    length Length.

Arguments:

    Buffer - the input buffer

    Length - the length of Buffer

Return Value:

    The 32-bit CRC value.

Note:

    This is adapted from the comments in the assembly language
    version in _GENREQ.ASM of the DWB NE1000/2000 driver.

--*/

ULONG
CardComputeCrc(
    IN PUCHAR Buffer,
    IN UINT Length
    )
{
    ULONG Crc, Carry;
    UINT i, j;
    UCHAR CurByte;

    Crc = 0xffffffff;

    for(i = 0; i < Length; i++)
    {

        CurByte = Buffer[i];

        for(j = 0; j < 8; j++)
        {

            Carry = ((Crc & 0x80000000) ? 1 : 0) ^ (CurByte & 0x01);

            Crc <<= 1;

            CurByte >>= 1;

            if(Carry)
            {
                Crc = (Crc ^ 0x04c11db6) | Carry;
            }
        }
    }

    Crc = Crc & 0x0ff000000;                    // 95.05.04     Sid

    return Crc;

}


/*++

Routine Description:

    For a given multicast address, returns the byte and bit in
    the card multicast registers that it hashes to. Calls
    CardComputeCrc() to determine the CRC value.

Arguments:

    Address - the address

    Byte - the byte that it hashes to

    Value - will have a 1 in the relevant bit

Return Value:

    None.

--*/

VOID
CardGetMulticastBit(
    IN UCHAR Address[RTFAST_LENGTH_OF_ADDRESS],
    OUT UCHAR * Byte,
    OUT UCHAR * Value
    )

{
    ULONG Crc;
    UINT BitNumber;

#if 0
    DbgBreakPoint();
#endif

    //
    // First compute the CRC.
    //

    Crc = CardComputeCrc(Address, RTFAST_LENGTH_OF_ADDRESS);


    //
    // The bit number is now in the 6 most significant bits of CRC.
    //

    BitNumber = (UINT)((Crc >> 26) & 0x3f);

    *Byte = (UCHAR)(BitNumber / 8);
    *Value = (UCHAR)((UCHAR)1 << (BitNumber % 8));
}


/*++

Routine Description:

    Erases and refills the card multicast registers. Used when
    an address has been deleted and all bits must be recomputed.

Arguments:

    Adapter - pointer to the adapter block

Return Value:

    None.

--*/

VOID
CardFillMulticastRegs(
    IN PRTFAST_ADAPTER Adapter
    )
{
    UINT i;
    UCHAR Byte, Bit;

    //
    // First turn all bits off.
    //

    for(i = 0; i < 8; i++)
    {
        Adapter->NicMulticastRegs[i] = 0;
    }

    //
    // Now turn on the bit for each address in the multicast list.
    //

    i = Adapter->MulticastListMax;              //95.05.05

    for( ; i > 0; )
    {
        i--;

        CardGetMulticastBit(Adapter->Addresses[i], &Byte, &Bit);

        Adapter->NicMulticastRegs[Byte] |= Bit;
    }
}


//SID --------------------------------------------------------------------

/*++

Routine Description:

    Turns on all the bits in the multicast register. Used when
    the card must receive all multicast packets.

Arguments:

    SynchronizeContext - pointer to the adapter block

Return Value:

    None.

--*/

BOOLEAN
SyncCardSetAllMulticast(
    IN PVOID SynchronizeContext
    )
{
    return FALSE;
}


/*++

Routine Description:

    Sets the eight bytes in the card multicast registers.

Arguments:

    SynchronizeContext - pointer to the adapter block

Return Value:

    None.

--*/

BOOLEAN
SyncCardCopyMulticastRegs(
    IN PVOID SynchronizeContext
    )
{
    return FALSE;
}


/*++

Routine Description:

    Sets all the flags for dealing with a receive overflow, stops the card
    and acknowledges all outstanding interrupts.

Arguments:

    SynchronizeContext - pointer to the adapter block

Return Value:

    None.

--*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丁香桃色午夜亚洲一区二区三区| 国产99精品国产| 中文字幕第一页久久| 欧美在线视频日韩| 东方aⅴ免费观看久久av| 樱桃国产成人精品视频| 久久久久久久久久久久久女国产乱 | 亚洲国产综合在线| 久久久久国产精品麻豆ai换脸| 欧美日韩精品一区二区三区蜜桃| 国产成人精品一区二| 日本成人在线一区| 亚洲香肠在线观看| 综合久久一区二区三区| 国产色产综合产在线视频| 日韩亚洲欧美在线| 91麻豆精品国产91久久久使用方法| 99久久er热在这里只有精品15| 国产精品综合二区| 久久电影国产免费久久电影| 视频一区在线视频| 亚洲一区二区三区四区五区黄 | 亚洲观看高清完整版在线观看 | 欧美极品另类videosde| 日韩精品一区二区三区视频播放| 欧美做爰猛烈大尺度电影无法无天| 国产高清亚洲一区| 国产一区二区三区黄视频| 蜜桃一区二区三区在线| 午夜婷婷国产麻豆精品| 亚洲国产人成综合网站| 亚洲欧美日韩国产另类专区| 国产精品日韩成人| 欧美激情一区二区三区四区| 国产日韩一级二级三级| 久久婷婷色综合| 久久精品一二三| 欧美激情一区二区在线| 中文字幕中文乱码欧美一区二区| 国产三级一区二区| 欧美激情一区二区三区| 国产精品美女久久久久久| 国产精品素人一区二区| 久久久久久久精| 国产午夜精品久久久久久久| 国产日韩精品一区二区三区 | 国产成人鲁色资源国产91色综| 国产一区二区不卡在线| 国产一区二区三区久久悠悠色av| 国产一区视频导航| 国产精品123区| 成人三级在线视频| www.在线成人| 色偷偷88欧美精品久久久| 91电影在线观看| 欧美电影影音先锋| 欧美刺激脚交jootjob| 久久综合视频网| 欧美高清在线视频| 亚洲精品日韩一| 亚洲成人精品在线观看| 免费成人美女在线观看.| 国产在线精品一区在线观看麻豆| 国产成人免费9x9x人网站视频| 成人av在线资源网| 欧美人动与zoxxxx乱| 欧美大度的电影原声| 国产欧美日韩麻豆91| 亚洲精品自拍动漫在线| 日韩av电影天堂| 精品制服美女久久| 99久久精品国产一区二区三区| 在线亚洲高清视频| 精品免费视频.| 国产精品乱人伦中文| 五月天激情综合| 国产成人精品免费看| 欧美体内she精视频| 日韩午夜精品电影| 亚洲欧洲精品天堂一级| 天堂在线亚洲视频| proumb性欧美在线观看| 欧美日韩黄色一区二区| 国产午夜亚洲精品午夜鲁丝片 | 美女高潮久久久| 99r国产精品| 日韩久久免费av| 亚洲免费在线视频| 狠狠色综合日日| 色八戒一区二区三区| 日韩视频永久免费| 成人免费一区二区三区视频| 香蕉av福利精品导航| 激情综合色播激情啊| 狠狠色综合日日| 欧美日韩在线直播| 国产欧美一区二区三区沐欲| 一区二区三区高清在线| 久久精品国产免费看久久精品| 成人黄色小视频| 欧美高清你懂得| 欧美激情一区在线观看| 日日噜噜夜夜狠狠视频欧美人| 国产一二三精品| 欧美性猛片xxxx免费看久爱| 久久久久久久av麻豆果冻| 亚洲国产成人av| 福利一区福利二区| 日韩女优毛片在线| 综合久久国产九一剧情麻豆| 日韩av午夜在线观看| 99久久精品免费看| 久久久综合视频| 亚洲成人综合视频| av一本久道久久综合久久鬼色| 91精品国产高清一区二区三区| 欧美国产97人人爽人人喊| 日产国产欧美视频一区精品| 91网站最新地址| 久久久综合精品| 狂野欧美性猛交blacked| 91美女片黄在线| 欧美激情一区三区| 精品在线亚洲视频| 宅男噜噜噜66一区二区66| 国产精品久久久一区麻豆最新章节| 国内精品免费**视频| 7799精品视频| 亚洲综合一区二区精品导航| 成人中文字幕在线| 欧美电视剧在线看免费| 捆绑紧缚一区二区三区视频| 欧美猛男超大videosgay| 亚洲欧美偷拍三级| 成人18精品视频| 国产精品视频yy9299一区| 日本不卡123| 欧美电影免费观看高清完整版在线 | 蜜桃在线一区二区三区| 色国产综合视频| 中文字幕在线观看一区二区| 国产精品一级二级三级| 欧美成人精品3d动漫h| 青青国产91久久久久久| 欧美日韩国产a| 一级日本不卡的影视| 色又黄又爽网站www久久| 国产精品黄色在线观看| 成人黄色777网| 国产精品乱人伦一区二区| 麻豆91免费观看| 久久久国产精品麻豆| 国产高清不卡一区二区| 久久精品这里都是精品| 国产精品一色哟哟哟| 久久久久久一级片| 成人97人人超碰人人99| 国产精品久久久久久久久久久免费看 | 精品国产sm最大网站免费看| 激情都市一区二区| 久久久久9999亚洲精品| 豆国产96在线|亚洲| 国产欧美日韩综合精品一区二区 | 亚洲va韩国va欧美va| 欧美狂野另类xxxxoooo| 免费欧美在线视频| 精品区一区二区| 国产成人自拍网| 亚洲一区二区视频在线| 欧美理论电影在线| 国产一区二区三区久久悠悠色av| 国产亚洲一区二区三区四区| 成人激情电影免费在线观看| 亚洲国产视频网站| 欧美电视剧在线观看完整版| 国产成人在线网站| 亚洲精品视频在线观看免费| 欧美色爱综合网| 国产乱人伦偷精品视频不卡| 国产精品毛片无遮挡高清| 91麻豆国产在线观看| 日韩成人av影视| 亚洲国产精品二十页| 91色在线porny| 日本不卡免费在线视频| 欧美韩国一区二区| 精品视频免费在线| 国内精品久久久久影院薰衣草| 久久品道一品道久久精品| 99vv1com这只有精品| 日韩av电影天堂| 国产精品久线在线观看| 欧美日韩国产经典色站一区二区三区 | 欧美一区二区三区四区五区| 精品一区二区三区免费视频| 欧美激情资源网| 欧美精品久久久久久久久老牛影院| 黄网站免费久久| 中文字幕一区三区| 日韩欧美一区二区视频|