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

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

?? ip_icmp.c

?? vxwork源代碼
?? 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一区二区三区免费野_久草精品视频
日本va欧美va欧美va精品| 国产欧美日韩亚州综合| 91麻豆精品在线观看| 色综合天天狠狠| 欧美视频一二三区| 正在播放一区二区| 精品理论电影在线观看| 欧美高清在线精品一区| 亚洲日本在线天堂| 无码av中文一区二区三区桃花岛| 一区二区三区四区在线| 日本欧美一区二区| 狠狠色狠狠色合久久伊人| 成人h版在线观看| 欧美日韩国产乱码电影| 精品国产免费人成在线观看| 欧美高清在线视频| 日韩激情中文字幕| 91在线视频18| 久久久久国产精品厨房| 一区二区在线观看免费视频播放| 五月天精品一区二区三区| 久久99久久精品| 欧美精品99久久久**| 国产精品丝袜黑色高跟| 久久精品久久久精品美女| 色综合天天综合色综合av| 久久综合国产精品| 日韩在线观看一区二区| 91在线看国产| 中文字幕日韩av资源站| 经典三级一区二区| 日韩精品一区二区三区视频播放 | 成人免费毛片嘿嘿连载视频| 欧美视频三区在线播放| 亚洲日韩欧美一区二区在线| 成人短视频下载| 国产日产精品1区| 欧美午夜理伦三级在线观看| 亚洲电影一区二区三区| 久久精品欧美一区二区三区不卡| 综合网在线视频| 色综合婷婷久久| 亚洲少妇最新在线视频| 99re在线视频这里只有精品| 中文字幕乱码日本亚洲一区二区 | 97se亚洲国产综合自在线观| 国产欧美日韩不卡| 粉嫩av亚洲一区二区图片| 国产精品免费网站在线观看| 国产aⅴ综合色| 一区二区三区精品在线观看| 欧美日韩精品一区二区三区蜜桃 | 精品久久久久av影院| 亚洲国产日日夜夜| 欧美大片日本大片免费观看| 国产一区二区h| 一区二区三区在线观看视频| 91精品国产手机| 成人av片在线观看| 琪琪一区二区三区| 亚洲欧美中日韩| 欧美大胆人体bbbb| 成人a免费在线看| 蜜臀精品久久久久久蜜臀| 国产精品的网站| 日韩一区二区电影网| 91浏览器打开| 国产成a人亚洲精| 精品亚洲porn| 久久激情综合网| 一区二区三区日韩精品视频| 久久影院午夜片一区| 欧美一区中文字幕| 欧美亚洲国产bt| 色婷婷精品大在线视频| 99久久精品国产一区二区三区| 午夜成人免费视频| 亚洲成人777| 婷婷激情综合网| 亚洲福利一区二区三区| 久久亚洲综合av| 久久久精品影视| 国产校园另类小说区| 久久综合av免费| 国产日产欧美一区二区三区| 久久久噜噜噜久久中文字幕色伊伊 | 日韩精品91亚洲二区在线观看| 亚洲精品成人a在线观看| 中文字幕精品三区| 国产精品久久久久婷婷二区次| www国产成人免费观看视频 深夜成人网| 欧美高清精品3d| 欧美成人vps| 国产精品青草久久| 亚洲摸摸操操av| 丝袜诱惑亚洲看片| 久久99国产精品麻豆| 国产精品一区二区久久不卡| 不卡一二三区首页| 在线观看国产一区二区| 在线不卡一区二区| 国产午夜亚洲精品不卡| 亚洲综合无码一区二区| 性久久久久久久久久久久| 日韩精品免费专区| av一区二区三区| 日韩精品一区二区在线| 亚洲男女一区二区三区| 久久精品国产亚洲高清剧情介绍 | 欧美精品一区二区在线观看| |精品福利一区二区三区| 日韩精品1区2区3区| 99久久精品一区二区| 久久亚洲影视婷婷| 婷婷中文字幕一区三区| 91色porny在线视频| 久久久美女艺术照精彩视频福利播放 | 国产亚洲欧洲997久久综合| 亚洲一区二区偷拍精品| 成人免费视频caoporn| 精品久久国产老人久久综合| 亚洲成av人片www| 日本国产一区二区| 亚洲三级小视频| 91小视频在线免费看| 欧美激情一区二区三区不卡| 久久国产精品99久久久久久老狼| 欧洲亚洲精品在线| 亚洲四区在线观看| 91小视频免费看| 亚洲制服欧美中文字幕中文字幕| 99这里都是精品| 亚洲欧美日韩系列| 在线精品视频一区二区| 亚洲一区二区三区激情| 欧美一区永久视频免费观看| 免费高清在线一区| 2020日本不卡一区二区视频| 国产乱人伦精品一区二区在线观看| 精品国产乱码久久久久久久久| 国产黄人亚洲片| 日韩伦理免费电影| 91精品欧美一区二区三区综合在| 亚洲成人av中文| 久久只精品国产| 色婷婷激情久久| 国产精品影视在线观看| 亚洲人成影院在线观看| 欧美日韩aaaaaa| 成人一级片网址| 亚洲午夜国产一区99re久久| 精品播放一区二区| 欧洲亚洲精品在线| 美女一区二区三区| 一区二区三区在线视频免费观看| 日韩一区二区三区在线观看| av综合在线播放| 国产电影一区二区三区| 青青青爽久久午夜综合久久午夜| 久久久综合精品| 亚洲精品一区二区三区在线观看| 欧美性一级生活| 91麻豆国产福利精品| 国产激情视频一区二区在线观看| 亚洲gay无套男同| 亚洲精品成人精品456| 中文字幕第一区第二区| 久久人人97超碰com| 欧美一区午夜视频在线观看| 91精品国产品国语在线不卡| 99精品国产99久久久久久白柏| 国产精品综合二区| 久久精品72免费观看| 激情五月婷婷综合网| 捆绑调教一区二区三区| 免费成人在线视频观看| 麻豆视频一区二区| 日本不卡一区二区三区| 手机精品视频在线观看| 日韩精品一二区| 国产一区二区精品在线观看| 国产真实精品久久二三区| 黑人精品欧美一区二区蜜桃| 国产精品中文字幕日韩精品| 国产a视频精品免费观看| 91在线国产福利| 日韩一本二本av| 久久精品人人做人人综合| 国产精品免费免费| 亚洲一区二区四区蜜桃| 麻豆精品精品国产自在97香蕉| 不卡视频一二三四| 国产99久久久精品| 国产一区欧美二区| 亚洲午夜影视影院在线观看| 蜜臀av性久久久久av蜜臀妖精| 久久精品国内一区二区三区| 成人国产精品免费观看| 欧美日韩国产小视频在线观看|