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

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

?? vj.c

?? lwip在ucos上的移植
?? C
?? 第 1 頁 / 共 2 頁
字號:
		break;		/* (fall through) */		case SPECIAL_I:	case SPECIAL_D:		/*		 * actual changes match one of our special case encodings --		 * send packet uncompressed.		 */		goto uncompressed;		case NEW_S|NEW_A:		if (deltaS == deltaA && deltaS == ntohs(cs->cs_ip.ip_len) - hlen) {			/* special case for echoed terminal traffic */			changes = SPECIAL_I;			cp = new_seq;		}		break;		case NEW_S:		if (deltaS == ntohs(cs->cs_ip.ip_len) - hlen) {			/* special case for data xfer */			changes = SPECIAL_D;			cp = new_seq;		}		break;	}		deltaS = (u_short)(ntohs(ip->ip_id) - ntohs(cs->cs_ip.ip_id));	if (deltaS != 1) {		ENCODEZ(deltaS);		changes |= NEW_I;	}	if (th->th_flags & TCP_PSH)	changes |= TCP_PUSH_BIT;	/*	 * Grab the cksum before we overwrite it below.  Then update our	 * state with this packet's header.	 */	deltaA = ntohs(th->th_sum);	BCOPY(ip, &cs->cs_ip, hlen);		/*	 * We want to use the original packet as our compressed packet.	 * (cp - new_seq) is the number of bytes we need for compressed	 * sequence numbers.  In addition we need one byte for the change	 * mask, one for the connection id and two for the tcp checksum.	 * So, (cp - new_seq) + 4 bytes of header are needed.  hlen is how	 * many bytes of the original packet to toss so subtract the two to	 * get the new packet size.	 */	deltaS = (u_short)(cp - new_seq);	if (!comp->compressSlot || comp->last_xmit != cs->cs_id) {		comp->last_xmit = cs->cs_id;		hlen -= deltaS + 4;		pbuf_header(pb, -hlen);		cp = (u_char *)pb->payload;		*cp++ = changes | NEW_C;		*cp++ = cs->cs_id;	} else {		hlen -= deltaS + 3;		pbuf_header(pb, -hlen);		cp = (u_char *)pb->payload;		*cp++ = changes;	}	*cp++ = deltaA >> 8;	*cp++ = deltaA;	BCOPY(new_seq, cp, deltaS);	INCR(vjs_compressed);	return (TYPE_COMPRESSED_TCP);	/*	 * Update connection state cs & send uncompressed packet (that is,	 * a regular ip/tcp packet but with the 'conversation id' we hope	 * to use on future compressed packets in the protocol field).	 */uncompressed:	BCOPY(ip, &cs->cs_ip, hlen);	ip->ip_p = cs->cs_id;	comp->last_xmit = cs->cs_id;	return (TYPE_UNCOMPRESSED_TCP);}/* * Called when we may have missed a packet. */void vj_uncompress_err(struct vjcompress *comp){    comp->flags |= VJF_TOSS;	INCR(vjs_errorin);}/* * "Uncompress" a packet of type TYPE_UNCOMPRESSED_TCP. * Return 0 on success, -1 on failure. */int vj_uncompress_uncomp(	struct pbuf *nb,	struct vjcompress *comp){	register u_int hlen;	register struct cstate *cs;	register struct ip *ip;		ip = (struct ip *)nb->payload;	hlen = getip_hl(*ip) << 2;	if (ip->ip_p >= MAX_SLOTS			|| hlen + sizeof(struct tcphdr) > nb->len			|| (hlen += getth_off(*((struct tcphdr *)&((char *)ip)[hlen])) << 2)			    > nb->len			|| hlen > MAX_HDR) {		PPPDEBUG((LOG_INFO, "vj_uncompress_uncomp: bad cid=%d, hlen=%d buflen=%d\n", 					ip->ip_p, hlen, nb->len));		comp->flags |= VJF_TOSS;		INCR(vjs_errorin);		return -1;	}	cs = &comp->rstate[comp->last_recv = ip->ip_p];	comp->flags &=~ VJF_TOSS;	ip->ip_p = IPPROTO_TCP;	BCOPY(ip, &cs->cs_ip, hlen);	cs->cs_hlen = hlen;	INCR(vjs_uncompressedin);	return 0;}/* * Uncompress a packet of type TYPE_COMPRESSED_TCP. * The packet is composed of a buffer chain and the first buffer * must contain an accurate chain length. * The first buffer must include the entire compressed TCP/IP header.  * This procedure replaces the compressed header with the uncompressed * header and returns the length of the VJ header. */int vj_uncompress_tcp(	struct pbuf **nb,	struct vjcompress *comp){	u_char *cp;	struct tcphdr *th;	struct cstate *cs;	u_short *bp;	struct pbuf *n0 = *nb;	u32_t tmp;	u_int vjlen, hlen, changes;		INCR(vjs_compressedin);	cp = (u_char *)n0->payload;	changes = *cp++;	if (changes & NEW_C) {		/* 		 * Make sure the state index is in range, then grab the state.		 * If we have a good state index, clear the 'discard' flag. 		 */		if (*cp >= MAX_SLOTS) {			PPPDEBUG((LOG_INFO, "vj_uncompress_tcp: bad cid=%d\n", *cp));			goto bad;		}				comp->flags &=~ VJF_TOSS;		comp->last_recv = *cp++;	} else {		/* 		 * this packet has an implicit state index.  If we've		 * had a line error since the last time we got an		 * explicit state index, we have to toss the packet. 		 */		if (comp->flags & VJF_TOSS) {			PPPDEBUG((LOG_INFO, "vj_uncompress_tcp: tossing\n"));			INCR(vjs_tossed);			return (-1);		}	}	cs = &comp->rstate[comp->last_recv];	hlen = getip_hl(cs->cs_ip) << 2;	th = (struct tcphdr *)&((u_char *)&cs->cs_ip)[hlen];	th->th_sum = htons((*cp << 8) | cp[1]);	cp += 2;	if (changes & TCP_PUSH_BIT)		th->th_flags |= TCP_PSH;	else		th->th_flags &=~ TCP_PSH;		switch (changes & SPECIALS_MASK) {	case SPECIAL_I:		{			register u32_t i = ntohs(cs->cs_ip.ip_len) - cs->cs_hlen;			/* some compilers can't nest inline assembler.. */			tmp = ntohl(th->th_ack) + i;			th->th_ack = htonl(tmp);			tmp = ntohl(th->th_seq) + i;			th->th_seq = htonl(tmp);		}		break;		case SPECIAL_D:		/* some compilers can't nest inline assembler.. */		tmp = ntohl(th->th_seq) + ntohs(cs->cs_ip.ip_len) - cs->cs_hlen;		th->th_seq = htonl(tmp);		break;		default:		if (changes & NEW_U) {			th->th_flags |= TCP_URG;			DECODEU(th->th_urp);		} else			th->th_flags &=~ TCP_URG;		if (changes & NEW_W)			DECODES(th->th_win);		if (changes & NEW_A)			DECODEL(th->th_ack);		if (changes & NEW_S)			DECODEL(th->th_seq);		break;	}	if (changes & NEW_I) {		DECODES(cs->cs_ip.ip_id);	} else {		cs->cs_ip.ip_id = ntohs(cs->cs_ip.ip_id) + 1;		cs->cs_ip.ip_id = htons(cs->cs_ip.ip_id);	}		/*	 * At this point, cp points to the first byte of data in the	 * packet.  Fill in the IP total length and update the IP	 * header checksum.	 */	vjlen = (u_short)(cp - (u_char*)n0->payload);	if (n0->len < vjlen) {		/* 		 * We must have dropped some characters (crc should detect		 * this but the old slip framing won't) 		 */		PPPDEBUG((LOG_INFO, "vj_uncompress_tcp: head buffer %d too short %d\n", 				  n0->len, vjlen));		goto bad;	}	#if BYTE_ORDER == LITTLE_ENDIAN	tmp = n0->tot_len - vjlen + cs->cs_hlen;	cs->cs_ip.ip_len = htons(tmp);#else	cs->cs_ip.ip_len = htons(n0->tot_len - vjlen + cs->cs_hlen);#endif		/* recompute the ip header checksum */	bp = (u_short *) &cs->cs_ip;	cs->cs_ip.ip_sum = 0;	for (tmp = 0; hlen > 0; hlen -= 2)		tmp += *bp++;	tmp = (tmp & 0xffff) + (tmp >> 16);	tmp = (tmp & 0xffff) + (tmp >> 16);	cs->cs_ip.ip_sum = (u_short)(~tmp);		/* Remove the compressed header and prepend the uncompressed header. */	pbuf_header(n0, -vjlen);	if(MEM_ALIGN(n0->payload) != n0->payload) {		struct pbuf *np, *q;		u8_t *bufptr;		np = pbuf_alloc(PBUF_RAW, n0->len + cs->cs_hlen, PBUF_POOL);		if(!np) {			PPPDEBUG((LOG_WARNING, "vj_uncompress_tcp: realign failed\n"));			*nb = NULL;			goto bad;		}		pbuf_header(np, -cs->cs_hlen);		bufptr = n0->payload;		for(q = np; q != NULL; q = q->next) {			memcpy(q->payload, bufptr, q->len);			bufptr += q->len;		}		if(n0->next) {			pbuf_chain(np, n0->next);			pbuf_dechain(n0);		}		pbuf_free(n0);		n0 = np;	}	if(pbuf_header(n0, cs->cs_hlen)) {		struct pbuf *np;		LWIP_ASSERT("vj_uncompress_tcp: cs->cs_hlen <= PBUF_POOL_BUFSIZE", cs->cs_hlen <= PBUF_POOL_BUFSIZE);		np = pbuf_alloc(PBUF_RAW, cs->cs_hlen, PBUF_POOL);		if(!np) {			PPPDEBUG((LOG_WARNING, "vj_uncompress_tcp: prepend failed\n"));			*nb = NULL;			goto bad;		}		pbuf_cat(np, n0);		n0 = np;	}	LWIP_ASSERT("n0->len >= cs->cs_hlen", n0->len >= cs->cs_hlen);	memcpy(n0->payload, &cs->cs_ip, cs->cs_hlen);	*nb = n0;	return vjlen;	bad:	comp->flags |= VJF_TOSS;	INCR(vjs_errorin);	return (-1);}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
制服丝袜亚洲色图| 91一区一区三区| 肉丝袜脚交视频一区二区| 亚洲欧美中日韩| 中文字幕一区二区三区在线不卡 | 亚洲一区二区三区在线播放| 国产精品久久久久婷婷| 国产亚洲欧美一区在线观看| 久久久久久久电影| 国产精品久久久久久久第一福利| 国产精品国产三级国产aⅴ原创 | 久久综合999| 久久麻豆一区二区| 国产精品理论在线观看| 亚洲狼人国产精品| 偷窥少妇高潮呻吟av久久免费| 三级影片在线观看欧美日韩一区二区| 日本少妇一区二区| 国产成人精品亚洲午夜麻豆| 91欧美一区二区| 91精品欧美综合在线观看最新| 日韩欧美一级二级三级| 欧美激情资源网| 一区二区理论电影在线观看| 蜜臀久久99精品久久久久久9| 国产大片一区二区| 欧美午夜片在线看| 精品久久久久av影院| 国产精品美女久久久久久久| 一区二区三区成人| 黄一区二区三区| 在线看国产一区二区| 日韩美女一区二区三区四区| 国产精品你懂的在线| 国产盗摄一区二区三区| 在线一区二区三区四区| 日韩片之四级片| 国产精品国产三级国产aⅴ原创| 日韩黄色一级片| 99精品视频在线播放观看| 日韩欧美在线不卡| 一区二区三区精品在线| 国产精品一区二区无线| 欧美日韩国产乱码电影| 国产精品久久久久三级| 久久精品国产精品亚洲综合| 91福利在线免费观看| 国产欧美一区二区精品仙草咪| 亚洲第一综合色| 99久久精品免费| 欧美一级一区二区| 亚洲一区二区三区视频在线播放| 国产不卡视频一区| 精品国产乱码久久久久久牛牛| 亚洲电影第三页| 一本大道久久a久久精二百| www成人在线观看| 秋霞电影一区二区| 欧美另类videos死尸| 亚洲天堂a在线| 成人午夜精品一区二区三区| 欧美精品一区二区三区高清aⅴ| 午夜影院久久久| 欧美日本一区二区| 亚洲电影一级片| 欧美日韩一级二级三级| 亚洲在线成人精品| 欧美性videosxxxxx| 一区二区视频在线看| 91片在线免费观看| 亚洲麻豆国产自偷在线| 一本大道久久a久久精品综合| 国产精品成人一区二区艾草 | 风间由美一区二区av101| 精品福利一二区| 久久成人麻豆午夜电影| 精品国产一区二区精华| 韩国成人在线视频| 欧美韩国日本一区| 粉嫩绯色av一区二区在线观看| 中文字幕第一页久久| 成人福利视频在线看| 中文字幕一区不卡| 欧美性猛片xxxx免费看久爱| 香蕉加勒比综合久久| 欧美视频在线一区| 欧美aa在线视频| 久久精品一区八戒影视| 成人涩涩免费视频| 亚洲三级在线免费观看| 欧美日韩国产一级片| 日韩精品亚洲一区| 久久美女艺术照精彩视频福利播放| 国产成人综合视频| 亚洲精品成人a在线观看| 欧美在线一区二区三区| 视频一区视频二区中文字幕| 欧美电影免费观看高清完整版在线观看| 麻豆专区一区二区三区四区五区| 久久久蜜桃精品| 一本大道久久a久久综合| 日本va欧美va精品发布| 午夜视频一区二区三区| 欧美电影免费观看完整版| 国产一区二区在线免费观看| 中文字幕一区二| 555夜色666亚洲国产免| 国产成人免费在线观看| 亚洲综合色网站| 久久久五月婷婷| 欧美日韩综合不卡| 成人黄页毛片网站| 免费一区二区视频| 亚洲视频 欧洲视频| 欧美一区二区三区不卡| 91香蕉视频黄| 久久99精品久久只有精品| 亚洲欧美日韩国产综合| 久久综合九色综合97婷婷女人| 色999日韩国产欧美一区二区| 日韩不卡免费视频| 亚洲人成在线观看一区二区| 欧美精品一区二区三区一线天视频| 色偷偷一区二区三区| 国产一区二区在线观看视频| 午夜日韩在线观看| 亚洲男人的天堂在线aⅴ视频| 久久久久久久久久美女| 日韩视频免费观看高清完整版| 色婷婷国产精品综合在线观看| 岛国一区二区三区| 国产麻豆视频一区二区| 日韩不卡在线观看日韩不卡视频| 亚洲精品伦理在线| 国产精品女同互慰在线看| 久久综合九色综合久久久精品综合 | 91视频观看视频| 国产成人亚洲综合a∨婷婷| 免费成人小视频| 日日摸夜夜添夜夜添亚洲女人| 亚洲欧美另类久久久精品| 国产精品妹子av| 国产偷国产偷精品高清尤物| 日韩美女一区二区三区四区| 欧美一区二区视频在线观看| 欧美久久一二区| 91精品国产综合久久久久久| 欧美日韩一区在线观看| 色网站国产精品| 欧美系列一区二区| 欧美日韩国产天堂| 91精品国产综合久久精品图片| 欧美日韩一区成人| 51精品国自产在线| 日韩三级视频在线看| 欧美一区二区三区视频免费| 日韩一区二区三区视频在线 | 国产成人自拍网| 国产999精品久久久久久绿帽| 国产mv日韩mv欧美| 99久久er热在这里只有精品15| 99精品久久99久久久久| 色偷偷成人一区二区三区91| 欧洲精品一区二区| 精品视频在线看| 日韩欧美亚洲另类制服综合在线| 欧美电视剧在线观看完整版| 久久精品视频免费| 国产精品毛片高清在线完整版 | 91精品中文字幕一区二区三区| 欧美老肥妇做.爰bbww| 亚洲精品一区二区三区四区高清| 石原莉奈在线亚洲二区| 久久99久久久欧美国产| 国产成人午夜精品影院观看视频| 菠萝蜜视频在线观看一区| 欧美少妇性性性| 久久久综合视频| 一区二区久久久久| 狂野欧美性猛交blacked| 国产ts人妖一区二区| 91福利国产精品| 精品久久久久久久人人人人传媒 | 日韩精品一区二区三区老鸭窝 | 天堂一区二区在线| 国产不卡视频在线播放| 欧美日韩精品三区| 中文一区二区完整视频在线观看| 亚洲激情网站免费观看| 极品瑜伽女神91| 欧美色图天堂网| 国产色产综合色产在线视频 | 国产一区二区主播在线| 色成年激情久久综合| 久久久久久久久久久电影| 一区二区欧美国产| 高清国产一区二区| 日韩欧美中文字幕一区| 亚洲男同性恋视频| 国产福利一区二区三区|