10#define NS_LOG_APPEND_CONTEXT \
13 std::clog << " [node " << m_node->GetId() << "] "; \
40#include "ns3/data-rate.h"
41#include "ns3/double.h"
42#include "ns3/inet-socket-address.h"
43#include "ns3/inet6-socket-address.h"
46#include "ns3/object.h"
47#include "ns3/packet.h"
48#include "ns3/pointer.h"
49#include "ns3/simulation-singleton.h"
50#include "ns3/simulator.h"
51#include "ns3/trace-source-accessor.h"
52#include "ns3/uinteger.h"
64const std::map<std::pair<ns3::TcpSocketBase::TcpPacketType_t, ns3::TcpSocketState::EcnMode_t>,
bool>
97 TypeId(
"ns3::TcpSocketBase")
99 .SetGroupName(
"Internet")
106 .AddAttribute(
"MaxSegLifetime",
107 "Maximum segment lifetime in seconds, use for TIME_WAIT state transition "
112 .AddAttribute(
"MaxWindowSize",
113 "Max size of advertised window",
117 .AddAttribute(
"IcmpCallback",
118 "Callback invoked whenever an icmp error is received on this socket.",
122 .AddAttribute(
"IcmpCallback6",
123 "Callback invoked whenever an icmpv6 error is received on this socket.",
127 .AddAttribute(
"WindowScaling",
128 "Enable or disable Window Scaling option",
132 .AddAttribute(
"Sack",
133 "Enable or disable Sack option",
137 .AddAttribute(
"Timestamp",
138 "Enable or disable Timestamp option",
142 .AddAttribute(
"Fack",
143 "Enable or disable FACK option",
149 "Minimum retransmit timeout value",
156 "Clock Granularity used in RTO calculations",
161 .AddAttribute(
"TxBuffer",
166 .AddAttribute(
"RxBuffer",
171 .AddAttribute(
"CongestionOps",
172 "Pointer to TcpCongestionOps object",
176 .AddAttribute(
"RecoveryOps",
177 "Pointer to TcpRecoveryOps object",
183 "Threshold for fast retransmit",
187 .AddAttribute(
"LimitedTransmit",
188 "Enable limited transmit",
192 .AddAttribute(
"UseEcn",
193 "Parameter to set ECN functionality",
202 .AddAttribute(
"UseAbe",
203 "Parameter to set ABE functionality",
207 .AddTraceSource(
"RTO",
208 "Retransmission timeout",
210 "ns3::TracedValueCallback::Time")
211 .AddTraceSource(
"RTT",
214 "ns3::TracedValueCallback::Time")
215 .AddTraceSource(
"LastRTT",
216 "RTT of the last (S)ACKed packet",
218 "ns3::TracedValueCallback::Time")
219 .AddTraceSource(
"NextTxSequence",
220 "Next sequence number to send (SND.NXT)",
222 "ns3::SequenceNumber32TracedValueCallback")
223 .AddTraceSource(
"HighestSequence",
224 "Highest sequence number ever sent in socket's life time",
226 "ns3::TracedValueCallback::SequenceNumber32")
227 .AddTraceSource(
"State",
230 "ns3::TcpStatesTracedValueCallback")
231 .AddTraceSource(
"CongState",
232 "TCP Congestion machine state",
234 "ns3::TcpSocketState::TcpCongStatesTracedValueCallback")
235 .AddTraceSource(
"EcnState",
236 "Trace ECN state change of socket",
238 "ns3::TcpSocketState::EcnStatesTracedValueCallback")
239 .AddTraceSource(
"AdvWND",
240 "Advertised Window Size",
242 "ns3::TracedValueCallback::Uint32")
243 .AddTraceSource(
"RWND",
244 "Remote side's flow control window",
246 "ns3::TracedValueCallback::Uint32")
247 .AddTraceSource(
"BytesInFlight",
248 "Socket estimation of bytes in flight",
250 "ns3::TracedValueCallback::Uint32")
251 .AddTraceSource(
"FackAwnd",
252 "Socket estimation of bytes in flight by FACK",
254 "ns3::TracedValueCallback::Uint32")
255 .AddTraceSource(
"HighestRxSequence",
256 "Highest sequence number received from peer",
258 "ns3::TracedValueCallback::SequenceNumber32")
259 .AddTraceSource(
"HighestRxAck",
260 "Highest ack received from peer",
262 "ns3::TracedValueCallback::SequenceNumber32")
263 .AddTraceSource(
"PacingRate",
264 "The current TCP pacing rate",
266 "ns3::TracedValueCallback::DataRate")
267 .AddTraceSource(
"CongestionWindow",
268 "The TCP connection's congestion window",
270 "ns3::TracedValueCallback::Uint32")
271 .AddTraceSource(
"CongestionWindowInflated",
272 "The TCP connection's congestion window inflates as in older RFC",
274 "ns3::TracedValueCallback::Uint32")
275 .AddTraceSource(
"SlowStartThreshold",
276 "TCP slow start threshold (bytes)",
278 "ns3::TracedValueCallback::Uint32")
279 .AddTraceSource(
"Tx",
280 "Send tcp packet to IP protocol",
282 "ns3::TcpSocketBase::TcpTxRxTracedCallback")
283 .AddTraceSource(
"Retransmission",
284 "Notification of a TCP retransmission",
286 "ns3::TcpSocketBase::RetransmissionCallback")
287 .AddTraceSource(
"Rx",
288 "Receive tcp packet from IP protocol",
290 "ns3::TcpSocketBase::TcpTxRxTracedCallback")
291 .AddTraceSource(
"EcnEchoSeq",
292 "Sequence of last received ECN Echo",
294 "ns3::SequenceNumber32TracedValueCallback")
295 .AddTraceSource(
"EcnCeSeq",
296 "Sequence of last received CE",
298 "ns3::SequenceNumber32TracedValueCallback")
299 .AddTraceSource(
"EcnCwrSeq",
300 "Sequence of last received CWR",
302 "ns3::SequenceNumber32TracedValueCallback");
328 ok =
m_tcb->TraceConnectWithoutContext(
331 NS_ASSERT_MSG(ok,
"Could not connect trace source PacingRate");
333 ok =
m_tcb->TraceConnectWithoutContext(
"CongestionWindow",
335 NS_ASSERT_MSG(ok,
"Could not connect trace source CongestionWindow");
337 ok =
m_tcb->TraceConnectWithoutContext(
"CongestionWindowInflated",
339 NS_ASSERT_MSG(ok,
"Could not connect trace source CongestionWindowInflated");
341 ok =
m_tcb->TraceConnectWithoutContext(
"SlowStartThreshold",
343 NS_ASSERT_MSG(ok,
"Could not connect trace source SlowStartThreshold");
345 ok =
m_tcb->TraceConnectWithoutContext(
"CongState",
347 NS_ASSERT_MSG(ok,
"Could not connect trace source CongState");
349 ok =
m_tcb->TraceConnectWithoutContext(
"EcnState",
351 NS_ASSERT_MSG(ok,
"Could not connect trace source EcnState");
354 m_tcb->TraceConnectWithoutContext(
"NextTxSequence",
356 NS_ASSERT_MSG(ok,
"Could not connect trace source NextTxSequence");
358 ok =
m_tcb->TraceConnectWithoutContext(
"HighestSequence",
360 NS_ASSERT_MSG(ok,
"Could not connect trace source HighestSequence");
362 ok =
m_tcb->TraceConnectWithoutContext(
"BytesInFlight",
364 NS_ASSERT_MSG(ok,
"Could not connect trace source BytesInFlight");
366 ok =
m_tcb->TraceConnectWithoutContext(
"FackAwnd",
368 NS_ASSERT_MSG(ok,
"Could not connect trace source FackAwnd");
373 ok =
m_tcb->TraceConnectWithoutContext(
"LastRTT",
477 if (
m_tcb->m_sendEmptyPacketCallback.IsNull())
487 ok =
m_tcb->TraceConnectWithoutContext(
490 NS_ASSERT_MSG(ok,
"Could not connect trace source PacingRate");
492 ok =
m_tcb->TraceConnectWithoutContext(
"CongestionWindow",
494 NS_ASSERT_MSG(ok,
"Could not connect trace source CongestionWindow");
496 ok =
m_tcb->TraceConnectWithoutContext(
"CongestionWindowInflated",
498 NS_ASSERT_MSG(ok,
"Could not connect trace source CongestionWindowInflated");
500 ok =
m_tcb->TraceConnectWithoutContext(
"SlowStartThreshold",
502 NS_ASSERT_MSG(ok,
"Could not connect trace source SlowStartThreshold");
504 ok =
m_tcb->TraceConnectWithoutContext(
"CongState",
506 NS_ASSERT_MSG(ok,
"Could not connect trace source CongState");
508 ok =
m_tcb->TraceConnectWithoutContext(
"EcnState",
510 NS_ASSERT_MSG(ok,
"Could not connect trace source EcnState");
513 m_tcb->TraceConnectWithoutContext(
"NextTxSequence",
515 NS_ASSERT_MSG(ok,
"Could not connect trace source NextTxSequence");
517 ok =
m_tcb->TraceConnectWithoutContext(
"HighestSequence",
519 NS_ASSERT_MSG(ok,
"Could not connect trace source HighestSequence");
520 ok =
m_tcb->TraceConnectWithoutContext(
"BytesInFlight",
522 NS_ASSERT_MSG(ok,
"Could not connect trace source BytesInFlight");
524 ok =
m_tcb->TraceConnectWithoutContext(
"FackAwnd",
530 ok =
m_tcb->TraceConnectWithoutContext(
"LastRTT",
618 m_tcp->AddSocket(
this);
634 m_tcp->AddSocket(
this);
705 m_tcp->AddSocket(
this);
717 "TcpSocketBase::SetSSThresh() cannot change initial ssThresh after connection started.");
719 m_tcb->m_initialSsThresh = threshold;
725 return m_tcb->m_initialSsThresh;
733 "TcpSocketBase::SetInitialCwnd() cannot change initial cwnd after connection started.");
735 m_tcb->m_initialCWnd = cwnd;
741 return m_tcb->m_initialCWnd;
847 if (
m_tcb->m_rxBuffer->Size() != 0)
849 NS_LOG_WARN(
"Socket " <<
this <<
" << unread rx data during close. Sending reset."
850 <<
"This is probably due to a bad sink application; check its code");
916 NS_ABORT_MSG_IF(flags,
"use of flags is not supported in TcpSocketBase::Send()");
932 m_tcb->m_bytesInFlight,
933 m_tcb->m_segmentSize,
935 m_tcb->m_nextTxSequence,
965 return Send(p, flags);
974 NS_ABORT_MSG_IF(flags,
"use of flags is not supported in TcpSocketBase::Recv()");
990 if (packet && packet->GetSize() != 0)
1023 return m_tcb->m_rxBuffer->Available();
1232 return (
m_tcb->m_rxBuffer->NextRxSequence() != head);
1236 return (tail < m_tcb->m_rxBuffer->NextRxSequence() ||
1237 m_tcb->m_rxBuffer->MaxRxSequence() <= head);
1257 uint32_t bytesRemoved = packet->PeekHeader(tcpHeader);
1261 packet->GetSize() - bytesRemoved))
1297 uint32_t bytesRemoved = packet->PeekHeader(tcpHeader);
1301 packet->GetSize() - bytesRemoved))
1334 m_icmpCallback(icmpSource, icmpTtl, icmpType, icmpCode, icmpInfo);
1359 if (tcpHeaderSize == 0 || tcpHeaderSize > 60)
1361 NS_LOG_ERROR(
"Bytes removed: " << tcpHeaderSize <<
" invalid");
1364 else if (tcpPayloadSize > 0 &&
OutOfRange(seq, seq + tcpPayloadSize))
1368 <<
":" << seq + tcpPayloadSize <<
") out of range ["
1369 <<
m_tcb->m_rxBuffer->NextRxSequence() <<
":"
1370 <<
m_tcb->m_rxBuffer->MaxRxSequence() <<
")");
1383 packet->RemovePacketTag(priorityTag);
1387 packet->RemoveHeader(tcpHeader);
1467 << seq <<
":" << seq + packet->GetSize()
1468 <<
") without TS option. Silently discard it");
1484 NS_LOG_LOGIC(
this <<
" Enter zerowindow persist state");
1486 this <<
" Cancelled ReTxTimeout event which was set to expire at "
1551 NS_LOG_LOGIC(
this <<
" Leaving zerowindow persist state");
1577 <<
" SND.UNA = " <<
m_txBuffer->HeadSequence());
1587 <<
" HighTxMark = " <<
m_tcb->m_highTxMark);
1596 <<
" -> ECN_SENDING_ECE");
1623 else if (tcpflags == 0)
1626 if (
m_tcb->m_rxBuffer->Finished())
1636 <<
" received. Reset packet is sent.");
1671 switch (option->GetKind())
1705 NS_LOG_INFO(
"Enter CWR recovery mode; set cwnd to " <<
m_tcb->m_cWnd <<
", ssthresh to "
1706 <<
m_tcb->m_ssThresh <<
", recover to "
1756 <<
"Reset cwnd to " <<
m_tcb->m_cWnd <<
", ssthresh to "
1758 <<
" calculated in flight: " << bytesInFlight);
1763 NS_ASSERT_MSG(sz > 0,
"SendDataPacket returned zero, indicating zero bytes were sent");
1797 "From OPEN->DISORDER but with " <<
m_dupAckCount <<
" dup ACKs");
1907 uint64_t previousDelivered =
m_rateOps->GetConnectionRate().m_delivered;
1913 if (ackNumber < oldHeadSequence)
1915 NS_LOG_DEBUG(
"Possibly received a stale ACK (ack number < head sequence)");
1917 if (packet->GetSize() > 0)
1923 if ((ackNumber > oldHeadSequence) && (ackNumber <
m_recover) &&
1926 uint32_t segAcked = (ackNumber - oldHeadSequence) /
m_tcb->m_segmentSize;
1927 for (
uint32_t i = 0; i < segAcked; i++)
1929 if (
m_txBuffer->IsRetransmittedDataAcked(ackNumber - (i *
m_tcb->m_segmentSize)))
1931 m_tcb->m_isRetransDataAcked =
true;
1932 NS_LOG_DEBUG(
"Ack Number " << ackNumber <<
"is ACK of retransmitted packet.");
1939 auto currentDelivered =
1940 static_cast<uint32_t>(
m_rateOps->GetConnectionRate().m_delivered - previousDelivered);
1941 m_tcb->m_lastAckedSackedBytes = currentDelivered;
1979 NS_LOG_INFO(
"Update bytes in flight before processing the ACK.");
1982 bool receivedData = packet->GetSize() > 0;
1986 ProcessAck(ackNumber, (bytesSacked > 0), currentDelivered, oldHeadSequence, receivedData);
1987 m_tcb->m_isRetransDataAcked =
false;
1993 (currentLost > previousLost) ? currentLost - previousLost : previousLost - currentLost;
1994 auto rateSample =
m_rateOps->GenerateSample(currentDelivered,
1999 auto rateConn =
m_rateOps->GetConnectionRate();
2016 bool scoreboardUpdated,
2021 NS_LOG_FUNCTION(
this << ackNumber << scoreboardUpdated << currentDelivered << oldHeadSequence);
2025 bool exitedFastRecovery =
false;
2027 m_tcb->m_lastAckedSeq = ackNumber;
2064 : (ackNumber == oldHeadSequence &&
2065 ackNumber <
m_tcb->m_highTxMark && !receivedData);
2067 NS_LOG_DEBUG(
"ACK of " << ackNumber <<
" SND.UNA=" << oldHeadSequence
2068 <<
" SND.NXT=" <<
m_tcb->m_nextTxSequence
2080 DupAck(currentDelivered);
2083 if (ackNumber == oldHeadSequence && ackNumber ==
m_tcb->m_highTxMark)
2088 else if (ackNumber == oldHeadSequence && ackNumber >
m_tcb->m_highTxMark)
2092 NS_LOG_DEBUG(
"Update nextTxSequence manually to " << ackNumber);
2093 m_tcb->m_nextTxSequence = ackNumber;
2095 else if (ackNumber == oldHeadSequence)
2100 else if (ackNumber > oldHeadSequence)
2104 bytesAcked = currentDelivered;
2107 bytesAcked -= bytesAcked %
m_tcb->m_segmentSize;
2112 bytesAcked +=
m_tcb->m_segmentSize;
2116 <<
" based on currentDelivered: " << currentDelivered);
2147 NS_LOG_INFO(
"Partial ACK. Manually setting head as lost");
2159 if (!
m_txBuffer->IsRetransmittedDataAcked(ackNumber +
m_tcb->m_segmentSize))
2174 <<
" and this is the first (RTO will be reset);"
2184 <<
" and this is NOT the first (RTO will not be reset)"
2200 <<
" ssTh=" <<
m_tcb->m_ssThresh);
2205 "Some segment got dup-acked in CA_LOSS state: " <<
m_txBuffer->GetSacked());
2228 if (segsAcked >= oldDupAckCount)
2231 segsAcked - oldDupAckCount,
2241 NS_LOG_DEBUG(segsAcked <<
" segments acked in CA_DISORDER, ack of " << ackNumber
2242 <<
" exiting CA_DISORDER -> CA_OPEN");
2246 NS_LOG_DEBUG(segsAcked <<
" segments acked in CA_DISORDER, ack of " << ackNumber
2247 <<
" but still in CA_DISORDER");
2268 static_cast<uint32_t>(ackNumber - oldHeadSequence) /
m_tcb->m_segmentSize;
2273 exitedFastRecovery =
true;
2276 NS_LOG_DEBUG(segsAcked <<
" segments acked in CA_RECOVER, ack of " << ackNumber
2277 <<
", exiting CA_RECOVERY -> CA_OPEN");
2292 NS_LOG_DEBUG(segsAcked <<
" segments acked in CA_LOSS, ack of" << ackNumber
2293 <<
", exiting CA_LOSS -> CA_OPEN");
2304 if (exitedFastRecovery)
2309 NS_LOG_DEBUG(
"Leaving Fast Recovery; BytesInFlight() = "
2319 <<
" ssTh: " <<
m_tcb->m_ssThresh
2320 <<
" segsAcked: " << segsAcked);
2429 m_tcb->m_highTxMark = ++
m_tcb->m_nextTxSequence;
2461 <<
" received in SYN_SENT. Reset packet is sent.");
2481 if (tcpflags == 0 ||
2493 m_tcb->m_highTxMark = ++
m_tcb->m_nextTxSequence;
2545 m_tcb->m_highTxMark = ++
m_tcb->m_nextTxSequence;
2566 <<
" received. Reset packet is sent.");
2624 <<
" received. Reset packet is sent.");
2682 <<
" received. Reset packet is sent.");
2720 <<
" received. Reset packet is sent.");
2749 if (!
m_tcb->m_rxBuffer->Finished())
2784 NS_LOG_LOGIC(
"TCP " <<
this <<
" calling NotifyNormalClose");
2799 NS_LOG_LOGIC(
"TcpSocketBase " <<
this <<
" scheduling LATO1");
2814 m_tcp->RemoveSocket(
this);
2816 NS_LOG_LOGIC(
this <<
" Cancelled ReTxTimeout event which was set to expire at "
2830 m_tcp->RemoveSocket(
this);
2832 NS_LOG_LOGIC(
this <<
" Cancelled ReTxTimeout event which was set to expire at "
2845 NS_LOG_WARN(
"Failed to send empty packet due to null endpoint");
2961 NS_LOG_INFO(
"Sending a pure ACK, acking seq " <<
m_tcb->m_rxBuffer->NextRxSequence());
2968 m_tcp->SendPacket(p,
2976 m_tcp->SendPacket(p,
2983 if (
m_retxEvent.IsExpired() && (hasSyn || hasFin) && !isAck)
2985 NS_LOG_LOGIC(
"Schedule retransmission timeout at time "
3017 m_tcp->RemoveSocket(
this);
3025 m_tcp->RemoveSocket(
this);
3036 if (!ipv4->GetRoutingProtocol())
3047 route = ipv4->GetRoutingProtocol()->RouteOutput(
Ptr<Packet>(), header, oif, errno_);
3056 m_endPoint->SetLocalAddress(route->GetSource());
3066 if (!ipv6->GetRoutingProtocol())
3077 route = ipv6->GetRoutingProtocol()->RouteOutput(
Ptr<Packet>(), header, oif, errno_);
3119 m_tcp->AddSocket(
this);
3182 p->AddPacketTag(ipTosTag);
3191 p->AddPacketTag(ipTosTag);
3208 p->AddPacketTag(ipTclassTag);
3217 p->AddPacketTag(ipTclassTag);
3225 p->AddPacketTag(ipTtlTag);
3232 p->AddPacketTag(ipHopLimitTag);
3240 p->ReplacePacketTag(priorityTag);
3254 m_rateOps->SkbSent(outItem, isStartOfTransmission);
3256 bool isRetransmission = outItem->
IsRetrans();
3274 <<
m_tcb->m_pacingRate.Get().CalculateBytesTxTime(sz));
3341 NS_LOG_LOGIC(
this <<
" SendDataPacket Schedule ReTxTimeout at time "
3348 if (isRetransmission)
3370 m_tcp->SendPacket(p,
3376 << sz <<
" with remaining data " << remainingData <<
" via TcpL4Protocol to "
3377 <<
m_endPoint->GetPeerAddress() <<
". Header " << header);
3381 m_tcp->SendPacket(p,
3387 << sz <<
" with remaining data " << remainingData <<
" via TcpL4Protocol to "
3388 <<
m_endPoint6->GetPeerAddress() <<
". Header " << header);
3408 if (!isRetransmission)
3412 (seq + sz -
m_tcb->m_highTxMark.Get()));
3415 m_tcb->m_highTxMark = std::max(seq + sz,
m_tcb->m_highTxMark.Get());
3425 if (!isRetransmission)
3455 "TcpSocketBase::SendPendingData: No endpoint; m_shutdownSend=" <<
m_shutdownSend);
3467 while (availableWindow > 0)
3482 NS_LOG_INFO(
"FIN_WAIT and OPEN state; no data to transmit");
3493 if (!
m_txBuffer->NextSeg(&next, &nextHigh, enableRule3))
3495 NS_LOG_INFO(
"no valid seq to transmit, or no data available");
3505 if (availableData < availableWindow)
3512 if (availableWindow < m_tcb->m_segmentSize && availableData > availableWindow)
3514 NS_LOG_LOGIC(
"Preventing Silly Window Syndrome. Wait to send.");
3522 << next <<
", SFS: " <<
m_txBuffer->SizeFromSequence(next)
3523 <<
". Wait to send.");
3527 uint32_t s = std::min(availableWindow,
m_tcb->m_segmentSize);
3529 auto maxSizeToSend =
static_cast<uint32_t>(nextHigh - next);
3530 s = std::min(s, maxSizeToSend);
3541 if (
m_tcb->m_nextTxSequence != next)
3543 m_tcb->m_nextTxSequence = next;
3545 if (
m_tcb->m_bytesInFlight.Get() == 0)
3552 <<
" highestRxAck " <<
m_txBuffer->HeadSequence() <<
" pd->Size "
3557 <<
" sent seq " <<
m_tcb->m_nextTxSequence <<
" size " << sz);
3558 m_tcb->m_nextTxSequence += sz;
3567 <<
m_tcb->m_pacingRate.Get().CalculateBytesTxTime(sz));
3585 if (nPacketsSent > 0)
3596 NS_LOG_DEBUG(
"SendPendingData sent " << nPacketsSent <<
" segments");
3602 return nPacketsSent;
3617 m_tcb->m_bytesInFlight = bytesInFlight;
3619 NS_LOG_DEBUG(
"Returning calculated bytesInFlight: " << bytesInFlight);
3620 return bytesInFlight;
3626 return std::min(
m_rWnd.Get(),
m_tcb->m_cWnd.Get());
3638 NS_LOG_DEBUG(
"FACK is enabled and win >= ssthresh (" <<
m_tcb->m_ssThresh <<
")");
3643 m_tcb->m_fackAwnd = awnd;
3646 <<
", RetranData :" << retranData);
3648 uint32_t awndDiff = (win > awnd) ? (win - awnd) : 0;
3649 NS_LOG_DEBUG(
"AWND: " << awnd <<
", win: " << win <<
", AWND_DIFF: " << awndDiff);
3655 if (inflight >= win)
3660 return win - inflight;
3671 if (
m_tcb->m_rxBuffer->GotFin())
3678 "Unexpected sequence number values");
3679 w =
static_cast<uint32_t>(
m_tcb->m_rxBuffer->MaxRxSequence() -
3680 m_tcb->m_rxBuffer->NextRxSequence());
3697 <<
m_maxWinSize <<
"; possibly to avoid overflow of the 16-bit integer");
3699 NS_LOG_LOGIC(
"Returning AdvertisedWindowSize of " <<
static_cast<uint16_t
>(w));
3700 return static_cast<uint16_t
>(w);
3709 <<
" pkt size=" << p->GetSize());
3713 if (!
m_tcb->m_rxBuffer->Add(p, tcpHeader))
3729 if (expectedSeq < m_tcb->m_rxBuffer->NextRxSequence())
3738 NS_LOG_WARN(
"Why TCP " <<
this <<
" got data after close notification?");
3749 if (
m_tcb->m_rxBuffer->Size() >
m_tcb->m_rxBuffer->Available() ||
3750 m_tcb->m_rxBuffer->NextRxSequence() > expectedSeq + p->GetSize())
3778 <<
" -> ECN_SENDING_ECE");
3796 this <<
" scheduled delayed ACK at "
3826 NS_LOG_LOGIC(
"TcpSocketBase::EstimateRtt - RTT calculated from TcpOption::TS "
3827 "is zero, approximating to 1us.");
3828 NS_LOG_DEBUG(
"RTT calculated from TcpOption::TS is zero, updating rtt to 1us.");
3832 else if (!rttHistory.
retx)
3857 RttHistory latestTransmittedPktHistory = earliestTransmittedPktHistory;
3868 latestTransmittedPktHistory = rttHistory;
3878 NS_LOG_DEBUG(
"Last RTT sample updated to: " << lastRtt);
3879 m_tcb->m_lastRtt = lastRtt;
3885 m_rtt->Measurement(rtt);
3916 this <<
" Cancelled ReTxTimeout event which was set to expire at "
3925 <<
" to expire at time "
3931 NS_LOG_LOGIC(
"TCP " <<
this <<
" NewAck " << ack <<
" numberAck "
3938 if (ack >
m_tcb->m_nextTxSequence)
3940 m_tcb->m_nextTxSequence = ack;
3945 this <<
" Cancelled ReTxTimeout event which was set to expire at "
3993 <<
m_tcb->m_highTxMark);
3999 NS_LOG_INFO(
"No more data retries available. Dropping connection");
4069 <<
", restart from seqnum " <<
m_txBuffer->HeadSequence()
4070 <<
" doubled rto to " <<
m_rto.Get().GetSeconds() <<
" s");
4073 "There are some bytes in flight after an RTO: " <<
BytesInFlight());
4078 "In flight (" <<
BytesInFlight() <<
") there is more than one segment ("
4079 <<
m_tcb->m_segmentSize <<
")");
4109 NS_LOG_INFO(
"LAST-ACK: No more data retries available. Dropping connection");
4116 NS_LOG_LOGIC(
"TcpSocketBase " <<
this <<
" rescheduling LATO1");
4157 m_tcp->SendPacket(p,
4165 m_tcp->SendPacket(p,
4189 res =
m_txBuffer->NextSeg(&seq, &seqHigh,
false);
4196 maxSizeToSend =
m_tcb->m_segmentSize;
4201 maxSizeToSend =
static_cast<uint32_t>(seqHigh - seq);
4207 m_tcb->m_nextTxSequence = seq;
4278 m_tcb->m_rxBuffer->SetMaxBufferSize(size);
4302 return m_tcb->m_rxBuffer->MaxBufferSize();
4309 m_tcb->m_segmentSize = size;
4318 return m_tcb->m_segmentSize;
4417 return (!allowBroadcast);
4467 maxSpace = maxSpace >> 1;
4473 NS_LOG_WARN(
"Possible error; scale exceeds 14: " << scale);
4478 <<
static_cast<int>(scale) <<
" for buffer size "
4479 <<
m_tcb->m_rxBuffer->MaxBufferSize());
4513 for (
const auto& [leftEdge, rightEdge] : s->GetSackList())
4518 << rightEdge.GetValue());
4556 uint8_t allowedSackBlocks = (optionLenAvail - 2) / 8;
4559 if (allowedSackBlocks == 0 || sackList.empty())
4561 NS_LOG_LOGIC(
"No space available or sack list empty, not adding sack blocks");
4568 for (
auto i = sackList.begin(); allowedSackBlocks > 0 && i != sackList.end(); ++i)
4570 option->AddSackBlock(*i);
4571 allowedSackBlocks--;
4588 if (
m_tcb->m_rcvTimestampValue > ts->GetTimestamp())
4594 m_tcb->m_rcvTimestampValue = ts->GetTimestamp();
4595 m_tcb->m_rcvTimestampEchoReply = ts->GetEcho();
4603 <<
" and Echo=" << ts->GetEcho());
4629 NS_LOG_INFO(
"Received (scaled) window is " << receivedWindow <<
" bytes");
4643 bool update =
false;
4701 return m_tcb->m_rxBuffer;
4830 if (!
m_tcb->m_pacing)
4836 if (
m_tcb->m_paceInitialWindow)
4875 <<
m_tcb->m_ssThresh);
4876 factor =
static_cast<double>(
m_tcb->m_pacingSsRatio) / 100;
4880 NS_LOG_DEBUG(
"Pacing according to congestion avoidance factor; " <<
m_tcb->m_cWnd <<
" "
4881 <<
m_tcb->m_ssThresh);
4882 factor =
static_cast<double>(
m_tcb->m_pacingCaRatio) / 100;
4890 if (pacingRate < m_tcb->m_maxPacingRate)
4892 NS_LOG_DEBUG(
"Pacing rate updated to: " << pacingRate);
4893 m_tcb->m_pacingRate = pacingRate;
4898 m_tcb->m_pacingRate =
m_tcb->m_maxPacingRate;
4906 m_tcb->m_pacing = pacing;
4913 m_tcb->m_paceInitialWindow = paceWindow;
4927 "Invalid packetType and ecnMode");
4929 return ECN_RESTRICTION_MAP.at(std::make_pair(packetType,
m_tcb->m_ecnMode));
4936 m_tcb->m_useEcn = useEcn;
4948 m_tcb->m_abeEnabled = useAbe;
4954 return m_tcb->m_abeEnabled;
a polymophic address class
AttributeValue implementation for Boolean.
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.
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()
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.
IPv6 layer implementation.
AttributeValue implementation for Pointer.
Smart pointer class similar to boost::intrusive_ptr.
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.
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.
bool IsManualIpTtl() const
Checks if the socket has a specific IPv4 TTL set.
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.
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.
void SetRecvCallback(Callback< void, Ptr< Socket > > receivedData)
Notify application when new data is available to be read.
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 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.
@ 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 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.
void AddSocketTags(const Ptr< Packet > &p, bool isEct) const
Add Tags for the Socket.
Ptr< TcpTxBuffer > GetTxBuffer() const
Get a pointer to the Tx buffer.
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.
void CancelAllTimers()
Cancel all timer when endpoint is deleted.
bool GetFackEnabled() const
Check whether Forward Acknowledgment (FACK) is enabled.
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.
uint32_t m_sndFack
Sequence number of the forward most acknowledgement.
void SetDelAckTimeout(Time timeout) override
Set the time to delay an ACK.
uint32_t m_outstandingRetransBytes
Number of outstanding retransmitted bytes.
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 Last 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.
TracedCallback< uint32_t, uint32_t > m_fackAwndTrace
Callback pointer for fackAwnd trace chaining.
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.
virtual void ProcessAck(const SequenceNumber32 &ackNumber, bool scoreboardUpdated, uint32_t currentDelivered, const SequenceNumber32 &oldHeadSequence, bool receivedData)
Process a received ack.
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.
SocketType GetSocketType() const override
int ShutdownSend() override
uint32_t GetSndFack() const
Get the current FACK sequence number.
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.
void UpdateLastRtt(Time oldValue, Time newValue) const
Callback function to hook to TcpSocketState lastRtt.
TracedCallback< Ptr< const Packet >, const TcpHeader &, const Address &, const Address &, Ptr< const TcpSocketBase > > m_retransmissionTrace
Trace of retransmitted packets.
uint32_t m_delAckCount
Delayed ACK counter.
Ipv4EndPoint * m_endPoint
the IPv4 endpoint
TcpPacketType_t
Tcp Packet Types.
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).
bool IsEct(TcpPacketType_t packetType) const
Checks if a TCP packet should be ECN-capable (ECT) according to the TcpPacketType and ECN mode.
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.
void SetUseAbe(bool useAbe)
Set ABE mode of use on the socket.
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.
bool m_useAbe
ABE mode It will override the UseEcn attribute if it is 'Off' and set it to 'On', but will leave it u...
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.
SocketErrno GetErrno() const override
Get last error number.
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.
bool GetUseAbe() const
Get ABE mode of use on the socket.
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.
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.
TracedCallback< Time, Time > m_srttTrace
Callback pointer for RTT trace chaining.
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.
bool m_fackEnabled
flag for enabling FACK
int DoConnect()
Perform the real connection tasks: Send SYN if allowed, RST if invalid.
virtual Time CalculateRttSample(const TcpHeader &tcpHeader, const RttHistory &rttHistory)
Calculate RTT sample for the ACKed packet.
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 NotifyConstructionCompleted() override
Notifier called once the ObjectBase is fully constructed.
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.
void UpdateFackAwnd(uint32_t oldValue, uint32_t newValue) const
Callback function to hook to TcpSocketState awnd(FACK's inflight).
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.
TracedCallback< uint32_t, uint32_t > m_cWndInflTrace
Callback pointer for cWndInfl trace chaining.
uint32_t GetRcvBufSize() const override
Get the receive buffer size.
static const char *const TcpStateName[TcpSocket::LAST_STATE]
Literal names of TCP states for use in log messages.
@ 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
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.
static INTERNET_EXPORT 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.
@ DctcpEcn
ECN functionality as described in RFC 8257.
@ ClassicEcn
ECN functionality as described in RFC 3168.
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.
static INTERNET_EXPORT const char *const EcnStateName[TcpSocketState::ECN_CWR_SENT+1]
Literal names of ECN states for use in log messages.
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.
Time TimeStep(uint64_t ts)
Scheduler interface.
static Time FromDouble(double value, Unit unit)
Create a Time equal to value in unit unit.
bool IsZero() const
Exactly equivalent to t == 0.
AttributeValue implementation for Time.
A simple virtual Timer class.
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 AttributeChecker > MakeBooleanChecker()
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 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 AttributeChecker > MakeDoubleChecker()
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< AttributeChecker > MakePointerChecker()
Create a PointerChecker for a type.
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 AttributeChecker > MakeTimeChecker()
Helper to make an unbounded Time checker.
Ptr< const AttributeChecker > MakeUintegerChecker()
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
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...
Callback< R, Args... > MakeNullCallback()
Build null Callbacks which take no arguments, for varying number of template arguments,...
#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.
#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.
Ptr< T > CreateObject(Args &&... args)
Create an object by type, with varying number of constructor parameters.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Ptr< T > Create(Ts &&... args)
Create class instances by constructors with varying numbers of arguments and return them by Ptr.
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.
const std::map< std::pair< ns3::TcpSocketBase::TcpPacketType_t, ns3::TcpSocketState::EcnMode_t >, bool > ECN_RESTRICTION_MAP
map TcpPacketType and EcnMode to boolean value to check whether ECN-marking is allowed or not
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ptr< const AttributeChecker > MakeEnumChecker(T v, std::string n, Ts... args)
Make an EnumChecker pre-configured with a set of allowed values by name.
Ptr< T1 > DynamicCast(const Ptr< T2 > &p)
Cast a Ptr.
Ptr< T > CopyObject(Ptr< const T > object)