mll-tracer.cc

00001 /*
00002  * Copyright (c) 2008, Karlstad University
00003  * Erik Andersson, Emil Ljungdahl, Lars-Olof Moilanen
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 are met:
00008  *     * Redistributions of source code must retain the above copyright
00009  *       notice, this list of conditions and the following disclaimer.
00010  *     * 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  *     * Neither the name of the <organization> 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 COPYRIGHT HOLDERS ``AS IS'' AND ANY
00018  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00019  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00020  * DISCLAIMED. IN NO EVENT SHALL <copyright holder> BE LIABLE FOR ANY
00021  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00022  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00023  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00024  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00025  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00026  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00027  *
00028  * $Id: mll-tracer.cc 92 2008-03-25 19:35:54Z emil $
00029  */
00030 
00031 #include "mll-tracer.h"
00032 
00033 MLLTracer::MLLTracer() : Tracer(1) {}
00034 
00035 void MLLTracer::format(Packet *p, SAP *sap)
00036 {
00037         hdr_cmn* ch = HDR_CMN(p);
00038         packet_t  t = ch->ptype();
00039 
00040         std::stringstream descrstream;
00041 
00042         if(t == PT_ARP)
00043         {
00044                 hdr_ll  *lh = HDR_LL(p);
00045                 hdr_arp *ah = HDR_ARP(p);
00046                 hdr_mac *mh = HDR_MAC(p);
00047 
00048                 if(ah->arp_op  == ARPOP_REQUEST)
00049                 {
00050                         descrstream << " ARP Who has "
00051                                     << ah->arp_tpa
00052                                     << " tell "
00053                                     << ah->arp_sha;
00054                 }
00055                 else if(ah->arp_op == ARPOP_REPLY)
00056                 {
00057                         descrstream << " ARP "
00058                                     << ah->arp_spa
00059                                     << " is at "
00060                                     << ah->arp_sha;
00061                 }
00062         }
00063         else
00064           {
00065             hdr_mac *mh = HDR_MAC(p);
00066             descrstream << " " << mh->macSA()  << " -> " << mh->macDA() << " ";
00067           }
00068 
00069                 
00070 
00071         if(descrstream.str().length() > 0)
00072                 writeTrace(sap, "%s", descrstream.str().c_str());
00073 }
00074 
00075 extern "C" int Mlltracer_Init()
00076 {
00077         SAP::addTracer(new MLLTracer);
00078         return 0;
00079 }
00080 extern "C" int  Cygmlltracer_Init()
00081 {
00082         Mlltracer_Init();
00083 }

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