loss-monitor.cc

Go to the documentation of this file.
00001 /* -*-  Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
00002 /*
00003  * Copyright (c) 1994-1997 Regents of the University of California.
00004  * All rights reserved.
00005  *
00006  * Redistribution and use in source and binary forms, with or without
00007  * modification, are permitted provided that the following conditions
00008  * are met:
00009  * 1. Redistributions of source code must retain the above copyright
00010  *    notice, this list of conditions and the following disclaimer.
00011  * 2. Redistributions in binary form must reproduce the above copyright
00012  *    notice, this list of conditions and the following disclaimer in the
00013  *    documentation and/or other materials provided with the distribution.
00014  * 3. All advertising materials mentioning features or use of this software
00015  *    must display the following acknowledgement:
00016  *  This product includes software developed by the Computer Systems
00017  *  Engineering Group at Lawrence Berkeley Laboratory.
00018  * 4. Neither the name of the University nor of the Laboratory may be used
00019  *    to endorse or promote products derived from this software without
00020  *    specific prior written permission.
00021  *
00022  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
00023  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00024  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00025  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
00026  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00027  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00028  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00029  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00031  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00032  * SUCH DAMAGE.
00033  */
00034 
00035 #ifndef lint
00036 static const char rcsid[] =
00037     "@(#) $Header: /nfs/jade/vint/CVSROOT/ns-2/tools/loss-monitor.cc,v 1.18 2000/09/01 03:04:06 haoboy Exp $ (LBL)";
00038 #endif
00039 
00040 #include <tclcl.h>
00041 
00042 #include "agent.h"
00043 #include "config.h"
00044 #include "packet.h"
00045 #include "ip.h"
00046 #include "rtp.h"
00047 #include "loss-monitor.h"
00048 
00049 static class LossMonitorClass : public TclClass {
00050 public:
00051     LossMonitorClass() : TclClass("Agent/LossMonitor") {}
00052     TclObject* create(int, const char*const*) {
00053         return (new LossMonitor());
00054     }
00055 } class_loss_mon;
00056 
00057 LossMonitor::LossMonitor() : Agent(PT_NTYPE)
00058 {
00059     bytes_ = 0;
00060     nlost_ = 0;
00061     npkts_ = 0;
00062     expected_ = -1;
00063     last_packet_time_ = 0.;
00064     seqno_ = 0;
00065     bind("nlost_", &nlost_);
00066     bind("npkts_", &npkts_);
00067     bind("bytes_", &bytes_);
00068     bind("lastPktTime_", &last_packet_time_);
00069     bind("expected_", &expected_);
00070 }
00071 
00072 void LossMonitor::recv(Packet* pkt, Handler*)
00073 {
00074     hdr_rtp* p = hdr_rtp::access(pkt);
00075     seqno_ = p->seqno();
00076     bytes_ += hdr_cmn::access(pkt)->size();
00077     ++npkts_;
00078     /*
00079      * Check for lost packets
00080      */
00081     if (expected_ >= 0) {
00082         int loss = seqno_ - expected_;
00083         if (loss > 0) {
00084             nlost_ += loss;
00085             Tcl::instance().evalf("%s log-loss", name());
00086         }
00087     }
00088     last_packet_time_ = Scheduler::instance().clock();
00089     expected_ = seqno_ + 1;
00090     Packet::free(pkt);
00091 }
00092 
00093 /*
00094  * $proc interval $interval
00095  * $proc size $size
00096  */
00097 int LossMonitor::command(int argc, const char*const* argv)
00098 {
00099     if (argc == 2) {
00100         if (strcmp(argv[1], "clear") == 0) {
00101             expected_ = -1;
00102             return (TCL_OK);
00103         }
00104     }
00105     return (Agent::command(argc, argv));
00106 }

Generated on Tue Mar 6 16:47:46 2007 for ns2 Network Simulator 2.29 by  doxygen 1.4.6