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

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

?? cmu-trace.cc

?? 此代碼是基于moav協議的qos改進代碼
?? CC
?? 第 1 頁 / 共 3 頁
字號:
/* -*-	Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- *//* * Copyright (c) 1997 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 Computer Systems *	Engineering Group at Lawrence Berkeley Laboratory. * 4. Neither the name of the University nor of the Laboratory 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. * * Ported from CMU/Monarch's code, appropriate copyright applies. * nov'98 -Padma. * * $Header: /cvsroot/nsnam/ns-2/trace/cmu-trace.cc,v 1.89 2006/03/21 22:31:32 liyuan Exp $ */#include <packet.h>#include <ip.h>#include <tcp.h>#include <sctp.h>#include <rtp.h>#include <arp.h>#include <dsr/hdr_sr.h>	// DSR#include <mac.h>#include <mac-802_11.h>#include <smac.h>#include <address.h>#include <tora/tora_packet.h> //TORA#include <imep/imep_spec.h>         // IMEP#include <aodv/aodv_packet.h> //AODV#include <cmu-trace.h>#include <mobilenode.h>#include <simulator.h>//<zheng: add for 802.15.4>#include "wpan/p802_15_4pkt.h"#include "wpan/p802_15_4trace.h"#include "wpan/p802_15_4nam.h"//</zheng: add for 802.15.4>#include "diffusion/diff_header.h" // DIFFUSION -- Chalermek//#define LOG_POSITION//extern char* pt_names[];static class CMUTraceClass : public TclClass {public:	CMUTraceClass() : TclClass("CMUTrace") { }	TclObject* create(int, const char*const* argv) {		return (new CMUTrace(argv[4], *argv[5]));	}} cmutrace_class;//<zheng: ns 2.27 removed the following part, but we need it to control the broadcast radius>double CMUTrace::bradius = 0.0;double CMUTrace::radius_scaling_factor_ = 0.0;double CMUTrace::duration_scaling_factor_ = 0.0;//</zheng>CMUTrace::CMUTrace(const char *s, char t) : Trace(t){	bzero(tracename, sizeof(tracename));	strncpy(tracename, s, MAX_ID_LEN);        if(strcmp(tracename, "RTR") == 0) {                tracetype = TR_ROUTER;        }	else if(strcmp(tracename, "TRP") == 0) {                tracetype = TR_ROUTER;        }        else if(strcmp(tracename, "MAC") == 0) {                tracetype = TR_MAC;        }        else if(strcmp(tracename, "IFQ") == 0) {                tracetype = TR_IFQ;        }        else if(strcmp(tracename, "AGT") == 0) {                tracetype = TR_AGENT;        }        else {                fprintf(stderr, "CMU Trace Initialized with invalid type\n");                exit(1);        }// change wrt Mike's code//	assert(type_ == DROP || type_ == SEND || type_ == RECV);	assert(type_ == DROP || type_ == SEND || type_ == RECV               || ((type_ == EOT) && (tracetype == TR_MAC)));	newtrace_ = 0;	for (int i=0 ; i < MAX_NODE ; i++) 		nodeColor[i] = 3 ;        node_ = 0;}voidCMUTrace::format_mac_common(Packet *p, const char *why, int offset){	struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_ip *ih = HDR_IP(p);	struct hdr_mac802_11 *mh;	struct hdr_smac *sh;	char mactype[SMALL_LEN];	strcpy(mactype, Simulator::instance().macType());	if (strcmp (mactype, "Mac/SMAC") == 0)		sh = HDR_SMAC(p);	else		mh = HDR_MAC802_11(p);		double x = 0.0, y = 0.0, z = 0.0;       	char op = (char) type_;	Node* thisnode = Node::get_node_by_address(src_);	double energy = -1;	if (thisnode) {	    if (thisnode->energy_model()) {		    energy = thisnode->energy_model()->energy();	    }	}	// hack the IP address to convert pkt format to hostid format	// for now until port ids are removed from IP address. -Padma.	int src = Address::instance().get_nodeaddr(ih->saddr());	if(tracetype == TR_ROUTER && type_ == SEND) {		if(src_ != src)			op = FWRD;	}	// use tagged format if appropriate	if (pt_->tagged()) {		int next_hop = -1 ;		Node* nextnode = Node::get_node_by_address(ch->next_hop_);        	if (nextnode) next_hop = nextnode->nodeid(); 		node_->getLoc(&x, &y, &z);		if (op == DROP) op = 'd';		if (op == SEND) op = '+';		if (op == FWRD) op = 'h';		sprintf(pt_->buffer() + offset,			"%c "TIME_FORMAT" -s %d -d %d -p %s -k %3s -i %d "			"-N:loc {%.2f %.2f %.2f} -N:en %f ",						op,				// event type			Scheduler::instance().clock(),	// time			src_,				// this node			next_hop,			// next hop			packet_info.name(ch->ptype()),	// packet type			tracename,			// trace level			ch->uid(),			// event id			x, y, z,			// location			energy);				// energy		offset = strlen(pt_->buffer());		if (strcmp (mactype, "Mac/SMAC") == 0) {			format_smac(p, offset);		} else {			format_mac(p, offset);		}		return;	}	// Use new ns trace format to replace the old cmu trace format)	if (newtrace_) {	    	    node_->getLoc(&x, &y, &z);	    // consistence	    if ( op == DROP ) { op = 'd';}	        // basic trace infomation + basic exenstion	    sprintf(pt_->buffer() + offset,		   "%c -t %.9f -Hs %d -Hd %d -Ni %d -Nx %.2f -Ny %.2f -Nz %.2f -Ne %f -Nl %3s -Nw %s ",		    op,                       // event type		    Scheduler::instance().clock(),  // time		    src_,                           // this node                    ch->next_hop_,                  // next hop		    src_,                           // this node		    x,                              // x coordinate		    y,                              // y coordinate		    z,                              // z coordinate		    energy,                         // energy, -1 = not existing		    tracename,                      // trace level                    why);                            // reason	    // mac layer extension	    offset = strlen(pt_->buffer());	    if (strcmp(mactype, "Mac/SMAC") == 0) {		    format_smac(p, offset);	    } else {		    format_mac(p, offset);	    }	    return;	}#ifdef LOG_POSITION        x = 0.0, y = 0.0, z = 0.0;        node_->getLoc(&x, &y, &z);#endif	sprintf(pt_->buffer() + offset,#ifdef LOG_POSITION		"%c %.9f %d (%6.2f %6.2f) %3s %4s %d %s %d ",#else		"%c %.9f _%d_ %3s %4s %d %s %d",#endif		op,		Scheduler::instance().clock(),                src_,                           // this node#ifdef LOG_POSITION                x,                y,#endif		tracename,		why,		                ch->uid(),                      // identifier for this event				((ch->ptype() == PT_MAC) ? (		  (mh->dh_fc.fc_subtype == MAC_Subtype_RTS) ? "RTS"  :		  (mh->dh_fc.fc_subtype == MAC_Subtype_CTS) ? "CTS"  :		  (mh->dh_fc.fc_subtype == MAC_Subtype_ACK) ? "ACK"  :		  //<zheng: add for 802.15.4>		  (mh->dh_fc.fc_subtype == MAC_Subtype_Beacon) ? "BCN"  :		//Beacon		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_AssoReq) ? "CM1"  :	//CMD: Association request		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_AssoRsp) ? "CM2"  :	//CMD: Association response		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_DAssNtf) ? "CM3"  :	//CMD: Disassociation notification		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_DataReq) ? "CM4"  :	//CMD: Data request		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_PIDCNtf) ? "CM5"  :	//CMD: PAN ID conflict notification		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_OrphNtf) ? "CM6"  :	//CMD: Orphan notification		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_BconReq) ? "CM7"  :	//CMD: Beacon request		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_CoorRea) ? "CM8"  :	//CMD: Coordinator realignment		  (mh->dh_fc.fc_subtype == MAC_Subtype_Command_GTSReq) ? "CM9"  :	//CMD: GTS request		  //</zheng: add for 802.15.4>		  "UNKN") :		 (ch->ptype() == PT_SMAC) ? (		  (sh->type == RTS_PKT) ? "RTS" :		  (sh->type == CTS_PKT) ? "CTS" :		  (sh->type == ACK_PKT) ? "ACK" :		  (sh->type == SYNC_PKT) ? "SYNC" :		  "UNKN") : 		 packet_info.name(ch->ptype())),		ch->size());		offset = strlen(pt_->buffer());	if (strncmp (mactype, "Mac/SMAC", 8) == 0) {		format_smac(p, offset);	} else {		format_mac(p, offset);        }		offset = strlen(pt_->buffer());	if (thisnode) {		if (thisnode->energy_model()) {			// log detailed energy consumption			// total energy and breakdown in idle, sleep, transmit and receive modes			sprintf(pt_->buffer() + offset,				"[energy %f ei %.3f es %.3f et %.3f er %.3f] ",				thisnode->energy_model()->energy(),				thisnode->energy_model()->ei(),				thisnode->energy_model()->es(),								thisnode->energy_model()->et(),				thisnode->energy_model()->er());						}        }}voidCMUTrace::format_mac(Packet *p, int offset){	struct hdr_mac802_11 *mh = HDR_MAC802_11(p);		if (pt_->tagged()) {		sprintf(pt_->buffer() + offset,			"-M:dur %x -M:s %x -M:d %x -M:t %x ",			mh->dh_duration,		// MAC: duration						// change wrt Mike's code			//ETHER_ADDR(mh->dh_da),		// MAC: source			//ETHER_ADDR(mh->dh_sa),		// MAC: destination			ETHER_ADDR(mh->dh_ra),          // MAC: source                       ETHER_ADDR(mh->dh_ta),          // MAC: destination			GET_ETHER_TYPE(mh->dh_body));	// MAC: type	} else if (newtrace_) {		sprintf(pt_->buffer() + offset, 			"-Ma %x -Md %x -Ms %x -Mt %x ",			mh->dh_duration,						// change wrt Mike's code			//ETHER_ADDR(mh->dh_da),			//ETHER_ADDR(mh->dh_sa),	   		ETHER_ADDR(mh->dh_ra),	                   ETHER_ADDR(mh->dh_ta),			GET_ETHER_TYPE(mh->dh_body));	} else {		sprintf(pt_->buffer() + offset,			" [%x %x %x %x] ",			//*((u_int16_t*) &mh->dh_fc),			mh->dh_duration,						// change wrt Mike's code			//ETHER_ADDR(mh->dh_da),			//ETHER_ADDR(mh->dh_sa),			ETHER_ADDR(mh->dh_ra),                        ETHER_ADDR(mh->dh_ta),			GET_ETHER_TYPE(mh->dh_body));	}}voidCMUTrace::format_smac(Packet *p, int offset){	struct hdr_smac *sh = HDR_SMAC(p);	sprintf(pt_->buffer() + offset,		" [%.2f %d %d] ",		sh->duration,		sh->dstAddr,		sh->srcAddr);}	voidCMUTrace::format_ip(Packet *p, int offset){        struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_ip *ih = HDR_IP(p);		// hack the IP address to convert pkt format to hostid format	// for now until port ids are removed from IP address. -Padma.	int src = Address::instance().get_nodeaddr(ih->saddr());	int dst = Address::instance().get_nodeaddr(ih->daddr());	if (pt_->tagged()) {		sprintf(pt_->buffer() + offset,			"-IP:s %d -IP:sp %d -IP:d %d -IP:dp %d -p %s -e %d "			"-c %d -i %d -IP:ttl %d ",			src,                           // packet src			ih->sport(),                   // src port			dst,                           // packet dest			ih->dport(),                   // dst port			packet_info.name(ch->ptype()), // packet type			ch->size(),                    // packet size			ih->flowid(),                  // flow id			ch->uid(),                     // unique id			ih->ttl_                       // ttl			);	} else if (newtrace_) {	    sprintf(pt_->buffer() + offset,		    "-Is %d.%d -Id %d.%d -It %s -Il %d -If %d -Ii %d -Iv %d ",		    src,                           // packet src		    ih->sport(),                   // src port		    dst,                           // packet dest		    ih->dport(),                   // dst port		    packet_info.name(ch->ptype()),  // packet type		    ch->size(),                     // packet size		    ih->flowid(),                   // flow id		    ch->uid(),                      // unique id		    ih->ttl_);                      // ttl	} else {	    sprintf(pt_->buffer() + offset, "------- [%d:%d %d:%d %d %d] ",		src, ih->sport(),		dst, ih->dport(),		ih->ttl_, (ch->next_hop_ < 0) ? 0 : ch->next_hop_);	}}// Note:  HDLC format (format_hdlc()) has moved to satellite tracingvoidCMUTrace::format_arp(Packet *p, int offset){	struct hdr_arp *ah = HDR_ARP(p);	if (pt_->tagged()) {	    sprintf(pt_->buffer() + offset,		    "-arp:op %s -arp:ms %d -arp:s %d -arp:md %d -arp:d %d ",		    ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		    ah->arp_sha,		    ah->arp_spa,		    ah->arp_tha,		    ah->arp_tpa);	} else if (newtrace_) {	    sprintf(pt_->buffer() + offset,		    "-P arp -Po %s -Pms %d -Ps %d -Pmd %d -Pd %d ",		    ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		    ah->arp_sha,		    ah->arp_spa,		    ah->arp_tha,		    ah->arp_tpa);	} else {	    sprintf(pt_->buffer() + offset,		"------- [%s %d/%d %d/%d]",		ah->arp_op == ARPOP_REQUEST ?  "REQUEST" : "REPLY",		ah->arp_sha,		ah->arp_spa,		ah->arp_tha,		ah->arp_tpa);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美专区在线| 欧美精品日韩一本| 欧美午夜视频网站| 国产精品美女久久久久高潮| 国产综合久久久久久久久久久久| 欧美精品乱人伦久久久久久| 欧美中文字幕一区| 国产精品久久久久久久久动漫| bt欧美亚洲午夜电影天堂| 亚洲欧美自拍偷拍| 91免费观看视频在线| 韩国精品主播一区二区在线观看 | 中文字幕一区二区三| 国产另类ts人妖一区二区| 精品久久久久99| 国产伦精一区二区三区| 精品国产伦一区二区三区观看方式 | 精品国产91九色蝌蚪| 美腿丝袜在线亚洲一区| 国产亲近乱来精品视频| a级精品国产片在线观看| 亚洲天堂免费在线观看视频| 色悠悠久久综合| 亚洲综合久久av| 日韩天堂在线观看| 国产91精品在线观看| 中文字幕精品三区| 欧美亚洲图片小说| 蜜臀va亚洲va欧美va天堂| 久久天天做天天爱综合色| 国产成人免费视频网站| 亚洲欧美日韩成人高清在线一区| 欧美视频一区二区三区四区 | 91在线观看美女| 亚洲成人三级小说| 欧美成人aa大片| 91视视频在线观看入口直接观看www| 亚洲一区二区视频在线| 日韩视频免费观看高清完整版在线观看| 美女网站在线免费欧美精品| 久久久久久免费网| 欧美精品一二三四| 91精品在线麻豆| 国产一区二区三区久久久| 国产精品人成在线观看免费 | 99热精品一区二区| 日本中文字幕不卡| 国产精品美女www爽爽爽| 欧美性大战xxxxx久久久| 麻豆传媒一区二区三区| 亚洲一线二线三线久久久| 日韩欧美久久久| 色嗨嗨av一区二区三区| 经典一区二区三区| 亚洲人成电影网站色mp4| 欧美电影在线免费观看| 97久久精品人人做人人爽50路| 日韩电影在线看| 国产精品久久久久久久久免费丝袜 | 国产成人免费视频网站| 亚洲国产中文字幕在线视频综合| 久久影院电视剧免费观看| 91免费国产在线| av网站免费线看精品| 国产精品污www在线观看| 精品捆绑美女sm三区| 91久久免费观看| 成人激情黄色小说| 国产精品色呦呦| 樱桃视频在线观看一区| 亚洲欧美日韩精品久久久久| 日韩久久精品一区| 欧美一区三区二区| 3atv一区二区三区| 3d动漫精品啪啪1区2区免费| 欧美日韩中文字幕一区二区| 欧美亚洲一区二区在线| 欧美日韩日日摸| 欧美美女直播网站| 制服丝袜成人动漫| 91精品国产一区二区三区蜜臀 | 国内成人精品2018免费看| 麻豆精品一区二区综合av| 麻豆成人综合网| 国产一本一道久久香蕉| 国产真实精品久久二三区| 国产美女主播视频一区| 成人黄色国产精品网站大全在线免费观看 | 亚洲成人综合在线| 亚洲国产成人tv| 日韩高清不卡一区二区| 久久国产视频网| 丰满白嫩尤物一区二区| 91美女片黄在线观看| 欧美亚洲国产一区二区三区va | 制服丝袜亚洲精品中文字幕| 欧美精品丝袜久久久中文字幕| 在线播放视频一区| 久久综合成人精品亚洲另类欧美| 国产视频一区不卡| 一区二区三区欧美视频| 日本不卡视频一二三区| 国产成人三级在线观看| 久久众筹精品私拍模特| 国产欧美日韩在线| 夜夜揉揉日日人人青青一国产精品| 亚洲午夜久久久久中文字幕久| 久久精品久久99精品久久| 风流少妇一区二区| 欧美区在线观看| 久久精品人人做人人综合| 亚洲色图在线看| 蜜臀av一级做a爰片久久| 风流少妇一区二区| 欧美区在线观看| 国产精品视频九色porn| 视频在线观看91| www.综合网.com| 91麻豆精品国产91久久久久久| 久久久99久久| 一区二区三区不卡视频| 国产在线播放一区二区三区| 色视频欧美一区二区三区| 欧美一级精品在线| 一区二区三区资源| 国产美女娇喘av呻吟久久| 欧美色综合网站| 欧美韩国日本不卡| 另类调教123区| 91日韩精品一区| 日韩一二三区不卡| 亚洲黄色尤物视频| 成人开心网精品视频| 日韩西西人体444www| 亚洲国产另类av| 成人精品小蝌蚪| 精品久久久久久亚洲综合网 | 制服丝袜亚洲色图| 亚洲日本在线视频观看| 国产精品18久久久久久久久| 欧美精品日日鲁夜夜添| 亚洲免费观看在线视频| 国产在线视频不卡二| 欧美一区二区在线免费观看| 亚洲综合激情另类小说区| 成人黄色a**站在线观看| 久久这里只有精品首页| 日本不卡一区二区| 欧美精品视频www在线观看| 尤物视频一区二区| 91色婷婷久久久久合中文| 国产欧美精品一区二区三区四区 | 欧美丰满一区二区免费视频| 亚洲欧美激情一区二区| 成人免费毛片app| 中文字幕久久午夜不卡| 国产精品一区二区无线| 精品国产乱子伦一区| 欧美日韩亚洲综合在线| 亚洲嫩草精品久久| 91麻豆自制传媒国产之光| 国产精品久久久久久一区二区三区| 狠狠色综合播放一区二区| 日韩免费电影一区| 久久精品国产秦先生| 欧美一区二区三区免费在线看| 亚洲午夜免费视频| 欧美日韩高清在线| 日本不卡在线视频| 日韩精品一区二区三区在线播放 | 国产精品资源网| 2020日本不卡一区二区视频| 黄一区二区三区| 亚洲国产精品99久久久久久久久| 福利电影一区二区| 国产精品二区一区二区aⅴ污介绍| 成人黄动漫网站免费app| 中文字幕亚洲不卡| 欧美伊人久久大香线蕉综合69| 夜夜精品浪潮av一区二区三区| 欧美日韩一区 二区 三区 久久精品| 亚洲国产成人91porn| 欧美一级片在线看| 精品一区二区三区免费播放| 久久精品男人的天堂| 成人a级免费电影| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩精品一区二区天天拍小说| 婷婷中文字幕综合| 精品国一区二区三区| 国产剧情一区在线| 亚洲精品水蜜桃| 日韩欧美综合在线| 丁香天五香天堂综合| 亚洲精品水蜜桃| 精品久久久久久久久久久院品网 | 亚洲最快最全在线视频| 91精品国产手机| 成人激情av网| 婷婷中文字幕综合|