A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
ns3::Ipv6Address Class Reference

Describes an IPv6 address. More...

#include <ipv6-address.h>

Public Member Functions

 Ipv6Address ()
 Default constructor.
 
 Ipv6Address (char const *address)
 Constructs an Ipv6Address by parsing the input C-string. More...
 
 Ipv6Address (uint8_t address[16])
 Constructs an Ipv6Address by using the input 16 bytes. More...
 
 Ipv6Address (Ipv6Address const &addr)
 Copy constructor. More...
 
 Ipv6Address (Ipv6Address const *addr)
 Copy constructor. More...
 
 ~Ipv6Address ()
 Destructor.
 
Ipv6Address CombinePrefix (Ipv6Prefix const &prefix)
 Combine this address with a prefix. More...
 
void GetBytes (uint8_t buf[16]) const
 Get the bytes corresponding to the address. More...
 
Ipv4Address GetIpv4MappedAddress () const
 Return the Ipv4 address. More...
 
bool IsAllHostsMulticast () const
 If the IPv6 address is "all hosts multicast" (ff02::3/8). More...
 
bool IsAllNodesMulticast () const
 If the IPv6 address is "all nodes multicast" (ff02::1/8). More...
 
bool IsAllRoutersMulticast () const
 If the IPv6 address is "all routers multicast" (ff02::2/8). More...
 
bool IsAny () const
 If the IPv6 address is the "Any" address. More...
 
bool IsEqual (const Ipv6Address &other) const
 Comparison operation between two Ipv6Addresses. More...
 
bool IsIpv4MappedAddress ()
 If the address is an IPv4-mapped address. More...
 
bool IsLinkLocal () const
 If the IPv6 address is a link-local address (fe80::/64). More...
 
bool IsLinkLocalMulticast () const
 If the IPv6 address is link-local multicast (ff02::/16). More...
 
bool IsLocalhost () const
 If the IPv6 address is localhost (::1). More...
 
bool IsMulticast () const
 If the IPv6 address is multicast (ff00::/8). More...
 
bool IsSolicitedMulticast () const
 If the IPv6 address is a Solicited multicast address. More...
 
 operator Address () const
 Convert to Address object.
 
void Print (std::ostream &os) const
 Print this address to the given output stream. More...
 
void Serialize (uint8_t buf[16]) const
 Serialize this address to a 16-byte buffer. More...
 
void Set (char const *address)
 Sets an Ipv6Address by parsing the input C-string. More...
 
void Set (uint8_t address[16])
 Set an Ipv6Address by using the input 16 bytes. More...
 

Static Public Member Functions

static Ipv6Address ConvertFrom (const Address &address)
 Convert the Address object into an Ipv6Address ones. More...
 
static Ipv6Address Deserialize (const uint8_t buf[16])
 Deserialize this address. More...
 
static Ipv6Address GetAllHostsMulticast ()
 Get the "all hosts multicast" address. More...
 
static Ipv6Address GetAllNodesMulticast ()
 Get the "all nodes multicast" address. More...
 
static Ipv6Address GetAllRoutersMulticast ()
 Get the "all routers multicast" address. More...
 
static Ipv6Address GetAny ()
 Get the "any" (::) Ipv6Address. More...
 
static Ipv6Address GetLoopback ()
 Get the loopback address. More...
 
static Ipv6Address GetOnes ()
 Get the "all-1" IPv6 address (ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff). More...
 
static Ipv6Address GetZero ()
 Get the 0 (::) Ipv6Address. More...
 
static bool IsMatchingType (const Address &address)
 If the Address matches the type. More...
 
static Ipv6Address MakeAutoconfiguredAddress (Mac48Address addr, Ipv6Address prefix)
 Make the autoconfigured IPv6 address with Mac48Address. More...
 
static Ipv6Address MakeAutoconfiguredLinkLocalAddress (Mac48Address mac)
 Make the autoconfigured link-local IPv6 address with Mac48Address. More...
 
static Ipv6Address MakeIpv4MappedAddress (Ipv4Address addr)
 Make the Ipv4-mapped IPv6 address. More...
 
static Ipv6Address MakeSolicitedAddress (Ipv6Address addr)
 Make the solicited IPv6 address. More...
 

Private Member Functions

Address ConvertTo (void) const
 convert the IPv6Address object to an Address object. More...
 

Static Private Member Functions

static uint8_t GetType (void)
 Return the Type of address. More...
 

Private Attributes

uint8_t m_address [16]
 The address representation on 128 bits (16 bytes).
 

Friends

bool operator!= (Ipv6Address const &a, Ipv6Address const &b)
 
bool operator< (Ipv6Address const &a, Ipv6Address const &b)
 
bool operator== (Ipv6Address const &a, Ipv6Address const &b)
 

Detailed Description

Describes an IPv6 address.

See Also
Ipv6Prefix

Definition at line 44 of file ipv6-address.h.

Constructor & Destructor Documentation

ns3::Ipv6Address::Ipv6Address ( char const *  address)

Constructs an Ipv6Address by parsing the input C-string.

Parameters
addressthe C-string containing the IPv6 address (e.g. 2001:660:4701::1).

Definition at line 270 of file ipv6-address.cc.

References ns3::AsciiToIpv6Host(), m_address, and NS_LOG_FUNCTION.

ns3::Ipv6Address::Ipv6Address ( uint8_t  address[16])

Constructs an Ipv6Address by using the input 16 bytes.

Parameters
addressthe 128-bit address
Warning
the parameter must point on a 16 bytes integer array!

Definition at line 276 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

ns3::Ipv6Address::Ipv6Address ( Ipv6Address const &  addr)

Copy constructor.

Parameters
addrIpv6Address object

Definition at line 258 of file ipv6-address.cc.

References m_address.

ns3::Ipv6Address::Ipv6Address ( Ipv6Address const *  addr)

Copy constructor.

Parameters
addrIpv6Address pointer

Definition at line 264 of file ipv6-address.cc.

References m_address.

Member Function Documentation

Ipv6Address ns3::Ipv6Address::CombinePrefix ( Ipv6Prefix const &  prefix)

Combine this address with a prefix.

Parameters
prefixa IPv6 prefix
Returns
an IPv6 address that is this address combined (bitwise AND) with a prefix, yielding an IPv6 network address.

Definition at line 460 of file ipv6-address.cc.

References m_address, NS_LOG_FUNCTION, and Set().

Referenced by ns3::Ipv6L3Protocol::GetInterfaceForPrefix(), ns3::Ipv6L3Protocol::IpForward(), IsLinkLocal(), ns3::Ipv6StaticRouting::NotifyAddAddress(), ns3::Ipv6StaticRouting::NotifyRemoveAddress(), and ns3::Ipv6StaticRouting::SourceAddressSelection().

Ipv6Address ns3::Ipv6Address::ConvertFrom ( const Address address)
static
Address ns3::Ipv6Address::ConvertTo ( void  ) const
private

convert the IPv6Address object to an Address object.

Returns
the Address object corresponding to this object.

Definition at line 536 of file ipv6-address.cc.

References GetType(), NS_LOG_FUNCTION, and Serialize().

Ipv6Address ns3::Ipv6Address::Deserialize ( const uint8_t  buf[16])
static

Deserialize this address.

Parameters
bufbuffer to read address from
Returns
an Ipv6Address

Definition at line 308 of file ipv6-address.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::Inet6SocketAddress::ConvertFrom(), ConvertFrom(), and ns3::Ipv6PacketInfoTag::Deserialize().

Ipv6Address ns3::Ipv6Address::GetAllHostsMulticast ( )
static

Get the "all hosts multicast" address.

Returns
the "ff02::3/8" Ipv6Address representation

Definition at line 574 of file ipv6-address.cc.

References NS_LOG_FUNCTION_NOARGS.

Referenced by ns3::Ipv6StaticRouting::LookupStatic(), ns3::Ipv6ListRouting::RouteInput(), and ns3::Ipv6StaticRouting::SourceAddressSelection().

Ipv6Address ns3::Ipv6Address::GetAllRoutersMulticast ( )
static
void ns3::Ipv6Address::GetBytes ( uint8_t  buf[16]) const

Get the bytes corresponding to the address.

Parameters
bufbuffer to store the data
Returns
bytes of the address

Definition at line 609 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

Referenced by ns3::Ipv6Prefix::IsMatch(), MakeAutoconfiguredAddress(), ns3::Ipv6AddressHash::operator()(), and ns3::Icmpv6OptionPrefixInformation::Serialize().

Ipv4Address ns3::Ipv6Address::GetIpv4MappedAddress ( ) const

Return the Ipv4 address.

Returns
Ipv4 address

Definition at line 324 of file ipv6-address.cc.

References ns3::Ipv4Address::Deserialize(), NS_LOG_FUNCTION, and Serialize().

Referenced by ns3::TcpSocketBase::Connect().

Ipv6Address ns3::Ipv6Address::GetLoopback ( void  )
static

Get the loopback address.

Returns
the "::1/128" Ipv6Address representation.

Definition at line 581 of file ipv6-address.cc.

References NS_LOG_FUNCTION_NOARGS.

Referenced by ns3::Ipv6L3Protocol::SetupLoopback().

Ipv6Address ns3::Ipv6Address::GetOnes ( void  )
static

Get the "all-1" IPv6 address (ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff).

Returns
all-1 Ipv6Address representation

Definition at line 602 of file ipv6-address.cc.

References NS_LOG_FUNCTION_NOARGS.

uint8_t ns3::Ipv6Address::GetType ( void  )
staticprivate

Return the Type of address.

Returns
type of address

Definition at line 553 of file ipv6-address.cc.

References NS_LOG_FUNCTION_NOARGS, and ns3::Address::Register().

Referenced by ConvertFrom(), ConvertTo(), and IsMatchingType().

bool ns3::Ipv6Address::IsAllHostsMulticast ( ) const

If the IPv6 address is "all hosts multicast" (ff02::3/8).

Returns
true if "all hosts multicast", false otherwise

Definition at line 511 of file ipv6-address.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::Ipv6L3Protocol::Send().

bool ns3::Ipv6Address::IsAllNodesMulticast ( ) const

If the IPv6 address is "all nodes multicast" (ff02::1/8).

Returns
true if "all nodes multicast", false otherwise

Definition at line 497 of file ipv6-address.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::Ipv6L3Protocol::Send().

bool ns3::Ipv6Address::IsAllRoutersMulticast ( ) const

If the IPv6 address is "all routers multicast" (ff02::2/8).

Returns
true if "all routers multicast", false otherwise

Definition at line 504 of file ipv6-address.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::Ipv6L3Protocol::Send().

bool ns3::Ipv6Address::IsEqual ( const Ipv6Address other) const

Comparison operation between two Ipv6Addresses.

Parameters
otherthe IPv6 address to which to compare thisaddress
Returns
true if the addresses are equal, false otherwise

Definition at line 626 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

Referenced by ns3::Icmpv6L4Protocol::HandleRedirection(), ns3::Ipv6RoutingTableEntry::IsDefault(), ns3::Ipv6RoutingTableEntry::IsGateway(), ns3::Ipv6ListRouting::RouteInput(), and ns3::Ipv6StaticRouting::RouteInput().

bool ns3::Ipv6Address::IsIpv4MappedAddress ( )

If the address is an IPv4-mapped address.

Returns
true if address is an IPv4-mapped address, otherwise false.

Definition at line 448 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

Referenced by ns3::TcpSocketBase::Connect().

bool ns3::Ipv6Address::IsLinkLocal ( ) const

If the IPv6 address is a link-local address (fe80::/64).

Returns
true if the address is link-local, false otherwise

Definition at line 615 of file ipv6-address.cc.

References CombinePrefix(), IsMulticast(), and NS_LOG_FUNCTION.

Referenced by ns3::Ipv6L3ProtocolTestCase::DoRun(), ns3::Icmpv6L4Protocol::FunctionDadTimeout(), ns3::Icmpv6L4Protocol::HandleNS(), ns3::Icmpv6L4Protocol::Lookup(), ns3::Ipv6L3Protocol::Send(), and ns3::Ipv6InterfaceAddress::SetAddress().

bool ns3::Ipv6Address::IsLinkLocalMulticast ( ) const

If the IPv6 address is link-local multicast (ff02::/16).

Returns
true if link-local multicast, false otherwise

Definition at line 438 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

bool ns3::Ipv6Address::IsLocalhost ( ) const

If the IPv6 address is localhost (::1).

Returns
true if localhost, false otherwise

Definition at line 421 of file ipv6-address.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::Ipv6Interface::AddAddress(), and ns3::Ipv6InterfaceAddress::SetAddress().

bool ns3::Ipv6Address::IsMatchingType ( const Address address)
static

If the Address matches the type.

Parameters
addressother address
Returns
true if the type matches, false otherwise

Definition at line 525 of file ipv6-address.cc.

References ns3::Address::CheckCompatible(), GetType(), and NS_LOG_FUNCTION.

Referenced by ns3::UdpClient::StartApplication(), ns3::UdpTraceClient::StartApplication(), and ns3::UdpEchoClient::StartApplication().

bool ns3::Ipv6Address::IsSolicitedMulticast ( ) const

If the IPv6 address is a Solicited multicast address.

Returns
true if it is, false otherwise

Definition at line 480 of file ipv6-address.cc.

References NS_LOG_FUNCTION, and Serialize().

Referenced by ns3::Ipv6StaticRouting::LookupStatic(), and ns3::Ipv6L3Protocol::Send().

Ipv6Address ns3::Ipv6Address::MakeAutoconfiguredAddress ( Mac48Address  addr,
Ipv6Address  prefix 
)
static

Make the autoconfigured IPv6 address with Mac48Address.

Parameters
addrthe MAC address (48 bits).
prefixthe IPv6 prefix
Returns
autoconfigured IPv6 address

Definition at line 335 of file ipv6-address.cc.

References ns3::Mac48Address::CopyTo(), GetBytes(), NS_LOG_FUNCTION, and Set().

Referenced by ns3::Ipv6L3Protocol::AddAutoconfiguredAddress(), ns3::Ipv6AddressHelper::NewAddress(), and ns3::Ipv6L3Protocol::RemoveAutoconfiguredAddress().

Ipv6Address ns3::Ipv6Address::MakeAutoconfiguredLinkLocalAddress ( Mac48Address  mac)
static

Make the autoconfigured link-local IPv6 address with Mac48Address.

Parameters
macthe MAC address (48 bits).
Returns
autoconfigured link-local IPv6 address

Definition at line 355 of file ipv6-address.cc.

References ns3::Mac48Address::CopyTo(), NS_LOG_FUNCTION, and Set().

Referenced by ns3::Ipv6Interface::DoSetup().

Ipv6Address ns3::Ipv6Address::MakeIpv4MappedAddress ( Ipv4Address  addr)
static

Make the Ipv4-mapped IPv6 address.

Parameters
addrthe IPv4 address
Returns
Ipv4-mapped IPv6 address

Definition at line 315 of file ipv6-address.cc.

References NS_LOG_FUNCTION, and ns3::Ipv4Address::Serialize().

Referenced by ns3::UdpL4Protocol::Receive(), and ns3::TcpL4Protocol::Receive().

Ipv6Address ns3::Ipv6Address::MakeSolicitedAddress ( Ipv6Address  addr)
static

Make the solicited IPv6 address.

Parameters
addrthe IPv6 address
Returns
Solicited IPv6 address

Definition at line 377 of file ipv6-address.cc.

References NS_LOG_FUNCTION, Serialize(), and Set().

Referenced by ns3::Icmpv6L4Protocol::DoDAD(), ns3::NdiscCache::Entry::FunctionRetransmitTimeout(), and ns3::Icmpv6L4Protocol::Lookup().

void ns3::Ipv6Address::Print ( std::ostream &  os) const

Print this address to the given output stream.

The print format is in the typical "2001:660:4701::1".

Parameters
osthe output stream to which this Ipv6Address is printed

Definition at line 399 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.

void ns3::Ipv6Address::Serialize ( uint8_t  buf[16]) const
void ns3::Ipv6Address::Set ( char const *  address)

Sets an Ipv6Address by parsing the input C-string.

Parameters
addressthe C-string containing the IPv6 address (e.g. 2001:660:4701::1).

Definition at line 289 of file ipv6-address.cc.

References ns3::AsciiToIpv6Host(), m_address, and NS_LOG_FUNCTION.

Referenced by CombinePrefix(), ns3::Icmpv6NS::Deserialize(), ns3::Icmpv6NA::Deserialize(), ns3::Icmpv6Redirection::Deserialize(), MakeAutoconfiguredAddress(), MakeAutoconfiguredLinkLocalAddress(), and MakeSolicitedAddress().

void ns3::Ipv6Address::Set ( uint8_t  address[16])

Set an Ipv6Address by using the input 16 bytes.

Parameters
addressthe 128-bit address
Warning
the parameter must point on a 16 bytes integer array!

Definition at line 295 of file ipv6-address.cc.

References m_address, and NS_LOG_FUNCTION.


The documentation for this class was generated from the following files: