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

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

?? ip.c

?? 用于底層開發(fā)的TCPIP協(xié)議棧源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
#undef SIM
/* Upper half of IP, consisting of send/receive primitives, including
 * fragment reassembly, for higher level protocols.
 * Not needed when running as a standalone gateway.
 */
#include "global.h"
#include "mbuf.h"
#include "timer.h"
#include "internet.h"
#include "netuser.h"
#include "iface.h"
#include "pktdrvr.h"
#include "ip.h"
#include "icmp.h"

static int fraghandle(struct ip *ip,struct mbuf **bpp);
static void ip_timeout(void *arg);
static void free_reasm(struct reasm *rp);
static void freefrag(struct frag *fp);
static struct reasm *lookup_reasm(struct ip *ip);
static struct reasm *creat_reasm(struct ip *ip);
static struct frag *newfrag(uint16 offset,uint16 last,struct mbuf **bpp);
void ttldec(struct iface *ifp);

struct mib_entry Ip_mib[20] = {
	"",			0,
	"ipForwarding",		1,
	"ipDefaultTTL",		MAXTTL,
	"ipInReceives",		0,
	"ipInHdrErrors",	0,
	"ipInAddrErrors",	0,
	"ipForwDatagrams",	0,
	"ipInUnknownProtos",	0,
	"ipInDiscards",		0,
	"ipInDelivers",		0,
	"ipOutRequests",	0,
	"ipOutDiscards",	0,
	"ipOutNoRoutes",	0,
	"ipReasmTimeout",	TLB,
	"ipReasmReqds",		0,
	"ipReasmOKs",		0,
	"ipReasmFails",		0,
	"ipFragOKs",		0,
	"ipFragFails",		0,
	"ipFragCreates",	0,
};

struct reasm *Reasmq;
uint16 Id_cntr = 0;	/* Datagram serial number */
static struct raw_ip *Raw_ip;
int Ip_trace = 0;

#define	INSERT	0
#define	APPEND	1
#define	PREPEND	2

/* Send an IP datagram. Modeled after the example interface on p 32 of
 * RFC 791
 */
int
ip_send(
int32 source,			/* source address */
int32 dest,			/* Destination address */
char protocol,			/* Protocol */
char tos,			/* Type of service */
char ttl,			/* Time-to-live */
struct mbuf **bpp,		/* Data portion of datagram */
uint16 length,			/* Optional length of data portion */
uint16 id,			/* Optional identification */
char df				/* Don't-fragment flag */
){
	struct ip ip;			/* IP header */

	ipOutRequests++;

	if(bpp == NULL)
		return -1;
	if(source == INADDR_ANY)
		source = locaddr(dest);
	if(length == 0 && *bpp != NULL)
		length = len_p(*bpp);
	if(id == 0)
		id = Id_cntr++;
	if(ttl == 0)
		ttl = ipDefaultTTL;

	/* Fill in IP header */
	ip.version = IPVERSION;
	ip.tos = tos;
	ip.length = IPLEN + length;
	ip.id = id;
	ip.offset = 0;
	ip.flags.mf = 0;
	ip.flags.df = df;
	ip.flags.congest = 0;
	ip.ttl = ttl;
	ip.protocol = protocol;
	ip.source = source;
	ip.dest = dest;
	ip.optlen = 0;
	if(Ip_trace)
		dumpip(NULL,&ip,*bpp,0);

	htonip(&ip,bpp,IP_CS_NEW);
	if(ismyaddr(ip.dest)){
		/* Pretend it has been sent by the loopback interface before
		 * it appears in the receive queue
		 */
#ifdef	SIM
		net_sim(bpp);
#else
		net_route(&Loopback,bpp);
#endif
		Loopback.ipsndcnt++;
		Loopback.rawsndcnt++;
		Loopback.lastsent = secclock();
	} else
		net_route(NULL,bpp);
	return 0;
}

/* Reassemble incoming IP fragments and dispatch completed datagrams
 * to the proper transport module
 */
void
ip_recv(
struct iface *iface,	/* Incoming interface */
struct ip *ip,		/* Extracted IP header */
struct mbuf **bpp,	/* Data portion */
int rxbroadcast,	/* True if received on subnet broadcast address */
int32 spi		/* Security association, if any */
){
	/* Function to call with completed datagram */
	register struct raw_ip *rp;
	struct mbuf *bp1;
	int rxcnt = 0;
	register struct iplink *ipp;

	/* If we have a complete packet, call the next layer
	 * to handle the result. Note that fraghandle passes back
	 * a length field that does NOT include the IP header
	 */
	if(bpp == NULL || fraghandle(ip,bpp) == -1)
		return;		/* Not done yet */

	/* Trim data segment if necessary. */
	trim_mbuf(bpp,ip->length - (IPLEN + ip->optlen));

	ipInDelivers++;
	if(Ip_trace)
		dumpip(iface,ip,*bpp,spi);

	for(rp = Raw_ip;rp != NULL;rp = rp->next){
		if(rp->protocol != ip->protocol)
			continue;
		rxcnt++;
		/* Duplicate the data portion, and put the header back on */
		dup_p(&bp1,*bpp,0,len_p(*bpp));
		if(bp1 != NULL){
			htonip(ip,&bp1,IP_CS_OLD);
			enqueue(&rp->rcvq,&bp1);
			if(rp->r_upcall != NULL)
				(*rp->r_upcall)(rp);
		} else {
			free_p(&bp1);
		}
	}
	/* Look it up in the transport protocol table */
	for(ipp = Iplink;ipp->funct != NULL;ipp++){
		if(ipp->proto == ip->protocol)
			break;
	}
	if(ipp->funct != NULL){
		/* Found, call transport protocol */
		(*ipp->funct)(iface,ip,bpp,rxbroadcast,spi);
	} else {
		/* Not found */
		if(rxcnt == 0){
			/* Send an ICMP Protocol Unknown response... */
			ipInUnknownProtos++;
			/* ...unless it's a broadcast */
			if(!rxbroadcast){
				icmp_output(ip,*bpp,ICMP_DEST_UNREACH,
				 ICMP_PROT_UNREACH,NULL);
			}
		}
		free_p(bpp);
	}
}
/* Handle IP packets encapsulated inside IP */
void
ipip_recv(
struct iface *iface,	/* Incoming interface */
struct ip *ip,		/* Extracted IP header */
struct mbuf **bpp,	/* Data portion */
int rxbroadcast,	/* True if received on subnet broadcast address */
int32 spi
){
	net_route(&Encap,bpp);
}

/* Process IP datagram fragments
 * If datagram is complete, return its length (MINUS header);
 * otherwise return -1
 */
static int
fraghandle(
struct ip *ip,		/* IP header, host byte order */
struct mbuf **bpp	/* The fragment itself */
){
	register struct reasm *rp; /* Pointer to reassembly descriptor */
	struct frag *lastfrag,*nextfrag,*tfp;
	struct mbuf *tbp;
	uint16 i;
	uint16 last;		/* Index of first byte beyond fragment */

	last = ip->offset + ip->length - (IPLEN + ip->optlen);

	rp = lookup_reasm(ip);
	if(ip->offset == 0 && !ip->flags.mf){
		/* Complete datagram received. Discard any earlier fragments */
		if(rp != NULL){
			free_reasm(rp);
			ipReasmOKs++;
		}
		return ip->length;
	}
	ipReasmReqds++;
	if(rp == NULL){
		/* First fragment; create new reassembly descriptor */
		if((rp = creat_reasm(ip)) == NULL){
			/* No space for descriptor, drop fragment */
			ipReasmFails++;
			free_p(bpp);
			return -1;
		}
	}
	/* Keep restarting timer as long as we keep getting fragments */
	stop_timer(&rp->timer);
	start_timer(&rp->timer);

	/* If this is the last fragment, we now know how long the
	 * entire datagram is; record it
	 */
	if(!ip->flags.mf)
		rp->length = last;

	/* Set nextfrag to the first fragment which begins after us,
	 * and lastfrag to the last fragment which begins before us
	 */
	lastfrag = NULL;
	for(nextfrag = rp->fraglist;nextfrag != NULL;nextfrag = nextfrag->next){
		if(nextfrag->offset > ip->offset)
			break;
		lastfrag = nextfrag;
	}
	/* Check for overlap with preceeding fragment */
	if(lastfrag != NULL  && ip->offset < lastfrag->last){
		/* Strip overlap from new fragment */
		i = lastfrag->last - ip->offset;
		pullup(bpp,NULL,i);
		if(*bpp == NULL)
			return -1;	/* Nothing left */
		ip->offset += i;
	}
	/* Look for overlap with succeeding segments */
	for(; nextfrag != NULL; nextfrag = tfp){
		tfp = nextfrag->next;	/* save in case we delete fp */

		if(nextfrag->offset >= last)
			break;	/* Past our end */
		/* Trim the front of this entry; if nothing is
		 * left, remove it.
		 */
		i = last - nextfrag->offset;
		pullup(&nextfrag->buf,NULL,i);
		if(nextfrag->buf == NULL){
			/* superseded; delete from list */
			if(nextfrag->prev != NULL)
				nextfrag->prev->next = nextfrag->next;
			else
				rp->fraglist = nextfrag->next;
			if(tfp->next != NULL)
				nextfrag->next->prev = nextfrag->prev;
			freefrag(nextfrag);
		} else
			nextfrag->offset = last;
	}
	/* Lastfrag now points, as before, to the fragment before us;
	 * nextfrag points at the next fragment. Check to see if we can
	 * join to either or both fragments.
	 */
	i = INSERT;
	if(lastfrag != NULL && lastfrag->last == ip->offset)
		i |= APPEND;
	if(nextfrag != NULL && nextfrag->offset == last)
		i |= PREPEND;
	switch(i){
	case INSERT:	/* Insert new desc between lastfrag and nextfrag */
		tfp = newfrag(ip->offset,last,bpp);
		tfp->prev = lastfrag;
		tfp->next = nextfrag;
		if(lastfrag != NULL)
			lastfrag->next = tfp;	/* Middle of list */
		else
			rp->fraglist = tfp;	/* First on list */
		if(nextfrag != NULL)
			nextfrag->prev = tfp;
		break;
	case APPEND:	/* Append to lastfrag */
		append(&lastfrag->buf,bpp);
		lastfrag->last = last;	/* Extend forward */
		break;
	case PREPEND:	/* Prepend to nextfrag */
		tbp = nextfrag->buf;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲国产bt| 久久精品视频免费| 精品国产一区a| 亚洲欧美经典视频| 国内国产精品久久| 欧美日韩免费高清一区色橹橹| 国产欧美日韩久久| 免费成人在线视频观看| 在线观看91视频| 国产精品毛片大码女人| 精品影院一区二区久久久| 欧美色手机在线观看| 成人欧美一区二区三区| 国产麻豆精品theporn| 国产区在线观看成人精品 | 日韩一区二区三区视频| 亚洲桃色在线一区| 波多野结衣欧美| 国产日产欧美一区二区视频| 蜜臀91精品一区二区三区| 欧美群妇大交群中文字幕| 亚洲色图视频免费播放| 高潮精品一区videoshd| 国产日韩欧美精品电影三级在线| 精品在线观看视频| 精品欧美一区二区在线观看| 蜜桃91丨九色丨蝌蚪91桃色| 91麻豆精品91久久久久同性| 香蕉乱码成人久久天堂爱免费| 91视频免费看| 亚洲美女淫视频| 色婷婷亚洲婷婷| 亚洲裸体xxx| 欧美性大战久久久| 亚洲一二三四久久| 欧美日韩小视频| 日韩av在线播放中文字幕| 欧美精品日韩精品| 日本sm残虐另类| 久久网站最新地址| 成人av在线资源网| 亚洲免费电影在线| 欧美日韩亚洲丝袜制服| 免费成人性网站| 精品免费日韩av| 福利一区二区在线| 亚洲人成伊人成综合网小说| a级精品国产片在线观看| 亚洲免费电影在线| 欧美日韩国产一区| 久久99国内精品| 国产欧美日韩精品一区| 色综合久久综合网97色综合| 亚洲不卡一区二区三区| 精品国产免费人成在线观看| 国产91丝袜在线播放九色| 亚洲欧美在线aaa| 欧美精品一卡两卡| 国产尤物一区二区| 一区二区三区四区视频精品免费| 欧美精品日日鲁夜夜添| 国产一区欧美日韩| 一卡二卡三卡日韩欧美| 日韩欧美国产午夜精品| 成人激情av网| 日本在线不卡视频| 国产精品国产自产拍在线| 欧美日韩国产不卡| 国产成人免费视频一区| 亚洲成在人线免费| 欧美国产精品专区| 欧美老女人在线| 成人午夜视频网站| 喷白浆一区二区| 亚洲精品水蜜桃| www欧美成人18+| 欧美婷婷六月丁香综合色| 国产成人亚洲综合a∨猫咪| 亚洲线精品一区二区三区八戒| 久久亚洲影视婷婷| 欧美日韩午夜在线视频| 成人黄色小视频在线观看| 人人狠狠综合久久亚洲| 一区二区三区在线观看欧美| 久久人人97超碰com| 欧美视频日韩视频在线观看| 成人午夜精品一区二区三区| 蜜臀久久99精品久久久久久9| 亚洲黄色免费网站| 中文字幕电影一区| 久久综合九色综合97婷婷| 欧美日韩精品三区| 在线亚洲高清视频| 成人av资源站| 福利一区福利二区| 国产米奇在线777精品观看| 免费不卡在线观看| 五月天激情小说综合| 一区二区欧美在线观看| 亚洲国产精华液网站w | 国产成人综合网站| 日本欧美一区二区三区乱码| 一区二区日韩电影| 亚洲乱码国产乱码精品精小说| 久久婷婷成人综合色| 精品sm在线观看| 精品欧美黑人一区二区三区| 欧美一区二区久久| 91精品国产91久久久久久最新毛片| 欧美午夜一区二区三区| 欧美综合久久久| 在线观看日韩精品| 欧美三级欧美一级| 欧美日韩国产综合久久| 欧美日韩卡一卡二| 91麻豆精品久久久久蜜臀| 在线播放亚洲一区| 91精品国产综合久久婷婷香蕉| 91麻豆精品久久久久蜜臀| 日韩一区二区三区在线| 日韩小视频在线观看专区| 日韩精品自拍偷拍| 欧美哺乳videos| 国产亚洲精品福利| 国产精品私房写真福利视频| 国产精品免费久久久久| 亚洲视频一区在线| 亚洲成人动漫在线免费观看| 日产欧产美韩系列久久99| 久久精品国产亚洲高清剧情介绍| 久久精品99久久久| 大白屁股一区二区视频| 色综合久久久久久久| 欧美电影一区二区| 亚洲精品在线免费观看视频| 国产精品网站在线| 一区二区激情视频| 捆绑紧缚一区二区三区视频| 国产不卡免费视频| 欧美性色aⅴ视频一区日韩精品| 制服丝袜激情欧洲亚洲| 精品福利一区二区三区| 亚洲视频在线一区观看| 日本中文一区二区三区| 成人午夜电影小说| 欧美日韩免费不卡视频一区二区三区| 91精品欧美久久久久久动漫| 国产欧美日韩综合精品一区二区| 亚洲美女一区二区三区| 久久精品国产77777蜜臀| 暴力调教一区二区三区| 欧美一区二区三区视频在线| 国产欧美一区视频| 亚洲成a人片综合在线| 国产一区999| 欧美精品视频www在线观看| 久久夜色精品国产噜噜av| 一区二区三区视频在线观看 | 亚洲综合久久久久| 久久99在线观看| 欧美亚洲动漫另类| 久久美女艺术照精彩视频福利播放| 亚洲欧美日韩人成在线播放| 麻豆视频一区二区| 欧洲一区二区三区免费视频| 国产亚洲成av人在线观看导航| 亚洲成a人v欧美综合天堂| 国产精品 日产精品 欧美精品| 欧美日韩国产免费| 中文字幕在线免费不卡| 久久国产精品第一页| 91成人网在线| 国产精品理伦片| 国产在线播放一区| 欧美一区日韩一区| 樱桃视频在线观看一区| 成人精品电影在线观看| 精品国产伦一区二区三区观看方式 | 国产一区二区在线观看免费| 欧洲av在线精品| 亚洲欧美日韩国产手机在线| 国产精品99久久久| 日韩午夜精品视频| 亚洲成a天堂v人片| 欧美三级中文字幕| 亚洲乱码国产乱码精品精的特点| 国产电影一区二区三区| 久久―日本道色综合久久| 久久 天天综合| 日韩欧美专区在线| 免费成人你懂的| 日韩一区二区免费视频| 日本一区中文字幕| 欧美日韩国产影片| 亚洲国产欧美日韩另类综合| 色综合欧美在线| 亚洲宅男天堂在线观看无病毒| 91麻豆蜜桃一区二区三区| 亚洲人成人一区二区在线观看| 91小视频免费看|