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

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

?? ppp.c

?? TCP_IPprotocol.rar
?? C
?? 第 1 頁 / 共 2 頁
字號:
			if ( mode & PPP_ESCAPED ) {
				ppp_skipped( ppp_p, &head_bp,
					"deliberate cancellation" );
				ppp_p->InFrame++;
			} else if ( mode & PPP_TOSS ) {
				free_p(& head_bp );
			} else if ( head_bp != NULL ) {
				if ( calc_fcs != HDLC_FCS_FINAL ) {
					ppp_skipped( ppp_p, &head_bp,
						"checksum error" );
					ppp_p->InChecksum++;
				} else {
					/* trim off FCS bytes */
					trim_mbuf(&head_bp, len_p(head_bp)-2);

					net_route(ifp,&head_bp);
					/* Especially on slow machines, serial I/O can be quite
					 * compute intensive, so release the machine before we
					 * do the next packet.  This will allow this packet to
					 * go on toward its ultimate destination. [Karn]
					 */
					kwait(NULL);
				}
			} else {
				ppp_p->InOpenFlag++;
			}

			/* setup for next buffer */
			mode = FALSE;
			head_bp = tail_bp = NULL;
			calc_fcs = HDLC_FCS_START;
			accm = LCP_ACCM_DEFAULT;

			/* Use negotiated values if LCP finished */
			if (ppp_p->fsm[Lcp].state == fsmOPENED) {
				struct lcp_s *lcp_p = ppp_p->fsm[Lcp].pdv;

				if (lcp_p->local.work.negotiate & LCP_N_ACCM) {
					accm = lcp_p->local.work.accm;
				}
			}
#ifdef PPP_DEBUG_RAW
			if (!(ifp->trace & IF_TRACE_RAW)) {
				if ( raw_bp != NULL ) {
					free_p(& raw_bp );
					raw_bp = NULL;
				}
			}
#endif
			continue;
		}

		/* We reach here for every byte inside a frame.
		 * (The order of the following tests is important.)
		 * Discard spurious control characters.
		 * Check for escape sequence.
		 * (Allow escaped escape.)
		 */
		if ( c < SP_CHAR && (accm & (1L << c)) ) {
			continue;
		} else if ( mode & PPP_ESCAPED ) {
			mode &= ~PPP_ESCAPED;
			c ^= HDLC_ESC_COMPL;
		} else if ( c == HDLC_ESC_ASYNC ) {
			mode |= PPP_ESCAPED;
			continue;
		}

		/* We reach here with a byte for the buffer.
		 * Make sure there is room for it.
		 */
		if ( tail_bp == NULL ) {
			if ((tail_bp = alloc_mbuf(PPP_ALLOC)) == NULL) {
				ppp_skipped( ppp_p, &tail_bp, Nospace );
				ppp_p->InMemory++;
				mode |= PPP_TOSS;
				continue;
			}
			head_bp = tail_bp;
			cp = tail_bp->data;
		} else if ( tail_bp->cnt >= tail_bp->size ) {
			/* Current mbuf is full */
			if ( (tail_bp->next = alloc_mbuf(PPP_ALLOC)) == NULL ) {
				/* No memory, drop the whole packet */
				ppp_skipped( ppp_p, &head_bp, Nospace );
				ppp_p->InMemory++;
				head_bp = NULL;
				mode |= PPP_TOSS;
				continue;
			}
			tail_bp = tail_bp->next;
			cp = tail_bp->data;
		}

		/* Store the byte, increment counts */
		*cp++ = c;
		tail_bp->cnt++;
		calc_fcs = pppfcs(calc_fcs, c);
	}

	/* clean up afterward */
	free_p(&raw_bp);
	free_p(&head_bp);
	ifp->rxproc = NULL;
}

#ifdef TURBOC_SWITCH_BUG
#pragma option -G-
#endif

/* Process incoming PPP packets */
/* (called from network task) */
void
ppp_proc(ifp,bpp)
struct iface *ifp;
struct mbuf **bpp;
{
	struct ppp_s *ppp_p;
	struct ipcp_s *ipcp_p;
	struct ppp_hdr ph;
	uint16 negotiated = FALSE;

	if ( ifp == NULL ) {
		logmsg(-1, "ppp_proc: missing iface" );
		return;
	}
	if ( *bpp == NULL ) {
		trace_log(ifp, "ppp_proc: missing buffer" );
		return;
	}

	ppp_p = ifp->edv;
	ppp_p->InRxOctetCount += len_p(*bpp) + 2;   /* count FCS bytes */

	/* Use negotiated values if LCP finished */
	if (ppp_p->fsm[Lcp].state == fsmOPENED) {
		struct lcp_s *lcp_p = ppp_p->fsm[Lcp].pdv;

		negotiated = lcp_p->local.work.negotiate;
	}

	/* HDLC address and control fields may be compressed out */
	if ((byte_t)(*bpp)->data[0] != HDLC_ALL_ADDR) {
		if (!(negotiated & LCP_N_ACFC)) {
			ppp_skipped( ppp_p, bpp, "missing ALL address" );
			ppp_p->InFrame++;
			return;
		}
	} else if ((byte_t)(*bpp)->data[1] != HDLC_UI) {
		if (!(negotiated & LCP_N_ACFC)
		 || !(negotiated & LCP_N_PFC)) {
			ppp_skipped( ppp_p, bpp, "missing UI" );
			ppp_p->InFrame++;
			return;
		}
	} else {
		/* skip address/control fields */
		pull16(bpp);
	}

	/* Initialize the expected header */
	ph.addr = HDLC_ALL_ADDR;
	ph.control = HDLC_UI;
	ph.protocol = PULLCHAR(bpp);

	/* First byte of PPP protocol field may be compressed out */
	if ( ph.protocol & 0x01 ) {
		if (!(negotiated & LCP_N_PFC)) {
			ppp_skipped( ppp_p, bpp, "missing upper protocol byte" );
			ppp_p->InFrame++;
			return;
		}
	} else {
		ph.protocol = (ph.protocol << 8) | PULLCHAR(bpp);

		/* Second byte of PPP protocol field must be odd */
		if ( !(ph.protocol & 0x01) ) {
			ppp_skipped( ppp_p, bpp, "missing lower protocol byte" );
			ppp_p->InFrame++;
			return;
		}
	}


	switch(ph.protocol) {
	case PPP_IP_PROTOCOL:	/* Regular IP */
		if ( ppp_p->fsm[IPcp].state != fsmOPENED ) {
			ppp_error( ppp_p, bpp, "not open for IP traffic" );
			ppp_p->InError++;
			break;
		}
		ip_route(ifp,bpp,0);
		break;

	case PPP_COMPR_PROTOCOL:	/* Van Jacobson Compressed TCP/IP */
		if ( ppp_p->fsm[IPcp].state != fsmOPENED ) {
			ppp_skipped( ppp_p, bpp, "not open for Compressed TCP/IP traffic" );
			ppp_p->InError++;
			break;
		}

		ipcp_p = ppp_p->fsm[IPcp].pdv;
		if (!(ipcp_p->local.work.negotiate & IPCP_N_COMPRESS)) {
			ppp_skipped( ppp_p, bpp, "Compressed TCP/IP not enabled" );
			ppp_p->InError++;
			break;
		}

		if ( slhc_uncompress(ipcp_p->slhcp, bpp) <= 0 ) {
			ppp_error( ppp_p, bpp, "Compressed TCP/IP packet error" );
			ppp_p->InError++;
			break;
		}
		ip_route(ifp,bpp,0);
		break;

	case PPP_UNCOMP_PROTOCOL:	/* Van Jacobson Uncompressed TCP/IP */
		if ( ppp_p->fsm[IPcp].state != fsmOPENED ) {
			ppp_skipped( ppp_p, bpp, "not open for Uncompressed TCP/IP traffic" );
			ppp_p->InError++;
			break;
		}

		ipcp_p = ppp_p->fsm[IPcp].pdv;
		if (!(ipcp_p->local.work.negotiate & IPCP_N_COMPRESS)) {
			ppp_skipped( ppp_p, bpp, "Uncompressed TCP/IP not enabled" );
			ppp_p->InError++;
			break;
		}

		if ( slhc_remember(ipcp_p->slhcp, bpp) <= 0 ) {
			ppp_error( ppp_p, bpp, "Uncompressed TCP/IP packet error" );
			ppp_p->InError++;
			break;
		}
		ip_route(ifp,bpp,0);
		break;

	case PPP_LCP_PROTOCOL:	/* Link Control Protocol */
		ppp_p->InNCP[Lcp]++;
		fsm_proc(&(ppp_p->fsm[Lcp]),bpp);
		break;

	case PPP_PAP_PROTOCOL:	/* Password Authenticate Protocol */
		if (ppp_p->phase != pppAP
		 && ppp_p->phase != pppREADY) {
			ppp_error( ppp_p, bpp, "not ready for Authentication" );
			ppp_p->InError++;
			break;
		}
		ppp_p->InNCP[Pap]++;
		pap_proc(&(ppp_p->fsm[Pap]),bpp);
		break;

	case PPP_IPCP_PROTOCOL:	/* IP Control Protocol */
		if (ppp_p->phase != pppREADY) {
			ppp_error( ppp_p, bpp, "not ready for IPCP traffic" );
			ppp_p->InError++;
			break;
		}
		ppp_p->InNCP[IPcp]++;
		fsm_proc(&(ppp_p->fsm[IPcp]),bpp);
		break;

	default:
		if ( ppp_p->trace )
			trace_log(ppp_p->iface, "%s PPP Unknown packet protocol: %x;",
				ppp_p->iface->name,
				ph.protocol);
		ppp_p->InUnknown++;

		/* Build Protocol Reject packet:
		 * put the header back on ...
		 */
		htonppp(&ph,bpp);
		/* ... then pull off the address and control fields ... */
		pull16(bpp);
		/* ... and send it as an LCP packet */
		fsm_send( &(ppp_p->fsm[Lcp]), PROT_REJ, 0, bpp );
		break;
	};
}

#ifdef TURBOC_SWITCH_BUG
#pragma option -G
#endif

/************************************************************************/

/* Keep track of changes in I-O status */
/* (called through iface iostatus vector) */
static int
ppp_iostatus( ifp, command, value )
struct iface *ifp;
int command;
int32 value;
{
	struct ppp_s *ppp_p = ifp->edv;

	switch ( command ) {
	case PARAM_UP:
		ppp_log( ppp_p, "Physical layer up" );

		if ( ppp_p->phase == pppDEAD ) {
			ppp_p->phase = pppLCP;
		}
		fsm_start( &(ppp_p->fsm[Lcp]) );
		return 0;

	case PARAM_DOWN:
		ppp_log( ppp_p, "Physical layer down" );

		fsm_down( &(ppp_p->fsm[Lcp]) );
		ppp_p->phase = pppDEAD;
		return 0;
	};
	return -1;
}


static int
ppp_discard(
struct iface *ifp,
struct mbuf **bpp
){
	struct ppp_s *ppp_p = ifp->edv;

	return fsm_send(&(ppp_p->fsm[Lcp]), DISCARD_REQ, 0, bpp);
}


static int
ppp_echo(
struct iface *ifp,
struct mbuf **bpp
){
	struct ppp_s *ppp_p = ifp->edv;

	return fsm_send(&(ppp_p->fsm[Lcp]), ECHO_REQ, 0, bpp);
}


/****************************************************************************/
/* Initialize PPP control structures for a Point-to-Point interface */
int
ppp_init(ifp)
struct iface *ifp;
{
	struct ppp_s *ppp_p;
	char *ifn;

	/* Setup for Point-to-Point Protocol */
	ifp->ioctl = asy_ioctl;

	ppp_p = callocw(1,sizeof(struct ppp_s));

	ifp->edv = ppp_p;
	ifp->iostatus = ppp_iostatus;
	ifp->raw = ppp_raw;
	ifp->show = ppp_show;
	ifp->echo = ppp_echo;
	ifp->discard = ppp_discard;

	ppp_p->iface = ifp;
	ppp_p->phase = pppDEAD;

	lcp_init(ppp_p);
	pap_init(ppp_p);
	ipcp_init(ppp_p);

	ifp->rxproc = newproc( ifn = if_name( ifp, " receive" ),
			320, ppp_recv, ifp->dev, ifp, NULL, 0);
	free(ifn);
	return 0;
}


int
ppp_free(ifp)
struct iface *ifp;
{
	struct ppp_s *ppp_p = ifp->edv;
	int fsmi;

	alert( ifp->rxproc, 1 );

	for ( fsmi = Lcp; fsmi < fsmi_Size; ) {
		fsm_free( &(ppp_p->fsm[fsmi++]) );
	}
	free( ppp_p->peername );
	free( ppp_p );
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国模一区二区三区| 91极品视觉盛宴| 亚洲尤物视频在线| 国产亚洲综合色| 日韩一区二区在线观看视频| 成人精品国产一区二区4080| 免费在线观看视频一区| 亚洲欧美另类久久久精品2019| 欧美xxxx老人做受| 欧美日韩国产123区| 成人黄色电影在线| 国产一区中文字幕| 日本怡春院一区二区| 亚洲最大成人网4388xx| 国产精品污污网站在线观看| 精品美女被调教视频大全网站| 91农村精品一区二区在线| 国产真实乱子伦精品视频| 日本不卡视频在线| 亚洲1区2区3区视频| 亚洲天堂精品在线观看| 欧美激情综合五月色丁香| 精品日韩一区二区三区| 欧美日韩国产成人在线91| 在线一区二区视频| 色噜噜狠狠一区二区三区果冻| 夫妻av一区二区| 国产福利不卡视频| 国产精品1区2区3区在线观看| 麻豆久久久久久| 免费看精品久久片| 美腿丝袜在线亚洲一区| 美国十次综合导航| 玖玖九九国产精品| 久久精品久久99精品久久| 青青草国产精品97视觉盛宴 | 精品电影一区二区| 欧美一区二视频| 欧美一区中文字幕| 日韩欧美激情一区| 精品国产不卡一区二区三区| 精品福利在线导航| 久久精品亚洲精品国产欧美 | 99久久久免费精品国产一区二区| 国产精品一区二区三区四区| 国产在线麻豆精品观看| 国产一区欧美日韩| 懂色av一区二区三区免费观看| 国产精品1区二区.| jizz一区二区| 欧美综合色免费| 欧美撒尿777hd撒尿| 欧美一区午夜视频在线观看| 日韩亚洲国产中文字幕欧美| 欧美成人a视频| 久久久av毛片精品| 国产精品视频一二三| 亚洲丝袜另类动漫二区| 亚洲一区二区欧美激情| 爽好多水快深点欧美视频| 日本欧美在线观看| 高清在线观看日韩| 91久久香蕉国产日韩欧美9色| 欧美日韩精品一区二区三区| 69堂精品视频| 中文字幕欧美区| 亚洲一区二区三区四区不卡| 麻豆精品一区二区综合av| 国产精品自拍毛片| 色成人在线视频| 日韩欧美精品在线| 日韩一区中文字幕| 日韩国产精品91| 成人午夜视频网站| 欧美少妇xxx| 国产午夜三级一区二区三| 亚洲欧美另类久久久精品2019| 日本成人在线电影网| 国产精品亚洲成人| 欧美日韩色综合| 国产欧美日韩不卡| 亚洲va欧美va人人爽| 国产精品一区二区在线观看网站| 色综合中文字幕| 精品久久久久久无| 一区二区三区在线免费观看| 国内偷窥港台综合视频在线播放| 色婷婷国产精品综合在线观看| 日韩午夜在线观看| 亚洲色图制服丝袜| 久久er精品视频| 欧美视频精品在线| 国产精品福利电影一区二区三区四区| 亚洲一区二区三区视频在线播放| 国产另类ts人妖一区二区| 欧美色网一区二区| 国产精品久久久久久久久免费樱桃| 图片区日韩欧美亚洲| av中文字幕一区| 精品国产精品一区二区夜夜嗨| 亚洲一区二区三区小说| 盗摄精品av一区二区三区| 日韩欧美在线123| 亚洲国产aⅴ天堂久久| 床上的激情91.| 精品不卡在线视频| 日韩影院在线观看| 在线一区二区观看| ●精品国产综合乱码久久久久| 韩国v欧美v日本v亚洲v| 91精品国产色综合久久| 一区二区三区在线视频免费| 丁香桃色午夜亚洲一区二区三区| 欧美一区二区在线不卡| 夜夜亚洲天天久久| 色先锋资源久久综合| 国产精品久久久久久久久免费丝袜 | 久久综合av免费| 日韩av二区在线播放| 欧美怡红院视频| 亚洲女厕所小便bbb| 成人美女视频在线观看18| 久久精品一区二区三区av| 精品一区二区免费视频| 欧美一区二区三区免费大片| 亚洲大片精品永久免费| 在线观看精品一区| 亚洲一区自拍偷拍| 欧美三级乱人伦电影| 亚洲电影第三页| 欧美精品乱码久久久久久| 亚洲高清在线精品| 欧美日韩国产影片| 日韩成人av影视| 欧美一区二区三区色| 日本sm残虐另类| 精品国产1区2区3区| 国产精品综合一区二区| 中文av一区特黄| 99精品久久免费看蜜臀剧情介绍| 国产精品人成在线观看免费| 成人影视亚洲图片在线| 国产精品电影一区二区三区| 91麻豆福利精品推荐| 亚洲综合久久久久| 91麻豆精品国产91久久久使用方法 | 成人免费不卡视频| 亚洲欧美另类图片小说| 欧美在线一二三| 午夜精品一区二区三区三上悠亚| 欧美日韩你懂得| 青青草原综合久久大伊人精品优势| 日韩欧美在线1卡| 国产一区二区0| 国产精品欧美一区二区三区| 91丨九色丨蝌蚪富婆spa| 亚洲一区在线看| 69堂国产成人免费视频| 国产一二精品视频| 亚洲人妖av一区二区| 欧美午夜精品一区二区三区 | 日产精品久久久久久久性色| 日韩欧美国产一区二区三区| 国产成a人亚洲精| 亚洲国产日韩综合久久精品| 日韩一区二区在线免费观看| 国产成人免费视频| 亚洲国产视频一区| 久久综合av免费| 91精彩视频在线观看| 久久成人免费网站| 国产精品国产三级国产| 51久久夜色精品国产麻豆| 国产精品自产自拍| 亚洲成人免费看| 欧美激情中文不卡| 欧美精品免费视频| 成人福利在线看| 日韩精品乱码免费| 国产精品久久久久久久久久久免费看| 欧美剧情片在线观看| 成人在线视频一区二区| 日韩av电影免费观看高清完整版| 亚洲国产精品成人综合色在线婷婷| 欧美日韩免费不卡视频一区二区三区| 国产伦精品一区二区三区视频青涩 | 中文字幕在线一区免费| 欧美精品日韩一本| 91麻豆产精品久久久久久| 激情欧美一区二区| 亚洲国产精品自拍| 欧美激情综合网| 精品乱码亚洲一区二区不卡| 一本色道亚洲精品aⅴ| 狠狠v欧美v日韩v亚洲ⅴ| 午夜激情一区二区| 亚洲美女屁股眼交3| 国产性天天综合网| 精品国产乱码久久久久久免费| 欧美日韩国产不卡|