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

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

?? spfutil.c

?? BCAST Implementation for NS2
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* *   OSPFD routing daemon *   Copyright (C) 1998 by John T. Moy *    *   This program is free software; you can redistribute it and/or *   modify it under the terms of the GNU General Public License *   as published by the Free Software Foundation; either version 2 *   of the License, or (at your option) any later version. *    *   This program is distributed in the hope that it will be useful, *   but WITHOUT ANY WARRANTY; without even the implied warranty of *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *   GNU General Public License for more details. *    *   You should have received a copy of the GNU General Public License *   along with this program; if not, write to the Free Software *   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *//* Various utility routines in support of the OSPF * implementation. */#include "ospfinc.h"#include "system.h"/* The OSPF FSM processing routine. * Organized as an array of FSM transitions; each * FSM transitions specifies a collection of current states, and * an event. The array is searched linearly. The first matching * transition provides an action, and a new state. If the * new state is 0, there is not state change and i_state (passed * by reference) is not changed. * * End of the FSM table is indicated by a states value of 0. * * Returns the action to be performed. 0 indicates no action, and * -1 indicates that no matching FSM transition was found. */int OSPF::run_fsm(FsmTran *table, int& i_state, int event){    FsmTran *transition;    for (transition = table; transition->states; transition++) {	if ((transition->states & i_state) == 0)	    continue;	if (transition->event != event)	    continue;	/* Matching transition. Update state if new state	 * is non-zero.	 */	if (transition->new_state != 0)	    i_state = transition->new_state;	return(transition->action);    }    return(-1);}/* Create a packet descriptor from a received OSPF packet. * "bsize" set to the length of the IP packet's contents, * which should be greater than or equal to the size of the * OSPF packet (verified by caller). */Pkt::Pkt(int rcvint, InPkt *inpkt){    int iphlen;    iphlen = (inpkt->i_vhlen & 0xf) << 2;    // Set Pkt fields    iphdr = inpkt;    phyint = rcvint;    llmult = false;    hold = false;    spfpkt = (SpfPkt *) (((byte *) iphdr) + iphlen);    end = (((byte *) iphdr) + ntoh16(iphdr->i_len));    bsize = ntoh16(inpkt->i_len) - iphlen;    dptr = (byte *) spfpkt;}/* Initialize an output packet descriptor. */Pkt::Pkt(){    iphdr = 0;    phyint = -1;    llmult = false;    hold = false;    xsummed = false;    spfpkt = 0;    end = 0;    bsize = 0;    dptr = 0;    body_xsum = 0;}/* Allocate a packet to be sent later. Initialize the offsets * of the IP and OSPF headers. * The data pointer is set pointing after the OSPF header, * because that is where the caller will start inserting * data. * Append room for digest if interface just in case cryptographic * authentication will be used. */int OSPF::ospf_getpkt(Pkt *pkt, int type, uns16 size){    InPkt *iphdr;    SpfPkt *spfpkt;    // Add a little extra on the end for MD5 digest    if (!(iphdr = sys->getpkt(size + 16)))	return(0);    pkt->iphdr = iphdr;    pkt->phyint = -1;    pkt->llmult = 0;    pkt->spfpkt = (SpfPkt *) (iphdr + 1);    pkt->end = ((byte *) iphdr) + size;    pkt->bsize = size - sizeof(iphdr);    pkt->dptr = (byte *) (pkt->spfpkt + 1);    iphdr->i_vhlen = IHLVER;    iphdr->i_tos = PREC_IC;    iphdr->i_ffo = 0;    iphdr->i_prot = PROT_OSPF;    spfpkt = pkt->spfpkt;    spfpkt->vers = OSPFv2;    spfpkt->ptype = type;    spfpkt->srcid = hton32(ospf->my_id());    return(size);}/* Finish filling in the headers of a packet that is to be sent, * including the header and packet checksums. * The caller has set Pkt::dptr to point to the end of the * packet. */void SpfIfc::finish_pkt(Pkt *pkt, InAddr dst){    InPkt *iphdr;    SpfPkt *spfpkt;    int size;    pkt->phyint = if_phyint;    spfpkt = pkt->spfpkt;    size = pkt->dptr - (byte *) spfpkt;    spfpkt->plen = hton16(size);    spfpkt->p_aid = hton32(if_area->id());    generate_message(pkt);    iphdr = pkt->iphdr;    // size may have changed in call to SpfIfc::generate_message()    size = pkt->dptr - (byte *) iphdr;    iphdr->i_len = hton16(size);    iphdr->i_id = 0;    iphdr->i_ttl = is_virtual() ? DEFAULT_TTL : 1;    iphdr->i_src = (if_addr != 0 ? hton32(if_addr) : hton32(ospf->my_addr()));    iphdr->i_dest = hton32(dst);    iphdr->i_chksum = 0;    iphdr->i_chksum = ~incksum((uns16 *) iphdr, sizeof(*iphdr));}/* Finish the common parts of a packet that we are going to send * out multiple interfaces. Will have its IP header built * later in SpfIfc::finish_pkt(). * Returns true as long as there is a packet present. */bool Pkt::partial_checksum(){    int datasize;    byte *bodyptr;    if (!iphdr)	return(false);    bodyptr = (byte *) (spfpkt+1);    datasize = dptr - bodyptr;    body_xsum = incksum((uns16 *) bodyptr, datasize);    xsummed = true;    return(true);}/* Free an OSPF packet. Reset all pointers, and return the buffer * to the system. */void OSPF::ospf_freepkt(Pkt *pkt){    if (!pkt->iphdr)	return;    if (pkt->hold)	return;    sys->freepkt(pkt->iphdr);    pkt->iphdr = 0;    pkt->spfpkt = 0;    pkt->end = 0;    pkt->bsize = 0;    pkt->dptr = 0;    pkt->xsummed = false;}/* Destructor not expected to be called during the life * of the program. */OspfSysCalls::~OspfSysCalls(){}/* Get a memory area to build an OSPF packet * for transmit. */InPkt *OspfSysCalls::getpkt(uns16 len){    return ((InPkt *) new char[len]);}/* Free a transmitted packet. */void OspfSysCalls::freepkt(InPkt *pkt){    delete [] ((char *) pkt);}/* The Internet standard ones complement checksum. 0xffff and 0 * are equivalent sums, but we make sure to always return * 0 in that case. When creating a checksum, caller should * take the ones complement of the return. * * It is assumed that the region being checksummed is in * network byte order, and the checksum returned is also * in network byte order. */uns16 incksum(uns16 *ptr, int len, uns16 seed){    uns32 xsum=seed;    for (; len > 1; len -= 2) {	xsum += *ptr++;	if (xsum & 0x10000) {	    xsum += 1;	    xsum &= 0xffff;	}    }    if (len == 1) {	xsum += hton16(*((byte *)ptr));	if (xsum & 0x10000) {	    xsum += 1;	    xsum &= 0xffff;	}    }    return ((xsum == 0xffff) ? 0 : (uns16) xsum);}/* Decide whether to log a message, based on its ID and * its priority. */// Error strings. Indices define in spflog.hconst char *msgtext(int msgno){    switch(msgno) {	// Configuration      case CFG_START:	return("ospfd Starting");      case CFG_ADD_AREA:      case CFG_ADD_IFC:      case LOG_ADDRT:      case LOG_ADDREJECT:	return("Adding");      case CFG_DEL_AREA:      case CFG_DEL_IFC:      case LOG_DELRT:	return("Deleting");	// Errors      case CFG_HTLRST:	return("Hitless restart, period");      case RCV_SHORT:	return("Received packet too short");      case RCV_BADV:	return("Received bad OSPF version number");      case RCV_NO_IFC:	return("No matching receive interface");      case RCV_NO_NBR:	return("No matching neighbor");      case RCV_AUTH:	return("Authentication failure");      case RCV_NOTDR:	return("Not DR/Backup, but rcvd");      case ERR_LSAXSUM:	return("Bad LSA checksum");      case ERR_EX_IN_STUB:	return("AS-external-LSAs in stub area");      case ERR_BAD_LSA_TYPE:	return("Unrecognized LS type");      case ERR_OLD_ACK:	return("Old ack");      case DUP_ACK:	return("Duplicate ack");      case ERR_NEWER_ACK:	return("Bad ack");      case ERR_IFC_FSM:      case ERR_NBR_FSM:	return("Unhandled case");      case ERR_SYS:	return("System error");      case ERR_DONOTAGE:	return("non-DoNotAge routers present");      case ERR_NOADDR:	return("send fails, no valid source");      case IGMP_RCV_SHORT:	return("Received IGMP packet too short");      case IGMP_RCV_XSUM:	return("Received IGMP packet bad xsum");      case IGMP_RCV_NOIFC:	return("No matching interface for received IGMP");	// Informational      case LOG_RXNEWLSA:	return("New");      case LOG_LSAORIG:	return("Originating");      case LOG_RCVPKT:	return("Received");      case LOG_TXPKT:	return("Sent");      case LOG_SELFORIG:	return("Received self-orig");      case LOG_MINARRIVAL:	return("Failed MinArrival");      case LOG_RXMTUPD:	return("Rxmt");      case LOG_RXMTDD:	return("Rxmt DD");      case LOG_RXMTRQ:	return("Rxmt LsReq");      case LOG_LSAFLUSH:	return("Flushing");      case LOG_LSAFREE:	return("Freeing");      case LOG_LSAREFR:	return("Refreshing");      case LOG_LSAMAXAGE:	return("Reflooding MaxAge");      case LOG_LSADEFER:	return("Deferring");      case LOG_LSAWRAP:	return("Seqno wrap");      case LOG_JOIN:	return("Join");      case LOG_LEAVE:	return("Leave");      case IFC_STATECH:	return("Ifc FSM");      case NBR_STATECH:	return("Nbr FSM");      case LOG_DRCH:	return("DR Election");      case LOG_BADMTU:	return("MTU mismatch");      case LOG_IMPORT:	return("Importing");      case LOG_DNAREFR:	return("Refreshing DoNotAge");      case LOG_JOINED:	return("Group joined");      case LOG_LEFT:	return("Group left");      case LOG_QUERIER:	return("New IGMP Querier");      case MCACHE_REQ:	return("Multicast cache request");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆国产精品官网| 国产欧美日韩亚州综合| 麻豆91精品91久久久的内涵| 国产精品麻豆一区二区| 欧美精品日韩一区| 99re这里只有精品6| 久久av资源站| 亚洲第一二三四区| 奇米777欧美一区二区| 国产精品网曝门| 日韩一区二区免费在线电影| 在线视频综合导航| av成人动漫在线观看| 国产一区二区三区电影在线观看 | 欧美视频一二三区| caoporn国产一区二区| 国产麻豆91精品| 久久99久久久久| 日韩国产精品91| 亚洲一区二区三区四区在线免费观看 | 国产乱理伦片在线观看夜一区 | 99视频精品在线| 国产一区二区三区四区在线观看| 亚洲成a人在线观看| 亚洲丝袜美腿综合| 国产精品久久99| 国产农村妇女精品| 国产亚洲1区2区3区| 日韩精品一区二区三区swag| 777午夜精品免费视频| 精品1区2区3区| 日本精品一级二级| 色综合天天天天做夜夜夜夜做| 国产成人在线电影| 国产成人免费视频| 国产精品99久久久久久久vr | 91国偷自产一区二区三区观看| 国产白丝网站精品污在线入口| 奇米精品一区二区三区在线观看一| 性做久久久久久免费观看| 久久精品国产77777蜜臀| 午夜精品久久久| 日本在线观看不卡视频| 日韩不卡一区二区三区| 全部av―极品视觉盛宴亚洲| 日韩制服丝袜av| 日本欧美一区二区在线观看| 日本不卡视频一二三区| 国产综合色产在线精品| 国产精品亚洲一区二区三区在线 | 欧美一级高清大全免费观看| 欧美精品一卡二卡| 欧美一区中文字幕| 日韩欧美卡一卡二| 国产欧美日本一区二区三区| 欧美高清在线视频| 蜜臀99久久精品久久久久久软件| 免费日韩伦理电影| 日韩综合小视频| 蜜桃久久久久久| 激情五月播播久久久精品| 国产精品乡下勾搭老头1| 成人性生交大片| 91国偷自产一区二区使用方法| 欧美日韩在线三级| 精品欧美一区二区三区精品久久| 国产欧美中文在线| 一区二区三区四区在线| 奇米精品一区二区三区四区| 欧美揉bbbbb揉bbbbb| 91精品国产综合久久久久| 精品剧情在线观看| 亚洲图片欧美激情| 日韩av不卡一区二区| 国产伦精一区二区三区| 成人av小说网| 欧美久久久久中文字幕| 亚洲精品一区二区三区蜜桃下载| 国产精品国产精品国产专区不蜜 | 精品亚洲免费视频| 成人午夜精品一区二区三区| 色综合久久久久久久久| 欧美一区二区视频观看视频| 国产欧美日韩在线| 天天爽夜夜爽夜夜爽精品视频| 久久国产精品色| 色婷婷国产精品综合在线观看| 精品国产欧美一区二区| 亚洲精品久久久蜜桃| 国内国产精品久久| 欧美乱妇20p| 日本一区二区免费在线| 婷婷开心激情综合| 91在线小视频| 久久精品视频免费观看| 日本伊人色综合网| 91免费版在线| 久久综合色之久久综合| 亚洲va国产天堂va久久en| 国产精品一区二区不卡| 欧美日韩国产中文| 中文字幕国产一区| 久久精品国产99国产| 欧美午夜电影在线播放| 国产无人区一区二区三区| 性欧美大战久久久久久久久| 99久久精品免费看| 欧美激情一区不卡| 极品尤物av久久免费看| 欧美一区二区在线播放| 一区二区欧美在线观看| 国产成人精品免费在线| 2022国产精品视频| 免费在线观看精品| 91麻豆精品国产91久久久资源速度| 中文字幕一区二区日韩精品绯色| 国产自产2019最新不卡| 欧美一区二区三区喷汁尤物| 亚洲6080在线| 欧美亚洲图片小说| 亚洲激情中文1区| 91麻豆免费看片| 亚洲日本免费电影| 不卡欧美aaaaa| 六月丁香婷婷久久| 欧美日韩中文精品| 不卡免费追剧大全电视剧网站| 精品精品国产高清一毛片一天堂| 97精品超碰一区二区三区| 精品污污网站免费看| 一区二区三区中文字幕精品精品| 波多野结衣欧美| 国产精品网站在线播放| 成人免费黄色大片| 国产精品久久久久一区二区三区| 国产成人免费网站| 国产精品网站在线播放| av激情亚洲男人天堂| 成人欧美一区二区三区白人| 99国产欧美久久久精品| 亚洲免费看黄网站| 欧美日韩免费高清一区色橹橹 | 成人小视频在线| 久久综合久色欧美综合狠狠| 国产精品原创巨作av| 国产偷国产偷精品高清尤物| 国产精品亚洲一区二区三区在线 | 免费成人性网站| 精品国产免费人成电影在线观看四季| 美女精品一区二区| 精品国产1区二区| 国产不卡在线视频| 亚洲精品日韩一| 欧美日韩精品一区视频| 久久国产视频网| 国产日韩一级二级三级| 色综合久久久久久久久久久| 午夜电影一区二区| 精品久久一区二区三区| www.欧美色图| 午夜久久福利影院| 久久综合狠狠综合久久综合88 | 亚洲国产视频一区二区| 日韩欧美高清一区| 成人黄色网址在线观看| 亚洲超丰满肉感bbw| 日韩午夜激情av| 不卡在线视频中文字幕| 亚洲图片有声小说| 久久亚洲一区二区三区明星换脸| 99精品国产热久久91蜜凸| 日本免费在线视频不卡一不卡二| 久久综合色一综合色88| 一本色道久久综合亚洲91| 麻豆视频观看网址久久| 亚洲欧洲日韩在线| 日韩一区二区电影网| 成人性生交大片免费看中文网站| 亚洲午夜久久久久中文字幕久| 日韩美女主播在线视频一区二区三区| 国产精品一区2区| 亚欧色一区w666天堂| 欧美高清在线一区| 日韩一区国产二区欧美三区| 99久久综合精品| 久久69国产一区二区蜜臀| 亚洲手机成人高清视频| 日韩伦理电影网| 日韩免费观看高清完整版在线观看| 不卡电影一区二区三区| 美女脱光内衣内裤视频久久影院| 亚洲美女电影在线| 日本一区二区免费在线观看视频 | 欧美日本韩国一区二区三区视频| 国产伦精品一区二区三区免费迷| 亚洲免费观看高清| 国产丝袜在线精品| 欧美大片拔萝卜| 欧美精品亚洲一区二区在线播放| 99国产欧美另类久久久精品|