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

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

?? tdiclient.c

?? 好東東
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*++

Copyright (c) 2005  Changzhi Zhou All Rights Reserved

Module Name:

    TDIClient.c

Abstract:

    This module contains the routines relevant to TDI client calls.

Environment:

    Kernel mode

Revision History:

	Changzhi Zhou Feb 5, 2005

--*/
#include "TDIClient.h"
#include "main.h"

NTSTATUS InitializeConnection( PDEVICE_EXTENSION deviceExtension )
/*++

Routine Description:

	1. Open a transport address and get the highest deviceobject of the transport stack.
	2. Build RecvContext in the DeviceExtension
	3. SetTdiEventHandle, includes TDI_EVENT_RECEIVE_DATAGRAM and TDI_EVENT_ERROR

Arguments:

    deviceExtension - pointer to a device object extension.

Return Value:

    NT status code.

--*/
{
	NTSTATUS	status;
	static USHORT		Port = LOCAL_PORT;

	if ( ( deviceExtension->hTransAddr ) || ( deviceExtension->lpTransAddrFileObject ) )
		return STATUS_INVALID_DEVICE_STATE;
	status = TDIOpenTransportAddress( wcharNetDevName,
		&deviceExtension->hTransAddr,
		&deviceExtension->lpTransAddrFileObject,
		Port
		);
	DebugPrint(("OpenTransAddr: handle = %x, lpFileObj = %x, status = %x\n",
		deviceExtension->hTransAddr, deviceExtension->lpTransAddrFileObject, status ));
	if ( status != STATUS_SUCCESS )
	{
		deviceExtension->lpTransAddrFileObject = NULL;
		deviceExtension->hTransAddr				= NULL;
		return status;
	}
	Port += 0x100;
	deviceExtension->TDILowerDeviceObject = IoGetRelatedDeviceObject( deviceExtension->lpTransAddrFileObject );
	DebugPrint(("TDI Provider: 0x%x\n", deviceExtension->TDILowerDeviceObject ));
	if ( deviceExtension->TDILowerDeviceObject == NULL )
	{
		ObDereferenceObject ( deviceExtension->lpTransAddrFileObject );
		ZwClose ( deviceExtension->hTransAddr );
		deviceExtension->lpTransAddrFileObject = NULL;
		deviceExtension->hTransAddr				= NULL;
		return STATUS_UNSUCCESSFUL;
	}

	TDIBuildRecvContext( &deviceExtension->recvContext );

	TDIClnSetEventHandler( deviceExtension->lpTransAddrFileObject,
		deviceExtension->TDILowerDeviceObject, TDI_EVENT_RECEIVE_DATAGRAM,
		TDIEventRecvDatagram, deviceExtension );
	TDIClnSetEventHandler( deviceExtension->lpTransAddrFileObject,
		deviceExtension->TDILowerDeviceObject, TDI_EVENT_ERROR,
		TDIEventError, NULL );
	return status;
}
NTSTATUS Disconnection ( PDEVICE_EXTENSION deviceExtension )
/*++

Routine Description:

	1. SetTdiEventhandle TDI_EVENT_RECEIVE_DATAGRAM to NULL
	2. Free RecvContext in the DeviceExtension
	3. Close an opened transport address.
	3. SetTdiEventHandle, includes TDI_EVENT_RECEIVE_DATAGRAM and TDI_EVENT_ERROR

Arguments:

    deviceExtension - pointer to a device object extension.

Return Value:

    NT status code.

--*/
{
	NTSTATUS	status;
	if ( ( deviceExtension->hTransAddr == NULL ) || ( deviceExtension->lpTransAddrFileObject == NULL ) )
		return STATUS_INVALID_DEVICE_STATE;
	TDIClnSetEventHandler( deviceExtension->lpTransAddrFileObject,
		deviceExtension->TDILowerDeviceObject, TDI_EVENT_RECEIVE_DATAGRAM,
		NULL, deviceExtension );
	TDIFreeRecvContext( &deviceExtension->recvContext );

	ObDereferenceObject ( deviceExtension->lpTransAddrFileObject );
	deviceExtension->lpTransAddrFileObject = NULL;
	status = ZwClose ( deviceExtension->hTransAddr );
	if ( status == STATUS_SUCCESS )
		deviceExtension->hTransAddr = NULL;
	else
	{
		DebugPrint(("ZwClose hTransAddr failed with status %x !\n", status ));
	}
	return status;
}
NTSTATUS	TDISendDatagram(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
	)
/*++

Routine Description:

  This function is called in SampleWrite. It builds a internel irp and send down 
  to the underlying transport. Until the irp completes or timeout, it will return.
  The remote peer's IP address and port are indicated by RemoteAddress and 
  RemotePort in deviceExtension.

	1. TdiBuildInternalDeviceControlIrp for TDI_SEND_DATAGRAM
	2. Allocate and lockpage a MDL based on Irp->MdlAddress
	3. TdiBuildSendDatagram and pass down to the underlying transport device.
	4. Wait 3 seconds for the completion. If timeout, cancel the irp
	5. Set the Irp according with the completed irp.

Note:
	This routine is synchronous.
	It must be running at IRQL = PASSIVE_LEVEL

Arguments:

   DeviceObject - pointer to a device object.

   Irp - pointer to an I/O Request Packet for IRP_MJ_WRITE.

Return Value:

    NT status code.

--*/
{
	NTSTATUS	status;
	PIRP		pIrp;
	PDEVICE_EXTENSION	deviceExtension;
	KEVENT		Event;
	IO_STATUS_BLOCK	IoStatus;
	PMDL		pMdl;
	PVOID		VirtualAddress;
	ULONG		Length;
	EXCEPTION_POINTERS        * pExceptionInfo;
	ULONG                       lclExceptionCode;
	PVOID                       lclExceptionAddr;
	PVOID		SystemAddress;

	TA_IP_ADDRESS	RmtAddress = {1, {TDI_ADDRESS_LENGTH_IP, TDI_ADDRESS_TYPE_IP, { REMOTE_PORT, REMOTE_ADDRESS}}};
	TDI_CONNECTION_INFORMATION RmtInfo = {0, 0, 0, 0, sizeof(RmtAddress), &RmtAddress};

	deviceExtension = ( PDEVICE_EXTENSION )DeviceObject->DeviceExtension;
	RmtAddress.Address->Address->sin_port	= deviceExtension->RemotePort;
	RmtAddress.Address->Address->in_addr	= deviceExtension->RemoteAddress;
	status		= STATUS_SUCCESS;
	KeInitializeEvent( &Event, NotificationEvent, FALSE);
	pIrp = TdiBuildInternalDeviceControlIrp(
		TDI_SEND_DATAGRAM,
		deviceExtension->TDILowerDeviceObject,
		deviceExtension->lpTransAddrFileObject,
		&Event,
		&IoStatus );
	if ( NULL == pIrp )
	{
		DebugPrint(("TDISendDatagram: Allocate Irp failed\n"));
		return STATUS_INSUFFICIENT_RESOURCES;
	}
	VirtualAddress	= MmGetMdlVirtualAddress ( Irp->MdlAddress );
	Length			= MmGetMdlByteCount( Irp->MdlAddress );
	ASSERT ( VirtualAddress && Length );

	pMdl = IoAllocateMdl ( VirtualAddress, Length, FALSE, FALSE, pIrp );
	if ( NULL == pMdl )
	{
		DebugPrint(("TDISendDatagram: Allocate Mdl failed\n"));
		return STATUS_INSUFFICIENT_RESOURCES;
	}
	_try
	{
		MmProbeAndLockPages(pMdl,                     // (Try to) fix buffer.
			KernelMode,
			IoModifyAccess
			);
	}
	_except(
		pExceptionInfo = GetExceptionInformation(),                                                                                                                                                                                                    
		lclExceptionCode = pExceptionInfo->ExceptionRecord->ExceptionCode,                                                                                                                                                                             
		lclExceptionAddr = pExceptionInfo->ExceptionRecord->ExceptionAddress,                                                                                                                                                                          
		EXCEPTION_EXECUTE_HANDLER                                                                                                                                                                                                                      
		)                                                                                                                                                                                                                                               
	{                                                                                                                                                                                                                                                    
		DebugPrint((".TDISendDatagram:  MmProbeAndLockPages() failed.  Error = 0x%08x at 0x%08x\n",
			lclExceptionCode, lclExceptionAddr));
		status = STATUS_UNSUCCESSFUL;
		IoFreeMdl ( pMdl );
		CompleteRequest ( pIrp, status, 0 );
		Irp->IoStatus.Information = 0;
		return status;
	}
	TdiBuildSendDatagram(
		pIrp,
		deviceExtension->TDILowerDeviceObject,
		deviceExtension->lpTransAddrFileObject,
		NULL,
		NULL,
		pMdl,
		Length,
		&RmtInfo
		);
	status = IoCallDriver ( deviceExtension->TDILowerDeviceObject, pIrp );
	if( ( status != STATUS_SUCCESS ) || ( STATUS_PENDING != status ) )
	{
		DebugPrint(("TDISendDatagram: Problem in IoCallDriver with status %x\n", status ));
	}
	if ( status == STATUS_PENDING )
	{
        LARGE_INTEGER TimeOut;
		NTSTATUS		waitStatus;
		DebugPrint(("Send data pending... wait for 3 seconds\n"));
        TimeOut.QuadPart = -30000 * 1000;         // Calculate timeout value (5 seconds from now).
		waitStatus = KeWaitForSingleObject( &Event, Executive, KernelMode, FALSE, &TimeOut);
		if ( STATUS_TIMEOUT == waitStatus )
		{
			DebugPrint(("TDISendDatagram: Send data time out...\n"));
			IoCancelIrp ( pIrp );
			KeWaitForSingleObject( &Event, Executive, KernelMode, FALSE, 0);
		}
	}
	Irp->IoStatus.Information = IoStatus.Information;
	DebugPrint(("TDISendDatagram: Send %d bytes\n", Irp->IoStatus.Information ));
	status = ((STATUS_SUCCESS==status) || (STATUS_PENDING== status)) ? IoStatus.Status : status;
	return status;
}
NTSTATUS TDIEventError(
   IN PVOID TdiEventContext,  // The endpoint's file object.
   IN NTSTATUS Status         // Status code indicating error type.
   )
/*++
	Tdi error handle.
--*/
{
   DebugPrint(("Sample ErrorEventHandler: Status: 0x%8.8X\n", Status) );

   return( STATUS_SUCCESS );
}

NTSTATUS TDIEventRecvDatagram(
    IN PVOID  TdiEventContext,
    IN LONG  SourceAddressLength,
    IN PVOID  SourceAddress,
    IN LONG  OptionsLength,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本视频一区二区| 91极品美女在线| 欧美精品日韩精品| 亚洲欧美日韩系列| 777奇米成人网| 欧美日韩一区久久| 91色在线porny| 亚洲一区视频在线| 亚洲综合色区另类av| 亚洲精品国产视频| 亚洲高清在线视频| 午夜精彩视频在线观看不卡| 石原莉奈一区二区三区在线观看| 午夜国产不卡在线观看视频| 蜜桃av一区二区| 国产乱对白刺激视频不卡| 国产精品白丝av| 波多野结衣91| 欧美主播一区二区三区美女| 欧美乱妇20p| 欧美不卡一区二区三区| 国产视频不卡一区| 亚洲欧美在线观看| 一区二区在线电影| 日韩成人精品在线| 韩日av一区二区| k8久久久一区二区三区| 在线免费视频一区二区| 91精品欧美久久久久久动漫 | 91小视频在线| 欧美日韩精品免费观看视频| 日韩欧美中文字幕精品| 国产嫩草影院久久久久| 亚洲激情自拍偷拍| 久久精品国产99| av资源站一区| 欧美一区二区在线免费观看| 久久蜜臀精品av| 亚洲精品日韩一| 麻豆91精品视频| 不卡视频在线观看| 欧美日韩成人一区二区| 久久久久久黄色| 一区二区激情视频| 国内外成人在线| 色天天综合色天天久久| 精品美女一区二区三区| 亚洲视频电影在线| 美女视频一区二区三区| www.激情成人| 日韩欧美国产不卡| 伊人色综合久久天天人手人婷| 日韩av电影免费观看高清完整版在线观看 | 看电影不卡的网站| 99热国产精品| 欧美xxxxxxxxx| 亚洲三级久久久| 久久9热精品视频| 欧美影院一区二区| 国产偷v国产偷v亚洲高清| 午夜免费欧美电影| 成人免费看片app下载| 日韩丝袜美女视频| 亚洲精品成人在线| 国产成人一区二区精品非洲| 欧美日本一道本在线视频| 国产女人18毛片水真多成人如厕| 日本不卡123| 在线影视一区二区三区| 欧美国产亚洲另类动漫| 极品瑜伽女神91| 欧美日韩一区中文字幕| 国产精品久久久久三级| 国产另类ts人妖一区二区| 538在线一区二区精品国产| 亚洲男人的天堂在线aⅴ视频| 国产不卡在线视频| 日韩欧美黄色影院| 性感美女久久精品| 在线亚洲+欧美+日本专区| 欧美高清在线视频| 国产乱人伦精品一区二区在线观看| 欧美日韩二区三区| 亚洲综合免费观看高清完整版| 高潮精品一区videoshd| 精品国内片67194| 日韩电影一二三区| 欧美日韩高清一区二区不卡| 亚洲影视在线播放| 色婷婷精品久久二区二区蜜臂av | 国产三级精品在线| 国产一区二区在线看| 色哟哟亚洲精品| 日韩一级免费观看| 日本亚洲最大的色成网站www| 欧美午夜精品一区| 亚洲国产成人高清精品| 欧美在线不卡视频| 亚洲最大色网站| 欧洲生活片亚洲生活在线观看| 中文字幕亚洲视频| 成人av资源下载| 国产精品毛片久久久久久| 国产精品白丝av| 欧美国产精品一区二区三区| 成人久久18免费网站麻豆| 国产精品丝袜91| 国产91精品精华液一区二区三区| 日本一区二区三区视频视频| 国产超碰在线一区| 中文字幕一区二区在线观看| 99久久综合色| 亚洲精品乱码久久久久久日本蜜臀| 91蝌蚪porny| 亚洲一区在线看| 欧美精三区欧美精三区| 免费精品视频最新在线| 精品区一区二区| 成人av电影在线| 亚洲三级电影网站| 欧美三级电影在线看| 人人超碰91尤物精品国产| 精品国产乱码久久久久久牛牛| 国产伦精品一区二区三区免费迷| 久久精品一区二区三区四区| 北岛玲一区二区三区四区| 亚洲精品中文字幕在线观看| 欧美日韩精品一区二区天天拍小说| 日韩影视精彩在线| 久久综合色天天久久综合图片| 岛国一区二区三区| 亚洲最色的网站| 精品国产乱码久久久久久久久| 成人免费不卡视频| 一二三区精品视频| 日韩午夜精品电影| 成人va在线观看| 亚洲一级二级三级| 26uuu成人网一区二区三区| av福利精品导航| 日韩成人精品在线| 国产精品福利一区| 欧美日韩成人一区| 成人中文字幕电影| 亚洲成av人片一区二区| 久久久久久久久99精品| 色偷偷久久一区二区三区| 日本女人一区二区三区| 亚洲国产高清不卡| 欧美日韩大陆在线| 国产91综合一区在线观看| 亚洲一区二区欧美| 久久久久久久久久久久久久久99| 91久久精品一区二区三区| 久草热8精品视频在线观看| 亚洲日本在线天堂| 久久亚洲欧美国产精品乐播 | 在线91免费看| 成年人网站91| 麻豆精品在线看| 亚洲精品中文在线观看| 精品日韩成人av| 欧美在线视频全部完| 福利一区二区在线观看| 日韩国产欧美三级| 日韩一区在线免费观看| 欧美大肚乱孕交hd孕妇| 91福利国产成人精品照片| 成人精品亚洲人成在线| 日韩成人一区二区| 亚洲欧美日韩国产中文在线| 国产三级欧美三级日产三级99| 91精品国产麻豆| 91精品福利视频| 99精品欧美一区二区三区小说| 国产一区二区三区高清播放| 天天综合天天综合色| 亚洲裸体xxx| 国产三级精品视频| 26uuu另类欧美亚洲曰本| 欧美妇女性影城| 欧美在线视频你懂得| 97精品电影院| 成人激情免费视频| 国产九色sp调教91| 九一九一国产精品| 日韩电影在线一区二区三区| 亚洲风情在线资源站| 一区二区三区毛片| 综合在线观看色| 国产精品三级av| 国产日韩欧美制服另类| 2021中文字幕一区亚洲| 欧美一区二区久久久| 欧美肥妇free| 欧美人妇做爰xxxⅹ性高电影| 在线观看一区二区精品视频| 日本精品视频一区二区三区| 91网站黄www| 在线免费av一区|