A Discrete-Event Network Simulator
API
tcp-prr-recovery.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2018 NITK Surathkal
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation;
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program; if not, write to the Free Software
15  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16  *
17  * Author: Viyom Mittal <viyommittal@gmail.com>
18  * Vivek Jain <jain.vivek.anand@gmail.com>
19  * Mohit P. Tahiliani <tahiliani@nitk.edu.in>
20  *
21  */
22 
23 #include "tcp-prr-recovery.h"
24 
25 #include "tcp-socket-state.h"
26 
27 #include "ns3/log.h"
28 
29 namespace ns3
30 {
31 
32 NS_LOG_COMPONENT_DEFINE("TcpPrrRecovery");
33 NS_OBJECT_ENSURE_REGISTERED(TcpPrrRecovery);
34 
35 TypeId
37 {
38  static TypeId tid = TypeId("ns3::TcpPrrRecovery")
40  .AddConstructor<TcpPrrRecovery>()
41  .SetGroupName("Internet")
42  .AddAttribute("ReductionBound",
43  "Type of Reduction Bound",
44  EnumValue(SSRB),
46  MakeEnumChecker(CRB, "CRB", SSRB, "SSRB"));
47  return tid;
48 }
49 
52 {
53  NS_LOG_FUNCTION(this);
54 }
55 
57  : TcpClassicRecovery(recovery),
58  m_prrDelivered(recovery.m_prrDelivered),
59  m_prrOut(recovery.m_prrOut),
60  m_recoveryFlightSize(recovery.m_recoveryFlightSize),
61  m_reductionBoundMode(recovery.m_reductionBoundMode)
62 {
63  NS_LOG_FUNCTION(this);
64 }
65 
67 {
68  NS_LOG_FUNCTION(this);
69 }
70 
71 void
73  uint32_t dupAckCount [[maybe_unused]],
74  uint32_t unAckDataCount,
75  uint32_t deliveredBytes)
76 {
77  NS_LOG_FUNCTION(this << tcb << dupAckCount << unAckDataCount);
78 
79  m_prrOut = 0;
80  m_prrDelivered = 0;
81  m_recoveryFlightSize = unAckDataCount;
82 
83  DoRecovery(tcb, deliveredBytes);
84 }
85 
86 void
87 TcpPrrRecovery::DoRecovery(Ptr<TcpSocketState> tcb, uint32_t deliveredBytes)
88 {
89  NS_LOG_FUNCTION(this << tcb << deliveredBytes);
90  m_prrDelivered += deliveredBytes;
91 
92  int sendCount;
93  if (tcb->m_bytesInFlight > tcb->m_ssThresh)
94  {
95  sendCount =
96  std::ceil(m_prrDelivered * tcb->m_ssThresh * 1.0 / m_recoveryFlightSize) - m_prrOut;
97  }
98  else
99  {
100  int limit = static_cast<int>(tcb->m_ssThresh - tcb->m_bytesInFlight);
101  if (m_reductionBoundMode == CRB)
102  {
103  limit = m_prrDelivered - m_prrOut;
104  }
105  else if (m_reductionBoundMode == SSRB)
106  {
107  if (tcb->m_isRetransDataAcked)
108  {
109  limit = std::max(m_prrDelivered - m_prrOut, deliveredBytes) + tcb->m_segmentSize;
110  }
111  else
112  {
113  limit = deliveredBytes;
114  }
115  }
116  sendCount = std::min(limit, static_cast<int>(tcb->m_ssThresh - tcb->m_bytesInFlight));
117  }
118 
119  /* Force a fast retransmit upon entering fast recovery */
120  sendCount = std::max(sendCount, static_cast<int>(m_prrOut > 0 ? 0 : tcb->m_segmentSize));
121  tcb->m_cWnd = tcb->m_bytesInFlight + sendCount;
122  tcb->m_cWndInfl = tcb->m_cWnd;
123 }
124 
125 void
127 {
128  NS_LOG_FUNCTION(this << tcb);
129  tcb->m_cWndInfl = tcb->m_cWnd;
130 }
131 
132 void
134 {
135  NS_LOG_FUNCTION(this << bytesSent);
136  m_prrOut += bytesSent;
137 }
138 
141 {
142  return CopyObject<TcpPrrRecovery>(this);
143 }
144 
145 std::string
147 {
148  return "PrrRecovery";
149 }
150 
151 } // namespace ns3
#define min(a, b)
Definition: 80211b.c:42
#define max(a, b)
Definition: 80211b.c:43
Hold variables of type enum.
Definition: enum.h:56
The Classic recovery implementation.
An implementation of PRR.
ReductionBound_t m_reductionBoundMode
mode of Reduction Bound to be used
void EnterRecovery(Ptr< TcpSocketState > tcb, uint32_t dupAckCount, uint32_t unAckDataCount, uint32_t deliveredBytes) override
Performs variable initialization at the start of recovery.
static TypeId GetTypeId()
Get the type ID.
void UpdateBytesSent(uint32_t bytesSent) override
Keeps track of bytes sent during recovery phase.
@ CRB
Conservative Reduction Bound.
@ SSRB
Slow Start Reduction Bound.
void ExitRecovery(Ptr< TcpSocketState > tcb) override
Performs cwnd adjustments at the end of recovery.
std::string GetName() const override
Get the name of the recovery algorithm.
uint32_t m_prrOut
total bytes sent during recovery phase
TcpPrrRecovery()
Create an unbound tcp socket.
uint32_t m_prrDelivered
total bytes delivered during recovery phase
Ptr< TcpRecoveryOps > Fork() override
Copy the recovery algorithm across socket.
void DoRecovery(Ptr< TcpSocketState > tcb, uint32_t deliveredBytes) override
Performs recovery based on the recovery algorithm.
uint32_t m_recoveryFlightSize
value of bytesInFlight at the start of recovery phase
uint32_t m_segmentSize
Segment size.
bool m_isRetransDataAcked
Retransmitted data is ACKed if true.
TracedValue< uint32_t > m_cWnd
Congestion window.
TracedValue< uint32_t > m_bytesInFlight
Bytes in flight.
TracedValue< uint32_t > m_cWndInfl
Inflated congestion window trace (used only for backward compatibility purpose)
TracedValue< uint32_t > m_ssThresh
Slow start threshold.
a unique identifier for an interface.
Definition: type-id.h:60
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition: type-id.cc:935
Ptr< const AttributeAccessor > MakeEnumAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Definition: enum.h:205
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:202
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition: object-base.h:46
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ptr< const AttributeChecker > MakeEnumChecker(int v, std::string n, Ts... args)
Make an EnumChecker pre-configured with a set of allowed values by name.
Definition: enum.h:163