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

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

?? asyncmac.c

?? wince3.0的源碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* Copyright (c) 1999-2000 Microsoft Corporation.  All rights reserved. */
#include "windows.h"
#include "tapi.h"
#include "ndis.h"
#include "ndiswan.h"
#include "ndistapi.h"
#include "asyncmac.h"
#include "frame.h"

#include "cclib.h"

#define DEV_CLASS_COMM_DATAMODEM TEXT("comm/datamodem")

#ifdef DEBUG
DBGPARAM dpCurSettings = {
    TEXT("AsyncMac"), {
    TEXT("Init"),     TEXT("Undefined"),TEXT("Undefined"),TEXT("Undefined"),
    TEXT("Undefined"),TEXT("Send"),		TEXT("Undefined"),TEXT("Undefined"),
    TEXT("Tapi"),     TEXT("Recv"),     TEXT("Interface"),TEXT("Misc"),
    TEXT("Alloc"),    TEXT("Function"), TEXT("Warning"),  TEXT("Error") },
    0x0000C000
};
#endif // DEBUG

HINSTANCE			v_hInstance;

NDIS_HANDLE			v_hNdisWrapper;
PDRIVER_OBJECT		v_AsyncDriverObject;
DWORD				v_GlobalAdapterCount;

// Because this driver only supports a single adapter, it is unnecessary to have
// a list of active adapters.  Instead, a single pointer to the active adapter (NULL
// if none active) is sufficient.  

PASYNCMAC_ADAPTER	v_pAdapter;
CRITICAL_SECTION	v_AdapterCS;


NDIS_OID SupportedOids[] = {
    OID_GEN_MAC_OPTIONS,
    OID_GEN_SUPPORTED_LIST,
    OID_GEN_MEDIA_SUPPORTED,
    OID_GEN_MEDIA_IN_USE,
    OID_GEN_VENDOR_DESCRIPTION,
    OID_GEN_VENDOR_ID,
    OID_GEN_DRIVER_VERSION,
    OID_GEN_HARDWARE_STATUS,
    OID_GEN_LINK_SPEED,
    OID_GEN_MAXIMUM_LOOKAHEAD,
    OID_GEN_CURRENT_LOOKAHEAD,
    OID_GEN_MAXIMUM_FRAME_SIZE,
    OID_GEN_TRANSMIT_BLOCK_SIZE,
    OID_GEN_RECEIVE_BLOCK_SIZE,
    OID_GEN_MAXIMUM_TOTAL_SIZE,

    OID_GEN_RECEIVE_BUFFER_SPACE,
    OID_GEN_TRANSMIT_BUFFER_SPACE,
	
    OID_WAN_CURRENT_ADDRESS,
    OID_WAN_PERMANENT_ADDRESS,
    OID_WAN_GET_INFO,
    OID_WAN_GET_LINK_INFO,
    OID_WAN_SET_LINK_INFO,
    OID_WAN_MEDIUM_SUBTYPE,
    OID_WAN_HEADER_FORMAT,
	

/* NOT Supported yet	

    OID_TAPI_GET_ADDRESS_CAPS,
    OID_TAPI_GET_EXTENSION_ID,
    OID_TAPI_NEGOTIATE_EXT_VERSION,
	*/
	
    OID_TAPI_GET_DEV_CAPS,
    OID_TAPI_PROVIDER_INITIALIZE,
	OID_TAPI_TRANSLATE_ADDRESS,
    OID_TAPI_OPEN,
	OID_TAPI_MAKE_CALL,
	OID_TAPI_DROP,
	OID_TAPI_CLOSE_CALL,
    OID_TAPI_CLOSE,

	/*
    OID_WAN_GET_BRIDGE_INFO,
    OID_WAN_GET_COMP_INFO,
    OID_WAN_GET_STATS_INFO,
    OID_WAN_LINE_COUNT,
    OID_WAN_PROTOCOL_TYPE,
    OID_WAN_QUALITY_OF_SERVICE,
    OID_WAN_SET_BRIDGE_INFO,
    OID_WAN_SET_COMP_INFO,
*/
};

#if DEBUG
PUCHAR
GetOidString(
    NDIS_OID Oid
    )
{
    PUCHAR OidName = NULL;
    #define OID_CASE(oid) case (oid): OidName = #oid; break
    switch (Oid)
    {
        OID_CASE(OID_GEN_CURRENT_LOOKAHEAD);
        OID_CASE(OID_GEN_DRIVER_VERSION);
        OID_CASE(OID_GEN_HARDWARE_STATUS);
        OID_CASE(OID_GEN_LINK_SPEED);
        OID_CASE(OID_GEN_MAC_OPTIONS);
        OID_CASE(OID_GEN_MAXIMUM_LOOKAHEAD);
        OID_CASE(OID_GEN_MAXIMUM_FRAME_SIZE);
        OID_CASE(OID_GEN_MAXIMUM_TOTAL_SIZE);
        OID_CASE(OID_GEN_MEDIA_SUPPORTED);
        OID_CASE(OID_GEN_MEDIA_IN_USE);
        OID_CASE(OID_GEN_RECEIVE_BLOCK_SIZE);
        OID_CASE(OID_GEN_RECEIVE_BUFFER_SPACE);
        OID_CASE(OID_GEN_SUPPORTED_LIST);
        OID_CASE(OID_GEN_TRANSMIT_BLOCK_SIZE);
        OID_CASE(OID_GEN_TRANSMIT_BUFFER_SPACE);
        OID_CASE(OID_GEN_VENDOR_DESCRIPTION);
        OID_CASE(OID_GEN_VENDOR_ID);
		OID_CASE(OID_802_3_CURRENT_ADDRESS);
        OID_CASE(OID_TAPI_ACCEPT);
        OID_CASE(OID_TAPI_ANSWER);
        OID_CASE(OID_TAPI_CLOSE);
        OID_CASE(OID_TAPI_CLOSE_CALL);
        OID_CASE(OID_TAPI_CONDITIONAL_MEDIA_DETECTION);
        OID_CASE(OID_TAPI_CONFIG_DIALOG);
        OID_CASE(OID_TAPI_DEV_SPECIFIC);
        OID_CASE(OID_TAPI_DIAL);
        OID_CASE(OID_TAPI_DROP);
        OID_CASE(OID_TAPI_GET_ADDRESS_CAPS);
        OID_CASE(OID_TAPI_GET_ADDRESS_ID);
        OID_CASE(OID_TAPI_GET_ADDRESS_STATUS);
        OID_CASE(OID_TAPI_GET_CALL_ADDRESS_ID);
        OID_CASE(OID_TAPI_GET_CALL_INFO);
        OID_CASE(OID_TAPI_GET_CALL_STATUS);
        OID_CASE(OID_TAPI_GET_DEV_CAPS);
        OID_CASE(OID_TAPI_GET_DEV_CONFIG);
        OID_CASE(OID_TAPI_GET_EXTENSION_ID);
        OID_CASE(OID_TAPI_GET_ID);
        OID_CASE(OID_TAPI_GET_LINE_DEV_STATUS);
        OID_CASE(OID_TAPI_MAKE_CALL);
        OID_CASE(OID_TAPI_NEGOTIATE_EXT_VERSION);
        OID_CASE(OID_TAPI_OPEN);
        OID_CASE(OID_TAPI_PROVIDER_INITIALIZE);
        OID_CASE(OID_TAPI_PROVIDER_SHUTDOWN);
        OID_CASE(OID_TAPI_SECURE_CALL);
        OID_CASE(OID_TAPI_SELECT_EXT_VERSION);
        OID_CASE(OID_TAPI_SEND_USER_USER_INFO);
        OID_CASE(OID_TAPI_SET_APP_SPECIFIC);
        OID_CASE(OID_TAPI_SET_CALL_PARAMS);
        OID_CASE(OID_TAPI_SET_DEFAULT_MEDIA_DETECTION);
        OID_CASE(OID_TAPI_SET_DEV_CONFIG);
        OID_CASE(OID_TAPI_SET_MEDIA_MODE);
        OID_CASE(OID_TAPI_SET_STATUS_MESSAGES);
		OID_CASE(OID_TAPI_TRANSLATE_ADDRESS);
        OID_CASE(OID_WAN_CURRENT_ADDRESS);
        OID_CASE(OID_WAN_GET_BRIDGE_INFO);
        OID_CASE(OID_WAN_GET_COMP_INFO);
        OID_CASE(OID_WAN_GET_INFO);
        OID_CASE(OID_WAN_GET_LINK_INFO);
        OID_CASE(OID_WAN_GET_STATS_INFO);
        OID_CASE(OID_WAN_HEADER_FORMAT);
        OID_CASE(OID_WAN_LINE_COUNT);
        OID_CASE(OID_WAN_MEDIUM_SUBTYPE);
        OID_CASE(OID_WAN_PERMANENT_ADDRESS);
        OID_CASE(OID_WAN_PROTOCOL_TYPE);
        OID_CASE(OID_WAN_QUALITY_OF_SERVICE);
        OID_CASE(OID_WAN_SET_BRIDGE_INFO);
        OID_CASE(OID_WAN_SET_COMP_INFO);
        OID_CASE(OID_WAN_SET_LINK_INFO);

        default:
            OidName = "Unknown OID";
            break;
    }
    return OidName;
}
#endif

//
// This constant is used for places where NdisAllocateMemory
// needs to be called and the HighestAcceptableAddress does
// not matter.
//
NDIS_PHYSICAL_ADDRESS HighestAcceptableMax = NDIS_PHYSICAL_ADDRESS_CONST(-1,-1);

// Number of bytes to allocate before and after each block to look for corruption
#define GUARD_REGION_SIZE	32
#define GUARD_BYTE_VALUE	(BYTE)'a'

#ifdef DEBUG

BOOL
memchk(
	  BYTE *pMem,
	  BYTE  bValue,
	  UINT	nBytes)
//
//	Return true if the bytes at pMem are all set to bValue.
//
{
	BYTE *pStartMem = pMem;
	UINT nOrigBytes = nBytes;

	//DEBUGMSG (1, (TEXT("Check %x bytes at %x\n"), nBytes, pMem));
	while (nBytes--)
		if (*pMem++ != bValue)
		{
			DumpMem(pStartMem, nOrigBytes);
			DebugBreak();
			return FALSE;
		}

	return TRUE;
}

BOOL
AsyncMacGuardRegionOk(
	IN	void	*pMem,
	IN	UINT	nBytes)
//
//	Validate the guard regions at the start and end of a block of allocated memory.
//
{
	BOOL bResult;

	pMem = (BYTE *)pMem - GUARD_REGION_SIZE;
	bResult =  memchk(pMem, GUARD_BYTE_VALUE, GUARD_REGION_SIZE)
			&& memchk((BYTE *)pMem + nBytes + GUARD_REGION_SIZE, GUARD_BYTE_VALUE, GUARD_REGION_SIZE);

	if (bResult == FALSE)
		DEBUGMSG(1, (TEXT("MemCorrupted: pMem=%x size=%x\n"), pMem, nBytes));

	return bResult;
}

#endif

void *
AsyncMacAllocateMemory(
	IN	UINT	nBytes)
//
//	Call NdisAllocateMemory to allocate a block of the requested size.
//	In DEBUG mode, allocate leading and trailing guard regions to look for memory corruption.
//
{
	void			*pMem;
	NDIS_STATUS		 Status;

#ifdef DEBUG
	nBytes += 2 * GUARD_REGION_SIZE;
#endif
    Status = NdisAllocateMemory( (PVOID *)&pMem, nBytes, 0, HighestAcceptableMax);
    if (Status != NDIS_STATUS_SUCCESS)
	{
		DEBUGMSG (ZONE_ERROR, (TEXT("+ASYNCMAC: AllocMem %d bytes failed\n")));
		pMem = NULL;
	}
#ifdef DEBUG
	else
	{
		memset(pMem, GUARD_BYTE_VALUE, GUARD_REGION_SIZE);
		memset((BYTE *)pMem + nBytes - GUARD_REGION_SIZE, GUARD_BYTE_VALUE, GUARD_REGION_SIZE);
		pMem = (BYTE *)pMem + GUARD_REGION_SIZE;

		ASSERT(AsyncMacGuardRegionOk(pMem, nBytes - 2 * GUARD_REGION_SIZE));
	}
#endif
	return pMem;
}

void
AsyncMacFreeMemory(
	IN	void	*pMem,
	IN	UINT	 nBytes)
{
#ifdef DEBUG
	ASSERT(AsyncMacGuardRegionOk(pMem, nBytes));
	pMem = (BYTE *)pMem - GUARD_REGION_SIZE;
	nBytes += 2 * GUARD_REGION_SIZE;
#endif
    NdisFreeMemory(pMem, nBytes, 0);
}



//
// ZZZ Portable interface.
//
NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT DriverObject,
    IN PUNICODE_STRING RegistryPath)


/*++

Routine Description:

    This is the primary initialization routine for the async driver.
    It is simply responsible for the intializing the wrapper and registering
    the MAC.  It then calls a system and architecture specific routine that
    will initialize and register each adapter.

Arguments:

    DriverObject - Pointer to driver object created by the system.

Return Value:

    The status of the operation.

--*/

{
	NDIS_STATUS	InitStatus;
    NDIS_MINIPORT_CHARACTERISTICS AsyncChar;

	DEBUGMSG (ZONE_INIT|ZONE_INTERFACE,
			  (TEXT("+ASYNCMAC:DriverEntry(0x%X, 0x%X)\r\n"),
			   DriverObject, RegistryPath));

    v_AsyncDriverObject = DriverObject;

	v_pAdapter = NULL;

    //
    //  Initialize the wrapper.
    //
    NdisMInitializeWrapper(&v_hNdisWrapper, DriverObject,
						   RegistryPath, NULL);

    //
    //  Initialize the MAC characteristics for the call to NdisRegisterMac.
    //
	NdisZeroMemory(&AsyncChar, sizeof(AsyncChar));

    AsyncChar.MajorNdisVersion = ASYNC_NDIS_MAJOR_VERSION;
    AsyncChar.MinorNdisVersion = ASYNC_NDIS_MINOR_VERSION;
	AsyncChar.Reserved = NDIS_USE_WAN_WRAPPER;

	//
	// We do not need the following handlers:
	// CheckForHang
	// DisableInterrupt
	// EnableInterrupt
	// HandleInterrupt
	// ISR
	// Send
	// TransferData
	//
	AsyncChar.HaltHandler = MpHalt;
	AsyncChar.InitializeHandler = MpInit;
	AsyncChar.QueryInformationHandler = MpQueryInfo;
	AsyncChar.ReconfigureHandler = MpReconfigure;
	AsyncChar.ResetHandler = MpReset;
	AsyncChar.WanSendHandler = MpSend;
	AsyncChar.SetInformationHandler = MpSetInfo;

	InitStatus = NdisMRegisterMiniport(v_hNdisWrapper,
									   &AsyncChar,
									   sizeof(AsyncChar));

    if ( InitStatus == NDIS_STATUS_SUCCESS ) {

		DEBUGMSG (ZONE_INIT|ZONE_INTERFACE,
				  (TEXT("-ASYNCMAC:DriverEntry: Returning STATUS_SUCCESS\r\n"),
				   DriverObject, RegistryPath));

		return NDIS_STATUS_SUCCESS;
    }

    NdisTerminateWrapper(v_hNdisWrapper, DriverObject);

	DEBUGMSG (ZONE_INIT|ZONE_INTERFACE|ZONE_ERROR,
			  (TEXT("-ASYNCMAC:DriverEntry: Returning STATUS_FAILURE\r\n"),
			   DriverObject, RegistryPath));

    return NDIS_STATUS_FAILURE;
}

//
// Standard Windows DLL entrypoint.
// Since Windows CE NDIS miniports are implemented as DLLs, a DLL entrypoint is
// needed.
//
BOOL __stdcall
DllEntry(
  HANDLE hDLL,
  DWORD dwReason,
  LPVOID lpReserved
)
{
	
    switch (dwReason) {
    case DLL_PROCESS_ATTACH:
		v_hInstance = (HINSTANCE) hDLL;
        DEBUGREGISTER(hDLL);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀av一级做a爰片久久| 欧美va天堂va视频va在线| 日韩欧美中文一区二区| 久久精品视频网| 国产精品二三区| 三级欧美韩日大片在线看| 精品一区二区三区蜜桃| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美无乱码久久久免费午夜一区| 3d成人h动漫网站入口| 2022国产精品视频| 亚洲精品成人精品456| 免费一区二区视频| 成人少妇影院yyyy| 欧美亚洲国产怡红院影院| 欧美tk—视频vk| 一区二区不卡在线播放| 久久99国产精品久久99| 色婷婷av久久久久久久| 亚洲一二三级电影| 国产中文字幕一区| 欧美亚洲愉拍一区二区| 久久综合九色综合97婷婷女人| 亚洲精品福利视频网站| 国产一区二区不卡在线| 欧美日韩你懂得| 国产精品久久影院| 毛片基地黄久久久久久天堂| 91在线看国产| 久久在线免费观看| 午夜精品福利久久久| 成人国产精品免费观看动漫| 欧美一级黄色片| 亚洲欧美日韩在线不卡| 国产成人福利片| 日韩欧美国产1| 一区二区三区在线播| 福利电影一区二区三区| 精品国产1区二区| 亚洲午夜久久久久中文字幕久| 懂色av中文一区二区三区| 欧美大度的电影原声| 亚洲一本大道在线| 高清日韩电视剧大全免费| 日韩免费视频一区| 亚洲第一成年网| 一本色道久久加勒比精品| 久久一夜天堂av一区二区三区| 午夜私人影院久久久久| 99久久国产免费看| 中文字幕精品三区| 国产精品一区二区果冻传媒| 欧美一区二区三区免费视频 | 日韩高清不卡一区| 色域天天综合网| 亚洲视频网在线直播| 国产成人av电影在线观看| 久久先锋影音av鲁色资源网| 免费久久精品视频| 欧美日本韩国一区二区三区视频 | 欧美日韩亚洲国产综合| 亚洲激情图片一区| 91在线国产福利| 中文字幕一区二区在线观看 | 国产精品狼人久久影院观看方式| 国内精品久久久久影院薰衣草 | 国产精品456露脸| 欧美精品一区二区三区蜜桃| 精品中文字幕一区二区| 日韩免费视频线观看| 免费观看在线综合| 欧美一级精品大片| 老司机免费视频一区二区| 日韩视频一区二区三区在线播放| 日韩精品欧美成人高清一区二区| 精品视频一区二区不卡| 亚洲va欧美va人人爽午夜| 欧美探花视频资源| 婷婷中文字幕一区三区| 欧美日韩一区中文字幕| 日韩国产欧美在线播放| 日韩三级中文字幕| 韩国女主播成人在线观看| 精品理论电影在线| 国产乱码精品一区二区三区av| 久久久久九九视频| 成人av免费在线播放| 亚洲你懂的在线视频| 91国内精品野花午夜精品| 亚洲国产中文字幕在线视频综合| 欧美三级在线播放| 蜜臀91精品一区二区三区| 久久一区二区视频| 成人黄色在线视频| 一区二区三区四区国产精品| 欧美亚洲国产一区在线观看网站| 亚洲va在线va天堂| 欧美va亚洲va| av一区二区三区黑人| 玉足女爽爽91| 日韩一级免费一区| 国产精品一级片| |精品福利一区二区三区| 欧洲精品在线观看| 久久99国产精品成人| 国产精品欧美一级免费| 91成人免费电影| 六月婷婷色综合| 中文字幕精品—区二区四季| 欧洲视频一区二区| 精品在线一区二区三区| 国产精品五月天| 欧美精品xxxxbbbb| 国产精品亚洲第一区在线暖暖韩国| 日韩美女精品在线| 欧美一区二区三区影视| 不卡av在线网| 日韩电影在线观看电影| 日韩片之四级片| 99国产欧美另类久久久精品| 日韩精品视频网| 国产精品久久久久影院老司| 欧美日韩中文一区| 成人一区在线看| 午夜精品影院在线观看| 欧美国产精品专区| 69精品人人人人| 成人激情电影免费在线观看| 日韩国产欧美在线播放| 国产精品护士白丝一区av| 欧美一级欧美一级在线播放| 波多野洁衣一区| 热久久久久久久| 综合色天天鬼久久鬼色| 26uuu欧美| 欧美日韩性生活| 99久久婷婷国产| 精品制服美女丁香| 亚洲成人动漫一区| 国产精品久久久久久福利一牛影视 | 在线观看视频欧美| 国产成人av福利| 日韩精品一级二级| 亚洲日本在线天堂| 久久久久久久网| 欧美一级专区免费大片| 在线看一区二区| 国产在线精品免费| 日韩专区欧美专区| 一区二区三区波多野结衣在线观看| 国产欧美一区二区精品婷婷| 日韩欧美的一区| 欧美日本在线看| 色哟哟精品一区| 波多野结衣在线aⅴ中文字幕不卡| 激情图区综合网| 日本不卡高清视频| 亚洲国产日韩a在线播放| 日韩一区中文字幕| 国产精品天美传媒| 国产香蕉久久精品综合网| 777a∨成人精品桃花网| 欧美羞羞免费网站| 成人在线视频一区| 粉嫩高潮美女一区二区三区| 精品系列免费在线观看| 免费一级欧美片在线观看| 亚洲妇女屁股眼交7| 亚洲精品五月天| 亚洲素人一区二区| 国产精品福利影院| 久久婷婷成人综合色| 日韩精品一区二区三区视频播放| 欧美在线观看18| 播五月开心婷婷综合| 丁香婷婷综合五月| 成人黄色综合网站| 国产一区在线观看视频| 久久精品国产色蜜蜜麻豆| 午夜激情一区二区三区| 中文字幕中文字幕一区| 精品99一区二区三区| 精品国精品国产| 久久久久九九视频| 精品国产百合女同互慰| 日韩一区二区三区精品视频| 色噜噜狠狠成人中文综合| 91亚洲精品久久久蜜桃网站| av亚洲精华国产精华| 国产成人av一区| 99久久伊人精品| 日本久久精品电影| 色综合天天综合在线视频| 欧美综合一区二区| 91官网在线免费观看| 欧美三级日韩在线| 日韩午夜精品电影| 日韩免费高清电影| 精品日韩一区二区三区免费视频| 日韩亚洲电影在线|