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

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

?? ppp.c

?? TCPIP源代碼C語言版本
?? 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一区二区三区免费野_久草精品视频
久久久精品中文字幕麻豆发布| 日韩丝袜情趣美女图片| 玉米视频成人免费看| 国产高清在线精品| 欧美tickling网站挠脚心| 91麻豆精品秘密| 国产麻豆视频精品| 99精品国产热久久91蜜凸| 欧美羞羞免费网站| 亚洲国产高清aⅴ视频| 91精品欧美久久久久久动漫| 日本午夜精品一区二区三区电影| 亚洲精品视频一区二区| 综合网在线视频| 国产日韩成人精品| 日韩伦理电影网| 国产在线视频不卡二| 97se狠狠狠综合亚洲狠狠| 欧美一级久久久| 久久国产麻豆精品| 国产亚洲欧美日韩在线一区| 色婷婷精品久久二区二区蜜臂av | 日本中文一区二区三区| 国产一区欧美二区| 欧美精品自拍偷拍| 日本一区二区视频在线观看| 亚洲精品综合在线| 99国产欧美另类久久久精品| 亚洲乱码精品一二三四区日韩在线| 国产精品原创巨作av| 丁香五精品蜜臀久久久久99网站| 日韩视频免费直播| 亚洲日本va午夜在线电影| 国产日韩在线不卡| 久久久久久久久久久久久女国产乱 | 色噜噜久久综合| 视频一区二区欧美| 欧美视频在线不卡| 色悠悠久久综合| 97久久精品人人澡人人爽| 这里只有精品视频在线观看| 亚洲欧洲性图库| 国产成人亚洲综合色影视| wwwwww.欧美系列| 秋霞影院一区二区| 日韩欧美区一区二| 激情图区综合网| 精品久久人人做人人爽| 久久精品国产一区二区三区免费看| 在线亚洲人成电影网站色www| 久久精品一区二区| 国产一区二区不卡老阿姨| ww久久中文字幕| 国产成人免费高清| 国产视频一区在线播放| 成人精品一区二区三区四区| 欧美电影免费观看高清完整版在 | 精品福利视频一区二区三区| 久久爱另类一区二区小说| 欧美一区中文字幕| 国产成人三级在线观看| 国产精品初高中害羞小美女文| caoporm超碰国产精品| 亚洲综合丝袜美腿| 正在播放亚洲一区| 国产不卡高清在线观看视频| 国产女人水真多18毛片18精品视频| 国产精品一区2区| 亚洲同性gay激情无套| 91精品婷婷国产综合久久| 国产美女在线精品| 亚洲一区二区在线免费观看视频| 日韩精品一区二区三区四区| av在线不卡电影| 国模一区二区三区白浆| 亚洲天堂2014| 日韩欧美国产一区二区三区| jiyouzz国产精品久久| 美日韩一级片在线观看| 亚洲精品美国一| 国产精品成人网| 久久久精品人体av艺术| 日韩一区二区三| 欧美视频一区二区在线观看| 99精品视频在线免费观看| 国产成人精品三级| 国产一区二区精品久久91| 日日夜夜精品免费视频| 国产精品久久久久久户外露出 | 国产拍揄自揄精品视频麻豆| 777色狠狠一区二区三区| 欧美在线观看视频一区二区三区| 国产福利一区二区三区| 精品在线你懂的| 国产美女在线精品| 丁香网亚洲国际| 91麻豆精品在线观看| 色婷婷久久久亚洲一区二区三区 | 欧美日韩夫妻久久| 欧美亚洲国产bt| 欧美人xxxx| 久久综合久久综合久久| 久久网站最新地址| 国产精品不卡视频| 一区二区三区免费网站| 日本亚洲最大的色成网站www| 日韩专区在线视频| 国产aⅴ综合色| 91色九色蝌蚪| 欧美一级生活片| 日韩一区在线播放| 久久精品国产亚洲高清剧情介绍 | 成人久久18免费网站麻豆| 在线观看日韩毛片| 精品久久久久久综合日本欧美| 国产精品久久久久久久第一福利| 亚洲女同一区二区| 久久精品噜噜噜成人av农村| 成人午夜av电影| 5566中文字幕一区二区电影| 久久影院电视剧免费观看| 亚洲精品乱码久久久久久 | 成人中文字幕合集| 欧美mv和日韩mv的网站| 亚洲中国最大av网站| 成人不卡免费av| 久久精品日产第一区二区三区高清版| 亚洲视频每日更新| 91社区在线播放| 国产精品免费av| 成人综合激情网| 久久久久久亚洲综合| 久久99国产精品麻豆| 日韩一区二区三区电影在线观看| 夜夜精品视频一区二区 | 精品噜噜噜噜久久久久久久久试看| 国产精品黄色在线观看| 国产乱人伦精品一区二区在线观看| 欧美精选在线播放| 日韩黄色在线观看| 日韩欧美亚洲一区二区| 精品在线视频一区| 久久久国产精品不卡| 色成年激情久久综合| 久久中文字幕电影| 国产成a人亚洲精品| 亚洲麻豆国产自偷在线| 3d成人动漫网站| av男人天堂一区| 日本在线不卡视频| 国产精品三级电影| 91精品国产美女浴室洗澡无遮挡| 美女www一区二区| 国产精品久久久久永久免费观看| 欧美在线观看18| 国产精品影视网| 日日噜噜夜夜狠狠视频欧美人 | 一区二区三区在线视频免费观看 | 亚洲成人在线网站| 国产精品久久久久一区二区三区| 一本色道久久综合亚洲aⅴ蜜桃 | 亚洲免费在线观看| 久久这里只有精品首页| 欧美美女喷水视频| 99久久精品国产观看| 国产成人综合亚洲网站| 日韩一级片网址| 波波电影院一区二区三区| 一区二区三区在线免费视频| 日韩一区二区三区在线| 国产乱码精品一品二品| 国产精品嫩草影院com| 精品久久一区二区| 国产网站一区二区| 久久久久久免费| 亚洲综合视频在线观看| 自拍偷拍国产亚洲| 日韩福利电影在线| 国产一区二区不卡在线| 色综合久久久网| 久久久综合激的五月天| 日韩激情视频在线观看| 色婷婷久久久综合中文字幕 | 国产精品超碰97尤物18| 精品国内片67194| 国产欧美一区二区三区在线老狼| 中文字幕国产一区| 五月激情综合网| 紧缚奴在线一区二区三区| 国产iv一区二区三区| 欧美综合天天夜夜久久| www.视频一区| 日本欧洲一区二区| 99国产精品国产精品久久| 欧美一级片在线| 欧美三级电影精品| 91精品国产综合久久蜜臀| 高清免费成人av| 成人黄色一级视频| 6080亚洲精品一区二区|