📄 loss-monitor.cc
字号:
/* -*- Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- *//* * Copyright (c) 1994-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. */#ifndef lintstatic const char rcsid[] = "@(#) $Header: /usr/src/mash/repository/vint/ns-2/loss-monitor.cc,v 1.16 1999/11/20 00:40:10 heideman Exp $ (LBL)";#endif#include "agent.h"#include "config.h"#include "tclcl.h"#include "packet.h"#include "ip.h"#include "rtp.h"extern int sq;class LossMonitor : public Agent { public: LossMonitor(); int command(int argc, const char*const* argv); void recv(Packet* pkt, Handler*);protected: int nlost_; int npkts_; int expected_; int bytes_; int seqno_; double last_packet_time_; int off_rtp_; //SHK int received; int misordered; FILE *cbrseqfile;};static class LossMonitorClass : public TclClass {public: LossMonitorClass() : TclClass("Agent/LossMonitor") {} TclObject* create(int, const char*const*) { return (new LossMonitor()); }} class_loss_mon;LossMonitor::LossMonitor() : Agent(PT_NTYPE){ bytes_ = 0; nlost_ = 0; npkts_ = 0; expected_ = -1; last_packet_time_ = 0.; seqno_ = 0; bind("nlost_", &nlost_); bind("npkts_", &npkts_); bind("bytes_", &bytes_); bind("lastPktTime_", &last_packet_time_); bind("expected_", &expected_); bind("off_rtp_", &off_rtp_); //SHK cbrseqfile = fopen("cbrseqfile", "w"); received = 0; misordered = 0;}void LossMonitor::recv(Packet* pkt, Handler*){ hdr_rtp* p = (hdr_rtp*)pkt->access(off_rtp_); seqno_ = p->seqno(); bytes_ += ((hdr_cmn*)pkt->access(off_cmn_))->size(); ++npkts_; //SHK fprintf(cbrseqfile, "%d\n", seqno_); received++; /* * Check for lost packets */ if (expected_ >= 0) { int loss = seqno_ - expected_; if (loss > 0) { nlost_ += loss; Tcl::instance().evalf("%s log-loss", name()); fprintf(cbrseqfile, "***** %d\n", nlost_); } else if(loss < 0) { fprintf(cbrseqfile, "D or M***** %d \n", loss); if(loss < -1) fprintf(cbrseqfile, "Misorded*******%d\n", ++misordered); } } last_packet_time_ = Scheduler::instance().clock(); expected_ = seqno_ + 1; Packet::free(pkt);}/* * $proc interval $interval * $proc size $size */int LossMonitor::command(int argc, const char*const* argv){ if (argc == 2) { if (strcmp(argv[1], "clear") == 0) { expected_ = -1; return (TCL_OK); } //SHK if (strcmp(argv[1], "print-lostpacket") == 0) { if(received > sq+1) printf("*sent: %d, received: %d DUP: %d\n", sq+1, received, (received - sq - 1)); else printf("*sent: %d, received: %d LOSS: %d\n", sq+1, received, (sq +1 - received)); return (TCL_OK); } } return (Agent::command(argc, argv));}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -