From: pug Date: Thu, 9 Apr 2009 08:52:01 +0000 (+0000) Subject: added Destination Options skeleton for IPv6 extension Header and added that to IpType... X-Git-Url: http://g0dil.de/git?a=commitdiff_plain;h=855741ade2ef52953e8c56c575494f91abb6bacf;p=senf.git added Destination Options skeleton for IPv6 extension Header and added that to IpTypes registry git-svn-id: https://svn.berlios.de/svnroot/repos/senf/trunk@1188 270642c3-0616-0410-b53a-bc976706d245 --- diff --git a/Packets/DefaultBundle/IPv6Extensions.cc b/Packets/DefaultBundle/IPv6Extensions.cc index 6ccd865..f673986 100644 --- a/Packets/DefaultBundle/IPv6Extensions.cc +++ b/Packets/DefaultBundle/IPv6Extensions.cc @@ -39,6 +39,8 @@ namespace { registerIPv6ExtensionType_Routing (43); senf::PacketRegistry::RegistrationProxy registerIPv6ExtensionType_HopByHop (0u); + senf::PacketRegistry::RegistrationProxy + registerIPv6ExtensionType_Destination (60u); } prefix_ void senf::IPv6ExtensionType_Fragment::dump(packet p, std::ostream & os) @@ -72,6 +74,13 @@ prefix_ void senf::IPv6ExtensionType_HopByHop::dump(packet p, std::ostream & os) << " header length : " << unsigned (p->headerLength()) << "\n"; } +prefix_ void senf::IPv6ExtensionType_Destination::dump(packet p, std::ostream & os) +{ + os << "Internet protocol Version 6 Destination Options extension:\n" + << " next header : " << unsigned (p->nextHeader()) << "\n" + << " header length : " << unsigned (p->headerLength()) << "\n"; +} + ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_ //#include "IPv6Extensions.mpp" diff --git a/Packets/DefaultBundle/IPv6Extensions.hh b/Packets/DefaultBundle/IPv6Extensions.hh index f768c1b..5e08e4a 100644 --- a/Packets/DefaultBundle/IPv6Extensions.hh +++ b/Packets/DefaultBundle/IPv6Extensions.hh @@ -281,6 +281,74 @@ The Type 0 Routing header has the following format: (RFC 2460) /** \brief IPv6 routing Hop-By-Hop packet typedef */ typedef ConcretePacket IPv6Extension_HopByHop; +// ===================================================================================================== + + /** \brief Parse in IPv6 Destination Options extension header + + Parser implementing the IPv6 Destination Options Header extension. The fields implemented are: + \image html IPv6Extensions_Destination.png + + \see IPv6ExtensionType_Destination \n + RFC 2460 + */ + + // Destination Options skeleton without TLV-Options + + struct IPv6PacketParserExtension_Destination : public PacketParserBase { +# include SENF_PARSER() + SENF_PARSER_FIELD ( nextHeader, UInt8Parser ); + SENF_PARSER_FIELD ( headerLength, UInt8Parser ); + + SENF_PARSER_FINALIZE ( IPv6PacketParserExtension_Destination ); + }; + + /** \brief IPv6 Destination Options extension + + \par Packet type (typedef): + \ref IPv6Extension_Destination + + \par Fields: + \ref IPv6PacketParserExtension_Destination + + \par Associated registries: + \ref IpTypes + + \par Finalize action: + Set \a nextHeader from type of next packet if found in \ref IpTypes + + \ingroup protocolbundle_default + */ + + struct IPv6ExtensionType_Destination + : public PacketTypeBase, + public PacketTypeMixin + { +#ifndef DOXYGEN + typedef PacketTypeMixin mixin; +#endif + /** \brief IPv6 Destination Options extension packet typedef */ + typedef ConcretePacket packet; + /** \brief typedef to the parser of IPv6 Destination Options extension packet */ + typedef IPv6PacketParserExtension_Destination parser; + + using mixin::nextPacketRange; + using mixin::nextPacketType; + using mixin::init; + using mixin::initSize; + + static key_t nextPacketKey(packet p) + { return p->nextHeader(); } + /** \brief Dump given IPv6Extension_Destination in readable form to given output stream */ + static void dump(packet p, std::ostream & os); + + static void finalize(packet p) { + p->nextHeader() << key(p.next(nothrow)); } + }; + + /** \brief IPv6 routing Destination Options packet typedef */ + typedef ConcretePacket IPv6Extension_Destination; + + } //namespace senf ///////////////////////////////hh.e//////////////////////////////////////// #endif diff --git a/Packets/DefaultBundle/IPv6Extensions.test.cc b/Packets/DefaultBundle/IPv6Extensions.test.cc index bace7a8..beb8c79 100644 --- a/Packets/DefaultBundle/IPv6Extensions.test.cc +++ b/Packets/DefaultBundle/IPv6Extensions.test.cc @@ -147,7 +147,11 @@ BOOST_AUTO_UNIT_TEST(ipv6Extensions) BOOST_CHECK_EQUAL( pICMPv6->code(), 0u); BOOST_CHECK_EQUAL( pICMPv6->checksum(), 0xa3d3); } - + //============================================================================================== + + /* + no unittests for Hop by Hop - and Destination - Options extension Header yet. No real implementation there, only IPv6 extension skeleton implemented. + */ ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_