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

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

?? pppasyncframing.c

?? 這是全套的PPP協議的源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
    return OK;    }/********************************************************************************* pppAsyncFramingLinkResetEventHandler - handle LCP link reset event** RETURNS: OK or ERROR*/LOCAL STATUS pppAsyncFramingLinkResetEventHandler    (    PFW_PLUGIN_OBJ_STATE * state,    void *eventData    )    {    ASYNC_FRAMING_STACK_DATA * pStackData = state->stackData;    pStackData->localMru = 1500;    pStackData->remoteMru = 1500;    pStackData->localToPeerACCMap  = DEFAULT_ASYNC_CONTROL_CHARACTER_MAP;    pStackData->peerToLocalACCMap  = DEFAULT_ASYNC_CONTROL_CHARACTER_MAP;    /* Address control and protocol compression is disabled by default */    pStackData->localToPeerACCompression = FALSE;    pStackData->peerToLocalACCompression = FALSE;    pStackData->localToPeerProtocolCompression = FALSE;    pStackData->peerToLocalProtocolCompression = FALSE;    pStackData->transmitFcsSize = PPP_16BIT_FCS;    pStackData->receiveFcsSize = PPP_16BIT_FCS;    return OK;    }/********************************************************************************* pppAsyncFramingSend - send data in asynchronous format** RETURNS: OK or ERROR*/LOCAL STATUS pppAsyncFramingSend    (    PFW_PLUGIN_OBJ_STATE *state,    M_BLK_ID * packet    )    {    register M_BLK_ID inPacket, outFrame;    M_BLK_ID endOfInPacket;    USHORT calculated16BitCkSum;    UINT32 calculated32BitCkSum;    char checksum[4] = {0,0,0,0};    char header[2];    UINT32 totalPacketLen = 0;    USHORT protocol;    ASYNC_FRAMING_STACK_DATA *stackData = (ASYNC_FRAMING_STACK_DATA *)					   state->stackData;    M_BLK pppHeader = {{NULL,NULL,NULL,2,MT_DATA,0,0},{NULL,0},NULL};    M_BLK pppCkSum  = {{NULL,NULL,NULL,2,MT_DATA,0,0},{NULL,0},NULL};    if (packet == NULL || (inPacket = *packet) == NULL)        {        RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 				stackData->pfwRFC2233CountPair,                               M2_ctrId_ifOutErrors, 1);        return (ERROR);        }    else	endOfInPacket = inPacket;    pppHeader.mBlkHdr.mData = header;    pppCkSum.mBlkHdr.mData = checksum;    totalPacketLen = inPacket->mBlkPktHdr.len;    protocol = (USHORT)((inPacket->mBlkHdr.mData[0] << 8) |			inPacket->mBlkHdr.mData[1]);    /* check for Protocol compression */    if (stackData->localToPeerProtocolCompression == TRUE &&	inPacket->mBlkHdr.mData[0] == 0) /* first byte of protocol field == 0 */	{	inPacket->mBlkHdr.mData++;	inPacket->mBlkHdr.mLen--;        inPacket->mBlkPktHdr.len--;	totalPacketLen--;	}    /* check for Address and control field compression */    if ((protocol == LCP_PROTOCOL) ||	(stackData->localToPeerACCompression != TRUE))	{	header[0] = (char)PPP_ALLSTATIONS;	header[1] = PPP_UI;	/* header mBlk is now head of chain */	pppHeader.mBlkHdr.mNext = inPacket;	pppHeader.mBlkHdr.mFlags |= M_PKTHDR;	pppHeader.mBlkPktHdr.len = totalPacketLen + 2;	/* clear chain information from inPacket */	inPacket->mBlkPktHdr.len = 0;	inPacket->mBlkHdr.mFlags &= ~M_PKTHDR;	inPacket = &pppHeader;	totalPacketLen += 2;	}    if (stackData->transmitFcsSize == PPP_16BIT_FCS)	{	calculated16BitCkSum = calculate16BitFcs (PPPINITFCS16,inPacket);	calculated16BitCkSum = (USHORT) ~calculated16BitCkSum;	checksum[0] = calculated16BitCkSum & 0x00ff;	checksum[1] = (calculated16BitCkSum & 0xff00) >> 8;	/* find the end of the inPacket chain */	endOfInPacket = inPacket;	while(endOfInPacket->mBlkHdr.mNext != NULL)	    endOfInPacket = endOfInPacket->mBlkHdr.mNext;	/* link in the checksum bytes at the end of the chain */        pppCkSum.mBlkHdr.mLen = 2;	endOfInPacket->mBlkHdr.mNext = &pppCkSum;	inPacket->mBlkPktHdr.len +=2;	totalPacketLen += 2;	}    else if (stackData->transmitFcsSize == PPP_32BIT_FCS)	{	calculated32BitCkSum = calculate32BitFcs (PPPINITFCS32,inPacket);	calculated32BitCkSum ^= 0xffffffff;	checksum[0] = calculated32BitCkSum  & 0x000000ff;	checksum[1] = (calculated32BitCkSum & 0x0000ff00) >> 8;	checksum[2] = (calculated32BitCkSum & 0x00ff0000) >> 16;	checksum[3] = (calculated32BitCkSum & 0xff000000) >> 24;	/* find the end of the inPacket chain */	endOfInPacket = inPacket;	while(endOfInPacket->mBlkHdr.mNext != NULL)	    endOfInPacket = endOfInPacket->mBlkHdr.mNext;	/* link in the checksum bytes at the end of the chain */	pppCkSum.mBlkHdr.mLen = 4;	endOfInPacket->mBlkHdr.mNext = &pppCkSum;	inPacket->mBlkPktHdr.len +=4;	totalPacketLen += 4;	}    else if (stackData->transmitFcsSize != PPP_NULL_FCS)	{	netMblkClChainFree(*packet);        RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 				stackData->pfwRFC2233CountPair,                               M2_ctrId_ifOutErrors, 1);	return ERROR;	}    /* allocate a new Mblk for the encoded frame */    if ((outFrame = netTupleGet(stackData->netPoolId,(totalPacketLen),				    M_DONTWAIT, MT_DATA ,TRUE)) == NULL)	{	printf ("AsyncFraming:Failed to get encoded frame for Stack 0x%x\n",			    (UINT32)state->stackObj);	endOfInPacket->mBlkHdr.mNext = NULL;	netMblkClChainFree(*packet);        RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 				stackData->pfwRFC2233CountPair,                               M2_ctrId_ifOutDiscards, 1);	return ERROR;	}    else	{	/* netTupleGet will not clear mLen */	outFrame->mBlkHdr.mLen  = 0;	outFrame->mBlkHdr.mFlags  &= ~M_PKTHDR;	outFrame->mBlkPktHdr.len  = 0;	}    /* set Frame start flag */    outFrame->mBlkHdr.mData[0] = 0x7e;    outFrame->mBlkHdr.mLen = 1;    /* move past frame start and encode the PPP packet */    outFrame->mBlkHdr.mData++;    /* encode the header, payload and checksum */    if (convertNormalDataToAsynchronousData (state, inPacket, outFrame) 	== ERROR)	{	netMblkClChainFree(outFrame);        endOfInPacket->mBlkHdr.mNext = NULL;        netMblkClChainFree(*packet);	return ERROR;	}    /* strip reference to attached checksum mBlk. free the original packet */    endOfInPacket->mBlkHdr.mNext = NULL;    netMblkClChainFree(*packet);    /* point to the frame start byte in the out going frame */    outFrame->mBlkHdr.mData--;    outFrame->mBlkPktHdr.len++;    *packet = outFrame;    return (OK);    }/********************************************************************************* convertNormalDataToAsynchronousData - convert data to an asynchronous format** RETURNS: OK or ERROR*/LOCAL STATUS convertNormalDataToAsynchronousData    (    PFW_PLUGIN_OBJ_STATE *state,    M_BLK_ID srcPacket,    M_BLK_ID dstFrame    )    {    ASYNC_FRAMING_STACK_DATA *stackData = state->stackData;    BYTE actual_byte = 0;    USHORT byte_counter;    USHORT number_of_escape_sequences = 0;    int dstByteCount = 0;    int srcByteLen = 0;    ULONG async_control_character_map = stackData->localToPeerACCMap;    char * dstBuf = dstFrame->mBlkHdr.mData;    char * srcBuf = NULL;    M_BLK_ID dstFrameChainHead = dstFrame;    do	{	srcBuf = srcPacket->mBlkHdr.mData;	srcByteLen = srcPacket->mBlkHdr.mLen;	for (byte_counter = 0; byte_counter < srcByteLen; byte_counter++)	    {	    actual_byte = *((BYTE *)((ULONG)  srcBuf + byte_counter));	    if ((encode_byte (&async_control_character_map,			      actual_byte) == TRUE) || 		(actual_byte == HDLC_FLAG_SEQUENCE) || 		(actual_byte == ASYNC_CONTROL_ESCAPE_SEQUENCE))		{		dstFrame->mBlkHdr.mLen++;		*dstBuf++ = ASYNC_CONTROL_ESCAPE_SEQUENCE;		dstByteCount++ ;		++number_of_escape_sequences;		actual_byte ^= ASYNC_SIXTH_BIT_COMPLEMENT;		if (dstBuf ==		    (dstFrame->pClBlk->clNode.pClBuf + dstFrame->pClBlk->clSize))		    {		    M_BLK_ID pNextMblk;		    if ((pNextMblk = 			netTupleGet(stackData->netPoolId,dstFrame->mBlkHdr.mLen,					    M_DONTWAIT, MT_DATA ,TRUE)) == NULL)			{			printf ("AsyncFraming:Failed to get another mBlk for \				encoded frame:Stack 0x%x\n",				(UINT32) state->stackObj);			RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 						stackData->pfwRFC2233CountPair,                                               M2_ctrId_ifOutDiscards, 1);			return ERROR;			}		    else			{			/* netTupleGet will not clear mLen */			pNextMblk->mBlkHdr.mLen  = 0;			pNextMblk->mBlkHdr.mFlags  &= ~M_PKTHDR;			pNextMblk->mBlkPktHdr.len  = 0;			}		    dstFrame->mBlkHdr.mNext = pNextMblk;		    dstFrame = dstFrame->mBlkHdr.mNext;		    dstBuf = dstFrame->mBlkHdr.mData;		    }		}	    *dstBuf++ = actual_byte;	    dstByteCount++ ;	    dstFrame->mBlkHdr.mLen++;	    if (dstBuf  ==		(dstFrame->pClBlk->clNode.pClBuf + dstFrame->pClBlk->clSize))		{		M_BLK_ID pNextMblk;		if ((pNextMblk = 			netTupleGet(stackData->netPoolId,dstFrame->mBlkHdr.mLen,					    M_DONTWAIT, MT_DATA ,TRUE)) == NULL)		    {		    printf ("AsyncFraming:Failed to get another mBlk for encoded \			frame:Stack 0x%x\n", (UINT32) state->stackObj);		    RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 					    stackData->pfwRFC2233CountPair,                                           M2_ctrId_ifOutDiscards, 1);		    return ERROR;		    }		else		    {		    /* netTupleGet will not clear mLen */		    pNextMblk->mBlkHdr.mLen  = 0;		    pNextMblk->mBlkHdr.mFlags  &= ~M_PKTHDR;		    pNextMblk->mBlkPktHdr.len  = 0;		    }		dstFrame->mBlkHdr.mNext = pNextMblk;		dstFrame = dstFrame->mBlkHdr.mNext;		dstBuf = dstFrame->mBlkHdr.mData;		}	    }	} while ((srcPacket = srcPacket->mBlkHdr.mNext) != NULL);    *dstBuf++ = 0x7e;    dstByteCount++;    dstFrame->mBlkHdr.mLen++;    dstFrameChainHead->mBlkHdr.mFlags |= M_PKTHDR;    dstFrameChainHead->mBlkPktHdr.len = dstByteCount;    return (OK);    }/********************************************************************************* encode_byte - check on the byte encoding** RETURNS: TRUE or FALSE*/LOCAL BOOL encode_byte     (    ULONG *async_control_character_map,    BYTE byte_to_encode    )    {    if ((byte_to_encode >= 0x20) || 	(*async_control_character_map == 0x00000000L))	{	return (FALSE);	}    if (*async_control_character_map == DEFAULT_ASYNC_CONTROL_CHARACTER_MAP)	if (byte_to_encode < 0x20)	    {	    return (TRUE);	    }    if (((ULONG) 1 << byte_to_encode) & *async_control_character_map)	{	return (TRUE);	}    else	{	return (FALSE);	}    }/********************************************************************************* pppAsyncFramingReceive - receive data in asynchronous format** RETURNS: OK or ERROR*/LOCAL STATUS pppAsyncFramingReceive    (    PFW_PLUGIN_OBJ_STATE *state,    M_BLK_ID * packet    )    {    register M_BLK_ID inFrame, outPacket;    ASYNC_FRAMING_STACK_DATA *stackData = state->stackData;    USHORT calculated16BitCkSum;    UINT32 calculated32BitCkSum;    int frameFlagsRemoved = 0;    int lengthOfEncodedData;    int sizeOfDecodedDataBuffer;    M_BLK_ID nextMblk;    PPP_LINK_STATUS_COUNTER_INCREMENT_INTERFACE * counterInterface = 		    (PPP_LINK_STATUS_COUNTER_INCREMENT_INTERFACE*)				stackData->pppLinkCounterInterface.interfaceObj;    if (packet == NULL || (inFrame = *packet) == NULL)        {        RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 				stackData->pfwRFC2233CountPair,                               M2_ctrId_ifInErrors, 1);        return (ERROR);        }    /* move past the frame Begin flag */    while (inFrame != NULL && *(inFrame->mBlkHdr.mData) == 0x7e)	{	inFrame->mBlkHdr.mData++;	frameFlagsRemoved++;	if (--inFrame->mBlkHdr.mLen == 0)	    {	    if ((nextMblk = inFrame->mBlkHdr.mNext) != NULL)		{		nextMblk->mBlkHdr.mFlags |= M_PKTHDR;		nextMblk->mBlkPktHdr.len = 				(inFrame->mBlkPktHdr.len - frameFlagsRemoved);		netMblkClFree(inFrame);		inFrame = nextMblk;		}	    else		{		netMblkClChainFree(inFrame);		RFC2233_COUNTER_UPDATE(stackData->pfwRFC2233CountTest, 					stackData->pfwRFC2233CountPair,                                       M2_ctrId_ifInErrors, 1);		return ERROR;		}	    frameFlagsRemoved = 0;	    }	}    if (inFrame->mBlkHdr.mNext != NULL)	{	inFrame->mBlkPktHdr.len -= frameFlagsRemoved;	lengthOfEncodedData = inFrame->mBlkPktHdr.len;	}    else	lengthOfEncodedData = inFrame->mBlkHdr.mLen;    sizeOfDecodedDataBuffer = min(lengthOfEncodedData,inFrame->pClBlk->clSize);    /* allocate a new Mblk for the decoded frame and allow for decompression */    if ((outPacket = netTupleGet(stackData->netPoolId,	    sizeOfDecodedDataBuffer, M_DONTWAIT, MT_DATA ,TRUE)) == NULL)	{	printf ("AsyncFraming:Failed to get decoded frame for StackObj 0x%x\n",		    (UINT32) state->stackObj);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久久动漫| 欧美男同性恋视频网站| 久久久久久日产精品| 国产一区二区精品在线观看| 精品福利一区二区三区| 国产精品小仙女| 欧美国产精品一区| a在线欧美一区| 亚洲美女在线国产| 在线观看av一区| 三级欧美韩日大片在线看| 91精品在线麻豆| 韩国欧美国产一区| 欧美激情一区二区三区蜜桃视频| av在线综合网| 亚洲地区一二三色| 欧美一区二区三区在线观看| 韩国精品免费视频| 中文字幕一区在线观看视频| 色婷婷综合视频在线观看| 日本一区中文字幕 | 色综合久久久久| 一卡二卡三卡日韩欧美| 欧美一级高清片在线观看| 国产精品自拍毛片| 亚洲午夜私人影院| 久久精品夜色噜噜亚洲a∨| 99久久er热在这里只有精品66| 午夜精品在线视频一区| 久久久99精品免费观看不卡| 91久久精品一区二区二区| 免费看日韩精品| 1024精品合集| 久久综合久色欧美综合狠狠| 91在线视频在线| 精品一区二区免费在线观看| 国产精品丝袜久久久久久app| 欧美三级视频在线| 高清不卡在线观看| 秋霞午夜鲁丝一区二区老狼| 国产精品免费视频观看| 69久久99精品久久久久婷婷| 成人三级伦理片| 日韩二区三区四区| 亚洲欧美自拍偷拍| 精品久久久久久久久久久久久久久 | 中文字幕一区二区在线观看| 91精品国产一区二区三区| www.亚洲在线| 久久99久久久欧美国产| 国内精品伊人久久久久av一坑 | 欧美色图在线观看| 高清av一区二区| 久久精品国内一区二区三区| 依依成人综合视频| 国产精品乱码久久久久久| 精品日韩一区二区三区| 欧美裸体一区二区三区| 欧美亚洲一区二区三区四区| 高清成人在线观看| 国产精品一区二区视频| 婷婷中文字幕综合| 亚洲香蕉伊在人在线观| 亚洲精品免费播放| 欧美高清在线视频| 国产网站一区二区| 精品久久免费看| 欧美成人乱码一区二区三区| 在线播放中文字幕一区| 欧美日韩成人在线一区| 欧美午夜片在线看| 91久久香蕉国产日韩欧美9色| 不卡的av在线播放| 成人夜色视频网站在线观看| 国产精品综合视频| 国产一区二区三区免费观看| 捆绑调教美女网站视频一区| 蜜桃精品视频在线| 麻豆精品久久久| 另类专区欧美蜜桃臀第一页| 蓝色福利精品导航| 另类中文字幕网| 精品一区二区av| 国产在线看一区| 国产高清成人在线| 成人一道本在线| 99精品一区二区三区| 91女人视频在线观看| 91黄色小视频| 欧美日韩在线电影| 91精品国产综合久久久久| 日韩欧美二区三区| 26uuu精品一区二区| 久久久99久久精品欧美| 欧美激情一区在线观看| 亚洲特级片在线| 亚洲一区二区三区四区不卡| 亚洲不卡av一区二区三区| 蜜臀精品一区二区三区在线观看| 久久精品国产亚洲一区二区三区| 久久不见久久见免费视频1| 国产在线精品一区二区三区不卡| 国产激情一区二区三区四区| 99久久99久久综合| 欧美精品乱码久久久久久按摩| 日韩精品综合一本久道在线视频| 国产亚洲欧美日韩俺去了| 亚洲欧洲一区二区在线播放| 午夜亚洲福利老司机| 另类成人小视频在线| gogogo免费视频观看亚洲一| 欧美在线观看视频一区二区三区| 日韩欧美你懂的| 日本不卡高清视频| 成人免费看视频| 欧美日韩免费观看一区二区三区| 日韩欧美国产不卡| 国产精品传媒在线| 日韩精品成人一区二区三区| 国内外成人在线| 在线精品视频一区二区| 日韩欧美中文字幕制服| 国产精品乱人伦一区二区| 亚洲高清在线视频| 国产91在线观看丝袜| 在线播放中文一区| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 亚洲一区二区三区视频在线| 激情综合网天天干| 在线观看视频欧美| 久久九九全国免费| 日韩福利视频导航| 日本韩国欧美国产| 国产肉丝袜一区二区| 日日摸夜夜添夜夜添精品视频 | 亚洲激情自拍视频| 国产麻豆精品theporn| 欧美精品1区2区| 亚洲天堂2014| 国产精品一区二区不卡| 欧美一区二区三区不卡| 亚洲婷婷综合色高清在线| 国产美女一区二区| 日韩一区二区三区观看| 洋洋av久久久久久久一区| 国产成人精品免费网站| 欧美一区二区三区白人| 一区二区欧美视频| 成人美女视频在线观看18| 精品国产免费人成在线观看| 亚洲成人av一区二区三区| 91婷婷韩国欧美一区二区| 欧美国产精品一区| 国产成人精品免费网站| 久久众筹精品私拍模特| 看片的网站亚洲| 在线综合视频播放| 偷拍亚洲欧洲综合| 欧美三区在线视频| 一区二区三区高清在线| jizz一区二区| 国产精品女主播在线观看| 国产精一品亚洲二区在线视频| 日韩女优视频免费观看| 捆绑紧缚一区二区三区视频| 欧美一区二区三区视频| 三级亚洲高清视频| 日韩欧美另类在线| 蜜臂av日日欢夜夜爽一区| 日韩女优av电影| 久久91精品久久久久久秒播| 日韩精品一区二区三区蜜臀 | 亚洲私人黄色宅男| 成人动漫视频在线| 中文字幕一区二区三区在线观看 | 亚洲福利视频三区| 欧美写真视频网站| 91片在线免费观看| 亚洲色图清纯唯美| 在线观看视频一区二区欧美日韩| 亚洲综合色网站| 欧美日韩视频一区二区| 亚洲777理论| 91精品国产免费| 久草中文综合在线| 久久久精品蜜桃| 成人免费黄色大片| 亚洲精品老司机| 欧美美女一区二区| 久久99久久精品| 久久免费国产精品| 99久久精品费精品国产一区二区| 一区二区三区欧美在线观看| 欧美日韩国产首页在线观看| 麻豆传媒一区二区三区| 欧美国产日本韩| 欧美日韩一卡二卡| 乱中年女人伦av一区二区| 久久久高清一区二区三区| 99久久久久久|