A Discrete-Event Network Simulator
API
tcp-socket-base.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2007 Georgia Tech Research Corporation
3  * Copyright (c) 2010 Adrian Sai-wah Tam
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Adrian Sai-wah Tam <adrian.sw.tam@gmail.com>
19  */
20 #ifndef TCP_SOCKET_BASE_H
21 #define TCP_SOCKET_BASE_H
22 
23 #include "ipv4-header.h"
24 #include "ipv6-header.h"
25 #include "tcp-socket-state.h"
26 #include "tcp-socket.h"
27 
28 #include "ns3/data-rate.h"
29 #include "ns3/node.h"
30 #include "ns3/sequence-number.h"
31 #include "ns3/timer.h"
32 #include "ns3/traced-value.h"
33 
34 #include <queue>
35 #include <stdint.h>
36 
37 namespace ns3
38 {
39 
40 class Ipv4EndPoint;
41 class Ipv6EndPoint;
42 class Node;
43 class Packet;
44 class TcpL4Protocol;
45 class TcpHeader;
46 class TcpCongestionOps;
47 class TcpRecoveryOps;
48 class RttEstimator;
49 class TcpRxBuffer;
50 class TcpTxBuffer;
51 class TcpOption;
52 class Ipv4Interface;
53 class Ipv6Interface;
54 class TcpRateOps;
55 
62 {
63  public:
70  RttHistory(SequenceNumber32 s, uint32_t c, Time t);
75  RttHistory(const RttHistory& h); // Copy constructor
76  public:
78  uint32_t count;
80  bool retx;
81 };
82 
219 class TcpSocketBase : public TcpSocket
220 {
221  public:
227  static TypeId GetTypeId();
228 
233  TypeId GetInstanceTypeId() const override;
234 
239  friend class TcpGeneralTest;
240 
244  TcpSocketBase();
245 
251  TcpSocketBase(const TcpSocketBase& sock);
252  ~TcpSocketBase() override;
253 
254  // Set associated Node, TcpL4Protocol, RttEstimator to this socket
255 
260  virtual void SetNode(Ptr<Node> node);
261 
266  virtual void SetTcp(Ptr<TcpL4Protocol> tcp);
267 
272  virtual void SetRtt(Ptr<RttEstimator> rtt);
273 
278  void SetMinRto(Time minRto);
279 
284  Time GetMinRto() const;
285 
290  void SetClockGranularity(Time clockGranularity);
291 
296  Time GetClockGranularity() const;
297 
303 
309 
314  void SetRetxThresh(uint32_t retxThresh);
315 
320  uint32_t GetRetxThresh() const
321  {
322  return m_retxThresh;
323  }
324 
329 
334 
339 
344 
349 
354 
359 
364 
369 
374 
380  void UpdatePacingRateTrace(DataRate oldValue, DataRate newValue) const;
381 
387  void UpdateCwnd(uint32_t oldValue, uint32_t newValue) const;
388 
394  void UpdateCwndInfl(uint32_t oldValue, uint32_t newValue) const;
395 
401  void UpdateSsThresh(uint32_t oldValue, uint32_t newValue) const;
402 
409  TcpSocketState::TcpCongState_t newValue) const;
410 
417  TcpSocketState::EcnState_t newValue) const;
418 
424  void UpdateHighTxMark(SequenceNumber32 oldValue, SequenceNumber32 newValue) const;
425 
431  void UpdateNextTxSequence(SequenceNumber32 oldValue, SequenceNumber32 newValue) const;
432 
438  void UpdateBytesInFlight(uint32_t oldValue, uint32_t newValue) const;
439 
445  void UpdateRtt(Time oldValue, Time newValue) const;
446 
453 
460 
467  inline uint8_t MarkEcnEct0(uint8_t tos) const
468  {
469  return ((tos & 0xfc) | 0x02);
470  }
471 
478  inline uint8_t MarkEcnEct1(uint8_t tos) const
479  {
480  return ((tos & 0xfc) | 0x01);
481  }
482 
489  inline uint8_t MarkEcnCe(uint8_t tos) const
490  {
491  return ((tos & 0xfc) | 0x03);
492  }
493 
500  inline uint8_t ClearEcnBits(uint8_t tos) const
501  {
502  return tos & 0xfc;
503  }
504 
511  inline bool CheckNoEcn(uint8_t tos) const
512  {
513  return ((tos & 0x03) == 0x00);
514  }
515 
522  inline bool CheckEcnEct0(uint8_t tos) const
523  {
524  return ((tos & 0x03) == 0x02);
525  }
526 
533  inline bool CheckEcnEct1(uint8_t tos) const
534  {
535  return ((tos & 0x03) == 0x01);
536  }
537 
544  inline bool CheckEcnCe(uint8_t tos) const
545  {
546  return ((tos & 0x03) == 0x03);
547  }
548 
556  inline uint8_t MarkEcnCodePoint(const uint8_t tos,
557  const TcpSocketState::EcnCodePoint_t codePoint) const
558  {
559  return ((tos & 0xfc) | codePoint);
560  }
561 
567  void SetUseEcn(TcpSocketState::UseEcn_t useEcn);
568 
573  void SetPacingStatus(bool pacing);
574 
579  void SetPaceInitialWindow(bool paceWindow);
580 
581  // Necessary implementations of null functions from ns3::Socket
582  SocketErrno GetErrno() const override; // returns m_errno
583  SocketType GetSocketType() const override; // returns socket type
584  Ptr<Node> GetNode() const override; // returns m_node
585  int Bind() override; // Bind a socket by setting up endpoint in TcpL4Protocol
586  int Bind6() override; // Bind a socket by setting up endpoint in TcpL4Protocol
587  int Bind(const Address& address) override; // ... endpoint of specific addr or port
588  int Connect(
589  const Address& address) override; // Setup endpoint and call ProcessAction() to connect
590  int Listen()
591  override; // Verify the socket is in a correct state and call ProcessAction() to listen
592  int Close() override; // Close by app: Kill socket upon tx buffer emptied
593  int ShutdownSend() override; // Assert the m_shutdownSend flag to prevent send to network
594  int ShutdownRecv() override; // Assert the m_shutdownRecv flag to prevent forward to app
595  int Send(Ptr<Packet> p, uint32_t flags) override; // Call by app to send data to network
596  int SendTo(Ptr<Packet> p,
597  uint32_t flags,
598  const Address& toAddress) override; // Same as Send(), toAddress is insignificant
599  Ptr<Packet> Recv(uint32_t maxSize,
600  uint32_t flags) override; // Return a packet to be forwarded to app
601  Ptr<Packet> RecvFrom(uint32_t maxSize, uint32_t flags, Address& fromAddress)
602  override; // ... and write the remote address at fromAddress
603  uint32_t GetTxAvailable() const override; // Available Tx buffer size
604  uint32_t GetRxAvailable()
605  const override; // Available-to-read data size, i.e. value of m_rxAvailable
606  int GetSockName(Address& address) const override; // Return local addr:port in address
607  int GetPeerName(Address& address) const override;
608  void BindToNetDevice(Ptr<NetDevice> netdevice) override; // NetDevice with my m_endPoint
609 
617  typedef void (*TcpTxRxTracedCallback)(const Ptr<const Packet> packet,
618  const TcpHeader& header,
619  const Ptr<const TcpSocketBase> socket);
620 
621  protected:
622  // Implementing ns3::TcpSocket -- Attribute get/set
623  // inherited, no need to doc
624 
625  void SetSndBufSize(uint32_t size) override;
626  uint32_t GetSndBufSize() const override;
627  void SetRcvBufSize(uint32_t size) override;
628  uint32_t GetRcvBufSize() const override;
629  void SetSegSize(uint32_t size) override;
630  uint32_t GetSegSize() const override;
631  void SetInitialSSThresh(uint32_t threshold) override;
632  uint32_t GetInitialSSThresh() const override;
633  void SetInitialCwnd(uint32_t cwnd) override;
634  uint32_t GetInitialCwnd() const override;
635  void SetConnTimeout(Time timeout) override;
636  Time GetConnTimeout() const override;
637  void SetSynRetries(uint32_t count) override;
638  uint32_t GetSynRetries() const override;
639  void SetDataRetries(uint32_t retries) override;
640  uint32_t GetDataRetries() const override;
641  void SetDelAckTimeout(Time timeout) override;
642  Time GetDelAckTimeout() const override;
643  void SetDelAckMaxCount(uint32_t count) override;
644  uint32_t GetDelAckMaxCount() const override;
645  void SetTcpNoDelay(bool noDelay) override;
646  bool GetTcpNoDelay() const override;
647  void SetPersistTimeout(Time timeout) override;
648  Time GetPersistTimeout() const override;
649  bool SetAllowBroadcast(bool allowBroadcast) override;
650  bool GetAllowBroadcast() const override;
651 
652  // Helper functions: Connection set up
653 
659  int SetupCallback();
660 
666  int DoConnect();
667 
671  void ConnectionSucceeded();
672 
679  int SetupEndpoint();
680 
687  int SetupEndpoint6();
688 
701  virtual void CompleteFork(Ptr<Packet> p,
702  const TcpHeader& tcpHeader,
703  const Address& fromAddress,
704  const Address& toAddress);
705 
706  // Helper functions: Transfer operation
707 
716  bool IsValidTcpSegment(const SequenceNumber32 seq,
717  const uint32_t tcpHeaderSize,
718  const uint32_t tcpPayloadSize);
719 
728  void ForwardUp(Ptr<Packet> packet,
729  Ipv4Header header,
730  uint16_t port,
731  Ptr<Ipv4Interface> incomingInterface);
732 
741  void ForwardUp6(Ptr<Packet> packet,
742  Ipv6Header header,
743  uint16_t port,
744  Ptr<Ipv6Interface> incomingInterface);
745 
758  virtual void DoForwardUp(Ptr<Packet> packet,
759  const Address& fromAddress,
760  const Address& toAddress);
761 
771  void ForwardIcmp(Ipv4Address icmpSource,
772  uint8_t icmpTtl,
773  uint8_t icmpType,
774  uint8_t icmpCode,
775  uint32_t icmpInfo);
776 
786  void ForwardIcmp6(Ipv6Address icmpSource,
787  uint8_t icmpTtl,
788  uint8_t icmpType,
789  uint8_t icmpCode,
790  uint32_t icmpInfo);
791 
800  uint32_t SendPendingData(bool withAck = false);
801 
811  virtual uint32_t SendDataPacket(SequenceNumber32 seq, uint32_t maxSize, bool withAck);
812 
818  virtual void SendEmptyPacket(uint8_t flags);
819 
823  void SendRST();
824 
832  bool OutOfRange(SequenceNumber32 head, SequenceNumber32 tail) const;
833 
834  // Helper functions: Connection close
835 
841  int DoClose();
842 
846  void CloseAndNotify();
847 
854  void Destroy();
855 
862  void Destroy6();
863 
867  void DeallocateEndPoint();
868 
875  void PeerClose(Ptr<Packet> p, const TcpHeader& tcpHeader);
876 
880  void DoPeerClose();
881 
885  void CancelAllTimers();
886 
890  void TimeWait();
891 
892  // State transition functions
893 
902  void ProcessEstablished(Ptr<Packet> packet,
903  const TcpHeader& tcpHeader); // Received a packet upon ESTABLISHED state
904 
913  void ProcessListen(Ptr<Packet> packet,
914  const TcpHeader& tcpHeader,
915  const Address& fromAddress,
916  const Address& toAddress);
917 
924  void ProcessSynSent(Ptr<Packet> packet, const TcpHeader& tcpHeader);
925 
934  void ProcessSynRcvd(Ptr<Packet> packet,
935  const TcpHeader& tcpHeader,
936  const Address& fromAddress,
937  const Address& toAddress);
938 
945  void ProcessWait(Ptr<Packet> packet, const TcpHeader& tcpHeader);
946 
953  void ProcessClosing(Ptr<Packet> packet, const TcpHeader& tcpHeader);
954 
961  void ProcessLastAck(Ptr<Packet> packet, const TcpHeader& tcpHeader);
962 
963  // Window management
964 
972  virtual uint32_t UnAckDataCount() const;
973 
981  virtual uint32_t BytesInFlight() const;
982 
987  virtual uint32_t Window() const;
988 
993  virtual uint32_t AvailableWindow() const;
994 
1001  virtual uint16_t AdvertisedWindowSize(bool scale = true) const;
1002 
1015  void UpdateWindowSize(const TcpHeader& header);
1016 
1017  // Manage data tx/rx
1018 
1023  virtual Ptr<TcpSocketBase> Fork();
1024 
1030  virtual void ReceivedAck(Ptr<Packet> packet, const TcpHeader& tcpHeader);
1031 
1040  virtual void ProcessAck(const SequenceNumber32& ackNumber,
1041  bool scoreboardUpdated,
1042  uint32_t currentDelivered,
1043  const SequenceNumber32& oldHeadSequence);
1044 
1050  virtual void ReceivedData(Ptr<Packet> packet, const TcpHeader& tcpHeader);
1051 
1056  virtual void EstimateRtt(const TcpHeader& tcpHeader);
1057 
1066  virtual void UpdateRttHistory(const SequenceNumber32& seq, uint32_t sz, bool isRetransmission);
1067 
1073  virtual void NewAck(const SequenceNumber32& seq, bool resetRTO);
1074 
1080  void DupAck(uint32_t currentDelivered);
1081 
1087  void EnterCwr(uint32_t currentDelivered);
1088 
1094  void EnterRecovery(uint32_t currentDelivered);
1095 
1099  virtual void ReTxTimeout();
1100 
1104  virtual void DelAckTimeout();
1105 
1109  virtual void LastAckTimeout();
1110 
1114  virtual void PersistTimeout();
1115 
1120  void DoRetransmit();
1121 
1129  void AddOptions(TcpHeader& tcpHeader);
1130 
1139  void ReadOptions(const TcpHeader& tcpHeader, uint32_t* bytesSacked);
1140 
1147  bool IsTcpOptionEnabled(uint8_t kind) const;
1148 
1157  void ProcessOptionWScale(const Ptr<const TcpOption> option);
1166  void AddOptionWScale(TcpHeader& header);
1167 
1175  uint8_t CalculateWScale() const;
1176 
1186 
1193  uint32_t ProcessOptionSack(const Ptr<const TcpOption> option);
1194 
1200  void AddOptionSackPermitted(TcpHeader& header);
1201 
1207  void AddOptionSack(TcpHeader& header);
1208 
1219  void ProcessOptionTimestamp(const Ptr<const TcpOption> option, const SequenceNumber32& seq);
1228  void AddOptionTimestamp(TcpHeader& header);
1229 
1239  static uint32_t SafeSubtraction(uint32_t a, uint32_t b);
1240 
1244  void NotifyPacingPerformed();
1245 
1250  bool IsPacingEnabled() const;
1251 
1255  void UpdatePacingRate();
1256 
1261  void AddSocketTags(const Ptr<Packet>& p) const;
1262 
1268  uint32_t GetRWnd() const;
1269 
1276 
1277  protected:
1278  // Counters and events
1284 
1285  // ACK management
1286  uint32_t m_dupAckCount{0};
1287  uint32_t m_delAckCount{0};
1288  uint32_t m_delAckMaxCount{0};
1289 
1290  // Nagle algorithm
1291  bool m_noDelay{false};
1292 
1293  // Retries
1294  uint32_t m_synCount{0};
1295  uint32_t m_synRetries{0};
1296  uint32_t m_dataRetrCount{0};
1297  uint32_t m_dataRetries{0};
1298 
1299  // Timeouts
1306 
1307  // History of RTT
1308  std::deque<RttHistory> m_history;
1309 
1310  // Connections to other layers of TCP/IP
1319 
1321 
1322  // Tx buffer management
1324 
1325  // State-related attributes
1327 
1329 
1330  bool m_closeNotified{false};
1331  bool m_closeOnEmpty{false};
1332  bool m_shutdownSend{false};
1333  bool m_shutdownRecv{false};
1334  bool m_connected{false};
1335  double m_msl{0.0};
1336 
1337  // Window management
1338  uint16_t m_maxWinSize{0};
1345 
1346  // Options
1347  bool m_sackEnabled{true};
1348  bool m_winScalingEnabled{true};
1349  uint8_t m_rcvWindShift{0};
1350  uint8_t m_sndWindShift{0};
1351  bool m_timestampEnabled{true};
1352  uint32_t m_timestampToEcho{0};
1353 
1355 
1356  // Fast Retransmit and Recovery
1358  0};
1359  bool m_recoverActive{false};
1362  uint32_t m_retxThresh{3};
1363  bool m_limitedTx{true};
1364 
1365  // Transmission Control Block
1370 
1371  // Guesses over the other connection end
1372  bool m_isFirstPartialAck{true};
1373 
1374  // The following two traces pass a packet with a TCP header
1376  const TcpHeader&,
1379 
1381  const TcpHeader&,
1384 
1385  // Pacing related variable
1387 
1388  // Parameters related to Explicit Congestion Notification
1390  0};
1392  0};
1394 };
1395 
1404  const TcpSocketState::TcpCongState_t newValue);
1405 
1414  const TcpSocketState::EcnState_t newValue);
1415 
1416 } // namespace ns3
1417 
1418 #endif /* TCP_SOCKET_BASE_H */
a polymophic address class
Definition: address.h:101
Callback template class.
Definition: callback.h:438
Class for representing data rates.
Definition: data-rate.h:89
An identifier for simulation events.
Definition: event-id.h:55
Ipv4 addresses are stored in host order in this class.
Definition: ipv4-address.h:42
A representation of an internet endpoint/connection.
Packet header for IPv4.
Definition: ipv4-header.h:34
Describes an IPv6 address.
Definition: ipv6-address.h:49
A representation of an IPv6 endpoint/connection.
Packet header for IPv6.
Definition: ipv6-header.h:35
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.
Ptr< Packet > Recv()
Read a single packet from the socket.
Definition: socket.cc:174
SocketType
Enumeration of the possible socket types.
Definition: socket.h:107
SocketErrno
Enumeration of the possible errors returned by a socket.
Definition: socket.h:84
@ ERROR_NOTERROR
Definition: socket.h:85
General infrastructure for TCP testing.
Header for the Transmission Control Protocol.
Definition: tcp-header.h:47
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.
bool CheckEcnEct1(uint8_t tos) const
Checks for ECT(1) codepoint.
Ptr< TcpCongestionOps > m_congestionControl
Congestion control.
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.
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.
uint8_t MarkEcnEct1(uint8_t tos) const
Mark ECT(1) codepoint.
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.
uint8_t MarkEcnEct0(uint8_t tos) const
Mark ECT(0) codepoint.
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.
SocketType GetSocketType() const override
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)
uint8_t MarkEcnCe(uint8_t tos) const
Mark CE codepoint.
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(* TcpTxRxTracedCallback)(const Ptr< const Packet > packet, const TcpHeader &header, const Ptr< const TcpSocketBase > socket)
TracedCallback signature for tcp packet transmission or reception events.
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.
uint8_t ClearEcnBits(uint8_t tos) const
Clears ECN bits from TOS.
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.
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.
bool CheckEcnCe(uint8_t tos) const
Checks for CE codepoint.
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.
bool CheckEcnEct0(uint8_t tos) const
Checks for ECT(0) codepoint.
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.
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
Definition: tcp-socket.h:48
EcnCodePoint_t
ECN code points.
UseEcn_t
Parameter value related to ECN enable/disable functionality similar to sysctl for tcp_ecn.
TcpCongState_t
Definition of the Congestion state machine.
EcnState_t
Definition of the Ecn state machine.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
static Time Max()
Maximum representable Time Not to be confused with Max(Time,Time).
Definition: nstime.h:297
A simple virtual Timer class.
Definition: timer.h:74
@ CANCEL_ON_DESTROY
This policy cancels the event from the destructor of the Timer or from Suspend().
Definition: timer.h:93
Forward calls to a chain of Callback.
a unique identifier for an interface.
Definition: type-id.h:59
uint16_t port
Definition: dsdv-manet.cc:44
void(* EcnStatesTracedValueCallback)(const TcpSocketState::EcnState_t oldValue, const TcpSocketState::EcnState_t newValue)
TracedValue Callback signature for ECN state trace.
void(* TcpCongStatesTracedValueCallback)(const TcpSocketState::TcpCongState_t oldValue, const TcpSocketState::TcpCongState_t newValue)
TracedValue Callback signature for TcpCongState_t.
@ CLOSED
Socket is finished
Definition: tcp-socket.h:67
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1326
address
Definition: first.py:47
Every class exported by the ns3 library is enclosed in the ns3 namespace.
ns3::Time timeout