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

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

?? cmu-trace.cc

?? 用C++編寫的GPRS協議棧源代碼
?? CC
?? 第 1 頁 / 共 2 頁
字號:
/* -*-	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: /nfs/jade/vint/CVSROOT/ns-2/cmu-trace.cc,v 1.59 2000/09/01 03:04:05 haoboy Exp $ */#include <packet.h>#include <ip.h>#include <tcp.h>#include <rtp.h>#include <arp.h>#include <dsr/hdr_sr.h>	// DSR#include <mac.h>#include <mac-802_11.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 <rlc.h>  //sandy - introducing an rlc layer #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;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);        }	assert(type_ == DROP || type_ == SEND || type_ == RECV);	newtrace_ = 0;	for (int i=0 ; i < MAX_NODE ; i++) 		nodeColor[i] = 3 ;    node_ = 0;}voidCMUTrace::format_mac(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 = 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 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(wrk_ + 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(wrk_);	    sprintf(wrk_ + offset, 		    "-Ma %x -Md %x -Ms %x -Mt %x ",		    mh->dh_duration,		    ETHER_ADDR(mh->dh_da),		    ETHER_ADDR(mh->dh_sa),		    GET_ETHER_TYPE(mh->dh_body));		    	     return;	}#ifdef LOG_POSITION        double x = 0.0, y = 0.0, z = 0.0;        node_->getLoc(&x, &y, &z);#endif	sprintf(wrk_ + offset,#ifdef LOG_POSITION		"%c %.9f %d (%6.2f %6.2f) %3s %4s %d %s %d [%x %x %x %x] ",#else		"%c %.9f _%d_ %3s %4s %d %s %d [%x %x %x %x] ",#endif		op,		Scheduler::instance().clock(),                src_,                           // this node#ifdef LOG_POSITION                x,                y,#endif		tracename,		why,                ch->uid(),                      // identifier for this event		packet_info.name(ch->ptype()),		ch->size(),		//*((u_int16_t*) &mh->dh_fc),		mh->dh_duration,		ETHER_ADDR(mh->dh_da),		ETHER_ADDR(mh->dh_sa),		GET_ETHER_TYPE(mh->dh_body));	offset = strlen(wrk_);	if (thisnode) {		if (thisnode->energy_model()) {			sprintf(wrk_ + offset,				"[energy %f] ",				thisnode->energy_model()->energy());		}        }}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 (newtrace_) {	    sprintf(wrk_ + 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(wrk_ + offset, "------- [%d:%d %d:%d %d %d] ",		src, ih->sport(),		dst, ih->dport(),		ih->ttl_, (ch->next_hop_ < 0) ? 0 : ch->next_hop_);	}}voidCMUTrace::format_arp(Packet *p, int offset){	struct hdr_arp *ah = HDR_ARP(p);	if (newtrace_) {	    sprintf(wrk_ + 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(wrk_ + 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);	}}voidCMUTrace::format_dsr(Packet *p, int offset){	hdr_sr *srh = hdr_sr::access(p);	if (newtrace_) {	    sprintf(wrk_ + offset, 		"-P dsr -Ph %d -Pq %d -Ps %d -Pp %d -Pn %d -Pl %d -Pe %d->%d -Pw %d -Pm %d -Pc %d -Pb %d->%d ",		    srh->num_addrs(),                   // how many nodes travered		srh->route_request(),		srh->rtreq_seq(),		srh->route_reply(),		srh->rtreq_seq(),		srh->route_reply_len(),		// the dest of the src route		srh->reply_addrs()[0].addr,		srh->reply_addrs()[srh->route_reply_len()-1].addr,		srh->route_error(),		srh->num_route_errors(),		srh->down_links()[srh->num_route_errors() - 1].tell_addr,		srh->down_links()[srh->num_route_errors() - 1].from_addr,		srh->down_links()[srh->num_route_errors() - 1].to_addr);	   return;	}	sprintf(wrk_ + offset, 		"%d [%d %d] [%d %d %d %d->%d] [%d %d %d %d->%d]",		srh->num_addrs(),		srh->route_request(),		srh->rtreq_seq(),		srh->route_reply(),		srh->rtreq_seq(),		srh->route_reply_len(),		// the dest of the src route		srh->reply_addrs()[0].addr,		srh->reply_addrs()[srh->route_reply_len()-1].addr,		srh->route_error(),		srh->num_route_errors(),		srh->down_links()[srh->num_route_errors() - 1].tell_addr,		srh->down_links()[srh->num_route_errors() - 1].from_addr,		srh->down_links()[srh->num_route_errors() - 1].to_addr);}voidCMUTrace::format_msg(Packet *, int){}voidCMUTrace::format_tcp(Packet *p, int offset){	struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_tcp *th = HDR_TCP(p);		if( newtrace_ ) {	    sprintf(wrk_ + offset,		"-Pn tcp -Ps %d -Pa %d -Pf %d -Po %d ",		th->seqno_,		th->ackno_,		ch->num_forwards(),		ch->opt_num_forwards());	} else {	    sprintf(wrk_ + offset,		"[%d %d] %d %d",		th->seqno_,		th->ackno_,		ch->num_forwards(),		ch->opt_num_forwards());	}}voidCMUTrace::format_rtp(Packet *p, int offset){	struct hdr_cmn *ch = HDR_CMN(p);	struct hdr_rtp *rh = HDR_RTP(p);	struct hdr_ip *ih = HDR_IP(p);        Node* thisnode = Node::get_node_by_address(src_);	//hacking, needs to change later,         int dst = Address::instance().get_nodeaddr(ih->daddr());		if (dst == src_){		// I just received a cbr data packet		if (thisnode->energy_model() && 		    thisnode->energy_model()->powersavingflag()) {			thisnode->energy_model()->set_node_state(EnergyModel::INROUTE);		}        }	if (newtrace_) {		sprintf(wrk_ + offset,			"-Pn cbr -Pi %d -Pf %d -Po %d ",			rh->seqno_,			ch->num_forwards(),			ch->opt_num_forwards());	} else {		sprintf(wrk_ + offset,			"[%d] %d %d",			rh->seqno_,			ch->num_forwards(),			ch->opt_num_forwards());	}}voidCMUTrace::format_imep(Packet *p, int offset){        struct hdr_imep *im = HDR_IMEP(p);#define U_INT16_T(x)    *((u_int16_t*) &(x))	if (newtrace_) {	    sprintf(wrk_ + offset,                "-P imep -Pa %c -Ph %c -Po %c -Pl 0x%04x ] ",                (im->imep_block_flags & BLOCK_FLAG_ACK) ? 'A' : '-',                (im->imep_block_flags & BLOCK_FLAG_HELLO) ? 'H' : '-',                (im->imep_block_flags & BLOCK_FLAG_OBJECT) ? 'O' : '-',                U_INT16_T(im->imep_length));	} else {            sprintf(wrk_ + offset,                "[%c %c %c 0x%04x] ",                (im->imep_block_flags & BLOCK_FLAG_ACK) ? 'A' : '-',                (im->imep_block_flags & BLOCK_FLAG_HELLO) ? 'H' : '-',                (im->imep_block_flags & BLOCK_FLAG_OBJECT) ? 'O' : '-',                U_INT16_T(im->imep_length));	}#undef U_INT16_T}voidCMUTrace::format_tora(Packet *p, int offset){        struct hdr_tora *th = HDR_TORA(p);        struct hdr_tora_qry *qh = HDR_TORA_QRY(p);        struct hdr_tora_upd *uh = HDR_TORA_UPD(p);        struct hdr_tora_clr *ch = HDR_TORA_CLR(p);        switch(th->th_type) {        case TORATYPE_QRY:		if (newtrace_) {		    sprintf(wrk_ + offset,			"-P tora -Pt 0x%x -Pd %d -Pc QUERY ",                        qh->tq_type, qh->tq_dst);			                } else {                    sprintf(wrk_ + offset, "[0x%x %d] (QUERY)",                        qh->tq_type, qh->tq_dst);		}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线视频免费播放| 欧美影院一区二区| 日韩你懂的在线播放| 首页亚洲欧美制服丝腿| 91精品国产91久久久久久最新毛片| 午夜精品久久久久久不卡8050| 7777精品伊人久久久大香线蕉经典版下载| www.欧美色图| 一区精品在线播放| 色婷婷狠狠综合| 首页综合国产亚洲丝袜| 日韩视频在线一区二区| 国产精品一品二品| 亚洲欧美日韩国产手机在线 | 成人激情开心网| 亚洲女与黑人做爰| 欧美电影影音先锋| 国产精品夜夜嗨| 亚洲乱码国产乱码精品精可以看 | 欧美疯狂做受xxxx富婆| 免费av成人在线| 中文天堂在线一区| 欧美日韩一级黄| 国内精品免费在线观看| 亚洲人亚洲人成电影网站色| 欧美日韩精品一区二区天天拍小说| 久久99深爱久久99精品| 中文字幕一区二区三区视频| 欧美乱妇23p| 成人黄色a**站在线观看| 亚洲成人精品影院| 国产欧美一区二区三区鸳鸯浴| 91年精品国产| 韩国v欧美v亚洲v日本v| 夜夜嗨av一区二区三区| 久久青草国产手机看片福利盒子| 色欧美片视频在线观看在线视频| 另类调教123区| 一区二区三区四区高清精品免费观看 | 欧美色区777第一页| 亚洲成av人片在线观看| 国产亚洲欧美日韩日本| 欧美日韩极品在线观看一区| 成人影视亚洲图片在线| 麻豆成人免费电影| 亚洲一区二区三区视频在线| 国产日韩一级二级三级| 欧美一区二视频| 91久久一区二区| 国产91丝袜在线18| 久久99久久久久| 亚洲国产日韩精品| 成人欧美一区二区三区1314| 精品国产免费一区二区三区香蕉 | 国产精品自拍三区| 七七婷婷婷婷精品国产| 亚洲图片有声小说| 亚洲精选免费视频| ...xxx性欧美| 国产精品久久久久久久蜜臀| 精品国产乱码久久久久久1区2区| 欧美精品电影在线播放| 在线亚洲人成电影网站色www| 国产精品一区二区91| 黑人精品欧美一区二区蜜桃| 琪琪久久久久日韩精品| 亚洲18色成人| 亚洲高清免费在线| 午夜免费久久看| 亚洲va国产va欧美va观看| 艳妇臀荡乳欲伦亚洲一区| 亚洲精品国产第一综合99久久 | 蜜桃视频在线观看一区二区| 亚洲成人午夜电影| 亚洲成av人片| 日韩中文字幕麻豆| 日韩av成人高清| 久久99精品久久久久久国产越南| 美腿丝袜亚洲色图| 久久精品99国产精品| 狠狠色丁香婷婷综合久久片| 国产综合久久久久影院| 国产精品亚洲一区二区三区妖精 | 久久99久久久欧美国产| 久久99久久99| 国产高清不卡一区二区| 懂色中文一区二区在线播放| 成熟亚洲日本毛茸茸凸凹| 不卡一区中文字幕| 色屁屁一区二区| 欧美福利电影网| 精品免费日韩av| 中文字幕av一区 二区| 中文字幕在线视频一区| 亚洲男人都懂的| 日韩国产欧美在线播放| 欧美精三区欧美精三区| 欧美一级欧美一级在线播放| 2024国产精品| 国产精品久久久久久久久快鸭| 亚洲欧美区自拍先锋| 天天综合日日夜夜精品| 蜜桃精品在线观看| 成人国产精品免费观看动漫| 色综合激情久久| 日韩精品专区在线| 国产精品久久三| 亚洲第一在线综合网站| 国产在线视频精品一区| aaa欧美日韩| 欧美一区二区日韩| 国产精品午夜电影| 亚洲成人激情自拍| 国产九色sp调教91| 欧洲精品中文字幕| 久久婷婷国产综合精品青草| 中文字幕日韩av资源站| 日本免费新一区视频| 国产91精品免费| 欧美日韩不卡一区二区| 亚洲国产精品成人综合| 日本不卡一二三区黄网| www.亚洲色图.com| 日韩你懂的在线观看| 亚洲男人的天堂在线aⅴ视频| 久久精品99国产精品| 欧美性色aⅴ视频一区日韩精品| 欧美videos中文字幕| 一区二区在线观看免费| 国产乱码精品一区二区三区五月婷| 在线观看日韩一区| 国产精品色一区二区三区| 日本不卡不码高清免费观看| 色综合亚洲欧洲| 国产欧美一区二区精品久导航| 亚洲mv大片欧洲mv大片精品| 成人中文字幕电影| 91精品国产aⅴ一区二区| 亚洲男人天堂av网| 成人激情小说乱人伦| 久久只精品国产| 视频一区中文字幕国产| 91网站最新地址| 欧美韩日一区二区三区| 捆绑调教美女网站视频一区| 欧美日韩电影在线播放| 亚洲免费观看视频| 成人激情免费视频| 国产欧美日韩精品在线| 久久99久久久久| 日韩欧美亚洲国产精品字幕久久久| 一区二区激情小说| 91在线porny国产在线看| 欧美激情在线免费观看| 国产乱码精品一区二区三区忘忧草 | 韩国视频一区二区| 欧美日韩在线一区二区| 一区二区三区在线免费视频| 国产不卡视频在线观看| 亚洲精品在线免费观看视频| 美国欧美日韩国产在线播放| 欧美日韩高清影院| 亚洲成年人影院| 欧美日韩免费高清一区色橹橹| 一区二区免费视频| 欧美最新大片在线看| 亚洲一区二区三区免费视频| 一本色道亚洲精品aⅴ| 国产精品不卡视频| 色综合久久66| 亚洲第一精品在线| 91精品国产91热久久久做人人| 亚洲成人手机在线| 欧美一级片在线看| 极品销魂美女一区二区三区| 久久亚洲一区二区三区四区| 国产在线播放一区二区三区| 国产午夜精品久久| fc2成人免费人成在线观看播放| 国产精品国产三级国产普通话三级 | 亚洲午夜日本在线观看| 色综合亚洲欧洲| 亚洲国产精品一区二区www在线 | 欧美日韩国产一区二区三区地区| 亚洲va天堂va国产va久| 91精品国产综合久久久蜜臀粉嫩 | 韩国一区二区视频| 国产日韩欧美制服另类| 99精品久久99久久久久| 夜色激情一区二区| 日韩欧美高清一区| 成人国产免费视频| 亚洲午夜免费电影| 精品国产乱码久久久久久1区2区| 处破女av一区二区| 亚洲午夜视频在线观看| 久久亚洲一区二区三区明星换脸| 白白色亚洲国产精品| 舔着乳尖日韩一区| 日本一区二区不卡视频|