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

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

?? vj.c

?? freertosV4.40 是一種small的嵌入式系統。利于嵌入式開好者入門學習嵌入式操作系統。通過對于源碼的學習可以很好的掌握freertos的運行機制。
?? 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一区二区三区免费野_久草精品视频
国产传媒日韩欧美成人| 精品国产乱码久久久久久久久 | 精品在线播放免费| 三级一区在线视频先锋| 丝袜美腿一区二区三区| 日韩精品一二区| 久久精品国产亚洲a| 裸体在线国模精品偷拍| 麻豆成人综合网| 欧洲视频一区二区| 欧美在线你懂的| 欧美三级一区二区| 欧美丰满高潮xxxx喷水动漫| 91精品欧美福利在线观看| 日韩一级片在线播放| 日韩一区二区三区免费看| 精品国产不卡一区二区三区| 国产日产欧美一区二区视频| 国产精品欧美久久久久无广告| 国产精品第13页| 一区二区在线观看免费视频播放| 欧美刺激午夜性久久久久久久| 26uuu亚洲婷婷狠狠天堂| 国产日韩欧美精品在线| 中文字幕一区二区三区四区| 一区二区三区不卡视频 | 色婷婷av一区二区三区之一色屋| 欧美性色综合网| 日韩三级视频中文字幕| 日本一区二区三区在线不卡| 国产精品久久久久久亚洲伦| 亚洲一区二区三区精品在线| 蜜桃一区二区三区在线观看| 国产99久久精品| 日本精品一级二级| 欧美一级精品在线| 国产精品久久精品日日| 夜夜揉揉日日人人青青一国产精品 | 精品久久久久香蕉网| 国产精品初高中害羞小美女文| 亚洲电影第三页| 国产成a人亚洲精| 欧美专区亚洲专区| 久久久久综合网| 亚洲一本大道在线| 极品尤物av久久免费看| 色综合久久久久综合99| 欧美福利一区二区| 中文字幕高清一区| 天天免费综合色| 99精品视频在线免费观看| 91精品国产麻豆| 亚洲精品视频在线观看免费| 久久99久久久欧美国产| 在线免费不卡电影| 中文字幕电影一区| 日本不卡中文字幕| 91污片在线观看| 2017欧美狠狠色| 亚洲风情在线资源站| 不卡影院免费观看| 日韩精品中文字幕在线一区| 亚洲精品国产精华液| 国产精品123区| 91精品婷婷国产综合久久性色| 亚洲人成网站色在线观看| 精品一区二区三区蜜桃| 欧美网站大全在线观看| 中文字幕日韩精品一区| 韩国精品主播一区二区在线观看 | 精品美女被调教视频大全网站| 一区二区三区在线免费播放| 国产一区999| 宅男噜噜噜66一区二区66| 亚洲欧美韩国综合色| 国产成人av电影免费在线观看| 日韩美女主播在线视频一区二区三区| 亚洲激情在线播放| av网站一区二区三区| 久久久久高清精品| 另类的小说在线视频另类成人小视频在线 | 日日夜夜精品视频天天综合网| 99国产精品久久久久久久久久| 国产色爱av资源综合区| 免费观看在线综合色| 欧美日韩久久久久久| 亚洲天堂网中文字| 成人综合婷婷国产精品久久| 欧美精品一区二区在线播放| 欧美aa在线视频| 欧美一区二区三区四区视频| 亚洲va欧美va人人爽午夜| 91久久免费观看| 亚洲乱码国产乱码精品精可以看| 国产91在线看| 久久久久久久久蜜桃| 久久99精品网久久| 精品久久久久av影院| 久久精品久久久精品美女| 91精品国产综合久久福利| 日韩电影在线观看网站| 91精品国产综合久久久蜜臀图片| 亚洲va国产天堂va久久en| 欧美视频在线一区二区三区 | 亚洲美女一区二区三区| 91日韩精品一区| 亚洲综合一区在线| 欧美卡1卡2卡| 日韩av中文在线观看| 日韩一二三区不卡| 久久99热狠狠色一区二区| 久久久久久久久久久久久夜| 国产91丝袜在线播放| 国产精品不卡在线| 91女神在线视频| 亚洲韩国一区二区三区| 欧美肥妇毛茸茸| 国产最新精品精品你懂的| 亚洲国产成人一区二区三区| 成人动漫一区二区| 亚洲免费在线观看| 欧美日韩免费视频| 黑人巨大精品欧美一区| 久久久久久久电影| 91麻豆产精品久久久久久 | 色哟哟在线观看一区二区三区| 尤物av一区二区| 日韩一区二区三区精品视频| 国产精品亚洲一区二区三区在线| 国产精品午夜在线| 欧美亚洲综合久久| 麻豆国产欧美一区二区三区| 欧美国产一区视频在线观看| 色综合久久中文综合久久牛| 日韩av网站免费在线| 久久精品欧美一区二区三区不卡| av午夜一区麻豆| 日韩精品一二三区| 中文字幕第一区第二区| 欧美亚洲日本国产| 卡一卡二国产精品 | 国产成人精品免费在线| 一区二区三区电影在线播| 日韩视频免费直播| a在线欧美一区| 日韩精品国产精品| 国产精品二三区| 日韩一区二区三区在线视频| caoporm超碰国产精品| 日本欧美在线看| 国产精品乱码一区二区三区软件| 欧美日韩成人一区| www.欧美色图| 人人爽香蕉精品| 中文字幕一区av| 精品国免费一区二区三区| 91亚洲永久精品| 精品无码三级在线观看视频| 亚洲欧美在线视频观看| 欧美成人免费网站| 欧美三区在线观看| eeuss鲁片一区二区三区在线看| 天堂成人免费av电影一区| 国产精品毛片无遮挡高清| 欧美一区二区三区四区在线观看| 色欧美片视频在线观看| 国产精品一区二区视频| 日韩 欧美一区二区三区| 成人免费在线视频观看| 久久久久成人黄色影片| 91精品国产高清一区二区三区 | 久久综合色综合88| 欧美精三区欧美精三区| 97se狠狠狠综合亚洲狠狠| 精品一区二区在线观看| 三级不卡在线观看| 一区二区三区在线看| 中文字幕乱码亚洲精品一区| 欧美电视剧免费全集观看| 欧美日韩你懂的| 一本一本大道香蕉久在线精品 | 欧美在线你懂的| 97精品久久久久中文字幕| 国产乱码一区二区三区| 美女www一区二区| 天堂一区二区在线| 亚洲一二三区在线观看| 一区二区三区四区亚洲| 国产精品久久久久久久裸模| 久久久久久亚洲综合影院红桃 | 亚洲国产一区二区a毛片| 最新中文字幕一区二区三区| 国产日韩欧美电影| 精品国产乱码久久久久久1区2区 | 国产精品乱码人人做人人爱| 国产日韩欧美不卡| 中文字幕欧美激情一区| 国产视频911| 国产欧美一区二区精品婷婷| 久久久久久久综合狠狠综合|