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

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

?? udp_usrreq.c

?? vxworks下的實現網絡TCPIP協議的原代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* udp_usrreq.c - UDP protocol routines *//* Copyright 1984-1996 Wind River Systems, Inc. */#include "copyright_wrs.h"/* * Copyright (c) 1982, 1986, 1988, 1990, 1993, 1995 *	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. * *	@(#)udp_usrreq.c	8.6 (Berkeley) 5/23/95 *//*modification history--------------------03f,31aug98,n_s  added udp_hlen validty check to udp_input (). spr #6263.03e,05oct97,vin  added fast multicasting.03d,31mar97,vin  modified for hash look ups for pcbs(FREEBSD 2.2.1).03c,20jan97,vin  replace icmp_error with _icmpErrorHook for scalability, 		 added new udpDoCkSumRcv variable, fixed bugs mentioned		 in Stevens VOLII chapter 23, pg772 & pg774.03b,22nov96,vin  added cluster support replaced m_get(..) with mBufClGet(..).03a,03mar96,vin  created from BSD4.4 stuff,integrated with 02r of udp_usrreq.c.*//*DESCRIPTION*/#include "vxWorks.h"#include "net/mbuf.h"#include "net/protosw.h"#include "sys/socket.h"#include "net/socketvar.h"#include "errno.h"#include "net/if.h"#include "net/route.h"#include "netinet/in.h"#include "netinet/in_pcb.h"#include "netinet/in_systm.h"#include "netinet/ip.h"#include "netinet/ip_var.h"#include "netinet/in_var.h"#include "netinet/ip_icmp.h"#include "netinet/udp.h"#include "netinet/udp_var.h"#include "net/systm.h"/* * UDP protocol implementation. * Per RFC 768, August, 1980. */#ifndef	COMPAT_42int	udpcksum 	= 1;	/* turn on send checksum by default */int	udpDoCkSumRcv	= 1;	/* turn on recv checksum by default */#elseint	udpcksum 	= 0;		/* XXX */int	udpDoCkSumRcv	= 0;#endif#ifndef UDBHASHSIZE#define UDBHASHSIZE 64#endif/* externs */extern VOIDFUNCPTR _icmpErrorHook;/* globals */struct  inpcbhead udb;          /* from udp_var.h */struct  inpcbinfo udbinfo;struct  udpstat udpstat;	/* global udp statistics structure */struct  sockaddr_in udp_in = { sizeof(udp_in), AF_INET };struct	inpcb * udp_last_inpcb = NULL;	/* last PCB cache for fast look up */int	udp_ttl = UDP_TTL;u_long	udp_sendspace = 9216;		/* really max datagram size */u_long	udp_recvspace = 40 * (1024 + sizeof(struct sockaddr_in));					/* 40 1K datagrams */u_short	udp_pcbhashsize = UDBHASHSIZE; 	/* size of hash table *//* forward declarations */static	void udp_detach (struct inpcb *);static	void udp_notify (struct inpcb *, int);static	struct mbuf *udp_saveopt (caddr_t, int, int);voidudp_init(){	LIST_INIT(&udb);	udbinfo.listhead = &udb;	udbinfo.hashbase = hashinit(udp_pcbhashsize, MT_PCB, &udbinfo.hashmask);}voidudp_input(m, iphlen)	register struct mbuf *m;	int iphlen;{	register struct ip *ip;	register struct udphdr *uh;	register struct inpcb *inp;	struct mbuf *opts = 0;	int len;	struct ip save_ip;	udpstat.udps_ipackets++;	/*	 * Strip IP options, if any; should skip this,	 * make available to user, and use on returned packets,	 * but we don't yet have a way to check the checksum	 * with options still present.	 */	if (iphlen > sizeof (struct ip)) {		ip_stripoptions(m, (struct mbuf *)0);		iphlen = sizeof(struct ip);	}	/*	 * Get IP and UDP header together in first mbuf.	 */	ip = mtod(m, struct ip *);	if (m->m_len < iphlen + sizeof(struct udphdr)) {		if ((m = m_pullup(m, iphlen + sizeof(struct udphdr))) == 0) {			udpstat.udps_hdrops++;			return;		}		ip = mtod(m, struct ip *);	}	uh = (struct udphdr *)((caddr_t)ip + iphlen);	/*	 * Make mbuf data length reflect UDP length.	 * If not enough data to reflect UDP length, drop.	 */	len = ntohs((u_short)uh->uh_ulen);	if (len < sizeof (struct udphdr))	    {	    udpstat.udps_badlen++;	    goto bad;	    }	if (ip->ip_len != len) {		if (len > ip->ip_len) {			udpstat.udps_badlen++;			goto bad;		}		m_adj(m, len - ip->ip_len);		/* ip->ip_len = len; */	}	/*	 * Save a copy of the IP header in case we want restore it	 * for sending an ICMP error message in response.	 */	save_ip = *ip;	/*	 * Checksum extended UDP header and data.	 */	if (udpDoCkSumRcv && uh->uh_sum) {		((struct ipovly *)ip)->ih_next = 0;		((struct ipovly *)ip)->ih_prev = 0;		((struct ipovly *)ip)->ih_x1 = 0;		((struct ipovly *)ip)->ih_len = uh->uh_ulen;		if ((uh->uh_sum = in_cksum(m, len + sizeof (struct ip)))) {			udpstat.udps_badsum++;			m_freem(m);			return;		}	}        if(IN_MULTICAST(ntohl(ip->ip_dst.s_addr)))            {            IN_MULTI * 	pInMulti;            M_BLK_ID	pInPcbMblk;            IN_LOOKUP_MULTI(ip->ip_dst, m->m_pkthdr.rcvif, pInMulti);            /* give the packet to all pcbs registered */            if (pInMulti != NULL)                {		struct socket *last;		/*		 * Construct sockaddr format source address.		 */		udp_in.sin_port = uh->uh_sport;		udp_in.sin_addr = ip->ip_src;		m->m_len -= sizeof (struct udpiphdr);		m->m_data += sizeof (struct udpiphdr);		/*		 * give the datagrams to all the pcbs 		 * 		 */		last = NULL;		for (pInPcbMblk = pInMulti->pInPcbMblk; pInPcbMblk != NULL;                     pInPcbMblk = pInPcbMblk->mBlkHdr.mNext)                    {                    inp = mtod (pInPcbMblk, struct inpcb *);                    if (inp->inp_lport != uh->uh_dport)                        continue;                    if (inp->inp_laddr.s_addr != INADDR_ANY)                        if (inp->inp_laddr.s_addr != ip->ip_dst.s_addr)                            continue;                    if (inp->inp_faddr.s_addr != INADDR_ANY)                        if (inp->inp_faddr.s_addr != ip->ip_src.s_addr ||                            inp->inp_fport != uh->uh_sport)                            continue;                    if (last != NULL)                        {                        struct mbuf *n;                        if ((n = m_copy(m, 0, M_COPYALL)) != NULL)                            {                            if (sbappendaddr(&last->so_rcv,                                             (struct sockaddr *)&udp_in,                                             n, (struct mbuf *)0) == 0)                                {                                m_freem(n);                                udpstat.udps_fullsock++;                                }                            else                                sorwakeup(last);                            }                        }                    last = inp->inp_socket;                    /*                     * Don't look for additional matches if this one does                     * not have either the SO_REUSEPORT or SO_REUSEADDR                     * socket options set.  This heuristic avoids searching                     * through all pcbs in the common case of a non-shared                     * port.  It * assumes that an application will never                     * clear these options after setting them.                     */                    if ((last->so_options & (SO_REUSEPORT|SO_REUSEADDR)) == 0)                        break;                    }		if (last == NULL)                    {                    /*                     * No matching pcb found; discard datagram.                     * (No need to send an ICMP Port Unreachable                     * for a broadcast or multicast datgram.)                     */                    udpstat.udps_noportbcast++;                    goto bad;                    }		if (sbappendaddr(&last->so_rcv, (struct sockaddr *)&udp_in,                                 m, (struct mbuf *)0) == 0)                    {                    udpstat.udps_fullsock++;                    goto bad;                    }		sorwakeup(last);		return;                }            }        	if (in_broadcast(ip->ip_dst, m->m_pkthdr.rcvif)) {		struct socket *last;		/*		 * Deliver a multicast or broadcast datagram to *all* sockets		 * for which the local and remote addresses and ports match		 * those of the incoming datagram.  This allows more than		 * one process to receive multi/broadcasts on the same port.		 * (This really ought to be done for unicast datagrams as		 * well, but that would cause problems with existing		 * applications that open both address-specific sockets and		 * a wildcard socket listening to the same port -- they would		 * end up receiving duplicates of every unicast datagram.		 * Those applications open the multiple sockets to overcome an		 * inadequacy of the UDP socket interface, but for backwards		 * compatibility we avoid the problem here rather than		 * fixing the interface.  Maybe 4.5BSD will remedy this?)		 */		/*		 * Construct sockaddr format source address.		 */		udp_in.sin_port = uh->uh_sport;		udp_in.sin_addr = ip->ip_src;		m->m_len -= sizeof (struct udpiphdr);		m->m_data += sizeof (struct udpiphdr);		/*		 * Locate pcb(s) for datagram.		 * (Algorithm copied from raw_intr().)		 */		last = NULL;		for (inp = udb.lh_first; inp != NULL;                     inp = inp->inp_list.le_next) {			if (inp->inp_lport != uh->uh_dport)				continue;			if (inp->inp_laddr.s_addr != INADDR_ANY) {				if (inp->inp_laddr.s_addr !=				    ip->ip_dst.s_addr)					continue;			}			if (inp->inp_faddr.s_addr != INADDR_ANY) {				if (inp->inp_faddr.s_addr !=				    ip->ip_src.s_addr ||				    inp->inp_fport != uh->uh_sport)					continue;			}			if (last != NULL) {				struct mbuf *n;				if ((n = m_copy(m, 0, M_COPYALL)) != NULL) {					if (sbappendaddr(&last->so_rcv,						(struct sockaddr *)&udp_in,						n, (struct mbuf *)0) == 0) {						m_freem(n);						udpstat.udps_fullsock++;					} else						sorwakeup(last);				}			}			last = inp->inp_socket;			/*			 * Don't look for additional matches if this one does			 * not have either the SO_REUSEPORT or SO_REUSEADDR			 * socket options set.  This heuristic avoids searching			 * through all pcbs in the common case of a non-shared			 * port.  It * assumes that an application will never			 * clear these options after setting them.			 */			if ((last->so_options & (SO_REUSEPORT|SO_REUSEADDR))                            == 0)				break;		}		if (last == NULL) {			/*			 * No matching pcb found; discard datagram.			 * (No need to send an ICMP Port Unreachable			 * for a broadcast or multicast datgram.)			 */			udpstat.udps_noportbcast++;			goto bad;		}		if (sbappendaddr(&last->so_rcv, (struct sockaddr *)&udp_in,		     m, (struct mbuf *)0) == 0) {			udpstat.udps_fullsock++;			goto bad;		}		sorwakeup(last);		return;	}	/*	 * Locate pcb for datagram. use the cached pcb if it matches.	 */	inp = udp_last_inpcb;        if ((inp != NULL) &&            (inp->inp_lport == uh->uh_dport) &&	    (inp->inp_fport == uh->uh_sport) &&	    (inp->inp_faddr.s_addr == ip->ip_src.s_addr) &&            (inp->inp_laddr.s_addr == ip->ip_dst.s_addr))            {            goto pcbMatchFound;            }        else            {            udpstat.udpps_pcbcachemiss++;            /*             * Locate pcb for datagram.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文在线不卡住| 免费观看日韩av| 午夜精品免费在线| 岛国精品在线观看| 欧美高清www午色夜在线视频| 久久久久高清精品| 日本中文一区二区三区| av不卡免费在线观看| 精品久久久久久久久久久久包黑料 | 亚洲免费在线观看| 久久精品国产亚洲5555| 欧美综合欧美视频| 综合亚洲深深色噜噜狠狠网站| 麻豆精品精品国产自在97香蕉 | 一区二区欧美在线观看| 国产成人精品三级麻豆| 日韩视频在线永久播放| 午夜亚洲福利老司机| 色系网站成人免费| 中文字幕亚洲一区二区av在线 | 日韩高清电影一区| 色就色 综合激情| 亚洲欧洲一区二区三区| 国产91清纯白嫩初高中在线观看| 精品噜噜噜噜久久久久久久久试看| 性做久久久久久免费观看| 日本韩国一区二区| 亚洲网友自拍偷拍| 欧美性色综合网| 亚洲综合男人的天堂| 色噜噜久久综合| 亚洲免费观看在线视频| 91免费版在线| 一区二区三区在线视频观看58| 99综合影院在线| 亚洲另类在线制服丝袜| 日本道色综合久久| 午夜一区二区三区视频| 欧美日本在线播放| 蜜桃视频在线观看一区二区| 欧美一区二区三区电影| 麻豆精品一区二区av白丝在线| 欧美va亚洲va国产综合| 国产精品1区2区3区| 国产欧美日韩精品a在线观看| 成人在线视频一区| 一区二区三区四区国产精品| 欧美日韩中文字幕精品| 日本欧美一区二区三区| 精品999在线播放| 成人在线一区二区三区| 一区二区三区高清不卡| 91精品婷婷国产综合久久性色 | 日韩av电影天堂| 久久新电视剧免费观看| av一本久道久久综合久久鬼色| 亚洲综合偷拍欧美一区色| 91麻豆精品国产91久久久更新时间| 麻豆91免费观看| 中文字幕中文在线不卡住| 欧美少妇一区二区| 国产在线日韩欧美| 亚洲欧美色图小说| 日韩一本二本av| 成人av免费观看| 午夜精品久久久久久久| 久久久久久久久久看片| 在线看不卡av| 国产真实乱对白精彩久久| 亚洲精品视频在线看| 日韩免费性生活视频播放| av一区二区三区四区| 老司机午夜精品| 依依成人精品视频| 久久影院视频免费| 欧美日韩国产综合视频在线观看 | 久久精品男人天堂av| 日本黄色一区二区| 丰满少妇在线播放bd日韩电影| 亚洲1区2区3区视频| 欧美韩国一区二区| 欧美zozozo| 欧美色综合影院| 99热精品国产| 国产乱理伦片在线观看夜一区| 亚洲国产视频网站| 中文字幕一区二区三| 久久人人爽人人爽| 日韩视频在线你懂得| 日本道精品一区二区三区| 国产91丝袜在线播放九色| 另类小说综合欧美亚洲| 亚洲午夜视频在线观看| 国产精品―色哟哟| 久久午夜电影网| 欧美大白屁股肥臀xxxxxx| 在线观看视频91| 91丨porny丨户外露出| 国产成人午夜视频| 精品影院一区二区久久久| 香蕉加勒比综合久久| 亚洲欧美另类图片小说| 综合中文字幕亚洲| 亚洲色图欧美激情| 自拍偷拍欧美精品| 最新热久久免费视频| 国产精品无码永久免费888| 久久中文娱乐网| 久久亚洲私人国产精品va媚药| 精品少妇一区二区三区免费观看| 欧美人伦禁忌dvd放荡欲情| 欧美性生活久久| 欧美年轻男男videosbes| 日本精品一区二区三区高清| 色屁屁一区二区| 一本色道久久加勒比精品| 91一区一区三区| 日本韩国精品在线| 欧美美女bb生活片| 69堂国产成人免费视频| 欧美一区二区三区视频在线| 91麻豆精品国产| 欧美一卡二卡三卡| 精品奇米国产一区二区三区| 精品国产一区二区三区忘忧草 | 国产日韩欧美综合一区| 国产午夜亚洲精品理论片色戒| 亚洲国产高清在线| 亚洲免费在线观看| 日韩av电影天堂| 国产成人福利片| 国产98色在线|日韩| 国产成人aaa| 一本色道久久综合狠狠躁的推荐 | 91原创在线视频| 欧美无砖砖区免费| 日韩欧美你懂的| 中文字幕乱码一区二区免费| 中文字幕综合网| 午夜国产精品一区| 久久精品免费观看| 成人av动漫在线| 欧美男人的天堂一二区| 日韩欧美高清一区| 国产精品美女www爽爽爽| 一片黄亚洲嫩模| 韩国女主播一区| 91久久精品网| 精品对白一区国产伦| 亚洲精选视频免费看| 免费精品99久久国产综合精品| 成人伦理片在线| 欧美日韩电影一区| 国产欧美一区二区三区在线老狼| 亚洲乱码精品一二三四区日韩在线| 亚洲va韩国va欧美va| 国产精品18久久久久久vr| 91黄色免费看| 国产精品无遮挡| 九九热在线视频观看这里只有精品| 国产91精品久久久久久久网曝门| 91官网在线免费观看| 久久丝袜美腿综合| 性做久久久久久久久| av电影在线观看一区| 欧美r级在线观看| 一区二区三区资源| 国产成人av资源| 精品国产免费一区二区三区四区| 亚洲黄色小视频| 成人av在线看| 2021久久国产精品不只是精品| 亚洲综合色网站| 日韩美女主播在线视频一区二区三区| 国产精品久久久久久久久果冻传媒| 天堂va蜜桃一区二区三区漫画版| 成人av动漫在线| 国产日产亚洲精品系列| 麻豆精品精品国产自在97香蕉 | 久久精品国产精品青草| 国产日韩欧美精品综合| 久久婷婷国产综合国色天香| eeuss鲁片一区二区三区在线观看| 国产成人一区在线| 精品粉嫩超白一线天av| 岛国av在线一区| 综合久久给合久久狠狠狠97色| 在线视频一区二区三区| 亚洲主播在线播放| 欧美一级专区免费大片| 国产伦精品一区二区三区免费| 欧美国产1区2区| 日本高清不卡在线观看| 婷婷久久综合九色综合伊人色| 日韩一区二区三| jizzjizzjizz欧美| 亚洲综合图片区| 久久久久久久精| 一本大道久久a久久精二百| 日韩高清不卡在线|