X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FDefaultBundle%2FICMPv6TypePacket.cc;h=c7f18c01bbcf858d7aac0040fa2a2208fd505aaf;hb=f723d7852a8195072eee387ea9ca77156b58438b;hp=57d1dcadc10fa6c4f9d7ba6a777b94f5cb54238b;hpb=ccff925ac3c102822a38617d00aef1bcf5217706;p=senf.git diff --git a/senf/Packets/DefaultBundle/ICMPv6TypePacket.cc b/senf/Packets/DefaultBundle/ICMPv6TypePacket.cc index 57d1dca..c7f18c0 100644 --- a/senf/Packets/DefaultBundle/ICMPv6TypePacket.cc +++ b/senf/Packets/DefaultBundle/ICMPv6TypePacket.cc @@ -27,7 +27,8 @@ #include "ICMPv6Packet.hh" #include "ICMPv6TypePacket.hh" -#ifndef DOXYGEN +#define prefix_ +///////////////////////////////cc.p//////////////////////////////////////// namespace { SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 1, senf::ICMPv6ErrDestUnreachable ); @@ -40,4 +41,84 @@ namespace { SENF_PACKET_REGISTRY_REGISTER( senf::ICMPTypes, 143, senf::MLDv2ListenerReport ); } -#endif +prefix_ void senf::ICMPv6EchoRequestType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Echo Request:\n" + << senf::fieldName("Identifier") << unsigned(p->identifier()) << "\n" + << senf::fieldName("SequenceNumber") << unsigned(p->seqNr() ) << "\n"; +} + +prefix_ void senf::ICMPv6EchoReplyType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Echo Reply:\n" + << senf::fieldName("Identifier") << unsigned(p->identifier()) << "\n" + << senf::fieldName("SequenceNumber") << unsigned(p->seqNr()) << "\n"; +} + +prefix_ void senf::ICMPv6ErrDestUnreachableType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Error Destination Unreachable (no further fields available here)\n"; +} + +prefix_ void senf::ICMPv6ErrTooBigType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Error Packet Too Big:\n" + << senf::fieldName("MTU") << unsigned(p->mtu() ) << "\n"; +} + +prefix_ void senf::ICMPv6ErrTimeExceededType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Error Time Exceeded:\n" + << senf::fieldName("Unused(32Bit)") << unsigned(p->unused() ) << "\n"; +} + +prefix_ void senf::ICMPv6ErrParamProblemType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Error Parameter Problem:\n" + << senf::fieldName("Pointer") << unsigned(p->pointer() ) << "\n"; +} + +prefix_ void senf::MLDv2ListenerQueryType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Multicast Listener Query:\n" + << senf::fieldName("Max. ResponseCode") << unsigned(p->maxResponseCode()) << "\n" + << senf::fieldName("Reserved(16Bit)") << unsigned(p->reserved()) << "\n" + << senf::fieldName("Multicast Address") << p->mcAddress() << "\n" + << senf::fieldName("Reserver(4Bit)") << unsigned(p->resv()) << "\n" + << senf::fieldName("Suppress Router-Side Processing") << unsigned(p->sFlag()) << "\n" + << senf::fieldName("Querier's Robustness Variable") << unsigned(p->qrv()) << "\n" + << senf::fieldName("Querier's Query Interval Code") << unsigned(p->qqic()) << "\n" + << " Source Addresses:\n"; + senf::MLDv2ListenerQuery::Parser::srcAddresses_t::container c (p->srcAddresses()); + senf::MLDv2ListenerQuery::Parser::srcAddresses_t::container::iterator i (c.begin()); + for (unsigned int nr =1; i != c.end(); ++i, ++nr) + os << " " << nr << ".) " << *i << "\n"; + os << "\n"; +} + +prefix_ void senf::MLDv2ListenerReportType::dump(packet p, std::ostream & os) +{ + os << "ICMPv6 Multicast Listener Report Message:\n" + << senf::fieldName("Reserved") << unsigned(p->reserved() ) + <<"\n Multicast Address Records:\n"; + + senf::MLDv2ListenerReport::Parser::mcastAddrRecords_t::container cAddrR (p->mcastAddrRecords() ); + senf::MLDv2ListenerReport::Parser::mcastAddrRecords_t::container::iterator iAddrR (cAddrR.begin() ); + for (; iAddrR != cAddrR.end(); ++iAddrR) { + os << senf::fieldName(" Record Type") << unsigned(iAddrR->recordType()) << "\n" + << senf::fieldName(" Multicast Address") << iAddrR->mcAddress() << "\n" + << " Source Addresses\n:"; + senf::MLDv2AddressRecordParser::srcAddresses_t::container cSrcAddr (iAddrR->srcAddresses()); + senf::MLDv2AddressRecordParser::srcAddresses_t::container::iterator iSrcAddr (cSrcAddr.begin()); + for (;iSrcAddr != cSrcAddr.end();++iSrcAddr) + os << " " << *iSrcAddr << "\n"; + os << " Auxiliary Data:\n"; + senf::MLDv2AddressRecordParser::auxData_t::container cAuxD ( iAddrR->auxData() ); + senf::MLDv2AddressRecordParser::auxData_t::container::iterator iAuxD (cAuxD.begin() ); + for (;iAuxD != cAuxD.end(); ++iAuxD) + os << " " << *iAuxD << "\n"; + } +} + +///////////////////////////////cc.e//////////////////////////////////////// +#undef prefix_