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

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

?? hooked_fn.c

?? 開源的防火墻代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:

/**
 * Hooked SendPacketsHandler (NdisSendPackets) from NDIS_OPEN_BLOCK.
 * Filter packets and call or not original handler or call it with modified array of packets
 */
VOID
new_SendPacketsHandler(
	struct ADAPTER_PROTOCOL		*adapter,			/* added by ASM stub */
	IN NDIS_HANDLE				NdisBindingHandle,
	IN PPNDIS_PACKET			PacketArray,
	IN UINT						NumberOfPackets)
{
	struct PROTOCOL_CHARS *pchars = adapter->pchars;

	// we get pchars only to check adapter
	_CHECK_PCHARS(pchars);

	// can't use UNICODE %S to output (see DbgPrint documentation)
	KdPrint(("[ndis_hk] new_SendPacketsHandler: (%d)\n", adapter->adapter_index));

	if (adapter->adapter_index != 0) 
	{
		UINT i, n_allow, j;

		// first get number of allow packets (and set status for deny packets)

		n_allow = NumberOfPackets;

		for (i = 0; i < NumberOfPackets; i++) 
		{
			if (!filter_packet(DIRECTION_OUT, adapter->adapter_index, PacketArray[i])) 
			{
				n_allow--;
				NDIS_SET_PACKET_STATUS(PacketArray[i], NDIS_STATUS_FAILURE);
			} 
			else
				NDIS_SET_PACKET_STATUS(PacketArray[i], NDIS_STATUS_SUCCESS);
		}

		if (n_allow < NumberOfPackets) 
		{
			PPNDIS_PACKET new_PacketArray;

			// deny some packets

			KdPrint(("new_SendPacketsHandler: DENY!\n"));

			if (n_allow == 0) 
			{

				// deny all packets
				for (i = 0; i < NumberOfPackets; i++) 
				{
					// call ProtocolSendComplete handler for each packet
					PCHARS_OLD_CHARS(pchars)->SendCompleteHandler(adapter->ProtocolBindingContext,
						PacketArray[i], NDIS_STATUS_SUCCESS);	// let protocol driver to think it's all right
				}

				return;
			}

			/** @test Somebody, please test the code below. I never seen it's called */
			_TEST_ME_

			// allocate new PacketArray

			new_PacketArray = (PPNDIS_PACKET)malloc_np(sizeof(PPNDIS_PACKET) * n_allow);
			if (new_PacketArray == NULL) 
			{

				// have not resources
				KdPrint(("new_SendPacketsHandler: malloc_np!\n"));

				for (i = 0; i < NumberOfPackets; i++) 
				{
					// call ProtocolSendComplete handler for each packet
					PCHARS_OLD_CHARS(pchars)->SendCompleteHandler(adapter->ProtocolBindingContext,
						PacketArray[i], NDIS_STATUS_RESOURCES);
				}

				return;
			}

			// fill new PacketArray

			j = 0;
			for (i = 0; i < NumberOfPackets; i++) 
				if (NDIS_GET_PACKET_STATUS(PacketArray[i]) == NDIS_STATUS_SUCCESS) 
				{

					// save allowed packet in new PacketArray

					// sanity check
					if (j >= n_allow)
						break;

					new_PacketArray[j++] = PacketArray[i];
				
				} 
				else 
				{
					// call ProtocolSendComplete handler to deny packet
					PCHARS_OLD_CHARS(pchars)->SendCompleteHandler(adapter->ProtocolBindingContext,
						PacketArray[i], NDIS_STATUS_SUCCESS);	// let protocol driver to think it's all right
				}

			// call original handler with new_PacketArray

			adapter->old_SendPacketsHandler(NdisBindingHandle, new_PacketArray, NumberOfPackets);

			// DDK: As soon as a protocol calls NdisSendPackets, it relinquishes ownership of the following...

			// So, don't care about packets in new_PacketArray

			// finally free new PacketArray and return
			free(new_PacketArray);
			return;
		}
	}

	// call original handler
	adapter->old_SendPacketsHandler(NdisBindingHandle, PacketArray, NumberOfPackets);	
}

/**
 * Hooked TransferDataHandler (NdisTransferData) from NDIS_OPEN_BLOCK.
 * MacReceiveContext is our buffer so just copy data from our buffer to packet
 */
NDIS_STATUS
new_TransferDataHandler(
	struct ADAPTER_PROTOCOL		*adapter,			/* added by ASM stub */
	IN	NDIS_HANDLE				MacBindingHandle,
	IN	NDIS_HANDLE				MacReceiveContext,
	IN	UINT					ByteOffset,
	IN	UINT					BytesToTransfer,
	OUT PNDIS_PACKET			Packet,
	OUT PUINT					BytesTransferred)
{
	PNDIS_BUFFER buffer;

	// we get pchars only to check adapter
	_CHECK_PCHARS(adapter->pchars);

	/** @test Somebody, please test the code below. I never seen it's called */
	_TEST_ME_

	// can't use UNICODE %S to output (see DbgPrint documentation)
	KdPrint(("[ndis_hk] new_TransferDataHandler: (%d)\n", adapter->adapter_index));

	// this function can be called _only_ inside new_ReceiveHandler -> old_ReceiveHandler (is it true?)
	// so MacReceiveContext is a buffer to the whole packet data: copy them

	NdisQueryPacket(Packet, NULL, NULL, &buffer, NULL);
	
	// A HACK! actually NDIS_BUFFER is MDL so use TdiCopyBufferToMdl (i don't know NDIS equialent)
	TdiCopyBufferToMdl((PVOID)MacReceiveContext, 0, BytesToTransfer, (PMDL)buffer, ByteOffset, BytesTransferred);

	return NDIS_STATUS_SUCCESS;

}

NTSTATUS
send_out_packet(int iface, PNDIS_PACKET packet)
{
	NTSTATUS status;
	int i;
	struct PROTOCOL_CHARS *pchars;
	struct ADAPTER_PROTOCOL *adapter;
	PNDIS_BUFFER buffer, new_buffer = NULL;
	PNDIS_PACKET new_packet = NULL;
	struct protocol_reserved *pr;
	char *data = NULL;
	ULONG size;

	for (i = 0; i < TCPIP_PCHARS_N; i++) {
		pchars = g_tcpip_pchars[i];
		if (pchars == NULL)
			continue;

		// get adapter
		for (adapter = pchars->adapter; adapter != NULL; adapter = adapter->next)
			if (adapter->adapter_index == iface)
				break;

		if (adapter != NULL)
			break;
	}

	// sanity check
	if (pchars == NULL) {
		KdPrint(("[ndis_hk] send_out_packet: no TCPIP protocol!\n"));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}

	if (adapter == NULL) {
		KdPrint(("[ndis_hk] send_out_packet: no adapter %d!\n", iface));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}

	NdisQueryPacket(packet, NULL, NULL, &buffer, &size);

	data = (char *)malloc_np(size);
	if (data == NULL) {
		KdPrint(("[ndis_hk] send_out_packet: malloc_np!\n"));
		return STATUS_INSUFFICIENT_RESOURCES;
	}
	
	__try {
		
		// A HACK! actually NDIS_BUFFER is MDL so use TdiCopyBufferToMdl (i don't know NDIS equialent)
		TdiCopyMdlToBuffer((PMDL)buffer, 0, data, 0, size, &size);
		
		// now create our own new_packet
		
		NdisAllocateBuffer(&status, &new_buffer, g_buffer_pool, data, size);
		if (status != NDIS_STATUS_SUCCESS) {
			KdPrint(("[ndis_hk] send_out_packet: NdisAllocateBuffer: 0x%x\n", status));
			__leave;
		}
		
		NdisAllocatePacket(&status, &new_packet, g_packet_pool);
		if (status != NDIS_STATUS_SUCCESS) {
			KdPrint(("[ndis_hk] send_out_packet: NdisAllocatePacket: 0x%x\n", status));
			__leave;
		}
		
		NdisChainBufferAtFront(new_packet, new_buffer);
		
		// setup ProtocolReserved for completion
		
		pr = PROTOCOL_RESERVED(new_packet);
		
		pr->magic = send_out_packet;
		pr->buffer = new_buffer;
		pr->data = data;
		
		// send it! (call original handler see NdisSend() macro in ndis.h)
		
		KdPrint(("[ndis_hk] send_out_packet: sending new_packet...\n"));
		
		status = adapter->old_SendHandler(
			((PNDIS_OPEN_BLOCK)(adapter->NdisBindingHandle))->MacBindingHandle, new_packet);
		
		if (status == NDIS_STATUS_PENDING) {
			// don't free resources (will be freed in completion)
			data = NULL;
			new_buffer = NULL;
			new_packet = NULL;
		}
		
		KdPrint(("[ndis_hk] send_out_packet: status: 0x%x\n", status));
	
	} __except((status = GetExceptionCode(), EXCEPTION_EXECUTE_HANDLER)) {
		KdPrint(("[ndis_hk] send_out_packet: exception 0x%x!\n", status));
	}
		
	if (data != NULL)
		free(data);
	if (new_buffer != NULL)
		NdisFreeBuffer(new_buffer);
	if (new_packet != NULL)
		NdisFreePacket(new_packet);
	
	return status;
}

NTSTATUS
send_in_packet(int iface, ULONG hdr_size, ULONG data_size, char *packet_data)
{
	NTSTATUS status;
	int i;
	struct PROTOCOL_CHARS *pchars;
	struct ADAPTER_PROTOCOL *adapter;
	KIRQL irql;

	for (i = 0; i < TCPIP_PCHARS_N; i++) {
		pchars = g_tcpip_pchars[i];
		if (pchars == NULL)
			continue;

		// get adapter
		for (adapter = pchars->adapter; adapter != NULL; adapter = adapter->next)
			if (adapter->adapter_index == iface)
				break;

		if (adapter != NULL)
			break;
	}

	// sanity check
	if (pchars == NULL) {
		KdPrint(("[ndis_hk] send_in_packet: no TCPIP protocol!\n"));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}

	if (adapter == NULL) {
		KdPrint(("[ndis_hk] send_in_packet: no adapter %d!\n", iface));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}
	
	/* send packet to protocol driver */
	
	// sanity check
	if (PCHARS_OLD_CHARS(pchars)->ReceiveHandler == NULL) {
		KdPrint(("[ndis_hk] send_in_packet: no ProtocolReceive!\n"));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}

	/** @todo Need to simulate NdisGetReceivedPacket for stability? */

	// raise IRQL to DISPATCH_LEVEL for ReceiveHandler
	KeRaiseIrql(DISPATCH_LEVEL, &irql);

    // simulate ProtocolReceive is called (MacReceiveContext is our buffer)
	status = PCHARS_OLD_CHARS(pchars)->ReceiveHandler(adapter->ProtocolBindingContext,
		(NDIS_HANDLE)(packet_data + hdr_size), packet_data, hdr_size,
		packet_data + hdr_size, data_size, data_size);

	KeLowerIrql(irql);
	return status;
}

NDIS_STATUS
ndis_request(int iface, NDIS_REQUEST *req)
{
	int i;
	struct PROTOCOL_CHARS *pchars;
	struct ADAPTER_PROTOCOL *adapter;
	NDIS_STATUS status;

	for (i = 0; i < TCPIP_PCHARS_N; i++) {
		pchars = g_tcpip_pchars[i];
		if (pchars == NULL)
			continue;

		// get adapter
		for (adapter = pchars->adapter; adapter != NULL; adapter = adapter->next)
			if (adapter->adapter_index == iface)
				break;

		if (adapter != NULL)
			break;
	}

	// sanity check
	if (pchars == NULL) {
		KdPrint(("[ndis_hk] ndis_request: no TCPIP protocol!\n"));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}

	if (adapter == NULL) {
		KdPrint(("[ndis_hk] ndis_request: no adapter %d!\n", iface));
		return STATUS_OBJECT_NAME_NOT_FOUND;
	}
	
	// to simplify processing serialize requests
	KeWaitForSingleObject(&g_request.guard, Executive, KernelMode, FALSE, NULL);

	g_request.pend_req = req;

	NdisResetEvent(&g_request.event);
	NdisRequest(&status, adapter->NdisBindingHandle, req);

	if (status == NDIS_STATUS_PENDING) {
		NdisWaitEvent(&g_request.event, 0);
		status = g_request.status;
	}

	g_request.pend_req = NULL;

	KeReleaseMutex(&g_request.guard, FALSE);
	return status;
}

/*@}*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产日韩a在线播放| 成人午夜精品一区二区三区| 国产99久久久久久免费看农村| 色婷婷精品久久二区二区蜜臂av| 91精品婷婷国产综合久久性色| 亚洲精品免费在线| 国产乱码精品一区二区三区av| 欧美三级欧美一级| 亚洲欧美一区二区三区久本道91| 国产老妇另类xxxxx| 91精品国产品国语在线不卡| 亚洲一区二区在线免费看| 国产成人免费在线视频| 日韩亚洲欧美一区| 亚洲国产精品天堂| 91在线国产观看| 国产精品久久午夜| 国产精品一区久久久久| 欧美成人三级在线| 日本午夜精品一区二区三区电影 | 亚洲欧洲色图综合| 国产成人午夜高潮毛片| 久久综合九色综合97_久久久| 日韩电影在线免费看| 在线不卡欧美精品一区二区三区| 亚洲一区电影777| 欧美性色黄大片| 亚洲国产精品一区二区www在线| 色网综合在线观看| 一区二区三区.www| 91电影在线观看| 亚洲成人先锋电影| 欧美久久久久久久久中文字幕| 亚洲成人综合视频| 日韩视频在线永久播放| 精一区二区三区| www国产成人| 国产91在线观看丝袜| 国产精品成人午夜| 在线观看视频91| 美女一区二区久久| 久久久高清一区二区三区| 国产一区二区三区综合| 国产精品国产三级国产普通话三级| jizzjizzjizz欧美| 亚洲午夜在线电影| 日韩一级二级三级| 国产成人精品免费网站| 国产精品国产三级国产专播品爱网| 91免费国产在线观看| 日韩一区精品字幕| 久久综合视频网| 99久久综合国产精品| 亚洲亚洲精品在线观看| 日韩欧美在线123| 国产精品影音先锋| 亚洲精品亚洲人成人网| 91精品麻豆日日躁夜夜躁| 国产乱人伦精品一区二区在线观看| 中文字幕一区av| 在线成人免费视频| 成人av高清在线| 免费三级欧美电影| 国产精品伦理一区二区| 91精品国产综合久久久蜜臀图片| 国产91丝袜在线播放| 亚洲国产成人av| 久久精品免视看| 欧美另类久久久品| 成人午夜激情影院| 视频一区在线视频| 国产精品毛片久久久久久| 91.xcao| 成人免费三级在线| 日本强好片久久久久久aaa| 国产精品三级久久久久三级| 91精品国产91热久久久做人人| 波多野结衣中文一区| 久久国产婷婷国产香蕉| 亚洲一区二区视频| 欧美国产精品久久| 精品成人一区二区三区| 欧美色精品在线视频| av在线免费不卡| 国产麻豆精品视频| 日韩成人免费电影| 一区二区欧美视频| 亚洲人123区| 国产性色一区二区| 久久综合资源网| 日韩欧美一区二区在线视频| 欧美日韩五月天| 日本精品一区二区三区四区的功能| 国产精品资源在线| 国产一区二区精品久久99| 丝瓜av网站精品一区二区| 亚洲色欲色欲www| 国产偷国产偷亚洲高清人白洁| 精品国产污网站| 日韩免费福利电影在线观看| 欧美日韩国产小视频在线观看| 色婷婷精品大在线视频| 97久久超碰国产精品电影| proumb性欧美在线观看| www.av精品| 色综合色狠狠天天综合色| 99精品久久久久久| www.日韩在线| 91行情网站电视在线观看高清版| 色婷婷国产精品综合在线观看| av电影在线观看一区| 99re6这里只有精品视频在线观看| 成人丝袜18视频在线观看| 国产精品影音先锋| 粉嫩av一区二区三区| 国产成a人亚洲精品| 99精品一区二区| 在线视频国产一区| 欧美精品自拍偷拍| 日韩视频在线你懂得| 2021久久国产精品不只是精品| 久久久亚洲精品石原莉奈| 国产亚洲一区二区三区| 亚洲欧洲成人精品av97| 亚洲欧美韩国综合色| 午夜欧美大尺度福利影院在线看| 青青草91视频| 国产91对白在线观看九色| 91视频在线观看免费| 欧美日韩一区二区在线观看 | 久久精品亚洲麻豆av一区二区 | 国产喷白浆一区二区三区| 国产欧美一区二区精品仙草咪| 国产精品久久久久一区二区三区| 亚洲精品亚洲人成人网| 日韩电影在线免费看| 国产在线精品一区在线观看麻豆| 成人在线视频一区二区| 91麻豆免费观看| 91精品国产综合久久久久久久久久| 精品伦理精品一区| 亚洲美女在线国产| 狠狠久久亚洲欧美| 色噜噜狠狠一区二区三区果冻| 欧美精品精品一区| 国产网站一区二区| 午夜久久久影院| 成人性视频免费网站| 欧美精品一级二级| 中文字幕亚洲不卡| 日本欧美韩国一区三区| 国产福利一区二区三区视频在线| 欧美日韩精品欧美日韩精品| 久久嫩草精品久久久精品| 亚洲精品一二三| 国产成人综合亚洲网站| 欧美精品成人一区二区三区四区| 国产欧美日韩另类一区| 五月天激情综合网| 国产精品一区三区| 538在线一区二区精品国产| 中文字幕一区二区三区视频| 狠狠色狠狠色综合系列| 欧美视频在线播放| 国产精品二三区| 国产精品影视天天线| 91精品国产综合久久香蕉麻豆| 亚洲麻豆国产自偷在线| 国产中文字幕精品| 欧美精品tushy高清| 亚洲尤物视频在线| 国产成人在线网站| 精品久久久久久久久久久久包黑料| 亚洲欧洲av色图| 国产iv一区二区三区| 日韩午夜精品电影| 亚洲国产你懂的| 色综合天天性综合| 中文字幕不卡的av| 国产精品69久久久久水密桃| 日韩欧美第一区| 丝袜脚交一区二区| 欧美日韩一区二区三区在线看| 亚洲人123区| 91蝌蚪porny| 国产精品久久午夜| 99久久免费精品高清特色大片| 久久夜色精品一区| 久久国产剧场电影| 日韩一二三区视频| 麻豆91精品91久久久的内涵| 欧美高清hd18日本| 五月天中文字幕一区二区| 欧美亚洲一区二区在线| 一区二区三区蜜桃| 欧美日韩精品三区| 性久久久久久久| 日韩精品最新网址| 久久99精品久久久久久 | 欧美天堂亚洲电影院在线播放|