A Discrete-Event Network Simulator
API
tcp-lp.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2016 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  * Authors: Charitha Sangaraju <charitha29193@gmail.com>
18  * Nandita G <gm.nandita@gmail.com>
19  * Mohit P. Tahiliani <tahiliani@nitk.edu.in>
20  *
21  */
22 
23 #ifndef TCPLP_H
24 #define TCPLP_H
25 
26 #include "tcp-congestion-ops.h"
27 
28 #include "ns3/traced-value.h"
29 
30 namespace ns3
31 {
32 
33 class TcpSocketState;
34 
40 class TcpLp : public TcpNewReno
41 {
42  public:
48  static TypeId GetTypeId();
49 
54  TcpLp();
55 
61  TcpLp(const TcpLp& sock);
62 
63  ~TcpLp() override;
64 
75  void PktsAcked(Ptr<TcpSocketState> tcb, uint32_t segmentsAcked, const Time& rtt) override;
76 
77  std::string GetName() const override;
78 
79  Ptr<TcpCongestionOps> Fork() override;
80 
81  protected:
88  void CongestionAvoidance(Ptr<TcpSocketState> tcb, uint32_t segmentsAcked) override;
89 
90  private:
95  enum State
96  {
97  LP_VALID_OWD = (1 << 1),
98  LP_WITHIN_THR = (1 << 3),
99  LP_WITHIN_INF = (1 << 4),
100  };
101 
102  uint32_t m_flag;
103  uint32_t m_sOwd;
104  uint32_t m_owdMin;
105  uint32_t m_owdMax;
106  uint32_t m_owdMaxRsv;
109 
110  private:
117  uint32_t OwdCalculator(Ptr<TcpSocketState> tcb);
118 
125  void RttSample(Ptr<TcpSocketState> tcb);
126 };
127 
128 } // namespace ns3
129 
130 #endif // TCPLP_H
TCP-LP (Low Priority) congestion control algorithm.
Definition: tcp-lp.h:41
std::string GetName() const override
Get the name of the congestion control algorithm.
Definition: tcp-lp.cc:231
Time m_inference
Current inference period.
Definition: tcp-lp.h:108
uint32_t m_flag
TcpLp state flag.
Definition: tcp-lp.h:102
~TcpLp() override
Definition: tcp-lp.cc:70
void PktsAcked(Ptr< TcpSocketState > tcb, uint32_t segmentsAcked, const Time &rtt) override
Timing information on received ACK.
Definition: tcp-lp.cc:167
uint32_t m_owdMax
Maximum One-Way Delay.
Definition: tcp-lp.h:105
void RttSample(Ptr< TcpSocketState > tcb)
Estimates minimum and maximum One-Way Delays and calculates the smoothed One-Way Delay.
Definition: tcp-lp.cc:117
Ptr< TcpCongestionOps > Fork() override
Copy the congestion control algorithm across sockets.
Definition: tcp-lp.cc:76
uint32_t m_owdMaxRsv
Reserved Maximum One-Way Delay.
Definition: tcp-lp.h:106
static TypeId GetTypeId()
Get the type ID.
Definition: tcp-lp.cc:35
void CongestionAvoidance(Ptr< TcpSocketState > tcb, uint32_t segmentsAcked) override
Invokes Congestion Avoidance of TcpNewReno if TcpLp is not within inference.
Definition: tcp-lp.cc:82
uint32_t m_owdMin
Minimum One-Way Delay.
Definition: tcp-lp.h:104
TcpLp()
Creates an unbound tcp socket.
Definition: tcp-lp.cc:44
State
Describes the state of TcpLp.
Definition: tcp-lp.h:96
@ LP_WITHIN_INF
TcpLp is within Inference.
Definition: tcp-lp.h:99
@ LP_VALID_OWD
Calculated One-Way Delay is valid.
Definition: tcp-lp.h:97
@ LP_WITHIN_THR
TcpLp is within Threshold.
Definition: tcp-lp.h:98
uint32_t OwdCalculator(Ptr< TcpSocketState > tcb)
Calculates One-Way Delay using Sender and Receiver timestamps.
Definition: tcp-lp.cc:93
Time m_lastDrop
Last time when cwnd was reduced.
Definition: tcp-lp.h:107
uint32_t m_sOwd
Smoothed One-Way Delay.
Definition: tcp-lp.h:103
The NewReno implementation.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.