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

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

?? ip_mroute.c

?? 完整的TCP/IP源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* ip_mroute.c - internet multicast routing routines *//* Copyright 1984-1996 Wind River Systems, Inc. */#include "copyright_wrs.h"/* * Copyright (c) 1989 Stephen Deering * Copyright (c) 1992, 1993 *	The Regents of the University of California.  All rights reserved. * * This code is derived from software contributed to Berkeley by * Stephen Deering of Stanford University. * * 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_mroute.c	8.2 (Berkeley) 11/15/93 *//*modification history--------------------01e,21aug98,n_s  fixed add_lgrp () call to MALLOC(). spr20595.01d,08apr97,vin  added mCastRouteFwdHook deleted ip_mrouter.01c,05dec96,vin  changed malloc(..) to MALLOC(..) to use only network buffers,		 changed free(..) to FREE(..).01b,22nov96,vin  added cluster support replaced m_gethdr(..) with mHdrClGet(..)01a,03mar96,vin  created from BSD4.4 stuff.*//* * Procedures for the kernel part of DVMRP, * a Distance-Vector Multicast Routing Protocol. * (See RFC-1075.) * * Written by David Waitzman, BBN Labs, August 1988. * Modified by Steve Deering, Stanford, February 1989. * * MROUTING 1.1 */#include "vxWorks.h"#include "errno.h"#include "net/mbuf.h"#include "sys/socket.h"#include "sys/times.h"#include "sys/ioctl.h"#include "net/protosw.h"#include "net/if.h"#include "net/route.h"#include "net/socketvar.h"#include "net/raw_cb.h"#include "netinet/in.h"#include "netinet/in_pcb.h"#include "netinet/in_var.h"#include "netinet/in_systm.h"#include "netinet/ip.h"#include "netinet/ip_var.h"#include "netinet/igmp.h"#include "netinet/igmp_var.h"#include "netinet/igmp.h"#include "netinet/igmp_var.h"#include "netinet/ip_mroute.h"#include "net/systm.h"/* externs */extern FUNCPTR _mCastRouteFwdHook;	/* WRS mcast forward command hook *//* Static forwards */#define __P(x)	xstatic	int ip_mrouter_init __P((struct socket *));static	int add_vif __P((struct vifctl *));static	int del_vif __P((vifi_t *vifip));static	int add_lgrp __P((struct lgrplctl *));static	int del_lgrp __P((struct lgrplctl *));static	int grplst_member __P((struct vif *, struct in_addr));static	u_long nethash __P((struct in_addr in));static	int add_mrt __P((struct mrtctl *));static	int del_mrt __P((struct in_addr *));static	struct mrt *mrtfind __P((struct in_addr));static	void phyint_send __P((struct mbuf *, struct vif *));static	void tunnel_send __P((struct mbuf *, struct vif *));static  int ip_mforward (struct mbuf * m, struct ifnet * ifp); static	int ip_mrouter_done (void); #define INSIZ sizeof(struct in_addr)#define	same(a1, a2) (bcmp((caddr_t)(a1), (caddr_t)(a2), INSIZ) == 0)#define	satosin(sa)	((struct sockaddr_in *)(sa))/* * Globals.  All but ip_mrouter and ip_mrtproto could be static, * except for netstat or debugging purposes. */int	ip_mrtproto = IGMP_DVMRP;		/* for netstat only */struct	mrt *mrttable[MRTHASHSIZ];struct	vif viftable[MAXVIFS];struct	mrtstat	mrtstat;/* * Private variables. */static	vifi_t numvifs = 0;static	struct mrt *cached_mrt = NULL;static	u_long cached_origin;static	u_long cached_originmask;/* * Handle DVMRP setsockopt commands to modify the multicast routing tables. */intip_mrouter_cmd(cmd, so, m)	register int cmd;	register struct socket *so;	register struct mbuf *m;{	register int error = 0;	if ((cmd != DVMRP_INIT) && (_mCastRouteFwdHook == NULL))		error = EACCES;	else switch (cmd) {	case DVMRP_INIT:		error = ip_mrouter_init(so);		break;	case DVMRP_DONE:		error = ip_mrouter_done();		break;	case DVMRP_ADD_VIF:		if (m == NULL || m->m_len < sizeof(struct vifctl))			error = EINVAL;		else			error = add_vif(mtod(m, struct vifctl *));		break;	case DVMRP_DEL_VIF:		if (m == NULL || m->m_len < sizeof(short))			error = EINVAL;		else			error = del_vif(mtod(m, vifi_t *));		break;	case DVMRP_ADD_LGRP:		if (m == NULL || m->m_len < sizeof(struct lgrplctl))			error = EINVAL;		else			error = add_lgrp(mtod(m, struct lgrplctl *));		break;	case DVMRP_DEL_LGRP:		if (m == NULL || m->m_len < sizeof(struct lgrplctl))			error = EINVAL;		else			error = del_lgrp(mtod(m, struct lgrplctl *));		break;	case DVMRP_ADD_MRT:		if (m == NULL || m->m_len < sizeof(struct mrtctl))			error = EINVAL;		else			error = add_mrt(mtod(m, struct mrtctl *));		break;	case DVMRP_DEL_MRT:		if (m == NULL || m->m_len < sizeof(struct in_addr))			error = EINVAL;		else			error = del_mrt(mtod(m, struct in_addr *));		break;	default:		error = EOPNOTSUPP;		break;	}	return (error);}/* * Enable multicast routing */static intip_mrouter_init (so)	register struct socket *so;{	if (so->so_type != SOCK_RAW ||	    so->so_proto->pr_protocol != IPPROTO_IGMP)		return (EOPNOTSUPP);	if ( _mCastRouteFwdHook != NULL)	/* if already installed */            return (EADDRINUSE);        _mCastRouteFwdHook = ip_mforward; 	/* forwarding func ptr */	return (0);}/* * Disable multicast routing */static intip_mrouter_done(){	register vifi_t vifi;	register int i;	register struct ifnet *ifp;	register int s;	struct ifreq ifr;	s = splnet();	/*	 * For each phyint in use, free its local group list and	 * disable promiscuous reception of all IP multicasts.	 */	for (vifi = 0; vifi < numvifs; vifi++) {		if (viftable[vifi].v_lcl_addr.s_addr != 0 &&		    !(viftable[vifi].v_flags & VIFF_TUNNEL)) {			if (viftable[vifi].v_lcl_grps)			    	{				FREE(viftable[vifi].v_lcl_grps, M_MRTABLE);				}			satosin(&ifr.ifr_addr)->sin_family = AF_INET;			satosin(&ifr.ifr_addr)->sin_addr.s_addr = INADDR_ANY;			ifp = viftable[vifi].v_ifp;			(*ifp->if_ioctl)(ifp, SIOCDELMULTI, (caddr_t)&ifr);		}	}	bzero((caddr_t)viftable, sizeof(viftable));	numvifs = 0;	/*	 * Free any multicast route entries.	 */	for (i = 0; i < MRTHASHSIZ; i++)		if (mrttable[i])		    	{			FREE(mrttable[i], M_MRTABLE);			}	bzero((caddr_t)mrttable, sizeof(mrttable));	cached_mrt = NULL;        _mCastRouteFwdHook = NULL; 	/* reset forwarding func ptr to NULL*/	splx(s);	return (0);}/* * Add a vif to the vif table */static intadd_vif(vifcp)	register struct vifctl *vifcp;{	register struct vif *vifp = viftable + vifcp->vifc_vifi;	register struct ifaddr *ifa;	register struct ifnet *ifp;	struct ifreq ifr;	register int error, s;	static struct sockaddr_in sin = { sizeof(sin), AF_INET };	if (vifcp->vifc_vifi >= MAXVIFS)		return (EINVAL);	if (vifp->v_lcl_addr.s_addr != 0)		return (EADDRINUSE);	/* Find the interface with an address in AF_INET family */	sin.sin_addr = vifcp->vifc_lcl_addr;	ifa = ifa_ifwithaddr((struct sockaddr *)&sin);	if (ifa == 0)		return (EADDRNOTAVAIL);	s = splnet();	if (vifcp->vifc_flags & VIFF_TUNNEL)		vifp->v_rmt_addr = vifcp->vifc_rmt_addr;	else {		/* Make sure the interface supports multicast */		ifp = ifa->ifa_ifp;		if ((ifp->if_flags & IFF_MULTICAST) == 0) {			splx(s);			return (EOPNOTSUPP);		}		/*		 * Enable promiscuous reception of all IP multicasts		 * from the interface.		 */		satosin(&ifr.ifr_addr)->sin_family = AF_INET;		satosin(&ifr.ifr_addr)->sin_addr.s_addr = INADDR_ANY;		error = (*ifp->if_ioctl)(ifp, SIOCADDMULTI, (caddr_t)&ifr);		if (error) {			splx(s);			return (error);		}	}	vifp->v_flags = vifcp->vifc_flags;	vifp->v_threshold = vifcp->vifc_threshold;	vifp->v_lcl_addr = vifcp->vifc_lcl_addr;	vifp->v_ifp = ifa->ifa_ifp;	/* Adjust numvifs up if the vifi is higher than numvifs */	if (numvifs <= vifcp->vifc_vifi)		numvifs = vifcp->vifc_vifi + 1;	splx(s);	return (0);}/* * Delete a vif from the vif table */static intdel_vif(vifip)	register vifi_t *vifip;{	register struct vif *vifp = viftable + *vifip;	register struct ifnet *ifp;	register int i, s;	struct ifreq ifr;	if (*vifip >= numvifs)		return (EINVAL);	if (vifp->v_lcl_addr.s_addr == 0)		return (EADDRNOTAVAIL);	s = splnet();	if (!(vifp->v_flags & VIFF_TUNNEL)) {		if (vifp->v_lcl_grps)		    	{			FREE(vifp->v_lcl_grps, M_MRTABLE);			}		satosin(&ifr.ifr_addr)->sin_family = AF_INET;		satosin(&ifr.ifr_addr)->sin_addr.s_addr = INADDR_ANY;		ifp = vifp->v_ifp;		(*ifp->if_ioctl)(ifp, SIOCDELMULTI, (caddr_t)&ifr);	}	bzero((caddr_t)vifp, sizeof (*vifp));	/* Adjust numvifs down */	for (i = numvifs - 1; i >= 0; i--)		if (viftable[i].v_lcl_addr.s_addr != 0)			break;	numvifs = i + 1;	splx(s);	return (0);}/* * Add the multicast group in the lgrpctl to the list of local multicast * group memberships associated with the vif indexed by gcp->lgc_vifi. */static intadd_lgrp(gcp)	register struct lgrplctl *gcp;{	register struct vif *vifp;	register int s;	if (gcp->lgc_vifi >= numvifs)		return (EINVAL);	vifp = viftable + gcp->lgc_vifi;	if (vifp->v_lcl_addr.s_addr == 0 || (vifp->v_flags & VIFF_TUNNEL))		return (EADDRNOTAVAIL);	/* If not enough space in existing list, allocate a larger one */	s = splnet();	if (vifp->v_lcl_grps_n + 1 >= vifp->v_lcl_grps_max) {		register int num;		register struct in_addr *ip;		num = vifp->v_lcl_grps_max;		if (num <= 0)			num = 32;	/* initial number */		else			num += num;	/* double last number */		MALLOC (ip, struct in_addr *, sizeof(*ip) * num, MT_MRTABLE, 			M_DONTWAIT); 		if (ip == NULL) {			splx(s);			return (ENOBUFS);		}		bzero((caddr_t)ip, num * sizeof(*ip));	/* XXX paranoid */		bcopy((caddr_t)vifp->v_lcl_grps, (caddr_t)ip,		    vifp->v_lcl_grps_n * sizeof(*ip));		vifp->v_lcl_grps_max = num;		if (vifp->v_lcl_grps)		    	{			FREE(vifp->v_lcl_grps, M_MRTABLE);			}		vifp->v_lcl_grps = ip;		splx(s);	}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆传媒一区二区三区| 国产成人免费视频网站高清观看视频 | 在线一区二区观看| 精品国产乱码久久久久久蜜臀| 国产99久久久精品| 欧美欧美欧美欧美| 一区在线中文字幕| 国模一区二区三区白浆| 91精品一区二区三区久久久久久 | 国产999精品久久久久久绿帽| 琪琪一区二区三区| 色综合久久综合网欧美综合网| 不卡的av在线| 亚洲精品一区二区三区影院| 亚洲高清视频中文字幕| 一本久久a久久精品亚洲| 久久精品一区二区三区不卡| 精品写真视频在线观看| 在线综合亚洲欧美在线视频| 日韩毛片视频在线看| 国产成人精品网址| 久久精品亚洲精品国产欧美kt∨| 国产色产综合色产在线视频| 免费av网站大全久久| 欧美性猛片aaaaaaa做受| 一区二区三区av电影| 99re热这里只有精品视频| 中文字幕欧美日本乱码一线二线| 中文字幕在线播放不卡一区| 加勒比av一区二区| 欧美zozo另类异族| 国产一区二区按摩在线观看| 精品国精品国产| 老司机精品视频线观看86| 欧美mv日韩mv国产| 精品一二三四区| 国产丝袜美腿一区二区三区| 成人午夜电影久久影院| 国产精品灌醉下药二区| 91浏览器打开| 国产成人av一区二区| 精品蜜桃在线看| 国产精品香蕉一区二区三区| 欧美极品xxx| 91女厕偷拍女厕偷拍高清| 亚洲日本在线观看| 欧美视频在线一区二区三区 | 日韩精品专区在线影院观看| 精品一区二区久久久| 久久久国产精品午夜一区ai换脸| 中文字幕亚洲区| 色偷偷一区二区三区| 亚洲乱码中文字幕| 欧美精品日日鲁夜夜添| 精品一区二区免费在线观看| 中文字幕欧美区| 欧美性色aⅴ视频一区日韩精品| 国产亚洲成aⅴ人片在线观看| 亚洲图片自拍偷拍| 日韩欧美成人午夜| 成人一区二区三区视频在线观看| 欧美伊人久久久久久午夜久久久久| 欧美xxxxxxxx| 99久久er热在这里只有精品15| 欧美人与禽zozo性伦| 欧美aaaaa成人免费观看视频| 色欧美88888久久久久久影院| 精品成人免费观看| 91免费观看视频在线| 日本美女一区二区三区| 国产人伦精品一区二区| 欧美日韩一区二区三区不卡| 国产在线日韩欧美| 一区二区免费在线播放| 国产亚洲精品中文字幕| 欧美日韩一区二区三区四区五区| 中文字幕亚洲不卡| 日韩视频一区二区三区| 白白色亚洲国产精品| 日韩av不卡在线观看| 亚洲美腿欧美偷拍| 久久久久久久综合色一本| 欧美日韩在线播| 91美女片黄在线观看| 国产精一品亚洲二区在线视频| 精品福利一区二区三区免费视频| 日韩在线一区二区三区| 国产精品久久久久久久久久久免费看| 国产成人精品1024| 日本一区中文字幕| 亚洲欧洲在线观看av| 久久免费午夜影院| 日韩欧美亚洲另类制服综合在线| 另类专区欧美蜜桃臀第一页| 亚洲黄一区二区三区| 中文一区在线播放| 久久综合色一综合色88| 日韩欧美在线1卡| 色8久久精品久久久久久蜜| 成人综合婷婷国产精品久久蜜臀| 亚洲欧洲av在线| 欧美精品一区二区三区很污很色的| 国产一区二区免费在线| 麻豆国产一区二区| 色综合久久久久| 国产麻豆91精品| 九九**精品视频免费播放| 日韩国产精品久久久久久亚洲| 日韩一级片网址| 日韩欧美第一区| 日韩欧美一区二区免费| 精品视频色一区| 欧美另类高清zo欧美| 欧美男男青年gay1069videost| 韩国三级中文字幕hd久久精品| 欧美国产精品一区| 亚洲国产精品二十页| 中文字幕欧美激情一区| 日韩一区中文字幕| 一区二区三区四区乱视频| 亚洲婷婷国产精品电影人久久| 欧美精品三级日韩久久| 51精品秘密在线观看| 欧美日韩成人综合在线一区二区| 久久av老司机精品网站导航| 日韩黄色免费电影| 久久精品国产精品亚洲精品| 精久久久久久久久久久| 国产精品亚洲专一区二区三区 | 日本aⅴ精品一区二区三区| 日韩二区三区四区| 黑人巨大精品欧美一区| 精品一区二区在线视频| 国产99一区视频免费| 色综合久久综合中文综合网| 欧美久久久久中文字幕| 精品福利av导航| 国产精品美女一区二区| 亚洲香肠在线观看| 精品一区二区三区免费毛片爱| 一区二区三区欧美| 日日夜夜精品视频天天综合网| 欧美激情一区二区| 亚洲一区在线播放| 奇米影视在线99精品| 国产精品一区二区久久精品爱涩 | 国产精品夜夜嗨| 色久优优欧美色久优优| 日韩欧美激情在线| 亚洲欧洲综合另类| 麻豆精品久久久| 色天使久久综合网天天| 日韩片之四级片| 亚洲美女免费视频| 久99久精品视频免费观看| 91影院在线免费观看| 日韩欧美亚洲一区二区| 亚洲精品高清在线观看| 久久国产精品99精品国产| 色综合久久久久网| www精品美女久久久tv| 一区二区三区不卡视频| 国产成人免费视频网站| 91精品久久久久久久99蜜桃| 亚洲丝袜自拍清纯另类| 九九热在线视频观看这里只有精品| 五月天视频一区| 99久久综合99久久综合网站| 日韩女优制服丝袜电影| 中文字幕一区二区视频| 久久av老司机精品网站导航| 在线中文字幕一区| 国产精品乱码一区二三区小蝌蚪| 国产精品欧美久久久久无广告| 久久久久久亚洲综合影院红桃| 精品国产乱码久久| 天天综合网 天天综合色| av电影在线不卡| 免费高清在线一区| 在线观看av一区二区| 国产精品久久久久久久久久久免费看| 亚洲国产精品精华液2区45| 久久机这里只有精品| 欧美理论在线播放| 亚洲一区二区三区三| 91丨九色丨蝌蚪丨老版| 久久亚洲二区三区| 久久国产精品72免费观看| 4438成人网| 午夜精品久久久久久久99樱桃| 日韩激情在线观看| 欧美午夜精品理论片a级按摩| 欧美美女bb生活片| 亚洲人成精品久久久久久| 国产凹凸在线观看一区二区| 久久综合九色综合欧美就去吻| 亚洲免费av高清| 在线观看亚洲精品视频| 亚洲国产日韩精品| 欧美人狂配大交3d怪物一区|