A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
udp-echo-server.cc
Go to the documentation of this file.
1/*
2 * Copyright 2007 University of Washington
3 *
4 * SPDX-License-Identifier: GPL-2.0-only
5 */
6
7#include "udp-echo-server.h"
8
9#include "ns3/address-utils.h"
10#include "ns3/inet-socket-address.h"
11#include "ns3/inet6-socket-address.h"
12#include "ns3/ipv4-address.h"
13#include "ns3/ipv6-address.h"
14#include "ns3/log.h"
15#include "ns3/nstime.h"
16#include "ns3/packet.h"
17#include "ns3/simulator.h"
18#include "ns3/socket-factory.h"
19#include "ns3/socket.h"
20#include "ns3/udp-socket.h"
21#include "ns3/uinteger.h"
22
23namespace ns3
24{
25
26NS_LOG_COMPONENT_DEFINE("UdpEchoServerApplication");
27
29
32{
33 static TypeId tid =
34 TypeId("ns3::UdpEchoServer")
36 .SetGroupName("Applications")
37 .AddConstructor<UdpEchoServer>()
38 .AddAttribute("Tos",
39 "The Type of Service used to send IPv4 packets. "
40 "All 8 bits of the TOS byte are set (including ECN bits).",
44 .AddTraceSource("RxWithAddresses",
45 "A packet has been received",
47 "ns3::Packet::TwoAddressTracedCallback");
48 return tid;
49}
50
57
62
63void
65{
66 NS_LOG_FUNCTION(this);
67
68 auto local = m_local;
69 if (local.IsInvalid())
70 {
72 }
73 if (m_socket->Bind(local) == -1)
74 {
75 NS_FATAL_ERROR("Failed to bind socket");
76 }
78 {
80 if (udpSocket)
81 {
82 // equivalent to setsockopt (MCAST_JOIN_GROUP)
83 udpSocket->MulticastJoinGroup(0, m_local);
84 }
85 else
86 {
87 NS_FATAL_ERROR("Error: Failed to join multicast group");
88 }
89 }
90 m_socket->SetIpTos(m_tos); // Affects only IPv4 sockets.
91 m_socket->SetRecvCallback(MakeCallback(&UdpEchoServer::HandleRead, this));
92
93 if (m_local.IsInvalid())
94 {
96 if (m_socket6->Bind(local) == -1)
97 {
98 NS_FATAL_ERROR("Failed to bind socket");
99 }
100 if (addressUtils::IsMulticast(local))
101 {
103 if (udpSocket)
104 {
105 // equivalent to setsockopt (MCAST_JOIN_GROUP)
106 udpSocket->MulticastJoinGroup(0, local);
107 }
108 else
109 {
110 NS_FATAL_ERROR("Error: Failed to join multicast group");
111 }
112 }
113 m_socket6->SetRecvCallback(MakeCallback(&UdpEchoServer::HandleRead, this));
114 }
115}
116
117void
119{
120 NS_LOG_FUNCTION(this << socket);
121
122 Address from;
123 while (auto packet = socket->RecvFrom(from))
124 {
125 Address localAddress;
126 socket->GetSockName(localAddress);
128 m_rxTrace(packet, from);
129 m_rxTraceWithAddresses(packet, from, localAddress);
131 {
132 NS_LOG_INFO("At time " << Simulator::Now().As(Time::S) << " server received "
133 << packet->GetSize() << " bytes from "
134 << InetSocketAddress::ConvertFrom(from).GetIpv4() << " port "
135 << InetSocketAddress::ConvertFrom(from).GetPort());
136 }
138 {
139 NS_LOG_INFO("At time " << Simulator::Now().As(Time::S) << " server received "
140 << packet->GetSize() << " bytes from "
141 << Inet6SocketAddress::ConvertFrom(from).GetIpv6() << " port "
142 << Inet6SocketAddress::ConvertFrom(from).GetPort());
143 }
144
145 packet->RemoveAllPacketTags();
146 packet->RemoveAllByteTags();
147
148 NS_LOG_LOGIC("Echoing packet");
149 socket->SendTo(packet, 0, from);
150
152 {
153 NS_LOG_INFO("At time " << Simulator::Now().As(Time::S) << " server sent "
154 << packet->GetSize() << " bytes to "
155 << InetSocketAddress::ConvertFrom(from).GetIpv4() << " port "
156 << InetSocketAddress::ConvertFrom(from).GetPort());
157 }
159 {
160 NS_LOG_INFO("At time " << Simulator::Now().As(Time::S) << " server sent "
161 << packet->GetSize() << " bytes to "
162 << Inet6SocketAddress::ConvertFrom(from).GetIpv6() << " port "
163 << Inet6SocketAddress::ConvertFrom(from).GetPort());
164 }
165 }
166}
167
168} // Namespace ns3
a polymophic address class
Definition address.h:111
An Inet6 address class.
static Inet6SocketAddress ConvertFrom(const Address &addr)
Convert the address to a InetSocketAddress.
static bool IsMatchingType(const Address &addr)
If the address match.
an Inet address class
static bool IsMatchingType(const Address &address)
static InetSocketAddress ConvertFrom(const Address &address)
Returns an InetSocketAddress which corresponds to the input Address.
static Ipv4Address GetAny()
static Ipv6Address GetAny()
Get the "any" (::) Ipv6Address.
Smart pointer class similar to boost::intrusive_ptr.
Definition ptr.h:67
static Time Now()
Return the current simulation virtual time.
Definition simulator.cc:197
ns3::TracedCallback< Ptr< const Packet > > m_rxTraceWithoutAddress
Callbacks for tracing the packet Rx events.
Ptr< Socket > m_socket6
IPv6 Socket (used if only port is specified).
TypeId m_protocolTid
Protocol TypeId value.
SinkApplication(uint16_t defaultPort=0)
Constructor.
Address m_local
Local address to bind to (address and port).
Ptr< Socket > m_socket
Socket (IPv4 or IPv6, depending on local address).
uint32_t m_port
Local port to bind to.
TracedCallback< Ptr< const Packet >, const Address & > m_rxTrace
Traced Callback: received packets, source address.
@ S
second
Definition nstime.h:107
a unique identifier for an interface.
Definition type-id.h:49
static TypeId LookupByName(std::string name)
Get a TypeId by name.
Definition type-id.cc:872
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition type-id.cc:1001
A Udp Echo server.
TracedCallback< Ptr< const Packet >, const Address &, const Address & > m_rxTraceWithAddresses
Callbacks for tracing the packet Rx events, includes source and destination addresses.
static constexpr uint16_t DEFAULT_PORT
default port
uint8_t m_tos
The packets Type of Service.
static TypeId GetTypeId()
Get the type ID.
void DoStartApplication() override
Application specific startup code for child subclasses.
void HandleRead(Ptr< Socket > socket)
Handle a packet reception.
Hold an unsigned integer type.
Definition uinteger.h:34
Ptr< const AttributeChecker > MakeUintegerChecker()
Definition uinteger.h:85
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Definition uinteger.h:35
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition log.h:191
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
Definition log.h:271
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Definition log.h:264
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition object-base.h:35
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
bool IsMulticast(const Address &ad)
Address family-independent test for a multicast address.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
Definition callback.h:684
Ptr< T1 > DynamicCast(const Ptr< T2 > &p)
Cast a Ptr.
Definition ptr.h:585