tcp-tracer.cc

00001 /*
00002  * Copyright (c) 2007 Regents of the SIGNET lab, University of Padova.
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University of Padova (SIGNET lab) nor the 
00014  *    names of its contributors may be used to endorse or promote products 
00015  *    derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
00018  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 
00019  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
00020  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
00021  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
00022  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
00023  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
00024  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
00025  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
00026  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
00027  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 
00030 #include"tcp-tracer.h"
00031 
00032 #include<packet.h>
00033 #include<tcp.h>
00034 
00035 TcpTracer::TcpTracer() : Tracer(4) {}
00036 
00037 
00038 void TcpTracer::format(Packet *p, SAP *sap)
00039 {
00040 
00041   hdr_cmn* ch = hdr_cmn::access(p);
00042 
00043   if ((ch->ptype() != PT_TCP)&&(ch->ptype() != PT_ACK))
00044     return;
00045 
00046   hdr_tcp* tcph = hdr_tcp::access(p);
00047   //  hdr_ip* iph = hdr_ip::access(p);
00048 
00049 
00050   writeTrace(sap, " id=%d %s sn=%d chts=%f ts=%f ts_echo=%f RTT=%f sz=%d",
00051              ch->uid_,
00052              ch->ptype() == PT_TCP ? "TCP" : "ACK",
00053              tcph->seqno_,
00054              ch->ts_,
00055              tcph->ts(),
00056              tcph->ts_echo(),
00057              NOW - tcph->ts_echo(),
00058              ch->size()
00059              );
00060 }
00061 
00062 
00063 extern "C" int Tcptracer_Init()
00064 {
00065   SAP::addTracer(new TcpTracer);  
00066   return 0;
00067 }
00068 extern "C" int  Cygtcptracer_Init()
00069 {
00070   Tcptracer_Init();
00071 }
00072 
00073 

Generated on Wed Nov 26 15:47:29 2008 for NS-MIRACLE library by  doxygen 1.5.2