A UDP server, receives UDP packets from a remote host. More...
#include "udp-server.h"
Public Member Functions | |
UdpServer () | |
~UdpServer () override | |
uint32_t | GetLost () const |
Returns the number of lost packets. | |
uint16_t | GetPacketWindowSize () const |
Returns the size of the window used for checking loss. | |
uint64_t | GetReceived () const |
Returns the number of received packets. | |
void | SetPacketWindowSize (uint16_t size) |
Set the size of the window used for checking loss. | |
Public Member Functions inherited from ns3::SinkApplication | |
SinkApplication (uint16_t defaultPort=0) | |
Constructor. | |
~SinkApplication () override | |
Public Member Functions inherited from ns3::Application | |
Application () | |
~Application () override | |
virtual int64_t | AssignStreams (int64_t stream) |
Assign a fixed random variable stream number to the random variables used by this Application object. | |
Ptr< Node > | GetNode () const |
void | SetNode (Ptr< Node > node) |
void | SetStartTime (Time start) |
Specify application start time. | |
void | SetStopTime (Time stop) |
Specify application stop time. | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. | |
~Object () override | |
Destructor. | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. | |
void | Dispose () |
Dispose of this Object. | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. | |
bool | IsInitialized () const |
Check if the object has been initialized. | |
void | UnidirectionalAggregateObject (Ptr< Object > other) |
Aggregate an Object to another Object. | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. | |
SimpleRefCount (const SimpleRefCount &o) | |
Copy constructor. | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. | |
SimpleRefCount & | operator= (const SimpleRefCount &o) |
Assignment operator. | |
void | Ref () const |
Increment the reference count. | |
void | Unref () const |
Decrement the reference count. | |
Public Member Functions inherited from ns3::ObjectBase | |
virtual | ~ObjectBase () |
Virtual destructor. | |
void | GetAttribute (std::string name, AttributeValue &value, bool permissive=false) const |
Get the value of an attribute, raising fatal errors if unsuccessful. | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising errors. | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. | |
Static Public Member Functions | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Member Functions inherited from ns3::SinkApplication | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Member Functions inherited from ns3::Application | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId () |
Register this type. | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Attributes | |
static constexpr uint16_t | DEFAULT_PORT {100} |
default port | |
Static Public Attributes inherited from ns3::SinkApplication | |
static constexpr uint32_t | INVALID_PORT {std::numeric_limits<uint32_t>::max()} |
invalid port | |
Private Member Functions | |
void | HandleRead (Ptr< Socket > socket) |
Handle a packet reception. | |
void | StartApplication () override |
Application specific startup code. | |
void | StopApplication () override |
Application specific shutdown code. | |
Private Attributes | |
PacketLossCounter | m_lossCounter |
Lost packet counter. | |
uint64_t | m_received |
Number of received packets. | |
TracedCallback< Ptr< const Packet > > | m_rxTrace |
Callbacks for tracing the packet Rx events. | |
TracedCallback< Ptr< const Packet >, const Address &, const Address & > | m_rxTraceWithAddresses |
Callbacks for tracing the packet Rx events, includes source and destination addresses. | |
Ptr< Socket > | m_socket |
Socket. | |
Ptr< Socket > | m_socket6 |
IPv6 Socket (used if only port is specified) | |
Additional Inherited Members | |
Public Types inherited from ns3::Application | |
typedef void(* | DelayAddressCallback) (const Time &delay, const Address &from) |
Common callback signature for packet delay and address. | |
typedef void(* | StateTransitionCallback) (const std::string &oldState, const std::string &newState) |
Common signature used by callbacks to application's state transition trace source. | |
Protected Member Functions inherited from ns3::Application | |
void | DoDispose () override |
Destructor implementation. | |
void | DoInitialize () override |
Initialize() implementation. | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. | |
virtual void | NotifyNewAggregate () |
Notify all Objects aggregated to this one of a new Object being aggregated. | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. | |
Protected Attributes inherited from ns3::SinkApplication | |
Address | m_local |
Local address to bind to (address and port) | |
uint32_t | m_port |
Local port to bind to. | |
Protected Attributes inherited from ns3::Application | |
Ptr< Node > | m_node |
The node that this application is installed on. | |
EventId | m_startEvent |
The event that will fire at m_startTime to start the application. | |
Time | m_startTime |
The simulation time that the application will start. | |
EventId | m_stopEvent |
The event that will fire at m_stopTime to end the application. | |
Time | m_stopTime |
The simulation time that the application will end. | |
Related Symbols inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. | |
A UDP server, receives UDP packets from a remote host.
UDP packets carry a 32bits sequence number followed by a 64bits time stamp in their payloads. The application uses the sequence number to determine if a packet is lost, and the time stamp to compute the delay.
ns3::UdpServer is accessible through the following paths with Config::Set and Config::Connect:
Address
Time
-9.22337e+18ns:+9.22337e+18ns Time
-9.22337e+18ns:+9.22337e+18ns Group: Applications
Size of this type is 256 bytes (on a 64-bit architecture).
Definition at line 37 of file udp-server.h.
ns3::UdpServer::UdpServer | ( | ) |
Definition at line 59 of file udp-server.cc.
References NS_LOG_FUNCTION.
|
override |
Definition at line 69 of file udp-server.cc.
References NS_LOG_FUNCTION.
uint32_t ns3::UdpServer::GetLost | ( | ) | const |
Returns the number of lost packets.
Definition at line 89 of file udp-server.cc.
References ns3::PacketLossCounter::GetLost(), m_lossCounter, and NS_LOG_FUNCTION.
uint16_t ns3::UdpServer::GetPacketWindowSize | ( | ) | const |
Returns the size of the window used for checking loss.
Definition at line 75 of file udp-server.cc.
References ns3::PacketLossCounter::GetBitMapSize(), m_lossCounter, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
uint64_t ns3::UdpServer::GetReceived | ( | ) | const |
Returns the number of received packets.
Definition at line 96 of file udp-server.cc.
References m_received, and NS_LOG_FUNCTION.
|
static |
Get the type ID.
Definition at line 34 of file udp-server.cc.
References GetPacketWindowSize(), m_rxTrace, m_rxTraceWithAddresses, ns3::MakeTraceSourceAccessor(), ns3::MakeUintegerAccessor(), ns3::MakeUintegerChecker(), SetPacketWindowSize(), and ns3::TypeId::SetParent().
Handle a packet reception.
This function is called by lower layers.
socket | the socket the packet was received to. |
Definition at line 170 of file udp-server.cc.
References ns3::Inet6SocketAddress::ConvertFrom(), ns3::InetSocketAddress::ConvertFrom(), ns3::SeqTsHeader::GetSeq(), ns3::SeqTsHeader::GetTs(), ns3::Inet6SocketAddress::IsMatchingType(), ns3::InetSocketAddress::IsMatchingType(), m_lossCounter, m_received, m_rxTrace, m_rxTraceWithAddresses, ns3::PacketLossCounter::NotifyReceived(), ns3::Simulator::Now(), NS_LOG_FUNCTION, and NS_LOG_INFO.
Referenced by StartApplication().
void ns3::UdpServer::SetPacketWindowSize | ( | uint16_t | size | ) |
Set the size of the window used for checking loss.
This value should be a multiple of 8
size | the size of the window used for checking loss. This value should be a multiple of 8 |
Definition at line 82 of file udp-server.cc.
References m_lossCounter, NS_LOG_FUNCTION, and ns3::PacketLossCounter::SetBitMapSize().
Referenced by GetTypeId().
|
overrideprivatevirtual |
Application specific startup code.
The StartApplication method is called at the start time specified by Start This method should be overridden by all or most application subclasses.
Reimplemented from ns3::Application.
Definition at line 103 of file udp-server.cc.
References ns3::Socket::Bind(), ns3::Inet6SocketAddress::ConvertFrom(), ns3::InetSocketAddress::ConvertFrom(), ns3::Socket::CreateSocket(), ns3::Ipv4Address::GetAny(), ns3::Ipv6Address::GetAny(), ns3::InetSocketAddress::GetIpv4(), ns3::Inet6SocketAddress::GetIpv6(), ns3::Application::GetNode(), HandleRead(), ns3::Address::IsInvalid(), ns3::InetSocketAddress::IsMatchingType(), ns3::Ipv6Address::IsMatchingType(), ns3::TypeId::LookupByName(), ns3::SinkApplication::m_local, ns3::SinkApplication::m_port, m_socket, m_socket6, ns3::MakeCallback(), NS_FATAL_ERROR, NS_LOG_FUNCTION, NS_LOG_INFO, and ns3::Socket::SetRecvCallback().
|
overrideprivatevirtual |
Application specific shutdown code.
The StopApplication method is called at the stop time specified by Stop This method should be overridden by all or most application subclasses.
Reimplemented from ns3::Application.
Definition at line 155 of file udp-server.cc.
References m_socket, m_socket6, ns3::MakeNullCallback(), NS_LOG_FUNCTION, and ns3::Socket::SetRecvCallback().
|
staticconstexpr |
default port
Definition at line 40 of file udp-server.h.
|
private |
Lost packet counter.
Definition at line 93 of file udp-server.h.
Referenced by GetLost(), GetPacketWindowSize(), HandleRead(), and SetPacketWindowSize().
|
private |
Number of received packets.
Definition at line 92 of file udp-server.h.
Referenced by GetReceived(), and HandleRead().
|
private |
Callbacks for tracing the packet Rx events.
Definition at line 96 of file udp-server.h.
Referenced by GetTypeId(), and HandleRead().
|
private |
Callbacks for tracing the packet Rx events, includes source and destination addresses.
Definition at line 99 of file udp-server.h.
Referenced by GetTypeId(), and HandleRead().
Definition at line 90 of file udp-server.h.
Referenced by StartApplication(), and StopApplication().
IPv6 Socket (used if only port is specified)
Definition at line 91 of file udp-server.h.
Referenced by StartApplication(), and StopApplication().