X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Examples%2FSniffer%2FSniffer.cc;h=53cba175a7617ae38a2e0ee5f7363b9d9f0cbbbc;hb=99c145da3884f5c20a74337927ef2cbc073d80d7;hp=9cf18838dbb7a53b9c813ba0b509fb29c2c99f95;hpb=493cb51085dccf46823d6e56947bb30d7129bf1b;p=senf.git diff --git a/Examples/Sniffer/Sniffer.cc b/Examples/Sniffer/Sniffer.cc index 9cf1883..53cba17 100644 --- a/Examples/Sniffer/Sniffer.cc +++ b/Examples/Sniffer/Sniffer.cc @@ -1,9 +1,9 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -29,81 +29,32 @@ #include #include #include -#include "Socket/PacketSocketHandle.hh" -#include "Scheduler/Scheduler.hh" -#include "Utils/membind.hh" - -#include "Packets/EthernetPacket.hh" -#include "Packets/IpV4Packet.hh" -#include "Packets/UDPPacket.hh" +#include +#include +#include +#include +#include //#include "Sniffer.mpp" #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// - -namespace { - - static const unsigned BLOCK_SIZE = 16; - - template - void hexdump(Iterator i, Iterator const & i_end) - { - unsigned offset (0); - std::string ascii; - for (; i != i_end; ++i, ++offset) { - switch (offset % BLOCK_SIZE) { - case 0: - if (!ascii.empty()) { - std::cout << " " << ascii << "\n"; - ascii = ""; - } - std::cout << " " - << std::hex << std::setw(4) << std::setfill('0') - << offset << ' '; - break; - case BLOCK_SIZE/2: - std::cout << " "; - ascii += ' '; - break; - } - std::cout << ' ' << std::hex << std::setw(2) << std::setfill('0') - << unsigned(*i); - ascii += (*i >= ' ' && *i < 126) ? *i : '.'; - } - if (!ascii.empty()) { - for (; (offset % BLOCK_SIZE) != 0; ++offset) { - if ((offset % BLOCK_SIZE) == BLOCK_SIZE/2) - std::cout << " "; - std::cout << " "; - } - std::cout << " " << ascii << "\n"; - } - std::cout << std::dec; - } - - void use_em() - { - // Pull in symbols from the wanted packets ... - senf::Packet::create(0,0); - senf::Packet::create(0,0); - } -} +//-///////////////////////////////////////////////////////////////////////////////////////////////// int loop_main (int argc, char const * argv[]) { try { senf::PacketSocketHandle sock; - sock.bind(senf::LLSocketAddress("eth0")); + sock.bind(senf::LLSocketAddress(argv[2])); // sock.protocol().promisc("eth0",senf::PacketProtocol::Promiscuous); while (true) { // forever - std::string data (sock.read()); - senf::EthernetPacket::ptr packet ( - senf::Packet::create( - data.begin(), data.end())); - packet->dump(std::cout); - hexdump(packet->last()->begin(), - packet->last()->end()); + senf::EthernetPacket packet (senf::EthernetPacket::create( + senf::noinit)); + sock.read(packet.data(),0); + packet.dump(std::cout); + senf::hexdump( + packet.last().data().begin(), + packet.last().data().end(), + std::cout); std::cout << "\n\n"; } } @@ -116,30 +67,32 @@ int loop_main (int argc, char const * argv[]) class Sniffer { senf::PacketSocketHandle sock; + senf::scheduler::FdEvent event; public: - Sniffer(std::string const & interface) + Sniffer(std::string const & interface) + : event ("Sniffer", senf::membind(&Sniffer::dumpPacket, this), + sock, senf::scheduler::FdEvent::EV_READ) { - sock.bind(senf::LLSocketAddress(interface)); + sock.bind(senf::LLSocketAddress(interface)); } - void run() + void run() { - senf::Scheduler::instance().add( - sock, senf::membind(&Sniffer::dumpPacket, this)); - senf::Scheduler::instance().process(); + senf::scheduler::process(); } - + private: - void dumpPacket(senf::FileHandle /* ignored */, senf::Scheduler::EventId event) + void dumpPacket(int event) { - std::string data (sock.read()); - senf::EthernetPacket::ptr packet ( - senf::Packet::create( - data.begin(), data.end())); - packet->dump(std::cout); - hexdump(packet->last()->begin(), - packet->last()->end()); + senf::EthernetPacket packet ( + senf::EthernetPacket::create(senf::noinit)); + sock.read(packet.data(),0); + packet.dump(std::cout); + senf::hexdump( + packet.last().data().begin(), + packet.last().data().end(), + std::cout); std::cout << "\n\n"; } }; @@ -147,7 +100,7 @@ private: int scheduler_main(int argc, char const * argv[]) { try { - Sniffer sniffer ("eth0"); + Sniffer sniffer (argv[2]); sniffer.run(); } catch (std::exception const & ex) { @@ -158,17 +111,21 @@ int scheduler_main(int argc, char const * argv[]) int main(int argc, char const * argv[]) { - if (argc >= 2) + std::cout << "Registered packets:\n\n"; + senf::dumpPacketRegistries(std::cout); + + if (argc >= 3) { if (std::string(argv[1]) == "loop") return loop_main(argc,argv); else if (std::string(argv[1]) == "scheduler") return scheduler_main(argc,argv); + } - std::cerr << "Usage: sniffer { loop | scheduler }" << std::endl; + std::cerr << "Usage: sniffer { loop | scheduler } [interface]" << std::endl; return 1; } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_ //#include "Sniffer.mpp" @@ -179,4 +136,6 @@ int main(int argc, char const * argv[]) // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u" +// comment-column: 40 // End: