21 #define NS_LOG_APPEND_CONTEXT                                                                      \ 
   24         std::clog << " [node " << m_node->GetId() << "] ";                                         \
 
   44 #include "ns3/abort.h" 
   45 #include "ns3/data-rate.h" 
   46 #include "ns3/double.h" 
   47 #include "ns3/inet-socket-address.h" 
   48 #include "ns3/inet6-socket-address.h" 
   49 #include "ns3/ipv4-interface-address.h" 
   50 #include "ns3/ipv4-route.h" 
   51 #include "ns3/ipv4-routing-protocol.h" 
   53 #include "ns3/ipv6-route.h" 
   54 #include "ns3/ipv6-routing-protocol.h" 
   58 #include "ns3/object.h" 
   59 #include "ns3/packet.h" 
   60 #include "ns3/pointer.h" 
   61 #include "ns3/simulation-singleton.h" 
   62 #include "ns3/simulator.h" 
   63 #include "ns3/tcp-rate-ops.h" 
   64 #include "ns3/trace-source-accessor.h" 
   65 #include "ns3/uinteger.h" 
   81         TypeId(
"ns3::TcpSocketBase")
 
   83             .SetGroupName(
"Internet")
 
   90             .AddAttribute(
"MaxSegLifetime",
 
   91                           "Maximum segment lifetime in seconds, use for TIME_WAIT state transition " 
   95                           MakeDoubleChecker<double>(0))
 
   96             .AddAttribute(
"MaxWindowSize",
 
   97                           "Max size of advertised window",
 
  100                           MakeUintegerChecker<uint16_t>())
 
  101             .AddAttribute(
"IcmpCallback",
 
  102                           "Callback invoked whenever an icmp error is received on this socket.",
 
  106             .AddAttribute(
"IcmpCallback6",
 
  107                           "Callback invoked whenever an icmpv6 error is received on this socket.",
 
  111             .AddAttribute(
"WindowScaling",
 
  112                           "Enable or disable Window Scaling option",
 
  116             .AddAttribute(
"Sack",
 
  117                           "Enable or disable Sack option",
 
  121             .AddAttribute(
"Timestamp",
 
  122                           "Enable or disable Timestamp option",
 
  128                 "Minimum retransmit timeout value",
 
  135                 "Clock Granularity used in RTO calculations",
 
  140             .AddAttribute(
"TxBuffer",
 
  144                           MakePointerChecker<TcpTxBuffer>())
 
  145             .AddAttribute(
"RxBuffer",
 
  149                           MakePointerChecker<TcpRxBuffer>())
 
  150             .AddAttribute(
"CongestionOps",
 
  151                           "Pointer to TcpCongestionOps object",
 
  154                           MakePointerChecker<TcpCongestionOps>())
 
  157                 "Threshold for fast retransmit",
 
  160                 MakeUintegerChecker<uint32_t>())
 
  161             .AddAttribute(
"LimitedTransmit",
 
  162                           "Enable limited transmit",
 
  166             .AddAttribute(
"UseEcn",
 
  167                           "Parameter to set ECN functionality",
 
  176             .AddTraceSource(
"RTO",
 
  177                             "Retransmission timeout",
 
  179                             "ns3::TracedValueCallback::Time")
 
  180             .AddTraceSource(
"RTT",
 
  183                             "ns3::TracedValueCallback::Time")
 
  184             .AddTraceSource(
"NextTxSequence",
 
  185                             "Next sequence number to send (SND.NXT)",
 
  187                             "ns3::SequenceNumber32TracedValueCallback")
 
  188             .AddTraceSource(
"HighestSequence",
 
  189                             "Highest sequence number ever sent in socket's life time",
 
  191                             "ns3::TracedValueCallback::SequenceNumber32")
 
  192             .AddTraceSource(
"State",
 
  195                             "ns3::TcpStatesTracedValueCallback")
 
  196             .AddTraceSource(
"CongState",
 
  197                             "TCP Congestion machine state",
 
  199                             "ns3::TcpSocketState::TcpCongStatesTracedValueCallback")
 
  200             .AddTraceSource(
"EcnState",
 
  201                             "Trace ECN state change of socket",
 
  203                             "ns3::TcpSocketState::EcnStatesTracedValueCallback")
 
  204             .AddTraceSource(
"AdvWND",
 
  205                             "Advertised Window Size",
 
  207                             "ns3::TracedValueCallback::Uint32")
 
  208             .AddTraceSource(
"RWND",
 
  209                             "Remote side's flow control window",
 
  211                             "ns3::TracedValueCallback::Uint32")
 
  212             .AddTraceSource(
"BytesInFlight",
 
  213                             "Socket estimation of bytes in flight",
 
  215                             "ns3::TracedValueCallback::Uint32")
 
  216             .AddTraceSource(
"HighestRxSequence",
 
  217                             "Highest sequence number received from peer",
 
  219                             "ns3::TracedValueCallback::SequenceNumber32")
 
  220             .AddTraceSource(
"HighestRxAck",
 
  221                             "Highest ack received from peer",
 
  223                             "ns3::TracedValueCallback::SequenceNumber32")
 
  224             .AddTraceSource(
"PacingRate",
 
  225                             "The current TCP pacing rate",
 
  227                             "ns3::TracedValueCallback::DataRate")
 
  228             .AddTraceSource(
"CongestionWindow",
 
  229                             "The TCP connection's congestion window",
 
  231                             "ns3::TracedValueCallback::Uint32")
 
  232             .AddTraceSource(
"CongestionWindowInflated",
 
  233                             "The TCP connection's congestion window inflates as in older RFC",
 
  235                             "ns3::TracedValueCallback::Uint32")
 
  236             .AddTraceSource(
"SlowStartThreshold",
 
  237                             "TCP slow start threshold (bytes)",
 
  239                             "ns3::TracedValueCallback::Uint32")
 
  240             .AddTraceSource(
"Tx",
 
  241                             "Send tcp packet to IP protocol",
 
  243                             "ns3::TcpSocketBase::TcpTxRxTracedCallback")
 
  244             .AddTraceSource(
"Rx",
 
  245                             "Receive tcp packet from IP protocol",
 
  247                             "ns3::TcpSocketBase::TcpTxRxTracedCallback")
 
  248             .AddTraceSource(
"EcnEchoSeq",
 
  249                             "Sequence of last received ECN Echo",
 
  251                             "ns3::SequenceNumber32TracedValueCallback")
 
  252             .AddTraceSource(
"EcnCeSeq",
 
  253                             "Sequence of last received CE",
 
  255                             "ns3::SequenceNumber32TracedValueCallback")
 
  256             .AddTraceSource(
"EcnCwrSeq",
 
  257                             "Sequence of last received CWR",
 
  259                             "ns3::SequenceNumber32TracedValueCallback");
 
  275     m_tcb = CreateObject<TcpSocketState>();
 
  276     m_rateOps = CreateObject<TcpRateLinux>();
 
  332       m_dupAckCount(sock.m_dupAckCount),
 
  334       m_delAckMaxCount(sock.m_delAckMaxCount),
 
  335       m_noDelay(sock.m_noDelay),
 
  336       m_synCount(sock.m_synCount),
 
  337       m_synRetries(sock.m_synRetries),
 
  338       m_dataRetrCount(sock.m_dataRetrCount),
 
  339       m_dataRetries(sock.m_dataRetries),
 
  341       m_minRto(sock.m_minRto),
 
  342       m_clockGranularity(sock.m_clockGranularity),
 
  343       m_delAckTimeout(sock.m_delAckTimeout),
 
  344       m_persistTimeout(sock.m_persistTimeout),
 
  345       m_cnTimeout(sock.m_cnTimeout),
 
  347       m_endPoint6(nullptr),
 
  350       m_state(sock.m_state),
 
  351       m_errno(sock.m_errno),
 
  352       m_closeNotified(sock.m_closeNotified),
 
  353       m_closeOnEmpty(sock.m_closeOnEmpty),
 
  354       m_shutdownSend(sock.m_shutdownSend),
 
  355       m_shutdownRecv(sock.m_shutdownRecv),
 
  356       m_connected(sock.m_connected),
 
  358       m_maxWinSize(sock.m_maxWinSize),
 
  359       m_bytesAckedNotProcessed(sock.m_bytesAckedNotProcessed),
 
  361       m_highRxMark(sock.m_highRxMark),
 
  362       m_highRxAckMark(sock.m_highRxAckMark),
 
  363       m_sackEnabled(sock.m_sackEnabled),
 
  364       m_winScalingEnabled(sock.m_winScalingEnabled),
 
  365       m_rcvWindShift(sock.m_rcvWindShift),
 
  366       m_sndWindShift(sock.m_sndWindShift),
 
  367       m_timestampEnabled(sock.m_timestampEnabled),
 
  368       m_timestampToEcho(sock.m_timestampToEcho),
 
  369       m_recover(sock.m_recover),
 
  370       m_recoverActive(sock.m_recoverActive),
 
  371       m_retxThresh(sock.m_retxThresh),
 
  372       m_limitedTx(sock.m_limitedTx),
 
  373       m_isFirstPartialAck(sock.m_isFirstPartialAck),
 
  374       m_txTrace(sock.m_txTrace),
 
  375       m_rxTrace(sock.m_rxTrace),
 
  376       m_pacingTimer(
Timer::CANCEL_ON_DESTROY),
 
  377       m_ecnEchoSeq(sock.m_ecnEchoSeq),
 
  378       m_ecnCESeq(sock.m_ecnCESeq),
 
  379       m_ecnCWRSeq(sock.m_ecnCWRSeq)
 
  391         MakeNullCallback<void, Ptr<Socket>, 
const Address&>();
 
  416     m_rateOps = CreateObject<TcpRateLinux>();
 
  548     m_tcp->AddSocket(
this);
 
  564     m_tcp->AddSocket(
this);
 
  636     m_tcp->AddSocket(
this);
 
  648         "TcpSocketBase::SetSSThresh() cannot change initial ssThresh after connection started.");
 
  664         "TcpSocketBase::SetInitialCwnd() cannot change initial cwnd after connection started.");
 
  781         NS_LOG_WARN(
"Socket " << 
this << 
" << unread rx data during close.  Sending reset." 
  782                               << 
"This is probably due to a bad sink application; check its code");
 
  848     NS_ABORT_MSG_IF(flags, 
"use of flags is not supported in TcpSocketBase::Send()");
 
  897     return Send(p, flags); 
 
  906     NS_ABORT_MSG_IF(flags, 
"use of flags is not supported in TcpSocketBase::Recv()");
 
  909         return Create<Packet>(); 
 
  922     if (packet && packet->
GetSize() != 0)
 
 1168     return (tail < m_tcb->m_rxBuffer->NextRxSequence() ||
 
 1189     uint32_t bytesRemoved = packet->
PeekHeader(tcpHeader);
 
 1193                            packet->
GetSize() - bytesRemoved))
 
 1229     uint32_t bytesRemoved = packet->
PeekHeader(tcpHeader);
 
 1233                            packet->
GetSize() - bytesRemoved))
 
 1262                          << 
static_cast<uint32_t
>(icmpType) << 
static_cast<uint32_t
>(icmpCode)
 
 1266         m_icmpCallback(icmpSource, icmpTtl, icmpType, icmpCode, icmpInfo);
 
 1278                          << 
static_cast<uint32_t
>(icmpType) << 
static_cast<uint32_t
>(icmpCode)
 
 1288                                  const uint32_t tcpHeaderSize,
 
 1289                                  const uint32_t tcpPayloadSize)
 
 1291     if (tcpHeaderSize == 0 || tcpHeaderSize > 60)
 
 1293         NS_LOG_ERROR(
"Bytes removed: " << tcpHeaderSize << 
" invalid");
 
 1296     else if (tcpPayloadSize > 0 && 
OutOfRange(seq, seq + tcpPayloadSize))
 
 1300                                 << 
":" << seq + tcpPayloadSize << 
") out of range [" 
 1399                                          << seq << 
":" << seq + packet->
GetSize()
 
 1400                                          << 
") without TS option. Silently discard it");
 
 1416         NS_LOG_LOGIC(
this << 
" Enter zerowindow persist state");
 
 1418             this << 
" Cancelled ReTxTimeout event which was set to expire at " 
 1483         NS_LOG_LOGIC(
this << 
" Leaving zerowindow persist state");
 
 1509                                           << 
" SND.UNA = " << 
m_txBuffer->HeadSequence());
 
 1528                              << 
" -> ECN_SENDING_ECE");
 
 1555     else if (tcpflags == 0)
 
 1568                                          << 
" received. Reset packet is sent.");
 
 1599     TcpHeader::TcpOptionList::const_iterator it;
 
 1602     for (it = options.begin(); it != options.end(); ++it)
 
 1684     uint32_t bytesInFlight =
 
 1692                                   << 
"Reset cwnd to " << 
m_tcb->
m_cWnd << 
", ssthresh to " 
 1694                                   << 
" calculated in flight: " << bytesInFlight);
 
 1732                       "From OPEN->DISORDER but with " << 
m_dupAckCount << 
" dup ACKs");
 
 1821     uint32_t previousLost = 
m_txBuffer->GetLost();
 
 1827     uint32_t bytesSacked = 0;
 
 1834     if (ackNumber < oldHeadSequence)
 
 1836         NS_LOG_DEBUG(
"Possibly received a stale ACK (ack number < head sequence)");
 
 1844     if ((ackNumber > oldHeadSequence) && (ackNumber < 
m_recover) &&
 
 1848         for (uint32_t i = 0; i < segAcked; i++)
 
 1853                 NS_LOG_DEBUG(
"Ack Number " << ackNumber << 
"is ACK of retransmitted packet.");
 
 1860     uint32_t currentDelivered =
 
 1900     NS_LOG_INFO(
"Update bytes in flight before processing the ACK.");
 
 1905     ProcessAck(ackNumber, (bytesSacked > 0), currentDelivered, oldHeadSequence);
 
 1910         uint32_t currentLost = 
m_txBuffer->GetLost();
 
 1912             (currentLost > previousLost) ? currentLost - previousLost : previousLost - currentLost;
 
 1935                           bool scoreboardUpdated,
 
 1936                           uint32_t currentDelivered,
 
 1943     bool exitedFastRecovery = 
false;
 
 1946     uint32_t bytesAcked = 0;
 
 1968     NS_LOG_DEBUG(
"ACK of " << ackNumber << 
" SND.UNA=" << oldHeadSequence
 
 1981         DupAck(currentDelivered);
 
 1993         NS_LOG_DEBUG(
"Update nextTxSequence manually to " << ackNumber);
 
 1996     else if (ackNumber == oldHeadSequence)
 
 2001     else if (ackNumber > oldHeadSequence)
 
 2005         bytesAcked = ackNumber - oldHeadSequence;
 
 2046                 NS_LOG_INFO(
"Partial ACK. Manually setting head as lost");
 
 2073                                                << 
" and this is the first (RTO will be reset);" 
 2083                              << 
" and this is NOT the first (RTO will not be reset)" 
 2104                     "Some segment got dup-acked in CA_LOSS state: " << 
m_txBuffer->GetSacked());
 
 2127                 if (segsAcked >= oldDupAckCount)
 
 2130                                                    segsAcked - oldDupAckCount,
 
 2140                     NS_LOG_DEBUG(segsAcked << 
" segments acked in CA_DISORDER, ack of " << ackNumber
 
 2141                                            << 
" exiting CA_DISORDER -> CA_OPEN");
 
 2145                     NS_LOG_DEBUG(segsAcked << 
" segments acked in CA_DISORDER, ack of " << ackNumber
 
 2146                                            << 
" but still in CA_DISORDER");
 
 2172                 exitedFastRecovery = 
true;
 
 2175                 NS_LOG_DEBUG(segsAcked << 
" segments acked in CA_RECOVER, ack of " << ackNumber
 
 2176                                        << 
", exiting CA_RECOVERY -> CA_OPEN");
 
 2191                 NS_LOG_DEBUG(segsAcked << 
" segments acked in CA_LOSS, ack of" << ackNumber
 
 2192                                        << 
", exiting CA_LOSS -> CA_OPEN");
 
 2203             if (exitedFastRecovery)
 
 2208                 NS_LOG_DEBUG(
"Leaving Fast Recovery; BytesInFlight() = " 
 2219                              << 
" segsAcked: " << segsAcked);
 
 2360                          << 
" received in SYN_SENT. Reset packet is sent.");
 
 2380     if (tcpflags == 0 ||
 
 2465                                          << 
" received. Reset packet is sent.");
 
 2523                                          << 
" received. Reset packet is sent.");
 
 2581                                          << 
" received. Reset packet is sent.");
 
 2619                                      << 
" received. Reset packet is sent.");
 
 2683         NS_LOG_LOGIC(
"TCP " << 
this << 
" calling NotifyNormalClose");
 
 2698         NS_LOG_LOGIC(
"TcpSocketBase " << 
this << 
" scheduling LATO1");
 
 2713         m_tcp->RemoveSocket(
this);
 
 2715     NS_LOG_LOGIC(
this << 
" Cancelled ReTxTimeout event which was set to expire at " 
 2729         m_tcp->RemoveSocket(
this);
 
 2731     NS_LOG_LOGIC(
this << 
" Cancelled ReTxTimeout event which was set to expire at " 
 2744         NS_LOG_WARN(
"Failed to send empty packet due to null endpoint");
 
 2846         m_tcp->SendPacket(p,
 
 2854         m_tcp->SendPacket(p,
 
 2863         NS_LOG_LOGIC(
"Schedule retransmission timeout at time " 
 2890         m_tcp->RemoveSocket(
this);
 
 2898         m_tcp->RemoveSocket(
this);
 
 2909     if (!ipv4->GetRoutingProtocol())
 
 2920     route = ipv4->GetRoutingProtocol()->RouteOutput(
Ptr<Packet>(), header, oif, errno_);
 
 2939     if (!ipv6->GetRoutingProtocol())
 
 2950     route = ipv6->GetRoutingProtocol()->RouteOutput(
Ptr<Packet>(), header, oif, errno_);
 
 2992     m_tcp->AddSocket(
this);
 
 3128     bool isRetransmission = outItem->
IsRetrans();
 
 3212         NS_LOG_LOGIC(
this << 
" SendDataPacket Schedule ReTxTimeout at time " 
 3222         m_tcp->SendPacket(p,
 
 3228                      << sz << 
" with remaining data " << remainingData << 
" via TcpL4Protocol to " 
 3233         m_tcp->SendPacket(p,
 
 3239                      << sz << 
" with remaining data " << remainingData << 
" via TcpL4Protocol to " 
 3253     if (!isRetransmission)
 
 3270     if (isRetransmission == 
false)
 
 3276         for (std::deque<RttHistory>::iterator i = 
m_history.begin(); i != 
m_history.end(); ++i)
 
 3300             "TcpSocketBase::SendPendingData: No endpoint; m_shutdownSend=" << 
m_shutdownSend);
 
 3304     uint32_t nPacketsSent = 0;
 
 3312     while (availableWindow > 0)
 
 3327             NS_LOG_INFO(
"FIN_WAIT and OPEN state; no data to transmit");
 
 3338         if (!
m_txBuffer->NextSeg(&next, &nextHigh, enableRule3))
 
 3340             NS_LOG_INFO(
"no valid seq to transmit, or no data available");
 
 3346             uint32_t availableData = 
m_txBuffer->SizeFromSequence(next);
 
 3350             if (availableData < availableWindow)
 
 3357             if (availableWindow < m_tcb->m_segmentSize && availableData > availableWindow)
 
 3359                 NS_LOG_LOGIC(
"Preventing Silly Window Syndrome. Wait to send.");
 
 3367                              << next << 
", SFS: " << 
m_txBuffer->SizeFromSequence(next)
 
 3368                              << 
". Wait to send.");
 
 3374             uint32_t maxSizeToSend = 
static_cast<uint32_t
>(nextHigh - next);
 
 3397                                    << 
" highestRxAck " << 
m_txBuffer->HeadSequence() << 
" pd->Size " 
 3430     if (nPacketsSent > 0)
 
 3441         NS_LOG_DEBUG(
"SendPendingData sent " << nPacketsSent << 
" segments");
 
 3447     return nPacketsSent;
 
 3459     uint32_t bytesInFlight = 
m_txBuffer->BytesInFlight();
 
 3464     NS_LOG_DEBUG(
"Returning calculated bytesInFlight: " << bytesInFlight);
 
 3465     return bytesInFlight;
 
 3479     return (inflight > win) ? 0 : win - inflight;
 
 3497                       "Unexpected sequence number values");
 
 3516                     << 
m_maxWinSize << 
"; possibly to avoid overflow of the 16-bit integer");
 
 3518     NS_LOG_LOGIC(
"Returning AdvertisedWindowSize of " << 
static_cast<uint16_t
>(w));
 
 3519     return static_cast<uint16_t
>(w);
 
 3528                                       << 
" pkt size=" << p->
GetSize());
 
 3548     if (expectedSeq < m_tcb->m_rxBuffer->NextRxSequence())
 
 3557             NS_LOG_WARN(
"Why TCP " << 
this << 
" got data after close notification?");
 
 3597                              << 
" -> ECN_SENDING_ECE");
 
 3615                 this << 
" scheduled delayed ACK at " 
 3642                     NS_LOG_LOGIC(
"TcpSocketBase::EstimateRtt - RTT calculated from TcpOption::TS " 
 3643                                  "is zero, approximating to 1us.");
 
 3691             this << 
" Cancelled ReTxTimeout event which was set to expire at " 
 3700                           << 
" to expire at time " 
 3706     NS_LOG_LOGIC(
"TCP " << 
this << 
" NewAck " << ack << 
" numberAck " 
 3720             this << 
" Cancelled ReTxTimeout event which was set to expire at " 
 3764     if (m_state <= ESTABLISHED && m_txBuffer->HeadSequence() >= 
m_tcb->
m_highTxMark &&
 
 3774         NS_LOG_INFO(
"No more data retries available. Dropping connection");
 
 3844                                        << 
", restart from seqnum " << 
m_txBuffer->HeadSequence()
 
 3848                   "There are some bytes in flight after an RTO: " << 
BytesInFlight());
 
 3853                   "In flight (" << 
BytesInFlight() << 
") there is more than one segment (" 
 3884             NS_LOG_INFO(
"LAST-ACK: No more data retries available. Dropping connection");
 
 3891         NS_LOG_LOGIC(
"TcpSocketBase " << 
this << 
" rescheduling LATO1");
 
 3938         m_tcp->SendPacket(p,
 
 3946         m_tcp->SendPacket(p,
 
 3966     uint32_t maxSizeToSend;
 
 3982         maxSizeToSend = 
static_cast<uint32_t
>(seqHigh - seq);
 
 4186     return (!allowBroadcast);
 
 4236         maxSpace = maxSpace >> 1;
 
 4242         NS_LOG_WARN(
"Possible error; scale exceeds 14: " << scale);
 
 4247                         << 
static_cast<int>(scale) << 
" for buffer size " 
 4310     uint8_t allowedSackBlocks = (optionLenAvail - 2) / 8;
 
 4313     if (allowedSackBlocks == 0 || sackList.empty())
 
 4315         NS_LOG_LOGIC(
"No space available or sack list empty, not adding sack blocks");
 
 4321     TcpOptionSack::SackList::iterator i;
 
 4322     for (i = sackList.begin(); allowedSackBlocks > 0 && i != sackList.end(); ++i)
 
 4324         option->AddSackBlock(*i);
 
 4325         allowedSackBlocks--;
 
 4357                                 << 
" and Echo=" << ts->GetEcho());
 
 4383     NS_LOG_INFO(
"Received (scaled) window is " << receivedWindow << 
" bytes");
 
 4397     bool update = 
false;
 
 4546     return CopyObject<TcpSocketBase>(
this);
 
 4631     if (pacingRate < m_tcb->m_maxPacingRate)
 
 4633         NS_LOG_DEBUG(
"Pacing rate updated to: " << pacingRate);
 
a polymophic address class
AttributeValue implementation for Boolean.
bool IsNull() const
Check for null implementation.
AttributeValue implementation for Callback.
Class for representing data rates.
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Hold variables of type enum.
void Cancel()
This method is syntactic sugar for the ns3::Simulator::Cancel method.
bool IsExpired() const
This method is syntactic sugar for the ns3::Simulator::IsExpired method.
bool IsRunning() const
This method is syntactic sugar for !IsExpired().
static Inet6SocketAddress ConvertFrom(const Address &addr)
Convert the address to a InetSocketAddress.
uint16_t GetPort() const
Get the port.
static bool IsMatchingType(const Address &addr)
If the address match.
Ipv6Address GetIpv6() const
Get the IPv6 address.
static bool IsMatchingType(const Address &address)
Ipv4Address GetIpv4() const
static InetSocketAddress ConvertFrom(const Address &address)
Returns an InetSocketAddress which corresponds to the input Address.
Ipv4 addresses are stored in host order in this class.
static Ipv4Address GetZero()
static Ipv4Address GetAny()
void BindToNetDevice(Ptr< NetDevice > netdevice)
Bind a socket to specific device.
void SetDestroyCallback(Callback< void > callback)
Set the default destroy callback.
void SetLocalAddress(Ipv4Address address)
Set the local address.
Ipv4Address GetPeerAddress()
Get the peer address.
void SetIcmpCallback(Callback< void, Ipv4Address, uint8_t, uint8_t, uint8_t, uint32_t > callback)
Set the ICMP callback.
uint16_t GetPeerPort()
Get the peer port.
uint16_t GetLocalPort()
Get the local port.
void SetPeer(Ipv4Address address, uint16_t port)
Set the peer information (address and port).
Ipv4Address GetLocalAddress()
Get the local address.
void SetRxCallback(Callback< void, Ptr< Packet >, Ipv4Header, uint16_t, Ptr< Ipv4Interface >> callback)
Set the reception callback.
Access to the IPv4 forwarding table, interfaces, and configuration.
Describes an IPv6 address.
static Ipv6Address GetAny()
Get the "any" (::) Ipv6Address.
bool IsIpv4MappedAddress() const
If the address is an IPv4-mapped address.
Ipv4Address GetIpv4MappedAddress() const
Return the Ipv4 address.
Ipv6Address GetLocalAddress()
Get the local address.
uint16_t GetLocalPort() const
Get the local port.
void SetPeer(Ipv6Address addr, uint16_t port)
Set the peer information (address and port).
void SetIcmpCallback(Callback< void, Ipv6Address, uint8_t, uint8_t, uint8_t, uint32_t > callback)
Set the ICMP callback.
void SetRxCallback(Callback< void, Ptr< Packet >, Ipv6Header, uint16_t, Ptr< Ipv6Interface >> callback)
Set the reception callback.
void SetLocalAddress(Ipv6Address addr)
Set the local address.
Ipv6Address GetPeerAddress()
Get the peer address.
void BindToNetDevice(Ptr< NetDevice > netdevice)
Bind a socket to specific device.
uint16_t GetPeerPort() const
Get the peer port.
void SetDestroyCallback(Callback< void > callback)
Set the default destroy callback.
IPv6 layer implementation.
bool TraceConnectWithoutContext(std::string name, const CallbackBase &cb)
Connect a TraceSource to a Callback without a context.
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
friend Ptr< T > CopyObject(Ptr< T > object)
Copy an Object.
bool RemovePacketTag(Tag &tag)
Remove a packet tag.
uint32_t RemoveHeader(Header &header)
Deserialize and remove the header from the internal buffer.
uint32_t GetSize() const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
void AddPacketTag(const Tag &tag) const
Add a packet tag.
uint32_t PeekHeader(Header &header) const
Deserialize but does not remove the header from the internal buffer.
bool ReplacePacketTag(Tag &tag)
Replace the value of a packet tag.
Hold objects of type Ptr<T>.
Helper class to store RTT measurements.
uint32_t count
Number of bytes sent.
RttHistory(SequenceNumber32 s, uint32_t c, Time t)
Constructor - builds an RttHistory with the given parameters.
bool retx
True if this has been retransmitted.
Time time
Time this one was sent.
SequenceNumber32 seq
First sequence number in packet sent.
NUMERIC_TYPE GetValue() const
Extracts the numeric value of the sequence number.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static Time Now()
Return the current simulation virtual time.
static EventId ScheduleNow(FUNC f, Ts &&... args)
Schedule an event to expire Now.
static Time GetDelayLeft(const EventId &id)
Get the remaining time until this event will execute.
Ptr< NetDevice > GetBoundNetDevice()
Returns socket's bound NetDevice, if any.
Ptr< Packet > Recv()
Read a single packet from the socket.
bool IsManualIpTtl() const
Checks if the socket has a specific IPv4 TTL set.
void SetIpTos(uint8_t ipTos)
Manually set IP Type of Service field.
void NotifySend(uint32_t spaceAvailable)
Notify through the callback (if set) that some data have been sent.
void NotifyNewConnectionCreated(Ptr< Socket > socket, const Address &from)
Notify through the callback (if set) that a new connection has been created.
virtual uint8_t GetIpTtl() const
Query the value of IP Time to Live field of this socket.
bool NotifyConnectionRequest(const Address &from)
Notify through the callback (if set) that an incoming connection is being requested by a remote host.
uint8_t GetIpTos() const
Query the value of IP Type of Service of this socket.
void SetRecvCallback(Callback< void, Ptr< Socket >> receivedData)
Notify application when new data is available to be read.
SocketType
Enumeration of the possible socket types.
void SetDataSentCallback(Callback< void, Ptr< Socket >, uint32_t > dataSent)
Notify application when a packet has been sent from transport protocol (non-standard socket call)
void SetSendCallback(Callback< void, Ptr< Socket >, uint32_t > sendCb)
Notify application when space in transmit buffer is added.
void NotifyErrorClose()
Notify through the callback (if set) that the connection has been closed due to an error.
void NotifyDataRecv()
Notify through the callback (if set) that some data have been received.
Ptr< NetDevice > m_boundnetdevice
the device this socket is bound to (might be null).
virtual void BindToNetDevice(Ptr< NetDevice > netdevice)
Bind a socket to specific device.
void NotifyNormalClose()
Notify through the callback (if set) that the connection has been closed.
virtual uint8_t GetIpv6HopLimit() const
Query the value of IP Hop Limit field of this socket.
SocketErrno
Enumeration of the possible errors returned by a socket.
void NotifyDataSent(uint32_t size)
Notify through the callback (if set) that some data have been sent.
void SetConnectCallback(Callback< void, Ptr< Socket >> connectionSucceeded, Callback< void, Ptr< Socket >> connectionFailed)
Specify callbacks to allow the caller to determine if the connection succeeds of fails.
void NotifyConnectionSucceeded()
Notify through the callback (if set) that the connection has been established.
uint8_t GetPriority() const
Query the priority value of this socket.
uint8_t GetIpv6Tclass() const
Query the value of IPv6 Traffic Class field of this socket.
bool IsManualIpv6HopLimit() const
Checks if the socket has a specific IPv6 Hop Limit set.
bool IsManualIpv6Tclass() const
Checks if the socket has a specific IPv6 Tclass set.
void NotifyConnectionFailed()
Notify through the callback (if set) that the connection has not been established due to an error.
indicates whether the socket has IP_TOS set.
void SetTos(uint8_t tos)
Set the tag's TOS.
This class implements a tag that carries the socket-specific TTL of a packet to the IP layer.
void SetTtl(uint8_t ttl)
Set the tag's TTL.
This class implements a tag that carries the socket-specific HOPLIMIT of a packet to the IPv6 layer.
void SetHopLimit(uint8_t hopLimit)
Set the tag's Hop Limit.
indicates whether the socket has IPV6_TCLASS set.
void SetTclass(uint8_t tclass)
Set the tag's Tclass.
indicates whether the socket has a priority set.
void SetPriority(uint8_t priority)
Set the tag's priority.
virtual uint8_t GetKind() const =0
Get the ‘kind’ (as in RFC 793) of this option.
@ SACKPERMITTED
SACKPERMITTED.
std::list< SackBlock > SackList
SACK list definition.
static Time ElapsedTimeFromTsValue(uint32_t echoTime)
Estimate the Time elapsed from a TS echo value.
static uint32_t NowToTsValue()
Return an uint32_t value which represent "now".
virtual void SkbSent(TcpTxItem *skb, bool isStartOfTransmission)=0
Put the rate information inside the sent skb.
virtual const TcpRateConnection & GetConnectionRate()=0
virtual void CalculateAppLimited(uint32_t cWnd, uint32_t in_flight, uint32_t segmentSize, const SequenceNumber32 &tailSeq, const SequenceNumber32 &nextTx, const uint32_t lostOut, const uint32_t retransOut)=0
If a gap is detected between sends, it means we are app-limited.
virtual const TcpRateSample & GenerateSample(uint32_t delivered, uint32_t lost, bool is_sack_reneg, uint32_t priorInFlight, const Time &minRtt)=0
Generate a TcpRateSample to feed a congestion avoidance algorithm.
virtual void SkbDelivered(TcpTxItem *skb)=0
Update the Rate information after an item is received.
A base class for implementation of a stream socket using TCP.
void AddOptionSack(TcpHeader &header)
Add the SACK option to the header.
int GetSockName(Address &address) const override
Get socket address.
Time m_persistTimeout
Time between sending 1-byte probes.
uint16_t m_maxWinSize
Maximum window size to advertise.
uint8_t m_rcvWindShift
Window shift to apply to outgoing segments.
void SetPaceInitialWindow(bool paceWindow)
Enable or disable pacing of the initial window.
int Bind6() override
Allocate a local IPv6 endpoint for this socket.
void TimeWait()
Move from CLOSING or FIN_WAIT_2 to TIME_WAIT state.
Ptr< TcpCongestionOps > m_congestionControl
Congestion control.
Ptr< TcpTxBuffer > GetTxBuffer() const
Get a pointer to the Tx buffer.
SocketErrno GetErrno() const override
Get last error number.
int SetupEndpoint()
Configure the endpoint to a local address.
virtual void LastAckTimeout()
Timeout at LAST_ACK, close the connection.
void ProcessEstablished(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received a packet upon ESTABLISHED state.
Time m_minRto
minimum value of the Retransmit timeout
uint32_t SendPendingData(bool withAck=false)
Send as much pending data as possible according to the Tx window.
TracedValue< uint32_t > m_advWnd
Advertised Window size.
TracedCallback< Ptr< const Packet >, const TcpHeader &, Ptr< const TcpSocketBase > > m_txTrace
Trace of transmitted packets.
SequenceNumber32 m_recover
Previous highest Tx seqnum for fast recovery (set it to initial seq number)
bool m_recoverActive
Whether "m_recover" has been set/activated It is used to avoid comparing with the old m_recover value...
void DoRetransmit()
Retransmit the first segment marked as lost, without considering available window nor pacing.
bool CheckNoEcn(uint8_t tos) const
Checks if TOS has no ECN codepoints.
virtual void SetNode(Ptr< Node > node)
Set the associated node.
int ShutdownRecv() override
uint8_t m_sndWindShift
Window shift to apply to incoming segments.
Ptr< TcpL4Protocol > m_tcp
the associated TCP L4 protocol
Ptr< TcpSocketState > m_tcb
Congestion control information.
bool GetAllowBroadcast() const override
Query whether broadcast datagram transmissions are allowed.
void UpdateSsThresh(uint32_t oldValue, uint32_t newValue) const
Callback function to hook to TcpSocketState slow start threshold.
TracedCallback< Ptr< const Packet >, const TcpHeader &, Ptr< const TcpSocketBase > > m_rxTrace
Trace of received packets.
virtual void SetTcp(Ptr< TcpL4Protocol > tcp)
Set the associated TCP L4 protocol.
void EnterRecovery(uint32_t currentDelivered)
Enter the CA_RECOVERY, and retransmit the head.
Time GetMinRto() const
Get the Minimum RTO.
void ProcessSynSent(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received a packet upon SYN_SENT.
void ForwardUp(Ptr< Packet > packet, Ipv4Header header, uint16_t port, Ptr< Ipv4Interface > incomingInterface)
Called by the L3 protocol when it received a packet to pass on to TCP.
bool SetAllowBroadcast(bool allowBroadcast) override
Configure whether broadcast datagram transmissions are allowed.
SocketType GetSocketType() const override
void CancelAllTimers()
Cancel all timer when endpoint is deleted.
Time GetDelAckTimeout() const override
Get the time to delay an ACK.
Ptr< TcpRecoveryOps > m_recoveryOps
Recovery Algorithm.
TracedCallback< uint32_t, uint32_t > m_bytesInFlightTrace
Callback pointer for bytesInFlight trace chaining.
uint32_t GetInitialSSThresh() const override
Get the initial Slow Start Threshold.
void NotifyPacingPerformed()
Notify Pacing.
void SetDelAckTimeout(Time timeout) override
Set the time to delay an ACK.
void CloseAndNotify()
Peacefully close the socket by notifying the upper layer and deallocate end point.
Ptr< TcpRateOps > m_rateOps
Rate operations.
void PeerClose(Ptr< Packet > p, const TcpHeader &tcpHeader)
Received a FIN from peer, notify rx buffer.
int Close() override
Close a socket.
bool m_shutdownSend
Send no longer allowed.
bool IsPacingEnabled() const
Return true if packets in the current window should be paced.
void ProcessOptionWScale(const Ptr< const TcpOption > option)
Read and parse the Window scale option.
bool m_closeOnEmpty
Close socket upon tx buffer emptied.
virtual void ReTxTimeout()
An RTO event happened.
void AddOptionSackPermitted(TcpHeader &header)
Add the SACK PERMITTED option to the header.
TracedValue< Time > m_rto
Retransmit timeout.
uint32_t GetSndBufSize() const override
Get the send buffer size.
virtual void ReceivedData(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Recv of a data, put into buffer, call L7 to get it if necessary.
EventId m_timewaitEvent
TIME_WAIT expiration event: Move this socket to CLOSED state.
Ptr< TcpTxBuffer > m_txBuffer
Tx buffer.
static TypeId GetTypeId()
Get the type ID.
uint32_t m_dupAckCount
Dupack counter.
void SetRetxThresh(uint32_t retxThresh)
Set the retransmission threshold (dup ack threshold for a fast retransmit)
int Send(Ptr< Packet > p, uint32_t flags) override
Send data (or dummy data) to the remote host.
TracedCallback< SequenceNumber32, SequenceNumber32 > m_nextTxSequenceTrace
Callback pointer for next tx sequence chaining.
void UpdateBytesInFlight(uint32_t oldValue, uint32_t newValue) const
Callback function to hook to TcpSocketState bytes inflight.
EventId m_delAckEvent
Delayed ACK timeout event.
TracedCallback< Time, Time > m_lastRttTrace
Callback pointer for RTT trace chaining.
bool GetTcpNoDelay() const override
Check if Nagle's algorithm is enabled or not.
virtual void SetRtt(Ptr< RttEstimator > rtt)
Set the associated RTT estimator.
TracedCallback< uint32_t, uint32_t > m_cWndTrace
Callback pointer for cWnd trace chaining.
void UpdatePacingRateTrace(DataRate oldValue, DataRate newValue) const
Callback function to hook to TcpSocketState pacing rate.
void SetDataRetries(uint32_t retries) override
Set the number of data transmission retries before giving up.
void AddOptions(TcpHeader &tcpHeader)
Add options to TcpHeader.
TracedCallback< TcpSocketState::EcnState_t, TcpSocketState::EcnState_t > m_ecnStateTrace
Callback pointer for ECN state trace chaining.
void SetSynRetries(uint32_t count) override
Set the number of connection retries before giving up.
void ProcessWait(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received a packet upon CLOSE_WAIT, FIN_WAIT_1, FIN_WAIT_2.
SequenceNumber32 m_highTxAck
Highest ack sent.
uint32_t GetTxAvailable() const override
Returns the number of bytes which can be sent in a single call to Send.
bool m_timestampEnabled
Timestamp option enabled.
virtual void PersistTimeout()
Send 1 byte probe to get an updated window size.
TracedValue< TcpStates_t > m_state
TCP state.
int SetupCallback()
Common part of the two Bind(), i.e.
Ptr< RttEstimator > m_rtt
Round trip time estimator.
Timer m_pacingTimer
Pacing Event.
EventId m_retxEvent
Retransmission event.
uint32_t m_bytesAckedNotProcessed
Bytes acked, but not processed.
void AddOptionTimestamp(TcpHeader &header)
Add the timestamp option to the header.
virtual uint32_t BytesInFlight() const
Return total bytes in flight.
uint32_t GetSegSize() const override
Get the segment size.
int SendTo(Ptr< Packet > p, uint32_t flags, const Address &toAddress) override
Send data to a specified peer.
uint32_t m_dataRetries
Number of data retransmission attempts.
double m_msl
Max segment lifetime.
void ProcessLastAck(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received a packet upon LAST_ACK.
bool m_limitedTx
perform limited transmit
virtual uint32_t SendDataPacket(SequenceNumber32 seq, uint32_t maxSize, bool withAck)
Extract at most maxSize bytes from the TxBuffer at sequence seq, add the TCP header,...
TracedCallback< TcpSocketState::TcpCongState_t, TcpSocketState::TcpCongState_t > m_congStateTrace
Callback pointer for congestion state trace chaining.
void ProcessSynRcvd(Ptr< Packet > packet, const TcpHeader &tcpHeader, const Address &fromAddress, const Address &toAddress)
Received a packet upon SYN_RCVD.
virtual void ReceivedAck(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received an ACK packet.
int ShutdownSend() override
TracedValue< SequenceNumber32 > m_ecnCWRSeq
Sequence number of the last sent CWR.
Time GetPersistTimeout() const override
Get the timeout for persistent connection.
void UpdateCwnd(uint32_t oldValue, uint32_t newValue) const
Callback function to hook to TcpSocketState congestion window.
uint32_t m_delAckCount
Delayed ACK counter.
Ipv4EndPoint * m_endPoint
the IPv4 endpoint
static uint32_t SafeSubtraction(uint32_t a, uint32_t b)
Performs a safe subtraction between a and b (a-b)
virtual void DelAckTimeout()
Action upon delay ACK timeout, i.e.
Ptr< Packet > RecvFrom(uint32_t maxSize, uint32_t flags, Address &fromAddress) override
Read a single packet from the socket and retrieve the sender address.
Time m_cnTimeout
Timeout for connection retry.
Time GetClockGranularity() const
Get the Clock Granularity (used in RTO calcs).
bool m_winScalingEnabled
Window Scale option enabled (RFC 7323)
void UpdateEcnState(TcpSocketState::EcnState_t oldValue, TcpSocketState::EcnState_t newValue) const
Callback function to hook to EcnState state.
EventId m_sendPendingDataEvent
micro-delay event to send pending data
uint32_t m_delAckMaxCount
Number of packet to fire an ACK before delay timeout.
uint8_t CalculateWScale() const
Calculate window scale value based on receive buffer space.
virtual void NewAck(const SequenceNumber32 &seq, bool resetRTO)
Update buffers w.r.t.
bool m_closeNotified
Told app to close socket.
int Listen() override
Listen for incoming connections.
void Destroy6()
Kill this socket by zeroing its attributes (IPv6)
TracedValue< SequenceNumber32 > m_ecnCESeq
Sequence number of the last received Congestion Experienced.
void SetClockGranularity(Time clockGranularity)
Sets the Clock Granularity (used in RTO calcs).
bool IsValidTcpSegment(const SequenceNumber32 seq, const uint32_t tcpHeaderSize, const uint32_t tcpPayloadSize)
Checks whether the given TCP segment is valid or not.
Time m_clockGranularity
Clock Granularity used in RTO calcs.
void DupAck(uint32_t currentDelivered)
Dupack management.
bool m_shutdownRecv
Receive no longer allowed.
void UpdateCongState(TcpSocketState::TcpCongState_t oldValue, TcpSocketState::TcpCongState_t newValue) const
Callback function to hook to TcpSocketState congestion state.
virtual uint32_t Window() const
Return the max possible number of unacked bytes.
Callback< void, Ipv6Address, uint8_t, uint8_t, uint8_t, uint32_t > m_icmpCallback6
ICMPv6 callback.
std::deque< RttHistory > m_history
List of sent packet.
void ProcessOptionSackPermitted(const Ptr< const TcpOption > option)
Read the SACK PERMITTED option.
int Bind() override
Allocate a local IPv4 endpoint for this socket.
virtual uint32_t AvailableWindow() const
Return unfilled portion of window.
TracedValue< SequenceNumber32 > m_highRxMark
Highest seqno received.
void ReadOptions(const TcpHeader &tcpHeader, uint32_t *bytesSacked)
Read TCP options before Ack processing.
virtual uint16_t AdvertisedWindowSize(bool scale=true) const
The amount of Rx window announced to the peer.
void ForwardUp6(Ptr< Packet > packet, Ipv6Header header, uint16_t port, Ptr< Ipv6Interface > incomingInterface)
Called by the L3 protocol when it received a packet to pass on to TCP.
bool m_connected
Connection established.
TracedValue< SequenceNumber32 > m_highRxAckMark
Highest ack received.
void AddOptionWScale(TcpHeader &header)
Add the window scale option to the header.
virtual void SendEmptyPacket(uint8_t flags)
Send a empty packet that carries a flag, e.g., ACK.
void UpdateWindowSize(const TcpHeader &header)
Update the receiver window (RWND) based on the value of the window field in the header.
uint32_t GetRxAvailable() const override
Return number of bytes which can be returned from one or multiple calls to Recv.
uint32_t GetDataRetries() const override
Get the number of data transmission retries before giving up.
int SetupEndpoint6()
Configure the endpoint v6 to a local address.
uint32_t GetRetxThresh() const
Get the retransmission threshold (dup ack threshold for a fast retransmit)
void DeallocateEndPoint()
Deallocate m_endPoint and m_endPoint6.
void Destroy()
Kill this socket by zeroing its attributes (IPv4)
void UpdateHighTxMark(SequenceNumber32 oldValue, SequenceNumber32 newValue) const
Callback function to hook to TcpSocketState high tx mark.
TcpSocketBase()
Create an unbound TCP socket.
void SetInitialSSThresh(uint32_t threshold) override
Set the initial Slow Start Threshold.
TracedCallback< DataRate, DataRate > m_pacingRateTrace
Callback pointer for pacing rate trace chaining.
uint32_t m_timestampToEcho
Timestamp to echo.
Ipv6EndPoint * m_endPoint6
the IPv6 endpoint
void SetSndBufSize(uint32_t size) override
Set the send buffer size.
virtual Ptr< TcpSocketBase > Fork()
Call CopyObject<> to clone me.
TracedCallback< uint32_t, uint32_t > m_ssThTrace
Callback pointer for ssTh trace chaining.
SocketErrno m_errno
Socket error code.
virtual void CompleteFork(Ptr< Packet > p, const TcpHeader &tcpHeader, const Address &fromAddress, const Address &toAddress)
Complete a connection by forking the socket.
void ProcessClosing(Ptr< Packet > packet, const TcpHeader &tcpHeader)
Received a packet upon CLOSING.
TracedCallback< SequenceNumber32, SequenceNumber32 > m_highTxMarkTrace
Callback pointer for high tx mark chaining.
int Connect(const Address &address) override
Initiate a connection to a remote host.
Ptr< Node > m_node
the associated node
void SetSegSize(uint32_t size) override
Set the segment size.
TypeId GetInstanceTypeId() const override
Get the instance TypeId.
uint32_t m_synRetries
Number of connection attempts.
void SetConnTimeout(Time timeout) override
Set the connection timeout.
void SetDelAckMaxCount(uint32_t count) override
Set the number of packet to fire an ACK before delay timeout.
EventId m_lastAckEvent
Last ACK timeout event.
bool IsTcpOptionEnabled(uint8_t kind) const
Return true if the specified option is enabled.
void UpdatePacingRate()
Dynamically update the pacing rate.
EventId m_persistEvent
Persist event: Send 1 byte to probe for a non-zero Rx window.
void SetPacingStatus(bool pacing)
Enable or disable pacing.
void UpdateRtt(Time oldValue, Time newValue) const
Callback function to hook to TcpSocketState rtt.
void SetCongestionControlAlgorithm(Ptr< TcpCongestionOps > algo)
Install a congestion control algorithm on this socket.
int GetPeerName(Address &address) const override
Get the peer address of a connected socket.
virtual uint32_t UnAckDataCount() const
Return count of number of unacked bytes.
uint32_t m_dataRetrCount
Count of remaining data retransmission attempts.
void UpdateCwndInfl(uint32_t oldValue, uint32_t newValue) const
Callback function to hook to TcpSocketState inflated congestion window.
Ptr< TcpRxBuffer > GetRxBuffer() const
Get a pointer to the Rx buffer.
void SetPersistTimeout(Time timeout) override
Set the timeout for persistent connection.
void ConnectionSucceeded()
Schedule-friendly wrapper for Socket::NotifyConnectionSucceeded()
bool m_noDelay
Set to true to disable Nagle's algorithm.
uint32_t GetDelAckMaxCount() const override
Get the number of packet to fire an ACK before delay timeout.
void ForwardIcmp(Ipv4Address icmpSource, uint8_t icmpTtl, uint8_t icmpType, uint8_t icmpCode, uint32_t icmpInfo)
Called by the L3 protocol when it received an ICMP packet to pass on to TCP.
virtual void ProcessAck(const SequenceNumber32 &ackNumber, bool scoreboardUpdated, uint32_t currentDelivered, const SequenceNumber32 &oldHeadSequence)
Process a received ack.
void ForwardIcmp6(Ipv6Address icmpSource, uint8_t icmpTtl, uint8_t icmpType, uint8_t icmpCode, uint32_t icmpInfo)
Called by the L3 protocol when it received an ICMPv6 packet to pass on to TCP.
virtual void DoForwardUp(Ptr< Packet > packet, const Address &fromAddress, const Address &toAddress)
Called by TcpSocketBase::ForwardUp{,6}().
bool m_isFirstPartialAck
First partial ACK during RECOVERY.
uint8_t MarkEcnCodePoint(const uint8_t tos, const TcpSocketState::EcnCodePoint_t codePoint) const
mark ECN code point
Time m_delAckTimeout
Time to delay an ACK.
Callback< void, Ipv4Address, uint8_t, uint8_t, uint8_t, uint32_t > m_icmpCallback
ICMP callback.
void SetInitialCwnd(uint32_t cwnd) override
Set the initial Congestion Window.
void SetUseEcn(TcpSocketState::UseEcn_t useEcn)
Set ECN mode of use on the socket.
void ProcessListen(Ptr< Packet > packet, const TcpHeader &tcpHeader, const Address &fromAddress, const Address &toAddress)
Received a packet upon LISTEN state.
uint32_t m_synCount
Count of remaining connection retries.
int DoConnect()
Perform the real connection tasks: Send SYN if allowed, RST if invalid.
uint32_t GetSynRetries() const override
Get the number of connection retries before giving up.
void DoPeerClose()
FIN is in sequence, notify app and respond with a FIN.
void SendRST()
Send reset and tear down this socket.
bool OutOfRange(SequenceNumber32 head, SequenceNumber32 tail) const
Check if a sequence number range is within the rx window.
TracedValue< SequenceNumber32 > m_ecnEchoSeq
Sequence number of the last received ECN Echo.
uint32_t m_retxThresh
Fast Retransmit threshold.
uint32_t GetRWnd() const
Get the current value of the receiver's offered window (RCV.WND)
SequenceNumber32 GetHighRxAck() const
Get the current value of the receiver's highest (in-sequence) sequence number acked.
void BindToNetDevice(Ptr< NetDevice > netdevice) override
Bind a socket to specific device.
void EnterCwr(uint32_t currentDelivered)
Enter CA_CWR state upon receipt of an ECN Echo.
virtual void EstimateRtt(const TcpHeader &tcpHeader)
Take into account the packet for RTT estimation.
uint32_t GetInitialCwnd() const override
Get the initial Congestion Window.
TracedValue< uint32_t > m_rWnd
Receiver window (RCV.WND in RFC793)
void ProcessOptionTimestamp(const Ptr< const TcpOption > option, const SequenceNumber32 &seq)
Process the timestamp option from other side.
void SetRcvBufSize(uint32_t size) override
Set the receive buffer size.
void SetTcpNoDelay(bool noDelay) override
Enable/Disable Nagle's algorithm.
virtual void UpdateRttHistory(const SequenceNumber32 &seq, uint32_t sz, bool isRetransmission)
Update the RTT history, when we send TCP segments.
bool m_sackEnabled
RFC SACK option enabled.
void UpdateNextTxSequence(SequenceNumber32 oldValue, SequenceNumber32 newValue) const
Callback function to hook to TcpSocketState next tx sequence.
void SetMinRto(Time minRto)
Sets the Minimum RTO.
Time GetConnTimeout() const override
Get the connection timeout.
Ptr< Node > GetNode() const override
Return the node this socket is associated with.
uint32_t ProcessOptionSack(const Ptr< const TcpOption > option)
Read the SACK option.
void SetRecoveryAlgorithm(Ptr< TcpRecoveryOps > recovery)
Install a recovery algorithm on this socket.
~TcpSocketBase() override
int DoClose()
Close a socket by sending RST, FIN, or FIN+ACK, depend on the current state.
void AddSocketTags(const Ptr< Packet > &p) const
Add Tags for the Socket.
TracedCallback< uint32_t, uint32_t > m_cWndInflTrace
Callback pointer for cWndInfl trace chaining.
uint32_t GetRcvBufSize() const override
Get the receive buffer size.
(abstract) base class of all TcpSockets
static const char *const TcpStateName[TcpSocket::LAST_STATE]
Literal names of TCP states for use in log messages.
uint32_t m_segmentSize
Segment size.
@ CA_EVENT_ECN_IS_CE
received CE marked IP packet.
@ CA_EVENT_ECN_NO_CE
ECT set, but not CE marked.
@ CA_EVENT_DELAYED_ACK
Delayed ack is sent.
@ CA_EVENT_NON_DELAYED_ACK
Non-delayed ack is sent.
@ CA_EVENT_COMPLETE_CWR
end of congestion recovery
@ CA_EVENT_LOSS
loss timeout
@ CA_EVENT_TX_START
first transmit when no packets in flight
Time m_minRtt
Minimum RTT observed throughout the connection.
TracedValue< SequenceNumber32 > m_highTxMark
Highest seqno ever sent, regardless of ReTx.
uint32_t m_initialSsThresh
Initial Slow Start Threshold value.
EcnMode_t m_ecnMode
ECN mode.
Callback< void, uint8_t > m_sendEmptyPacketCallback
Callback to send an empty packet.
TracedValue< DataRate > m_pacingRate
Current Pacing rate.
UseEcn_t
Parameter value related to ECN enable/disable functionality similar to sysctl for tcp_ecn.
@ AcceptOnly
Enable only when the peer endpoint is ECN capable.
TracedValue< TcpCongState_t > m_congState
State in the Congestion state machine.
bool m_paceInitialWindow
Enable/Disable pacing for the initial window.
DataRate m_maxPacingRate
Max Pacing rate.
UseEcn_t m_useEcn
Socket ECN capability.
bool m_pacing
Pacing status.
bool m_isRetransDataAcked
Retransmitted data is ACKed if true.
static const char *const TcpCongStateName[TcpSocketState::CA_LAST_STATE]
Literal names of TCP states for use in log messages.
TcpCongState_t
Definition of the Congestion state machine.
@ CA_RECOVERY
CWND was reduced, we are fast-retransmitting.
@ CA_DISORDER
In all the respects it is "Open", but requires a bit more attention.
@ CA_CWR
cWnd was reduced due to some congestion notification event, such as ECN, ICMP source quench,...
@ CA_LOSS
CWND was reduced due to RTO timeout or SACK reneging.
@ CA_OPEN
Normal state, no dubious events.
SequenceNumber32 m_lastAckedSeq
Last sequence ACKed.
@ DctcpEcn
ECN functionality as described in RFC 8257.
TracedValue< uint32_t > m_cWnd
Congestion window.
uint32_t m_initialCWnd
Initial cWnd value.
uint32_t m_rcvTimestampEchoReply
Sender Timestamp echoed by the receiver.
TracedValue< Time > m_lastRtt
Last RTT sample collected.
EcnState_t
Definition of the Ecn state machine.
@ ECN_CWR_SENT
Sender has reduced the congestion window, and sent a packet with CWR bit set in TCP header.
@ ECN_DISABLED
ECN disabled traffic.
@ ECN_ECE_RCVD
Last ACK received had ECE bit set in TCP header.
@ ECN_IDLE
ECN is enabled but currently there is no action pertaining to ECE or CWR to be taken.
@ ECN_CE_RCVD
Last packet received had CE bit set in IP header.
@ ECN_SENDING_ECE
Receiver sends an ACK with ECE bit set in TCP header.
TracedValue< uint32_t > m_bytesInFlight
Bytes in flight.
TracedValue< uint32_t > m_cWndInfl
Inflated congestion window trace (used only for backward compatibility purpose)
uint16_t m_pacingCaRatio
CA pacing ratio.
Ptr< TcpRxBuffer > m_rxBuffer
Rx buffer (reordering buffer)
TracedValue< SequenceNumber32 > m_nextTxSequence
Next seqnum to be sent (SND.NXT), ReTx pushes it back.
uint32_t m_lastAckedSackedBytes
The number of bytes acked and sacked as indicated by the current ACK received.
uint16_t m_pacingSsRatio
SS pacing ratio.
static const char *const EcnStateName[TcpSocketState::ECN_CWR_SENT+1]
Literal names of ECN states for use in log messages.
TracedValue< EcnState_t > m_ecnState
Current ECN State, represented as combination of EcnState values.
TracedValue< uint32_t > m_ssThresh
Slow start threshold.
uint32_t m_rcvTimestampValue
Receiver Timestamp value.
EcnCodePoint_t m_ectCodePoint
ECT code point to use.
Item that encloses the application packet and some flags for it.
Ptr< Packet > GetPacketCopy() const
Get a copy of the Packet underlying this item.
bool IsRetrans() const
Is the item retransmitted?
Simulation virtual time values and global simulation resolution.
double GetSeconds() const
Get an approximation of the time stored in this instance in the indicated unit.
static Time FromDouble(double value, Unit unit)
Create a Time equal to value in unit unit.
AttributeValue implementation for Time.
A simple virtual Timer class.
Time GetDelayLeft() const
void Cancel()
Cancel the currently-running event if there is one.
void Schedule()
Schedule a new event using the currently-configured delay, function, and arguments.
T Get() const
Get the underlying value.
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Hold an unsigned integer type.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
Ptr< const AttributeAccessor > MakeBooleanAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeChecker > MakeBooleanChecker()
Ptr< const AttributeAccessor > MakeCallbackAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeChecker > MakeCallbackChecker()
Ptr< const AttributeAccessor > MakeDoubleAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeAccessor > MakeEnumAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeAccessor > MakePointerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeAccessor > MakeTimeAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
#define NS_ABORT_MSG_UNLESS(cond, msg)
Abnormal program termination if a condition is false, with a message.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
int64x64_t Max(const int64x64_t &a, const int64x64_t &b)
Maximum.
int64x64_t Min(const int64x64_t &a, const int64x64_t &b)
Minimum.
#define NS_LOG_ERROR(msg)
Use NS_LOG to output a message of level LOG_ERROR.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
SequenceNumber< uint32_t, int32_t > SequenceNumber32
32 bit Sequence number.
@ ESTABLISHED
Connection established
@ FIN_WAIT_2
All buffered data sent, waiting for remote to shutdown.
@ LISTEN
Listening for a connection
@ CLOSE_WAIT
Remote side has shutdown and is waiting for us to finish writing our data and to shutdown (we have to...
@ SYN_SENT
Sent a connection request, waiting for ack
@ CLOSED
Socket is finished
@ FIN_WAIT_1
Our side has shutdown, waiting to complete transmission of remaining buffered data
@ TIME_WAIT
Timeout to catch resent junk before entering closed, can only be entered from FIN_WAIT2 or CLOSING.
@ SYN_RCVD
Received a connection request, sent ack, waiting for final ack in three-way handshake.
@ LAST_ACK
Our side has shutdown after remote has shutdown.
@ CLOSING
Both sides have shutdown but we still have data we have to finish sending
Time MicroSeconds(uint64_t value)
Construct a Time in the indicated unit.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit.
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
log2() macro definition; to deal with Bug 1467.
void(* Time)(Time oldValue, Time newValue)
TracedValue callback signature for Time.
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...
Ptr< const AttributeChecker > MakeEnumChecker(int v, std::string n, Ts... args)
Make an EnumChecker pre-configured with a set of allowed values by name.
Ptr< const AttributeChecker > MakeTimeChecker(const Time min, const Time max)
Helper to make a Time checker with bounded range.
uint64_t m_delivered
The total amount of data in bytes delivered so far.