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

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

?? tdiclient.c

?? 好東東
?? C
?? 第 1 頁 / 共 3 頁
字號:
    IN PVOID  Options,
    IN ULONG  ReceiveDatagramFlags,
    IN ULONG  BytesIndicated,
    IN ULONG  BytesAvailable,
    OUT ULONG  *BytesTaken,
    IN PVOID  Tsdu,
    OUT PIRP  *IoRequestPacket
    )
/*++

Routine Description:

  TDI_EVENT_RECEIVE_DATAGRAM handle.
  When a UDP packet from particular address and port arrive, this callback function will be called.
  Usually BytesIndicated is less than or equal to BytesAvailable. If less, a Irp should be buildt
  for the remainder data. This irp has be pre-allocated by TDIBuildRecvContext.

Note:
	Don't forget to call IoSetNextIrpStackLocation to handle the IoRequestPacket.
	Because the stack locations of this irp between this function and underlying transport are identical.

  Pls refer to Windows DDK documentation chapter relevant to this handle.

--*/
{
	LONG	i;
	PUCHAR	p;
	PIRP	pIrp;

	NTSTATUS	status;
	ULONG	BytesToCopy;
	ULONG	stageSize;
	PDEVICE_EXTENSION	deviceExtension;

	deviceExtension = (PDEVICE_EXTENSION)TdiEventContext;
	DebugPrint(("SourceAddress: "));
	p = (PUCHAR)SourceAddress;
	for( i = 0; i < SourceAddressLength; i++)
	{
		DbgPrint("%2x ", p[ i ] );
	}
	DbgPrint(("\n"));
	DebugPrint(("ReceiveDatagramFlags: %x\n", ReceiveDatagramFlags ));
	DebugPrint(("BytesIndicated: %d\n", BytesIndicated ));
	DebugPrint(("BytesAvailable: %d\n", BytesAvailable ));
	*BytesTaken = BytesIndicated;
	CopyToRingBuffer( deviceExtension, (PUCHAR)Tsdu, BytesIndicated );

	*IoRequestPacket = NULL;
	status = STATUS_SUCCESS;
	if ( BytesIndicated < BytesAvailable )
	{
		if ( deviceExtension->recvContext.pIrp )
		{
			pIrp = deviceExtension->recvContext.pIrp;
			DebugPrint(("EventRecvDatagram: pIrp = %x\n", deviceExtension->recvContext.pIrp ));
			TdiBuildReceiveDatagram( pIrp,
				deviceExtension->TDILowerDeviceObject,
				deviceExtension->lpTransAddrFileObject,
				TDIRecvRemainderCompRoutine,
				deviceExtension,
				deviceExtension->recvContext.pMdl,
				0,
				&(deviceExtension->recvContext.ReceiveDatagramInfo),
				&(deviceExtension->recvContext.ReturnInfo),
				TDI_RECEIVE_NORMAL);
			IoSetNextIrpStackLocation ( pIrp );
			*IoRequestPacket = pIrp;
			status = STATUS_MORE_PROCESSING_REQUIRED;
		}
	}
	return status;
}
VOID CopyToRingBuffer(
	PDEVICE_EXTENSION deviceExtension,
	PUCHAR	LinearBuffer,
	ULONG	BytesIndicated )
/*++

Routine Description:

  This function is called by TDIEventRecvDatagram and TDIRecvRemainderCompRoutine.

  It copies linear buffer containing network packet to ring buffer. If source buffer length
  is more than the length of ReceiveBuffer, the last part of LinearBuffer will be copied
  to destination buffer.

  If there is WaitOnMaskIrp in deviceExtension and the WaitMask meets SERIAL_EV_RXCHAR || SERIAL_EV_RLSD,
  it will complete the WaitOnMaskIrp to indicate the application that there are some data arrive.

  The destination ringbuffer, deviceExtension->RxBuffer, is shared with IRP_MJ_READ.
  So the access to the ringbuffer must be synchronous.
	
Arguments:

  deviceExtension	- pointer to device object extension
  LinearBuffer		- Tsdu containing network packets.
  BytesIndicated	- the length of LinearBuffer

Return Value:

    NT status code.

--*/
{
	ULONG	stageSize;
	KIRQL	oldIrql;
	ULONG	BytesToCopy;
	PUCHAR	lpSrc;

	BytesToCopy = BytesIndicated;
	lpSrc		= LinearBuffer;
	if ( BytesIndicated > RINGBUFFER_SIZE )
	{
		lpSrc		= (PUCHAR)LinearBuffer + BytesIndicated - RINGBUFFER_SIZE;
		BytesToCopy = RINGBUFFER_SIZE;
	}
	KeAcquireSpinLock(&deviceExtension->ThreadSpinLock, &oldIrql);
	stageSize = deviceExtension->RxBuffer + RINGBUFFER_SIZE - deviceExtension->lpRx;
	if( BytesToCopy <= stageSize )
		RtlCopyMemory ( deviceExtension->lpRx, lpSrc, BytesToCopy );
	else
	{
		RtlCopyMemory ( deviceExtension->lpRx, lpSrc, stageSize );
		RtlCopyMemory ( deviceExtension->RxBuffer, lpSrc + stageSize, ( BytesToCopy - stageSize ) );
	}
	deviceExtension->lpRx = deviceExtension->RxBuffer + ( ( RINGBUFFER_SIZE - stageSize + BytesToCopy ) % RINGBUFFER_SIZE );
	deviceExtension->SerialStatus.AmountInInQueue += BytesToCopy;
	if ( deviceExtension->SerialStatus.AmountInInQueue > RINGBUFFER_SIZE )
	{
		deviceExtension->lpRead = deviceExtension->lpRx;
		deviceExtension->SerialStatus.AmountInInQueue = RINGBUFFER_SIZE;
	}
	if( ( deviceExtension->WaitOnMaskIrp ) &&
		( ( deviceExtension->WaitMask & SERIAL_EV_RXCHAR ) || ( deviceExtension->WaitMask & SERIAL_EV_RLSD ) ) )
	{
		DebugPrint(("ClientEventRecv: Complete WaitOnMaskIrp\n"));
		deviceExtension->SerialStatus.EofReceived = TRUE;
		*(PULONG)deviceExtension->WaitOnMaskIrp->AssociatedIrp.SystemBuffer = ( SERIAL_EV_RXCHAR | SERIAL_EV_RLSD );
		CompleteRequest( deviceExtension->WaitOnMaskIrp, STATUS_SUCCESS, sizeof( ULONG ) );
		deviceExtension->WaitOnMaskIrp = NULL;
		SampleIoDecrement( deviceExtension );
	}
	KeReleaseSpinLock( &deviceExtension->ThreadSpinLock, oldIrql );	
}
NTSTATUS TDIBuildRecvContext( PRECV_CONTEXT lpContext)
/*++

Routine Description:

  This function is called by InitializeConnection.
  It builds RecvContext, including pIrp, pMdl, and locks the Mdl.
	
Arguments:

  lpContext	- pointer to deviceExtension->recvContext

Return Value:

    NT status code.

--*/
{
	PIRP				pIrp;
	PMDL				pMdl;
	PDEVICE_EXTENSION		deviceExtension;
	EXCEPTION_POINTERS        * pExceptionInfo;
	ULONG                       lclExceptionCode;
	PVOID                       lclExceptionAddr;
	PIO_STACK_LOCATION	ioStack;

	if( lpContext->pIrp || lpContext->pMdl || ( lpContext->RemainderBuffer == NULL ) )
		return STATUS_UNSUCCESSFUL;
	deviceExtension = CONTAINING_RECORD( lpContext, DEVICE_EXTENSION, recvContext );
	pIrp = IoAllocateIrp ( deviceExtension->TDILowerDeviceObject->StackSize + 2, FALSE );
	/*
	Because the irp will be used for many times, TdiBuildInternalDeviceControlIrp is not best.
	*/
/*	pIrp = TdiBuildInternalDeviceControlIrp(
		TDI_RECEIVE_DATAGRAM,
		deviceExtension->TDILowerDeviceObject,
		deviceExtension->lpTransAddrFileObject,
		&lpContext->Event,
		&lpContext->IoStatus
		);
*/
	if (NULL == pIrp)
	{
		DebugPrint(("TdiBuildInternalIrp failed\n"));
		return STATUS_INSUFFICIENT_RESOURCES;
	}else
	{
		DebugPrint(("TDIBuildRecvContext: pIrp = %x\n", pIrp ));
	}
	pMdl = IoAllocateMdl ( lpContext->RemainderBuffer,
		RECVREMAINDER_BUFFER_SIZE, FALSE, FALSE, NULL );
	if (NULL==pMdl)
	{
		goto Error_Exit;
	}
	_try
	{
		// lockpage the Mdl, even though it is allocated based on NonPagesPool
		MmProbeAndLockPages(pMdl,                     // (Try to) fix buffer.
			KernelMode,
			IoModifyAccess
			);
		lpContext->bLocked = TRUE;
		DebugPrint(("RemainderBuffer: 0x%x,  pMdl: 0x%x\n", lpContext->RemainderBuffer, pMdl ));
	}
	_except(
		pExceptionInfo = GetExceptionInformation(),                                                                                                                                                                                                    
		lclExceptionCode = pExceptionInfo->ExceptionRecord->ExceptionCode,                                                                                                                                                                             
		lclExceptionAddr = pExceptionInfo->ExceptionRecord->ExceptionAddress,                                                                                                                                                                          
		EXCEPTION_EXECUTE_HANDLER                                                                                                                                                                                                                      
		)                                                                                                                                                                                                                                               
	{                                                                                                                                                                                                                                                    
		DebugPrint((".TDIClnRecv:  MmProbeAndLockPages() failed.  Error = 0x%08x at 0x%08x\n",
			lclExceptionCode, lclExceptionAddr));
		goto Error_Exit;
	}
	lpContext->pIrp = pIrp;
	lpContext->pMdl = pMdl;
	return STATUS_SUCCESS;
Error_Exit:
	if ( pMdl )
		IoFreeMdl ( pMdl );
	if ( pIrp )
		IoFreeIrp ( pIrp );
	return STATUS_UNSUCCESSFUL;
}
NTSTATUS                                          
TDIRecvRemainderCompRoutine(
	PDEVICE_OBJECT      DeviceObject, // TDI driver's device object.
	PIRP                pIrp,    // Address of completed Irp.
	PVOID               pCtx     // Pointer to context.
	)
/*++

Routine Description:

  Completion routine of IoRequestPacket in TDIEventRecvDatagram.
  It copies receiving data in recvContext.RemainderBuffer to RxBuffer.
  The length of receining data is indicated by pIrp->IoStatus.Information.

Arguments:

    DeviceObject - pointer to the device object
	pIrp		- pointer to completed Irp, which is recvContext->pIrp
	pCtx		- pointer to context, which is deviceExtension

Return Value:

    NT status code.

--*/
{
	PDEVICE_EXTENSION	deviceExtension;
	PRECV_CONTEXT lpContext;
	ULONG			RecvDataLength;
	PUCHAR			lpSrc;

	DebugPrint(("TDIRecvRemainderCompRoutine...\n"));
	RecvDataLength = pIrp->IoStatus.Information;
	deviceExtension = (PDEVICE_EXTENSION)pCtx;
	DebugPrint(("Remainder length: %d\n", RecvDataLength ));
	CopyToRingBuffer ( deviceExtension,
		(PUCHAR)deviceExtension->recvContext.RemainderBuffer,
		RecvDataLength );
	return STATUS_MORE_PROCESSING_REQUIRED;
}
NTSTATUS TDIFreeRecvContext( PRECV_CONTEXT lpContext )
/*++

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品的网站| 欧美性色黄大片| 国产亚洲成aⅴ人片在线观看| 捆绑变态av一区二区三区| 欧美精品v国产精品v日韩精品| 一区二区三区四区视频精品免费| 色呦呦一区二区三区| 亚洲电影中文字幕在线观看| 在线播放国产精品二区一二区四区| 亚洲观看高清完整版在线观看| 欧美二区乱c少妇| 国产美女在线观看一区| 欧美激情中文字幕| 欧美三级日本三级少妇99| 日韩国产一二三区| 日本一区二区三区久久久久久久久不| 成人动漫在线一区| 亚洲午夜久久久久久久久电影网 | 亚洲国产三级在线| 欧美色图一区二区三区| 久久精品理论片| 国产精品免费视频观看| 欧美三级三级三级爽爽爽| 激情小说亚洲一区| 国产精品情趣视频| 欧美日韩一区二区欧美激情| 国产精品香蕉一区二区三区| 国产精品美女视频| 欧美精品1区2区| 成人黄色在线视频| 麻豆国产精品官网| 亚洲欧洲三级电影| 日韩欧美一区二区免费| 91麻豆swag| 精品一区二区三区免费毛片爱| 国产精品二三区| 欧美一区二区三区婷婷月色| 国产宾馆实践打屁股91| 午夜精品成人在线视频| 国产女人水真多18毛片18精品视频 | 极品少妇一区二区三区精品视频| 中文字幕一区二区日韩精品绯色| 欧美一级片免费看| 91电影在线观看| 国产精品小仙女| 久久精品99久久久| 亚洲免费观看高清完整版在线观看| 欧美tickling网站挠脚心| 色乱码一区二区三区88| 国产精品99久| 韩国一区二区在线观看| 亚洲成人激情综合网| 日韩伦理免费电影| 中文字幕精品三区| 亚洲精品一区二区三区四区高清| 欧美日韩免费观看一区二区三区| 波多野结衣在线一区| 国内精品国产成人| 久久精品国产99久久6| 亚洲超碰97人人做人人爱| 亚洲免费观看高清完整| 国产精品第四页| 中文字幕高清一区| 欧美国产一区在线| 日韩精品中文字幕在线不卡尤物| 欧美片在线播放| 欧美性大战xxxxx久久久| av在线不卡电影| caoporen国产精品视频| 北条麻妃国产九九精品视频| 国产精品综合视频| 国产乱码字幕精品高清av| 狠狠色狠狠色综合| 国产一区二区电影| 国产又粗又猛又爽又黄91精品| 日韩电影在线观看电影| 日韩国产欧美三级| 喷白浆一区二区| 久久国产精品色| 狠狠色狠狠色综合日日91app| 久久精品久久99精品久久| 乱一区二区av| 国产一区日韩二区欧美三区| 蜜桃久久精品一区二区| 极品少妇一区二区三区精品视频| 韩国成人福利片在线播放| 国内成人免费视频| 国产91精品露脸国语对白| 成人精品国产福利| 91在线一区二区| 在线精品视频免费播放| 欧美精品在线视频| 精品美女被调教视频大全网站| 精品久久五月天| 国产精品视频yy9299一区| 国产精品丝袜91| 伊人一区二区三区| 五月婷婷欧美视频| 久久99精品久久久久久久久久久久| 国产一区福利在线| aaa欧美大片| 欧美三级欧美一级| 精品福利av导航| 国产精品污污网站在线观看| 亚洲精品第一国产综合野| 亚洲国产日韩一区二区| 蜜臀av一区二区在线免费观看 | 亚洲成人自拍一区| 国内成+人亚洲+欧美+综合在线| 成人av网址在线| 欧美日韩在线播放| 亚洲乱码国产乱码精品精98午夜| 国产精品二三区| 日韩综合小视频| 国产成人精品免费网站| 91丝袜美女网| 日韩视频一区在线观看| 中文字幕在线一区免费| 免费的成人av| 成人av电影免费观看| 欧美丰满嫩嫩电影| 国产精品久99| 欧美aaaaaa午夜精品| 91网上在线视频| 精品国产伦一区二区三区观看体验| 国产精品入口麻豆原神| 免费黄网站欧美| 一本大道久久a久久精品综合| 欧美mv日韩mv| 亚洲一级二级在线| 成人免费va视频| 26uuu国产电影一区二区| 亚洲精品国久久99热| 国产成人在线电影| 日韩欧美高清在线| 亚洲国产成人tv| 色噜噜狠狠色综合中国| 中文字幕av一区 二区| 日韩精品欧美精品| 在线欧美日韩精品| 国产日韩欧美高清在线| 另类小说视频一区二区| 欧美探花视频资源| 亚洲精品乱码久久久久久| 国产精品一区二区你懂的| 日韩一区二区在线看片| 亚洲一区日韩精品中文字幕| 成人网男人的天堂| 国产偷国产偷亚洲高清人白洁| 日韩国产一二三区| 欧美日韩综合在线| 一区二区在线观看视频| 成人性生交大片免费看在线播放 | 91丝袜国产在线播放| 国产无一区二区| 国产综合色视频| 欧美一区二区在线播放| 日韩精品午夜视频| 91精品国产综合久久精品app| 亚洲地区一二三色| 欧美日韩免费视频| 视频在线观看国产精品| 91超碰这里只有精品国产| 一区二区三区91| 欧美亚洲一区二区在线| 一色桃子久久精品亚洲| a在线播放不卡| 日韩成人免费看| 67194成人在线观看| 天天av天天翘天天综合网色鬼国产| 在线观看成人小视频| 亚洲香蕉伊在人在线观| 欧美色手机在线观看| 五月天一区二区三区| 91精品久久久久久久久99蜜臂| 天堂蜜桃一区二区三区| 日韩欧美成人激情| 国产一区二区三区国产| 国产精品久久看| 在线精品亚洲一区二区不卡| 亚洲第一狼人社区| 日韩午夜av电影| 国产一区二区三区四| 国产精品久久久久影院色老大| 91在线观看地址| 亚洲午夜国产一区99re久久| 91精品国产综合久久精品app | 欧美综合视频在线观看| 日韩成人伦理电影在线观看| 欧美一级日韩免费不卡| 国产在线不卡一卡二卡三卡四卡| 久久久三级国产网站| av一区二区三区| 视频一区二区不卡| 精品久久久久久亚洲综合网| www.性欧美| 天堂资源在线中文精品| 久久久久久久久岛国免费| 99久久免费精品| 午夜精品久久久久久久久|