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 }