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

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

?? trace.cc.cc

?? 在網絡的邊緣路由器中并不能完全接受所到的包
?? CC
?? 第 1 頁 / 共 2 頁
字號:
/* -*-	Mode:C++; c-basic-offset:8; tab-width:8 -*- */
/*
 * Copyright (c) 1990-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.
 *
 * @(#) $Header: /usr/src/mash/repository/vint/ns-2/trace.cc,v 1.58 1999/03/13 03:53:10 haoboy Exp $ (LBL)
 */

#include <stdio.h>
#include <stdlib.h>
#include "packet.h"
#include "ip.h"
#include "tcp.h"
#include "rtp.h"
#include "srm.h"
#include "flags.h"
#include "address.h"
#include "trace.h"
#include "Temporary_class.h"

const double Trace::PRECISION = 1.0e+6; 

class TraceClass : public TclClass {
public:
	TraceClass() : TclClass("Trace") { }
	TclObject* create(int argc, const char*const* argv) {
		if (argc >= 5)
			return (new Trace(*argv[4]));
		return 0;
	}
} trace_class;


Trace::Trace(int type)
	: Connector(), type_(type), src_(0), dst_(0), channel_(0), callback_(0)
#ifdef NAM_TRACE
	, namChan_(0)
#endif
{
	bind("src_", (int*)&src_);
	bind("dst_", (int*)&dst_);
	bind("callback_", &callback_);
	bind("show_tcphdr_", &show_tcphdr_);

#ifdef OFF_HDR
	bind("off_ip_", &off_ip_);
	bind("off_tcp_", &off_tcp_);
	bind("off_rtp_", &off_rtp_);
	bind("off_srm_", &off_srm_);
#endif

        //begin archana krishna
          bind("off_cmn_", &off_cmn_);
          bind("off_ip_", &off_ip_);
          bind("off_rtp_", &off_rtp_);
          bind("bandwidth_", &bandwidth_);
          bind("congest1_", &congest1_);
          bind("congest2_", &congest2_);

          if(measure == NULL)
          {
            measure = new Measure[NUMOFPACKS];
          }
        //end archana krishna
}

Trace::~Trace()
{
  //begin archanakrishna
    delete [] measure;
  //end archanakrishna

}

/*
 * $trace detach
 * $trace flush
 * $trace attach $fileID
 */
int Trace::command(int argc, const char*const* argv)
{
	Tcl& tcl = Tcl::instance();
	if (argc == 2) {
		if (strcmp(argv[1], "detach") == 0) {
			channel_ = 0;
#ifdef NAM_TRACE
			namChan_ = 0;
#endif
			return (TCL_OK);
		}
		if (strcmp(argv[1], "flush") == 0) {
#ifdef NAM_TRACE
			if (channel_ != 0) 
				Tcl_Flush(channel_);
			if (namChan_ != 0)
				Tcl_Flush(namChan_);
#else
			Tcl_Flush(channel_);
#endif
			return (TCL_OK);
		}
	} else if (argc == 3) {
		if (strcmp(argv[1], "annotate") == 0) {
			if (channel_ != 0)
				annotate(argv[2]);
			return (TCL_OK);
		}
		if (strcmp(argv[1], "attach") == 0) {
			int mode;
			const char* id = argv[2];
			channel_ = Tcl_GetChannel(tcl.interp(), (char*)id,
						  &mode);
			if (channel_ == 0) {
				tcl.resultf("trace: can't attach %s for writing", id);
				return (TCL_ERROR);
			}
			return (TCL_OK);
		}
#ifdef NAM_TRACE
		if (strcmp(argv[1], "namattach") == 0) {
			int mode;
			const char* id = argv[2];
			namChan_ = Tcl_GetChannel(tcl.interp(), (char*)id,
						  &mode);
			if (namChan_ == 0) {
				tcl.resultf("trace: can't attach %s for writing", id);
				return (TCL_ERROR);
			}
			return (TCL_OK);
		}
		if (strcmp(argv[1], "ntrace") == 0) {
			if (namChan_ != 0) 
				write_nam_trace(argv[2]);
			return (TCL_OK);
		}
#endif
	}
	return (Connector::command(argc, argv));
}

#ifdef NAM_TRACE

void Trace::write_nam_trace(const char *s)
{
	sprintf(nwrk_, "%s", s);
	namdump();
}
#endif

void Trace::annotate(const char* s)
{
	sprintf(wrk_, "v %g eval {set sim_annotation {%s}}", 
		round(Scheduler::instance().clock()), s);
	dump();
	sprintf(nwrk_, "v -t %.17g sim_annotation %g %s", 
		Scheduler::instance().clock(), 
		Scheduler::instance().clock(), s);
	namdump();
}

char* srm_names[] = {
        SRM_NAMES
};

// this function should retain some backward-compatibility, so that
// scripts don't break.
void Trace::format(int tt, int s, int d, Packet* p)
{
#ifdef OFF_HDR
	hdr_cmn *th = (hdr_cmn*)p->access(off_cmn_);
	hdr_ip *iph = (hdr_ip*)p->access(off_ip_);
	hdr_tcp *tcph = (hdr_tcp*)p->access(off_tcp_);
	hdr_rtp *rh = (hdr_rtp*)p->access(off_rtp_);
	hdr_srm *sh = (hdr_srm*)p->access(off_srm_); 
#else
	hdr_cmn *th = hdr_cmn::access(p);
	hdr_ip *iph = hdr_ip::access(p);
	hdr_tcp *tcph = hdr_tcp::access(p);
	hdr_rtp *rh = hdr_rtp::access(p);
	hdr_srm *sh = hdr_srm::access(p); 
#endif
	const char* sname = "null";

	packet_t t = th->ptype();
	const char* name = packet_info.name(t);

        /* SRM-specific */
	if (strcmp(name,"SRM") == 0 || strcmp(name,"cbr") == 0 || strcmp(name,"udp") == 0) {
            if ( sh->type() < 5 && sh->type() > 0 ) {
	        sname = srm_names[sh->type()];
	    }
	}

	if (name == 0)
		abort();

	int seqno;
	/* XXX */
	/* UDP's now have seqno's too */
	if (t == PT_RTP || t == PT_CBR || t == PT_UDP || t == PT_EXP ||
	    t == PT_PARETO)
		seqno = rh->seqno();
	else if (t == PT_TCP || t == PT_ACK || t == PT_HTTP || t == PT_FTP ||
	    t == PT_TELNET)
		seqno = tcph->seqno();
	else
		seqno = -1;
        /* 
         * When new flags are added, make sure to change NUMFLAGS
         * in trace.h
         */
        char flags[NUMFLAGS+1];
        for (int i = 0; i < NUMFLAGS; i++)
		flags[i] = '-';
        flags[NUMFLAGS] = 0;

#ifdef OFF_HDR
	hdr_flags* hf = (hdr_flags*)p->access(off_flags_);
#else
	hdr_flags* hf = hdr_flags::access(p);
#endif
	flags[0] = hf->ecn_ ? 'C' : '-';          // Ecn Echo
	flags[1] = hf->pri_ ? 'P' : '-'; 
	flags[2] = '-';
	flags[3] = hf->cong_action_ ? 'A' : '-';   // Congestion Action
	flags[4] = hf->ecn_to_echo_ ? 'E' : '-';   // Congestion Experienced
	flags[5] = hf->fs_ ? 'F' : '-';
	flags[6] = hf->ecn_capable_ ? 'N' : '-';
	
#ifdef notdef
	flags[1] = (iph->flags() & PF_PRI) ? 'P' : '-';
	flags[2] = (iph->flags() & PF_USR1) ? '1' : '-';
	flags[3] = (iph->flags() & PF_USR2) ? '2' : '-';
	flags[5] = 0;
#endif
	char *src_nodeaddr = Address::instance().print_nodeaddr(iph->src());
	char *src_portaddr = Address::instance().print_portaddr(iph->src());
	char *dst_nodeaddr = Address::instance().print_nodeaddr(iph->dst());
	char *dst_portaddr = Address::instance().print_portaddr(iph->dst());

	if (!show_tcphdr_) {
                sprintf(wrk_, "%c %12.7f %d %d %s %d %s %d %s%s %s%s %d %d",
			tt,
			round(Scheduler::instance().clock()),
			s,
			d,
			name,
			th->size(),
			flags,
			iph->flowid() /* was p->class_ */,
			src_nodeaddr,
			src_portaddr,
			dst_nodeaddr,
			dst_portaddr,
			seqno,
			th->uid() /* was p->uid_ */);
	} else {
		sprintf(wrk_, 
			"%c %g %d %d %s %d %s %d %s%s %s%s %d %d %d 0x%x %d %d",
			tt,
			round(Scheduler::instance().clock()),
			s,
			d,
			name,
			th->size(),
			flags,
			iph->flowid(), /* was p->class_ */
			src_nodeaddr,
			src_portaddr,
			dst_nodeaddr,
			dst_portaddr,
			seqno,
			th->uid(), /* was p->uid_ */
			tcph->ackno(),

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级片在线| 欧美亚洲一区二区在线观看| av一区二区不卡| 欧美一区二区视频在线观看2022| 欧美mv和日韩mv的网站| 亚洲丝袜精品丝袜在线| 日韩av不卡一区二区| 91片黄在线观看| 精品理论电影在线| 日日夜夜精品视频天天综合网| 成人福利视频网站| 久久久精品影视| 日韩经典中文字幕一区| 91久久免费观看| 国产精品视频yy9299一区| 青青青伊人色综合久久| 欧美日韩视频不卡| 亚洲免费看黄网站| 成人精品电影在线观看| 欧美精品一区二区三区四区| 日韩av午夜在线观看| 欧美性极品少妇| 亚洲美女视频一区| www.日韩大片| 国产网站一区二区三区| 久久97超碰国产精品超碰| 欧美一区二区三区在| 亚洲午夜影视影院在线观看| 色综合久久久久综合| 国产精品传媒入口麻豆| 国产精品夜夜嗨| 99久久精品99国产精品| 开心九九激情九九欧美日韩精美视频电影| 风间由美一区二区三区在线观看| 欧美日韩一区三区四区| 国产精品色眯眯| 成人午夜电影久久影院| 欧美xxxxx牲另类人与| 久久99精品网久久| 日韩欧美一级特黄在线播放| 日韩国产一二三区| 欧美日韩mp4| 日韩中文字幕区一区有砖一区| 日本高清无吗v一区| 一区二区三区精品| 91丨porny丨最新| 精品国偷自产国产一区| 国产精品自拍一区| 久久久另类综合| 国产99久久久久久免费看农村| 日韩一区二区三区在线视频| 九一九一国产精品| 欧美视频第二页| 国产精品久久久久影院亚瑟| 五月天激情综合| 日韩视频免费观看高清完整版在线观看 | 色综合夜色一区| 国产精品久久久久久久久免费丝袜 | 国产精品五月天| 成人理论电影网| 一区二区三区美女视频| 欧美日韩1区2区| 激情欧美一区二区三区在线观看| 精品国产一二三区| www.亚洲免费av| 亚洲午夜免费电影| 精品国产乱码久久久久久夜甘婷婷| 国产精品久久久久久久岛一牛影视 | 欧美国产一区二区在线观看| 国产成人精品一区二| 2023国产精华国产精品| 风流少妇一区二区| 亚洲欧美电影一区二区| 欧美日韩中文字幕一区| 美女一区二区在线观看| 精品国产精品一区二区夜夜嗨| 91麻豆福利精品推荐| 亚洲精品免费看| 日韩美女在线视频| 成人理论电影网| 日本欧美一区二区三区乱码 | 97精品国产露脸对白| 亚洲激情在线激情| 久久久综合精品| 99视频一区二区| 国产又黄又大久久| 亚洲精品写真福利| 精品女同一区二区| 91在线观看高清| 国产成人小视频| 亚洲va国产天堂va久久en| 国产精品国产精品国产专区不蜜| 欧美日韩不卡一区| 在线日韩国产精品| 国产精品一区二区不卡| 美女精品一区二区| 亚洲视频免费观看| 日本精品免费观看高清观看| 国产乱子轮精品视频| 亚洲电影欧美电影有声小说| 国产精品不卡一区| 日韩午夜精品电影| 制服丝袜亚洲精品中文字幕| eeuss影院一区二区三区| 国产精品一区二区在线播放| 亚洲成人午夜影院| 亚洲成人免费观看| 国产精品不卡在线| 综合久久久久综合| 久久夜色精品国产欧美乱极品| 精品久久久久久久人人人人传媒| 欧美三级日韩在线| 欧美亚洲高清一区二区三区不卡| 国产91精品精华液一区二区三区| 久久91精品久久久久久秒播| 日韩电影在线免费| 美女一区二区久久| 日韩成人av影视| 蜜桃91丨九色丨蝌蚪91桃色| 午夜私人影院久久久久| 日本视频一区二区三区| 亚洲一区在线电影| 午夜欧美一区二区三区在线播放| 亚洲欧洲色图综合| 亚洲一区二区三区影院| 一区二区三区在线观看网站| 亚洲免费观看在线观看| 中文字幕一区二区三区在线观看| 日本一区二区三区国色天香| 国产日韩精品视频一区| 国产精品久久久久久久久动漫| 中文一区二区完整视频在线观看| 中文字幕乱码久久午夜不卡| 国产午夜亚洲精品羞羞网站| 中文字幕亚洲在| 亚洲欧洲成人自拍| 亚洲成人av在线电影| 亚洲不卡av一区二区三区| 日韩电影在线一区二区三区| 日韩黄色免费网站| 国产一区二区调教| 国产69精品久久99不卡| 91碰在线视频| 在线精品视频免费播放| 欧美日韩大陆在线| 日韩欧美另类在线| 国产欧美精品一区二区色综合朱莉| 欧美国产一区在线| 亚洲男同性视频| 狠狠色综合色综合网络| 国产999精品久久久久久| 欧美性猛片aaaaaaa做受| 91麻豆精品国产无毒不卡在线观看| 日韩女优电影在线观看| 欧美韩国日本一区| 石原莉奈一区二区三区在线观看| 蜜桃传媒麻豆第一区在线观看| 不卡的电视剧免费网站有什么| 色婷婷久久99综合精品jk白丝| 日韩你懂的在线播放| 国产欧美精品一区二区色综合 | 日本一不卡视频| 激情久久五月天| 在线日韩一区二区| 精品久久久久久久久久久久包黑料| 亚洲女同ⅹxx女同tv| 青青草原综合久久大伊人精品| av男人天堂一区| 欧美精品色一区二区三区| 欧美激情资源网| 亚洲欧美乱综合| 国产成人在线视频免费播放| 懂色一区二区三区免费观看| 欧美日韩国产经典色站一区二区三区 | 国产精品毛片久久久久久 | 日韩一区二区三| 国产精品美女久久久久久久网站| 五月天婷婷综合| 不卡的电影网站| 国产欧美一区二区三区在线看蜜臀| 亚洲最色的网站| 91啪在线观看| 久久久国产精华| 激情小说欧美图片| 在线观看日韩一区| 亚洲三级小视频| 精品一区二区三区在线观看国产 | 欧美日韩国产精品成人| 一区二区三区精品在线观看| 精品一区二区影视| 精品国产一区二区三区忘忧草 | 亚洲伦在线观看| 老司机午夜精品99久久| 欧美高清www午色夜在线视频| 中日韩免费视频中文字幕| 国产一区二区三区四区在线观看| 欧美在线免费观看亚洲| 一区二区三区小说| 99久久伊人精品| 亚洲欧美另类在线|