Main Page | Namespace List | Class Hierarchy | Alphabetical List | Compound List | File List | Compound Members | File Members

loss-monitor-plm.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/plm/loss-monitor-plm.cc,v 1.2 2000/09/01 03:04:11 haoboy Exp $ (LBL)";
00038 #endif
00039 
00040 #include <tclcl.h>
00041 #include "loss-monitor.h"
00042 
00043 class PLMLossMonitor : public LossMonitor {
00044 public:
00045         PLMLossMonitor();
00046         virtual void recv(Packet* pkt, Handler*);
00047 protected:
00048         // PLM only
00049         int flag_PP_;
00050         double packet_time_PP_;
00051         int fid_PP_;
00052 };
00053 
00054 static class PLMLossMonitorClass : public TclClass {
00055 public:
00056         PLMLossMonitorClass() : TclClass("Agent/LossMonitor/PLM") {}
00057         TclObject* create(int, const char*const*) {
00058                 return (new PLMLossMonitor());
00059         }
00060 } class_loss_mon_plm;
00061 
00062 PLMLossMonitor::PLMLossMonitor() : LossMonitor()
00063 {
00064         flag_PP_ = 0;
00065         bind("flag_PP_", &flag_PP_);
00066         bind("packet_time_PP_", &packet_time_PP_);
00067         bind("fid_PP_", &fid_PP_);
00068         bind("seqno_", &seqno_);
00069 }
00070 
00071 void PLMLossMonitor::recv(Packet* pkt, Handler*)
00072 {
00073         packet_time_PP_ = Scheduler::instance().clock();
00074         hdr_ip* iph = HDR_IP(pkt);
00075         fid_PP_ = iph->flowid();
00076 
00077         hdr_rtp* p = HDR_RTP(pkt);
00078         seqno_ = p->seqno();
00079         bytes_ += HDR_CMN(pkt)->size();
00080         flag_PP_ = p->flags();
00081         ++npkts_;
00082         /*
00083          * Check for lost packets
00084          */
00085         if (expected_ >= 0) {
00086                 int loss = seqno_ - expected_;
00087                 if (loss > 0) {
00088                         nlost_ += loss;
00089                         Tcl::instance().evalf("%s log-loss", name());
00090                 }
00091         }
00092         Tcl::instance().evalf("%s log-PP", name());
00093         last_packet_time_ = Scheduler::instance().clock();
00094         expected_ = seqno_ + 1;
00095         Packet::free(pkt);
00096 }

Generated on Tue Apr 20 12:14:22 2004 for NS2.26SourcesOriginal by doxygen 1.3.3