X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FDefaultBundle%2FICMPv6Packet.cc;h=be0daf5172e3bc5f343261cbea17e929a39e1d2d;hb=6c0332484574ed1cb571bbc0dc9f0a37d6653282;hp=42a48bd7377d8c9fbce5498e4f250942b4da463b;hpb=26610f603ebdd465307b9621f532c1fe19fd5571;p=senf.git diff --git a/senf/Packets/DefaultBundle/ICMPv6Packet.cc b/senf/Packets/DefaultBundle/ICMPv6Packet.cc index 42a48bd..be0daf5 100644 --- a/senf/Packets/DefaultBundle/ICMPv6Packet.cc +++ b/senf/Packets/DefaultBundle/ICMPv6Packet.cc @@ -30,40 +30,46 @@ #include #include #include +#include #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// -namespace { - senf::PacketRegistry::RegistrationProxy - registerICMPv6Packet (58); -} +SENF_PACKET_REGISTRY_REGISTER( senf::IpTypes, 58, senf::ICMPv6Packet); prefix_ boost::uint16_t senf::ICMPv6PacketParser::calcChecksum() const { - - senf::IpChecksum summer; senf::IPv6Packet ipv6 (packet().rfind(senf::nothrow)); - - if (! ipv6) - return 0u; + if (! ipv6) return 0u; - summer.feed( ipv6->source().i(), - ipv6->source().i() + senf::IPv6Packet::Parser::source_t::fixed_bytes ); - // The destination used here must be the *final* destination ... - summer.feed( ipv6->destination().i(), ipv6->destination().i() + senf::IPv6PacketParser::destination_t::fixed_bytes ); + senf::IpChecksum summer; - // This is a simplification. The value is really 32bit to support UDP Jumbograms - // (RFC2147). However, skipping an even number of 0 bytes does not change the checksum - summer.feed( i() + ipv6->length(), i() + ipv6->length() + 2 ); - // --> http://www.iana.org/assignments/protocol-numbers - // need to insert the correct protocol number here, NOT static 17!! + //////////////////////////////////////// + // IPv6 pseudo header + summer.feed( ipv6->source().i(), + ipv6->source().i() + senf::IPv6Packet::Parser::source_t::fixed_bytes ); + // need support for HopByHop routing header -> the destination used here must be the *final* + // destination ... + summer.feed( ipv6->destination().i(), + ipv6->destination().i() + senf::IPv6PacketParser::destination_t::fixed_bytes ); + // packet length + boost::uint32_t size (data().size()); + summer.feed((size>>24)&0xff); + summer.feed((size>>16)&0xff); + summer.feed((size>> 8)&0xff); + summer.feed((size )&0xff); + // protocol number + // summer.feed( 0u ); + // summer.feed( 0u ); summer.feed( 0u ); summer.feed( 58u ); - // since header are 16 / even 32bit aligned we don't have to care for padding. since IpChecksum - // cares for padding at the final summing we don't have to care is the payload is 16nbit-aligned, too. + + //////////////////////////////////////// + // ICMP Packet summer.feed( i(), i()+checksum_offset ); + // checksum + // summer.feed(0); summer.feed(0); summer.feed( i()+checksum_offset+2, data().end() ); boost::uint16_t rv (summer.sum()); @@ -74,9 +80,10 @@ prefix_ void senf::ICMPv6PacketType::dump(packet p, std::ostream &os) { boost::io::ios_all_saver ias(os); os << "ICMPv6 protocol:\n" - << " type : " << p->type() <<"\n" - << " code : " << p->code() <<"\n" - << " checksum : " << p->checksum() << "\n"; + << senf::fieldName("type") << unsigned(p->type()) <<"\n" + << senf::fieldName("code") << unsigned(p->code()) <<"\n" + << senf::fieldName("checksum") + << "0x" << std::hex << std::setw(4) << unsigned(p->checksum()) << "\n"; } ///////////////////////////////cc.e////////////////////////////////////////