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

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

?? ip_icmp.c

?? vxworks的完整的源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* ip_icmp.c - internet ICMP routines *//* Copyright 1984 - 2002 Wind River Systems, Inc. */#include "copyright_wrs.h"/* * Copyright (c) 1982, 1986, 1988, 1993 *	The Regents of the University of California.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *	This product includes software developed by the University of *	California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors *    may be used to endorse or promote products derived from this software *    without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * *	@(#)ip_icmp.c	8.2 (Berkeley) 1/4/94 *//*modification history--------------------03h,18apr02,vvv  removed incorrect icmpmaskrepl initialization from icmp_init		 (SPR #74338)03g,18dec01,vvv  reflect messages with correct source address (SPR #71684)03f,12oct01,rae  merge from truestack ver 03j, base 03e (SPRs 69344, 69683 etc)03e,16mar99,spm  recovered orphaned code from tor2_0_x branch (SPR #25770)03d,09feb99,ham  fixed SPR#24975.03c,31jan97,vin  changed declaration according to prototype decl in protosw.h03b,07jan96,vin  added icmp_init(..) for scalability, moved iptime to 		 ip_input.c03a,31oct96,vin  changed m_gethdr(..) to mHdrClGet(..).02u,24aug96,vin  integrated with BSD44 and 02t of ip_icmp.c.*//* * ICMP routines: error generation, receive packet processing, and * routines to turnaround packets back to the originator, and * host table maintenance routines. */#include "vxWorks.h"#include "net/mbuf.h"#include "net/protosw.h"#include "sys/socket.h"#include "sys/ioctl.h"#include "net/systm.h"#include "net/route.h"#include "net/if.h"#include "net/if_types.h"#include "netinet/in.h"#include "netinet/in_systm.h"#include "netinet/in_var.h"#include "netinet/ip.h"#include "netinet/ip_var.h"#include "netinet/ip_icmp.h"#include "netinet/icmp_var.h"#ifdef WV_INSTRUMENTATION#ifdef INCLUDE_WVNET#include "wvNetLib.h"#endif#endif#ifdef VIRTUAL_STACK#include "netinet/vsLib.h"#endif /* VIRTUAL_STACK *//* defines */#ifndef VIRTUAL_STACK#define MAXTABLESIZE 64		/*                                 * smallest cluster limits setsockopt()                                  * routine to 64 2-byte integers                                 */#endif /* VIRTUAL_STACK */#define PATHMTU_MIN  68 	/* Lowest allowable path MTU estimate *//* externs */extern void pfctlinput ();#ifndef VIRTUAL_STACKextern	struct protosw inetsw[];extern VOIDFUNCPTR	_icmpErrorHook; #endif /* VIRTUAL_STACK *//* globals */#ifndef VIRTUAL_STACKstruct icmpstat icmpstat;struct sockaddr_in icmpmask = { 8, 0 };int	icmpmaskrepl = 0;#ifdef ICMPPRINTFSint	icmpprintfs = 0;#endif#endif /* VIRTUAL_STACK *//* locals */#ifndef VIRTUAL_STACKstatic struct sockaddr_in icmpsrc = { sizeof (struct sockaddr_in), AF_INET };static struct sockaddr_in icmpdst = { sizeof (struct sockaddr_in), AF_INET };static struct sockaddr_in icmpgw = { sizeof (struct sockaddr_in), AF_INET };LOCAL u_short mtuTable [MAXTABLESIZE] = {68, 296, 508, 1006, 1492, 2002,                                         4352, 8166, 17914, 32000, 65535};LOCAL int mtuTableSize = 11;#endif /* VIRTUAL_STACK *//* forward declarations */static void	icmp_error (struct mbuf *, int, int, n_long, struct ifnet *);static void	icmp_reflect (struct mbuf *);static void	icmp_send (struct mbuf *, struct mbuf *);LOCAL void ip_next_mtu (struct sockaddr *, int);#ifdef WV_INSTRUMENTATION#ifdef INCLUDE_WVNET    /* Set common fields of event identifiers for this module. */LOCAL UCHAR wvNetModuleId = WV_NET_IPICMP_MODULE;   /* Value for ip_icmp.c */LOCAL UCHAR wvNetLocalFilter = WV_NET_NONE;     /* Available event filter */LOCAL ULONG wvNetEventId;       /* Event identifier: see wvNetLib.h */#endif    /* INCLUDE_WVNET */#endifvoidicmp_init(){	if (_icmpErrorHook == NULL)	/* initialize the hook if not null */	    _icmpErrorHook = icmp_error; #ifdef ICMPPRINTFS        icmpprintfs = 0;#endif        icmpsrc.sin_len = sizeof(struct sockaddr_in);        icmpsrc.sin_family = AF_INET;        icmpdst.sin_len = sizeof(struct sockaddr_in);        icmpdst.sin_family = AF_INET;        icmpgw.sin_len = sizeof(struct sockaddr_in);        icmpgw.sin_family = AF_INET;        mtuTable[0] = 68;        mtuTable[1] = 296;        mtuTable[2] = 508;        mtuTable[3] = 1006;        mtuTable[4] = 1492;        mtuTable[5] = 2002;        mtuTable[6] = 4352;        mtuTable[7] = 8166;        mtuTable[8] = 17914;        mtuTable[9] = 32000;        mtuTable[10] = 65535;        mtuTableSize = 11;}/* * ICMP routines: error generation, receive packet processing, and * routines to turnaround packets back to the originator, and * host table maintenance routines. *//* * Generate an error packet of type error * in response to bad packet ip. */static voidicmp_error(n, type, code, dest, destifp)	struct mbuf *n;	int type, code;	n_long dest;	struct ifnet *destifp;{	register struct ip *oip = mtod(n, struct ip *), *nip;	register unsigned oiplen = oip->ip_hl << 2;	register struct icmp *icp;	register struct mbuf *m;        MTU_QUERY mtuQuery;	unsigned icmplen;	short    offset;#ifdef WV_INSTRUMENTATION#ifdef INCLUDE_WVNET    /* WV_NET_EMERGENCY or WV_NET_ALERT event */        if (type == ICMP_SOURCEQUENCH) 	/* ENOBUFS error: out of memory. */            {            WV_NET_MARKER_2 (NET_CORE_EVENT, WV_NET_EMERGENCY, 9, 2,                              WV_NETEVENT_ICMPERR_START, type, code)            }        else            {            WV_NET_MARKER_2 (NET_CORE_EVENT, WV_NET_CRITICAL, 8, 2,                              WV_NETEVENT_ICMPERR_START, type, code)            }#endif  /* INCLUDE_WVNET */#endif#ifdef ICMPPRINTFS	if (icmpprintfs)		printf("icmp_error(%x, %d, %d)\n", oip, type, code);#endif	if (type != ICMP_REDIRECT)	    {#ifdef VIRTUAL_STACK	    _icmpstat.icps_error++;#else	    icmpstat.icps_error++;#endif /* VIRTUAL_STACK */            offset = oip->ip_off;	    }        else	    {            /* 	     * If ICMP_REDIRECT, offset field is in network host order	     * (changed when ip_output forwarded this packet). We need it 	     * to be in host order for the processing.	     */	    offset = ntohs (oip->ip_off);	    }	/*	 * Don't send error if not the first fragment of message.	 * Don't error if the old packet protocol was ICMP	 * error message, only known informational types.	 */	if (offset &~ (IP_MF|IP_DF))		goto freeit;	if (oip->ip_p == IPPROTO_ICMP && type != ICMP_REDIRECT &&	  n->m_len >= oiplen + ICMP_MINLEN &&	  !ICMP_INFOTYPE(((struct icmp *)((caddr_t)oip + oiplen))->icmp_type)) {#ifdef VIRTUAL_STACK		_icmpstat.icps_oldicmp++;#else		icmpstat.icps_oldicmp++;#endif /* VIRTUAL_STACK */		goto freeit;	}	/* Don't send error in response to a multicast or broadcast packet */	if (n->m_flags & (M_BCAST|M_MCAST))		goto freeit;	/*	 * First, formulate icmp message	 */	if ((m = mHdrClGet(M_DONTWAIT, MT_HEADER, CL_SIZE_128, TRUE)) == NULL)		goto freeit;	icmplen = oiplen + min(8, oip->ip_len);	m->m_len = icmplen + ICMP_MINLEN;	MH_ALIGN(m, m->m_len);	icp = mtod(m, struct icmp *);	if ((u_int)type > ICMP_MAXTYPE)            {#ifdef WV_INSTRUMENTATION#ifdef INCLUDE_WVNET    /* WV_NET_EMERGENCY event */            WV_NET_MARKER_1 (NET_CORE_EVENT, WV_NET_EMERGENCY, 14, 1,                              WV_NETEVENT_ICMPERR_PANIC, type)#endif  /* INCLUDE_WVNET */#endif            panic("icmp_error");            }#ifdef VIRTUAL_STACK	_icmpstat.icps_outhist[type]++;#else	icmpstat.icps_outhist[type]++;#endif /* VIRTUAL_STACK */	icp->icmp_type = type;	if (type == ICMP_REDIRECT)		icp->icmp_gwaddr.s_addr = dest;	else {		icp->icmp_void = 0;		/* 		 * The following assignments assume an overlay with the		 * zeroed icmp_void field.		 */		if (type == ICMP_PARAMPROB) {			icp->icmp_pptr = code;			code = 0;		} else if (type == ICMP_UNREACH &&			code == ICMP_UNREACH_NEEDFRAG && destifp) {                        /*                         * Point-to-multipoint devices allow a separate MTU                         * for each destination address. Get that value or                         * leave the next MTU unspecified if not available.                         */                        if (destifp->if_type == IFT_PMP)                            {                            mtuQuery.family = AF_INET;                            mtuQuery.dstIpAddr = dest;                            if (destifp->if_ioctl (destifp, SIOCGMTU,                                                   (caddr_t) &mtuQuery) == 0)                                {                                icp->icmp_nextmtu = htons (mtuQuery.mtu);                                }                            }                        else                            {                            icp->icmp_nextmtu = htons(destifp->if_mtu);                            }		}	}	icp->icmp_code = code;	bcopy((caddr_t)oip, (caddr_t)&icp->icmp_ip, icmplen);	nip = &icp->icmp_ip;	if (type != ICMP_REDIRECT)	    {	    /*	     * If ICMP_REDIRECT, these changes have already been made in 	     * ip_output when the packet was forwarded.	     */	    nip->ip_len = htons((u_short)(nip->ip_len + oiplen));	    HTONS (nip->ip_id);	    HTONS (nip->ip_off);	    }	/*	 * Now, copy old ip header (without options)	 * in front of icmp message.	 */	if (m->m_data - sizeof(struct ip) < m->m_extBuf)		panic("icmp len");	m->m_data -= sizeof(struct ip);	m->m_len += sizeof(struct ip);	m->m_pkthdr.len = m->m_len;	m->m_pkthdr.rcvif = n->m_pkthdr.rcvif;	nip = mtod(m, struct ip *);	bcopy((caddr_t)oip, (caddr_t)nip, sizeof(struct ip));	nip->ip_len = m->m_len;	nip->ip_hl = sizeof(struct ip) >> 2;	nip->ip_p = IPPROTO_ICMP;	nip->ip_tos = 0;	icmp_reflect(m);freeit:	m_freem(n);}/* * Process a received ICMP message. */void

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜影院久久久| 亚洲少妇屁股交4| 久久se这里有精品| 久久久久久久久久看片| 国产精品99久久久久久久女警 | 色美美综合视频| 亚洲精品乱码久久久久久日本蜜臀 | 日韩三级av在线播放| 国产精品一区在线| 亚洲少妇30p| 欧美精品久久99久久在免费线 | 日本三级亚洲精品| 国产日韩精品久久久| 日本精品一级二级| 免费在线看一区| 国产日韩精品一区二区三区 | 色综合婷婷久久| 日韩精品福利网| 国产日韩精品一区| 精品视频色一区| 国产精品综合久久| 亚洲小少妇裸体bbw| 久久久久国色av免费看影院| 91激情五月电影| 久久99精品国产.久久久久久| 国产精品色眯眯| 欧美卡1卡2卡| 国产成人av电影在线观看| 亚洲午夜激情av| 国产日韩在线不卡| 欧美精品欧美精品系列| 岛国一区二区三区| 日本vs亚洲vs韩国一区三区二区 | 2022国产精品视频| 91视频免费观看| 久久99最新地址| 亚洲一区二区视频| 国产日韩成人精品| 日韩欧美国产1| 欧美中文字幕不卡| 99精品偷自拍| 国产麻豆精品视频| 蜜桃一区二区三区在线| 亚洲综合免费观看高清完整版 | 欧美日本在线看| 亚洲视频在线一区| 欧美大胆人体bbbb| 香蕉久久一区二区不卡无毒影院 | 91福利精品视频| 日韩精品一区二区三区中文精品| 亚洲精品视频观看| 日韩欧美三级在线| 在线亚洲一区观看| 成人性生交大片免费看视频在线 | 色综合久久精品| 欧美日韩精品一区二区天天拍小说 | 久久久久九九视频| 欧美三级电影一区| 色综合久久99| 91在线云播放| 国产99精品视频| 精品在线播放午夜| 免费观看在线色综合| 亚洲成在人线在线播放| 一区二区三区免费观看| 亚洲免费观看高清完整版在线观看熊| 欧美激情资源网| 日本一区二区三区电影| 久久精子c满五个校花| 亚洲精品一区二区三区影院 | 丁香六月久久综合狠狠色| 国产一区欧美一区| 国产综合久久久久影院| 激情综合网天天干| 国产一区二区在线观看免费| 男女激情视频一区| 老汉av免费一区二区三区| 蜜臀精品久久久久久蜜臀| 久久99在线观看| 国产精品77777竹菊影视小说| 国产剧情一区二区三区| 豆国产96在线|亚洲| 成人黄色电影在线 | 91在线观看视频| 日本高清不卡aⅴ免费网站| 欧洲激情一区二区| 欧美精品在线观看播放| 91精品国产综合久久国产大片| 制服丝袜亚洲播放| 精品国精品国产| 日本一区二区三区四区| 亚洲精品成人少妇| 视频一区二区不卡| 国产精品资源在线| 91麻豆国产精品久久| 欧美人动与zoxxxx乱| 日韩女优视频免费观看| 中文字幕第一区第二区| 亚洲欧美另类在线| 日本va欧美va欧美va精品| 国内外成人在线视频| 91在线视频观看| 91精品国产欧美一区二区18| 久久综合久久鬼色中文字| 中文字幕在线一区| 亚洲第一成人在线| 国产精品一二二区| 日本福利一区二区| 久久亚洲精品小早川怜子| 亚洲人一二三区| 狂野欧美性猛交blacked| 成人18视频在线播放| 欧美日韩dvd在线观看| 久久久久久一级片| 亚洲妇女屁股眼交7| 国内外精品视频| 欧美午夜宅男影院| 久久精品视频在线看| 亚洲蜜臀av乱码久久精品蜜桃| 人人精品人人爱| 99视频超级精品| 欧美v国产在线一区二区三区| 国产精品国产成人国产三级| 蜜臀av一级做a爰片久久| 成人激情校园春色| 精品奇米国产一区二区三区| 亚洲欧美色一区| 国产剧情一区二区| 欧美一区二区在线播放| 亚洲色图欧洲色图婷婷| 国产一区二区女| 欧美人与性动xxxx| 亚洲精品国久久99热| 国产大片一区二区| 日韩一区二区中文字幕| 亚洲国产婷婷综合在线精品| 成人99免费视频| 久久久三级国产网站| 免费人成精品欧美精品| 在线看国产一区二区| 亚洲欧美怡红院| 国产精品一区免费视频| 欧美电视剧在线看免费| 亚洲第一福利一区| 在线观看网站黄不卡| 欧美高清在线视频| 国产一区欧美日韩| 精品日韩欧美在线| 青青青伊人色综合久久| 欧美性猛交xxxxxxxx| ㊣最新国产の精品bt伙计久久| 国产精品99久久久| 国产午夜精品美女毛片视频| 麻豆精品精品国产自在97香蕉 | 精品在线亚洲视频| 日韩午夜激情免费电影| 日本成人在线视频网站| 欧美日韩国产a| 亚洲一区二区三区爽爽爽爽爽| 99久久婷婷国产综合精品电影| 国产精品视频在线看| 国产69精品久久99不卡| 国产欧美一区二区精品久导航| 国产一区二区三区在线看麻豆| 精品日本一线二线三线不卡| 久久精品久久99精品久久| 日韩三级视频在线观看| 精品制服美女丁香| 久久精品人人做人人爽人人| 国产精品18久久久久久久久| 久久精品人人爽人人爽| 国产69精品久久久久777| 国产精品不卡在线| 欧美综合欧美视频| 亚洲成人免费视| 日韩欧美一二三区| 国产一区二区三区高清播放| 国产欧美一区视频| 99re66热这里只有精品3直播 | 777色狠狠一区二区三区| 丝袜脚交一区二区| 日韩欧美亚洲国产精品字幕久久久| 久久超级碰视频| 日本一区二区三区在线观看| 91毛片在线观看| 偷拍自拍另类欧美| 欧美va亚洲va在线观看蝴蝶网| 国产成人av电影在线观看| 亚洲人成亚洲人成在线观看图片| 欧美性一级生活| 麻豆极品一区二区三区| 国产精品入口麻豆原神| 在线观看日韩精品| 老司机一区二区| 中文字幕日韩av资源站| 欧美三级日韩三级国产三级| 韩国在线一区二区| 一区二区不卡在线播放 | 中文字幕精品在线不卡| 在线看不卡av|