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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? netbuff.cpp

?? 小型的操作系統(tǒng)開發(fā)的原代碼
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
//***********************************************************************/
//    Author                    : Garry
//    Original Date             : Aug,06 2005
//    Module Name               : NETBUFF.CPP
//    Module Funciton           : 
//                                This module countains net buffer's
//                                implementation code.
//    Last modified Author      :
//    Last modified Date        :
//    Last modified Content     :
//                                1.
//                                2.
//    Lines number              :
//***********************************************************************/

#ifndef __STDAFX_H__
#include "..\INCLUDE\StdAfx.h"
#endif

#ifndef __DEFINES_H__
#include "DEFINES.H"
#endif

#ifndef __NETBUFF_H__
#include "NETBUFF.H"
#endif

/*--------------- ** Some important hints about net buffer object ** -------------------
  The net buffer object is used by network entity,such as IP kernel thread,net interface
card,to store data or packets.When you use the net buffer object,the following rules must
be obeied:
  1. When you transfer a net buffer object as a parameter to another kernel thread,you 
     must first increment the reference counter by calling NetBufferGet routine;
  2. When you finished to use a net buffer object,you must call NetBufferFree routine to
     release the memory or decrement the reference counter,if the net buffer object is created
	 by yourself,if the object is not created by your self,but is transfered by another 
	 kernel thread,you must call NetBufferFree routine too;
  3. All net buffer operations are interrupt safe,so you can call the operations anywhere.
---------------------------------------------------------------------------------------*/

//
//The implementation of net buffer queue.
//This is a FIFO queue,can be used by any entity,such as IP kernel thread.
//

//
//The implementation of InsertIntoQueue.
//This routine adds the net buffer object to the end of the queue.
//If the current element number is not exceed the max number,then insert it,and
//returns TRUE,otherwise,returns FALSE.
//

static BOOL InsertIntoQueue(__NET_BUFFER_QUEUE* lpQueue,__NET_BUFFER* lpNetBuffer)
{
	DWORD                   dwFlags        = 0L;

	__ENTER_CRITICAL_SECTION(NULL,dwFlags);  //The following operation should not be
	                                         //interrupted.
	if(lpQueue->dwQueueNum == lpQueue->dwMaxNum)  //The queue is full.
	{
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return FALSE;
	}
	//
	//The following code insert the net buffer object into queue's tail.
	//
	if(NULL == lpQueue->lpQueueTail)    //There is not any element in the queue.
	{
		lpQueue->lpQueueHdr  = lpNetBuffer;
		lpQueue->lpQueueTail = lpNetBuffer;
		lpNetBuffer->lpNext  = NULL;
		lpNetBuffer->lpPrev  = NULL;
		lpQueue->dwQueueNum ++;
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return TRUE;
	}
	else    //The queu is not empty.
	{
		lpQueue->lpQueueTail->lpNext  = lpNetBuffer;
		lpNetBuffer->lpPrev           = lpQueue->lpQueueTail;
		lpNetBuffer->lpNext           = NULL;
		lpQueue->lpQueueTail          = lpNetBuffer;
		lpQueue->dwQueueNum ++;
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return TRUE;
	}
	return TRUE;
}

//
//The implementation of DeleteFromQueue.
//This routine first check if the object is in the queue,if not,returns FALSE,
//else,deletes it and returns TRUE.
//

static BOOL DeleteFromQueue(__NET_BUFFER_QUEUE*,__NET_BUFFER*)
{
	BOOL                    bResult             = FALSE;
	return bResult;
}

//
//The implementation of GetFromQueue.This routine gets the first element of this queue.
//

static __NET_BUFFER* GetFromQueue(__NET_BUFFER_QUEUE* lpQueue)
{
	__NET_BUFFER*                 lpNetBuffer         = NULL;
	DWORD                         dwFlags             = 0L;

	if(NULL == lpQueue)    //Parameter check.
		return NULL;
	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	if(NULL == lpQueue->lpQueueHdr)    //The current queue is empty.
	{
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return NULL;
	}
	if(lpQueue->lpQueueHdr == lpQueue->lpQueueTail)  //There is only one element in the queue.
	{
		lpNetBuffer = lpQueue->lpQueueHdr;
		lpQueue->lpQueueHdr  = NULL;
		lpQueue->lpQueueTail = NULL;
		lpNetBuffer->lpPrev  = NULL;
		lpNetBuffer->lpNext  = NULL;
		lpQueue->dwQueueNum--;
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return lpNetBuffer;
	}
	else    //There are at least two elements in the current queue.
	{
		lpNetBuffer = lpQueue->lpQueueHdr;
		lpQueue->lpQueueHdr = lpNetBuffer->lpNext;
		lpQueue->lpQueueHdr->lpPrev = NULL;
		lpQueue->dwQueueNum --;
		__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
		return lpNetBuffer;
	}
	return NULL;    //This instruction should never be executed.
}

//
//The implementation of GetQueueLength.
//

static DWORD GetQueueLen(__NET_BUFFER_QUEUE* lpQueue)
{
	if(NULL == lpQueue)
		return 0L;
	return lpQueue->dwQueueNum;
}

//
//The implementation of SetMaxLen.
//

static VOID SetMaxLen(__NET_BUFFER_QUEUE* lpQueue,DWORD dwMaxLen)
{
	DWORD             dwFlags             = 0L;

	if(NULL == lpQueue)    //Parameter check.
		return;
	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	lpQueue->dwMaxNum = dwMaxLen;
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
	return;
}

//
//The implementation of Initialize.
//

static VOID QueueInitialize(__NET_BUFFER_QUEUE* lpQueue)
{
	if(NULL == lpQueue)
		return;

	lpQueue->lpQueueHdr        = NULL;
	lpQueue->lpQueueTail       = NULL;
	lpQueue->dwQueueNum        = 0L;
	lpQueue->dwMaxNum          = 0L;

	lpQueue->Initialize        = QueueInitialize;
	lpQueue->SetMaxLen         = SetMaxLen;
	lpQueue->GetQueueLen       = GetQueueLen;
	lpQueue->GetFromQueue      = GetFromQueue;
	lpQueue->DeleteFromQueue   = DeleteFromQueue;
	lpQueue->InsertIntoQueue   = InsertIntoQueue;

	return;
}

BOOL NetBufferQueueInit(__NET_BUFFER_QUEUE* lpQueue)    //Global routine.
{
	if(NULL == lpQueue)
		return FALSE;
	QueueInitialize(lpQueue);
	return TRUE;
}

//--------------------------------------------------------------------------------------

//
//The implementation of net buffer manager.
//

//
//Pre-declaration of routines.
//
static VOID NetBufferFreeData(__NET_BUFFER_MANAGER*,__NET_BUFFER*);

//
//A helper routine,used to get a free net buffer from free list.
//
static __NET_BUFFER* __GetFreeNetBuffer(__NET_BUFFER_MANAGER* lpMgr)
{
	__NET_BUFFER*                     lpNetBuffer           = NULL;
	
	lpNetBuffer = ALLOC_BUFF_MEMORY(sizeof(__NET_BUFFER));
	if(NULL == lpNetBuffer)
		return NULL;

#define SET(member,value) lpNetBuffer->member = value    //This macro initializes a member.

	SET(lpPrev,          NULL);
	SET(lpNext,          NULL);
	SET(lpSocket,        NULL);
	SET(Time,            NULL);
	SET(lpNetDevice,     NULL);
	SET(TransLayerHdr.lpTransLayerData, NULL);
	SET(NetLayerHdr.lpNetLayerData,     NULL);
	SET(LinkLayerHdr.lpLinkLayerData,   NULL);
	SET(dwDataLen,       0L);
	SET(dwTotalLen,      0L);
	SET(dwCheckSum,      0L);
	SET(dwPktType,       PACKET_TYPE_UNKNOWN);
	SET(bCloned,         FALSE);
	SET(ucProtocol,      PACKET_PROTOCOL_UNKNOWN);
	SET(ucReserved1,     0);
	SET(ucReserved2,     0);
	SET(ucReserved3,     0);
	SET(lpBufferHdr,     NULL);
	SET(lpBufferEnd,     NULL);
	SET(lpDataHdr,       NULL);
	SET(lpDataEnd,       NULL);

#undef SET    //Finish to initialize the net buffer allocated just now.
	__INIT_ATOMIC(lpNetBuffer->Users);
	AtomicSet(&lpNetBuffer->Users,1);
	return lpNetBuffer;
}

//
//A helper routine,used to free a net buffer object.
//

static VOID __FreeNetBuffer(__NET_BUFFER_MANAGER* lpMgr,__NET_BUFFER* lpNetBuffer)
{
	if(NULL == lpNetBuffer)  //Parameter check.
		return;
	FREE_BUFF_MEMORY(lpNetBuffer);    //Release the net buffer memory.
	return;
}

//
//The implementation of NetBufferAlloc.
//

static __NET_BUFFER* NetBufferAlloc(__NET_BUFFER_MANAGER* lpManager,DWORD dwBuffLen)
{
	__NET_BUFFER*                   lpNetBuffer                     = NULL;
	DWORD                           dwFlags                         = 0L;
	UCHAR*                          lpDataBuff                      = NULL;
	__FRAG_DATA*                    lpFragData                      = NULL;

	if((NULL == lpManager) || (0 == dwBuffLen)) //Parameter check.
		return NULL;
	lpNetBuffer = __GetFreeNetBuffer(lpManager);
	if(NULL == lpNetBuffer)    //Can not get a net buffer object,no memory may be the 
		                       //most reasonable reason.
		return NULL;

	lpDataBuff = ALLOC_DATA_MEMORY(dwBuffLen);
	if(NULL == lpDataBuff)     //Can not allocate memory to hold data.
	{
		__FreeNetBuffer(lpManager,lpNetBuffer);
		return NULL;
	}
	//
	//We have get a net buffer object and allocate a data buffer successfully,then,
	//we should initialize the net buffer object according to data buffer.
	//
	lpNetBuffer->lpBufferHdr    = lpDataBuff;
	lpNetBuffer->lpBufferEnd    = lpDataBuff + dwBuffLen;
	lpNetBuffer->lpDataHdr      = lpDataBuff;
	lpNetBuffer->lpDataEnd      = lpDataBuff;

	lpFragData = NET_BUFFER_FRAG_DATA(lpNetBuffer);  //Get the fragment data.
	NetBufferQueueInit(&lpFragData->FragQueue);      //Initialize the frag data queue.
	__INIT_ATOMIC(lpFragData->SharedCounter);        //Initialize the shared counter.
	AtomicSet(&lpFragData->SharedCounter,1);         //Set the shared counter to 1.

	return lpNetBuffer;
}

//
//The implementation of NetBufferFree.
//This routine decrement the reference counter of net buffer object,if the reference
//counter hits zero,then release the net buffer object and it's data buffer,else,
//only return.
//

static VOID NetBufferFree(__NET_BUFFER_MANAGER* lpManager,__NET_BUFFER* lpNetBuffer)
{
	if((NULL == lpManager) || (NULL == lpNetBuffer)) //parameter check.
		return;
	if(AtomicDec(&lpNetBuffer->Users))  //The reference counter hit zero.
	{
		NetBufferFreeData(lpManager,lpNetBuffer);  //Release the data buffer.
		__FreeNetBuffer(lpManager,lpNetBuffer);    //Release the net buffer object.
	}
	else    //The reference counter does not hit zero,it means,that there also some other
		    //entities are using the net buffer object.
		return;
}

//
//The implementation of NetBufferFreeData.
//

static VOID NetBufferFreeData(__NET_BUFFER_MANAGER* lpMgr,__NET_BUFFER* lpNetBuffer)
{
	__FRAG_DATA*              lpFragData                  = NULL;
	__NET_BUFFER*             lpNetBuff                   = NULL;

	if((NULL == lpMgr) || (NULL == lpNetBuffer)) //Parameter check.
		return;
	lpFragData = NET_BUFFER_FRAG_DATA(lpNetBuffer);
	if(AtomicDec(&lpFragData->SharedCounter))    //Share counter hits zero,should release
		                                         //all data.
	{
		lpNetBuff = lpFragData->FragQueue.GetFromQueue(&lpFragData->FragQueue);
		while(lpNetBuff)    //There is fragment data.
		{
			NetBufferFree(lpMgr,lpNetBuff);  //Release the fragment data.
			lpNetBuff = lpFragData->FragQueue.GetFromQueue(&lpFragData->FragQueue);
		}
		//__FreeNetBuffer(lpMgr,lpNetBuff);    //Release the memory the data buffer occupied.
		FREE_DATA_MEMORY(lpNetBuffer->lpBufferHdr);  //Release the data buffer.
	}
	else  //The shared counter is not zero,it means there is other entity is using the data
		  //buffer.
	{
		DWORD dwLoop = lpFragData->FragQueue.GetQueueLen(&lpFragData->FragQueue);
		for(DWORD i = 0;i < dwLoop;i ++)  //Decrement the reference counter of all fragment.
			                              //The reference counter of all fragments should
										  //never less than the reference counter of data
										  //buffer.
										  //This can be ensure by NetBufferClone routine,
										  //this routine will increment the reference counter
										  //of data buffer and all fragments.
										  //So,NetBufferFree routine only decrement the
										  //reference counter of all fragments.
		{
			lpNetBuff = lpFragData->FragQueue.GetFromQueue(&lpFragData->FragQueue);
			NetBufferFree(lpMgr,lpNetBuff);
			lpFragData->FragQueue.InsertIntoQueue(&lpFragData->FragQueue,lpNetBuff);
		}
	}
	return;
}

//
//The implementation of NetBufferGet.

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合色8888| 亚洲人成7777| 亚洲欧洲国产日本综合| 午夜激情一区二区三区| 成人国产精品免费观看视频| 在线播放一区二区三区| 中文字幕亚洲在| 国产成人av资源| 日韩亚洲欧美综合| 五月综合激情婷婷六月色窝| 93久久精品日日躁夜夜躁欧美| 欧美va日韩va| 日韩福利电影在线| 在线视频中文字幕一区二区| 久久色在线观看| 麻豆精品视频在线| 欧美精品一二三| 亚洲黄色片在线观看| 成人免费毛片片v| 久久先锋影音av| 精品一区二区三区久久久| 欧美日韩大陆一区二区| 亚洲免费观看高清完整版在线| 成人午夜视频在线| 久久久久亚洲蜜桃| 国产精品一区二区免费不卡| 精品国精品国产| 看电视剧不卡顿的网站| 日韩一区二区视频| 日韩电影在线观看网站| 欧美最猛黑人xxxxx猛交| 亚洲老妇xxxxxx| 91色乱码一区二区三区| 亚洲免费在线观看| 在线观看区一区二| 亚洲一区二区视频在线| 欧美私模裸体表演在线观看| 一区二区三区四区亚洲| 日本久久一区二区三区| 亚洲午夜在线电影| 欧美乱妇20p| 蜜臀av一区二区在线免费观看| 9191精品国产综合久久久久久| 午夜激情综合网| 欧美刺激脚交jootjob| 精品一区二区三区香蕉蜜桃| 久久久久青草大香线综合精品| 粉嫩在线一区二区三区视频| 国产精品美日韩| 欧美综合一区二区三区| 视频一区视频二区中文| 欧美v日韩v国产v| 福利电影一区二区三区| 亚洲免费av观看| 7777女厕盗摄久久久| 美女视频网站久久| 国产亚洲一二三区| 99国产精品国产精品毛片| 一区二区三区不卡视频| 欧美一级搡bbbb搡bbbb| 国产福利精品一区| 一区二区欧美在线观看| 日韩欧美国产三级| 91在线观看污| 三级在线观看一区二区| 国产拍欧美日韩视频二区| 在线免费不卡视频| 国内成人自拍视频| 一区二区日韩电影| 久久精品人人做| 欧美日韩精品欧美日韩精品一| 激情久久五月天| 一区二区在线观看视频| 2021国产精品久久精品| 欧美午夜精品一区二区三区| 国内不卡的二区三区中文字幕| 日韩码欧中文字| 久久五月婷婷丁香社区| 欧美日韩久久一区| 不卡大黄网站免费看| 久久国产综合精品| 亚洲一级不卡视频| 欧美国产日韩在线观看| 91麻豆精品国产91久久久久| 成人免费黄色大片| 久久精品99国产精品| 亚洲成人三级小说| 亚洲欧美色图小说| 国产免费成人在线视频| 精品乱人伦小说| 在线播放欧美女士性生活| 99久久国产综合精品女不卡| 国产精品亚洲第一| 久色婷婷小香蕉久久| 日韩主播视频在线| 亚洲综合成人在线| 亚洲免费av网站| **网站欧美大片在线观看| 久久久久久免费| 2021国产精品久久精品| 欧美变态tickle挠乳网站| 91精品啪在线观看国产60岁| 欧美日韩aaa| 欧美肥胖老妇做爰| 欧美性一区二区| 91久久精品一区二区二区| av亚洲精华国产精华精华| 国产91精品免费| 国产高清无密码一区二区三区| 韩国av一区二区三区在线观看| 人人超碰91尤物精品国产| 午夜国产精品影院在线观看| 亚洲成人动漫一区| 日韩精品久久久久久| 日本色综合中文字幕| 蜜臀av一区二区| 国产中文一区二区三区| 国产91富婆露脸刺激对白| 国产成人综合在线| 97久久精品人人做人人爽50路| 成人av网站大全| 91老司机福利 在线| 欧美日韩一区二区欧美激情| 制服丝袜一区二区三区| 精品少妇一区二区三区在线播放| 日韩色在线观看| 欧美韩国日本综合| 亚洲欧美日韩电影| 午夜影院久久久| 麻豆精品新av中文字幕| 国产精品一区二区视频| av男人天堂一区| 在线亚洲高清视频| 欧美大片在线观看一区二区| 国产性做久久久久久| 国产精品二三区| 亚洲成人一区二区在线观看| 久久精品国产77777蜜臀| 波多野结衣中文字幕一区二区三区| 色综合久久综合| 欧美一区二区在线不卡| 日本一区二区三区久久久久久久久不| 国产精品免费aⅴ片在线观看| 夜夜嗨av一区二区三区中文字幕| 天堂影院一区二区| 国产成人av电影在线| 日本精品免费观看高清观看| 欧美一级高清大全免费观看| 国产女同性恋一区二区| 天天色天天操综合| 成人app在线| 日韩亚洲欧美在线| 亚洲美女免费视频| 激情五月婷婷综合网| 91丨porny丨蝌蚪视频| 91精品国产黑色紧身裤美女| 国产精品入口麻豆原神| 日韩福利视频导航| 色综合亚洲欧洲| 精品国内片67194| 亚洲一区二区在线观看视频| 国产福利一区二区三区视频在线 | 在线精品视频免费观看| 精品国产一区a| 亚洲一级片在线观看| 成人午夜av在线| 日韩欧美成人激情| 天堂va蜜桃一区二区三区| 成人福利视频在线看| 精品第一国产综合精品aⅴ| 亚洲一区二区三区激情| 99re成人精品视频| 中文字幕av资源一区| 久久精品国产亚洲a| 欧美精品自拍偷拍动漫精品| 亚洲免费观看高清| 99国产精品99久久久久久| 26uuu另类欧美亚洲曰本| 秋霞午夜av一区二区三区| 欧美色成人综合| 亚洲欧美另类久久久精品| 成人午夜激情影院| 久久女同精品一区二区| 麻豆精品新av中文字幕| 欧美一卡2卡三卡4卡5免费| 亚洲综合在线五月| 色哟哟亚洲精品| 亚洲乱码中文字幕| 99re视频精品| 1024成人网| 一本到不卡精品视频在线观看| 欧美高清在线一区二区| 国产福利电影一区二区三区| 久久男人中文字幕资源站| 国产美女精品人人做人人爽| 精品免费国产二区三区| 激情五月婷婷综合网| 久久久久亚洲综合| 成人污视频在线观看| 国产精品福利一区二区|