BBR congestion control algorithm. More...
#include "tcp-bbr.h"
 Inheritance diagram for ns3::TcpBbr:
 Inheritance diagram for ns3::TcpBbr: Collaboration diagram for ns3::TcpBbr:
 Collaboration diagram for ns3::TcpBbr:| Public Types | |
| enum | BbrMode_t { BBR_STARTUP , BBR_DRAIN , BBR_PROBE_BW , BBR_PROBE_RTT } | 
| BBR has the following 4 modes for deciding how fast to send:  More... | |
| typedef WindowedFilter< DataRate, MaxFilter< DataRate >, uint32_t, uint32_t > | MaxBandwidthFilter_t | 
| Definition of max bandwidth filter. | |
| Public Member Functions | |
| TcpBbr () | |
| Constructor. | |
| TcpBbr (const TcpBbr &sock) | |
| Copy constructor. | |
| uint32_t | AckAggregationCwnd () | 
| Find Cwnd increment based on ack aggregation. | |
| void | AdvanceCyclePhase () | 
| Advances pacing gain using cycle gain algorithm, while in BBR_PROBE_BW state. | |
| void | CheckCyclePhase (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Checks whether to advance pacing gain in BBR_PROBE_BW state, and if allowed calls AdvanceCyclePhase () | |
| void | CheckDrain (Ptr< TcpSocketState > tcb) | 
| Checks whether its time to enter BBR_DRAIN or BBR_PROBE_BW state. | |
| void | CheckFullPipe (const TcpRateOps::TcpRateSample &rs) | 
| Identifies whether pipe or BDP is already full. | |
| void | CheckProbeRTT (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| This method handles the steps related to the ProbeRTT state. | |
| void | CongControl (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateConnection &rc, const TcpRateOps::TcpRateSample &rs) override | 
| Called when packets are delivered to update cwnd and pacing rate. | |
| void | CongestionStateSet (Ptr< TcpSocketState > tcb, const TcpSocketState::TcpCongState_t newState) override | 
| Trigger events/calculations specific to a congestion state. | |
| void | CwndEvent (Ptr< TcpSocketState > tcb, const TcpSocketState::TcpCAEvent_t event) override | 
| Trigger events/calculations on occurrence of congestion window event. | |
| void | EnterDrain () | 
| Updates variables specific to BBR_DRAIN state. | |
| void | EnterProbeBW () | 
| Updates variables specific to BBR_PROBE_BW state. | |
| void | EnterProbeRTT () | 
| Updates variables specific to BBR_PROBE_RTT state. | |
| void | EnterStartup () | 
| Updates variables specific to BBR_STARTUP state. | |
| void | ExitProbeRTT () | 
| Called on exiting from BBR_PROBE_RTT state, it eithers invoke EnterProbeBW () or EnterStartup () | |
| Ptr< TcpCongestionOps > | Fork () override | 
| Copy the congestion control algorithm across sockets. | |
| uint32_t | GetBbrState () | 
| Gets BBR state. | |
| double | GetCwndGain () | 
| Gets current cwnd gain. | |
| std::string | GetName () const override | 
| Get the name of the congestion control algorithm. | |
| double | GetPacingGain () | 
| Gets current pacing gain. | |
| uint32_t | GetSsThresh (Ptr< const TcpSocketState > tcb, uint32_t bytesInFlight) override | 
| Get the slow start threshold after a loss event. | |
| void | HandleProbeRTT (Ptr< TcpSocketState > tcb) | 
| Handles the steps for BBR_PROBE_RTT state. | |
| void | HandleRestartFromIdle (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates pacing rate if socket is restarting from idle state. | |
| bool | HasCongControl () const override | 
| Returns true when Congestion Control Algorithm implements CongControl. | |
| uint32_t | InFlight (Ptr< TcpSocketState > tcb, double gain) | 
| Estimates the target value for congestion window. | |
| void | InitFullPipe () | 
| Initializes the full pipe estimator. | |
| void | InitPacingRate (Ptr< TcpSocketState > tcb) | 
| Initializes the pacing rate. | |
| void | InitRoundCounting () | 
| Initializes the round counting related variables. | |
| bool | IsNextCyclePhase (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Checks whether to move to next value of pacing gain while in BBR_PROBE_BW. | |
| void | ModulateCwndForProbeRTT (Ptr< TcpSocketState > tcb) | 
| Modulates congestion window in BBR_PROBE_RTT. | |
| bool | ModulateCwndForRecovery (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Modulates congestion window in CA_RECOVERY. | |
| void | RestoreCwnd (Ptr< TcpSocketState > tcb) | 
| Helper to restore the last-known good congestion window. | |
| void | SaveCwnd (Ptr< const TcpSocketState > tcb) | 
| Helper to remember the last-known good congestion window or the latest congestion window unmodulated by loss recovery or ProbeRTT. | |
| void | SetBbrState (BbrMode_t state) | 
| Sets BBR state. | |
| void | SetCwnd (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates congestion window based on the network model. | |
| void | SetPacingRate (Ptr< TcpSocketState > tcb, double gain) | 
| Updates pacing rate based on network model. | |
| void | SetRateOps (Ptr< TcpRateOps > rateOps) override | 
| Set rate operation required by the congestion control algorithm. | |
| void | SetSendQuantum (Ptr< TcpSocketState > tcb) | 
| Updates send quantum based on the network model. | |
| virtual void | SetStream (uint32_t stream) | 
| Assign a fixed random variable stream number to the random variables used by this model. | |
| void | UpdateAckAggregation (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Estimates max degree of aggregation. | |
| void | UpdateBottleneckBandwidth (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates maximum bottleneck. | |
| void | UpdateControlParameters (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates control parameters congestion windowm, pacing rate, send quantum. | |
| void | UpdateModelAndState (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates BBR network model (Maximum bandwidth and minimum RTT). | |
| void | UpdateRound (Ptr< TcpSocketState > tcb, const TcpRateOps::TcpRateSample &rs) | 
| Updates round counting related variables. | |
| void | UpdateRTprop (Ptr< TcpSocketState > tcb) | 
| Updates minimum RTT. | |
| void | UpdateTargetCwnd (Ptr< TcpSocketState > tcb) | 
| Updates target congestion window. | |
|  Public Member Functions inherited from ns3::TcpCongestionOps | |
| TcpCongestionOps () | |
| TcpCongestionOps (const TcpCongestionOps &other) | |
| Copy constructor. | |
| ~TcpCongestionOps () override | |
| virtual void | IncreaseWindow (Ptr< TcpSocketState > tcb, uint32_t segmentsAcked) | 
| Congestion avoidance algorithm implementation. | |
| virtual void | Init (Ptr< TcpSocketState > tcb) | 
| Set configuration required by congestion control algorithm. | |
| virtual void | PktsAcked (Ptr< TcpSocketState > tcb, uint32_t segmentsAcked, const Time &rtt) | 
| Timing information on received ACK. | |
|  Public Member Functions inherited from ns3::Object | |
| Object () | |
| Constructor. | |
| ~Object () override | |
| Destructor. | |
| void | AggregateObject (Ptr< Object > other) | 
| Aggregate two Objects together. | |
| void | Dispose () | 
| Dispose of this Object. | |
| AggregateIterator | GetAggregateIterator () const | 
| Get an iterator to the Objects aggregated to this one. | |
| TypeId | GetInstanceTypeId () const final | 
| Get the most derived TypeId for this Object. | |
| template<typename T> | |
| Ptr< T > | GetObject () const | 
| Get a pointer to the requested aggregated Object. | |
| template<> | |
| Ptr< Object > | GetObject () const | 
| Specialization of ()  for objects of type ns3::Object. | |
| template<typename T> | |
| Ptr< T > | GetObject (TypeId tid) const | 
| Get a pointer to the requested aggregated Object by TypeId. | |
| template<> | |
| Ptr< Object > | GetObject (TypeId tid) const | 
| Specialization of (TypeId tid)  for objects of type ns3::Object. | |
| void | Initialize () | 
| Invoke DoInitialize on all Objects aggregated to this one. | |
| bool | IsInitialized () const | 
| Check if the object has been initialized. | |
| void | UnidirectionalAggregateObject (Ptr< Object > other) | 
| Aggregate an Object to another Object. | |
|  Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
| SimpleRefCount () | |
| Default constructor. | |
| SimpleRefCount (const SimpleRefCount &o) | |
| Copy constructor. | |
| uint32_t | GetReferenceCount () const | 
| Get the reference count of the object. | |
| SimpleRefCount & | operator= (const SimpleRefCount &o) | 
| Assignment operator. | |
| void | Ref () const | 
| Increment the reference count. | |
| void | Unref () const | 
| Decrement the reference count. | |
|  Public Member Functions inherited from ns3::ObjectBase | |
| virtual | ~ObjectBase () | 
| Virtual destructor. | |
| void | GetAttribute (std::string name, AttributeValue &value, bool permissive=false) const | 
| Get the value of an attribute, raising fatal errors if unsuccessful. | |
| bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const | 
| Get the value of an attribute without raising errors. | |
| void | SetAttribute (std::string name, const AttributeValue &value) | 
| Set a single attribute, raising fatal errors if unsuccessful. | |
| bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) | 
| Set a single attribute without raising errors. | |
| bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) | 
| Connect a TraceSource to a Callback with a context. | |
| bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) | 
| Connect a TraceSource to a Callback without a context. | |
| bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) | 
| Disconnect from a TraceSource a Callback previously connected with a context. | |
| bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) | 
| Disconnect from a TraceSource a Callback previously connected without a context. | |
| Static Public Member Functions | |
| static TypeId | GetTypeId () | 
| Get the type ID. | |
|  Static Public Member Functions inherited from ns3::TcpCongestionOps | |
| static TypeId | GetTypeId () | 
| Get the type ID. | |
|  Static Public Member Functions inherited from ns3::Object | |
| static TypeId | GetTypeId () | 
| Register this type. | |
|  Static Public Member Functions inherited from ns3::ObjectBase | |
| static TypeId | GetTypeId () | 
| Get the type ID. | |
| Static Public Attributes | |
| static const char *const | BbrModeName [BBR_PROBE_RTT+1] | 
| Literal names of BBR mode for use in log messages. | |
| static const uint8_t | GAIN_CYCLE_LENGTH = 8 | 
| The number of phases in the BBR ProbeBW gain cycle. | |
| static const double | PACING_GAIN_CYCLE [] = {5.0 / 4, 3.0 / 4, 1, 1, 1, 1, 1, 1} | 
| BBR uses an eight-phase cycle with the given pacing_gain value in the BBR ProbeBW gain cycle. | |
| Private Attributes | |
| uint32_t | m_ackEpochAcked {0} | 
| Bytes ACked in sampling epoch. | |
| uint32_t | m_ackEpochAckedResetThresh | 
| Max allowed val for m_ackEpochAcked, after which sampling epoch is reset. | |
| Time | m_ackEpochTime | 
| Starting of ACK sampling epoch time. | |
| uint32_t | m_bandwidthWindowLength {0} | 
| A constant specifying the length of the BBR.BtlBw max filter window, default 10 packet-timed round trips. | |
| TracedValue< double > | m_cWndGain {0} | 
| The dynamic congestion window gain factor. | |
| uint32_t | m_cycleIndex {0} | 
| Current index of gain cycle. | |
| Time | m_cycleStamp | 
| Last time gain cycle updated. | |
| uint64_t | m_delivered {0} | 
| The total amount of data in bytes delivered so far. | |
| uint32_t | m_extraAcked [2] {0, 0} | 
| Maximum excess data acked in epoch. | |
| uint32_t | m_extraAckedGain {1} | 
| Gain factor for adding extra ack to cwnd. | |
| uint32_t | m_extraAckedIdx {0} | 
| Current index in extra acked array. | |
| uint32_t | m_extraAckedWinRtt {0} | 
| Age of extra acked in rtt. | |
| uint32_t | m_extraAckedWinRttLength {5} | 
| Window length of extra acked window. | |
| DataRate | m_fullBandwidth {0} | 
| Value of full bandwidth recorded. | |
| uint32_t | m_fullBandwidthCount {0} | 
| Count of full bandwidth recorded consistently. | |
| bool | m_hasSeenRtt {false} | 
| Have we seen RTT sample yet? | |
| double | m_highGain {0} | 
| A constant specifying highest gain factor, default is 2.89. | |
| bool | m_idleRestart {false} | 
| When restarting from idle, set it true. | |
| bool | m_isInitialized {false} | 
| Set to true after first time initialization variables. | |
| bool | m_isPipeFilled {false} | 
| A boolean that records whether BBR has filled the pipe. | |
| MaxBandwidthFilter_t | m_maxBwFilter | 
| Maximum bandwidth filter. | |
| uint32_t | m_minPipeCwnd | 
| The minimal congestion window value BBR tries to target, default 4 Segment size. | |
| TracedValue< Time > | m_minRtt | 
| Estimated two-way round-trip propagation delay of the path, estimated from the windowed minimum recent round-trip delay sample. | |
| bool | m_minRttExpired {false} | 
| A boolean recording whether the BBR.RTprop has expired. | |
| Time | m_minRttFilterLen {Seconds(10)} | 
| A constant specifying the length of the RTProp min filter window, default 10 secs. | |
| Time | m_minRttStamp | 
| The wall clock time at which the current BBR.RTProp sample was obtained. | |
| uint32_t | m_nextRoundDelivered {0} | 
| Denotes the end of a packet-timed round trip. | |
| TracedValue< double > | m_pacingGain {0} | 
| The dynamic pacing gain factor. | |
| double | m_pacingMargin {0.01} | 
| BBR intentionally reduces the pacing rate by 1% to drain any standing queues. | |
| bool | m_packetConservation {false} | 
| Enable/Disable packet conservation mode. | |
| uint32_t | m_priorCwnd {0} | 
| The last-known good congestion window. | |
| Time | m_probeRtPropStamp | 
| The wall clock time at which the current BBR.RTProp sample was obtained. | |
| Time | m_probeRttDoneStamp | 
| Time to exit from BBR_PROBE_RTT state. | |
| Time | m_probeRttDuration {MilliSeconds(200)} | 
| A constant specifying the minimum duration for which ProbeRTT state, default 200 millisecs. | |
| bool | m_probeRttRoundDone {false} | 
| True when it is time to exit BBR_PROBE_RTT. | |
| Ptr< TcpRateOps > | m_rateOps | 
| Rate operations. | |
| uint32_t | m_roundCount {0} | 
| Count of packet-timed round trips. | |
| bool | m_roundStart {false} | 
| A boolean that BBR sets to true once per packet-timed round trip. | |
| uint32_t | m_sendQuantum | 
| The maximum size of a data aggregate scheduled and transmitted together. | |
| BbrMode_t | m_state {BbrMode_t::BBR_STARTUP} | 
| Current state of BBR state machine. | |
| uint32_t | m_targetCWnd {0} | 
| Target value for congestion window, adapted to the estimated BDP. | |
| Ptr< UniformRandomVariable > | m_uv {nullptr} | 
| Uniform Random Variable. | |
| Friends | |
| class | ::TcpBbrCheckGainValuesTest | 
| TcpBbrCheckGainValuesTest friend class (for tests). | |
| Additional Inherited Members | |
|  Protected Member Functions inherited from ns3::Object | |
| Object (const Object &o) | |
| Copy an Object. | |
| virtual void | DoDispose () | 
| Destructor implementation. | |
| virtual void | DoInitialize () | 
| Initialize() implementation. | |
| virtual void | NotifyNewAggregate () | 
| Notify all Objects aggregated to this one of a new Object being aggregated. | |
|  Protected Member Functions inherited from ns3::ObjectBase | |
| void | ConstructSelf (const AttributeConstructionList &attributes) | 
| Complete construction of ObjectBase; invoked by derived classes. | |
| virtual void | NotifyConstructionCompleted () | 
| Notifier called once the ObjectBase is fully constructed. | |
|  Related Symbols inherited from ns3::ObjectBase | |
| static TypeId | GetObjectIid () | 
| Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. | |
BBR congestion control algorithm.
This class implement the BBR (Bottleneck Bandwidth and Round-trip propagation time) congestion control type.
ns3::TcpBbr is accessible through the following paths with Config::Set and Config::Connect:
Time -9.22337e+18ns:+9.22337e+18ns Time -9.22337e+18ns:+9.22337e+18ns Group: Internet
 Size of this type is 440 bytes (on a 64-bit architecture).
 
| ns3::TcpBbr::TcpBbr | ( | ) | 
Constructor.
Definition at line 84 of file tcp-bbr.cc.
References ns3::TcpCongestionOps::TcpCongestionOps(), ns3::CreateObject(), m_uv, and NS_LOG_FUNCTION.
Referenced by TcpBbr().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| ns3::TcpBbr::TcpBbr | ( | const TcpBbr & | sock | ) | 
Copy constructor.
| sock | The socket to copy from. | 
Definition at line 91 of file tcp-bbr.cc.
References TcpBbr(), ns3::TcpCongestionOps::TcpCongestionOps(), m_ackEpochAcked, m_ackEpochAckedResetThresh, m_ackEpochTime, m_bandwidthWindowLength, m_cWndGain, m_cycleIndex, m_cycleStamp, m_delivered, m_extraAckedGain, m_extraAckedIdx, m_extraAckedWinRtt, m_extraAckedWinRttLength, m_fullBandwidth, m_fullBandwidthCount, m_hasSeenRtt, m_highGain, m_idleRestart, m_isInitialized, m_isPipeFilled, m_minPipeCwnd, m_minRtt, m_minRttExpired, m_minRttFilterLen, m_minRttStamp, m_nextRoundDelivered, m_pacingGain, m_packetConservation, m_priorCwnd, m_probeRtPropStamp, m_probeRttDoneStamp, m_probeRttDuration, m_probeRttRoundDone, m_roundCount, m_roundStart, m_sendQuantum, m_targetCWnd, m_uv, ns3::Max(), and NS_LOG_FUNCTION.
 Here is the call graph for this function:
 Here is the call graph for this function:| uint32_t ns3::TcpBbr::AckAggregationCwnd | ( | ) | 
Find Cwnd increment based on ack aggregation.
Definition at line 483 of file tcp-bbr.cc.
References m_extraAcked, m_extraAckedGain, m_isPipeFilled, m_maxBwFilter, and NS_LOG_FUNCTION.
Referenced by UpdateTargetCwnd().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::AdvanceCyclePhase | ( | ) | 
Advances pacing gain using cycle gain algorithm, while in BBR_PROBE_BW state.
Definition at line 263 of file tcp-bbr.cc.
References GAIN_CYCLE_LENGTH, m_cycleIndex, m_cycleStamp, m_pacingGain, ns3::Simulator::Now(), NS_LOG_FUNCTION, and PACING_GAIN_CYCLE.
Referenced by CheckCyclePhase(), and EnterProbeBW().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::CheckCyclePhase | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Checks whether to advance pacing gain in BBR_PROBE_BW state, and if allowed calls AdvanceCyclePhase ()
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 292 of file tcp-bbr.cc.
References AdvanceCyclePhase(), BBR_PROBE_BW, IsNextCyclePhase(), m_state, and NS_LOG_FUNCTION.
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::CheckDrain | ( | Ptr< TcpSocketState > | tcb | ) | 
Checks whether its time to enter BBR_DRAIN or BBR_PROBE_BW state.
| tcb | the socket state. | 
Definition at line 347 of file tcp-bbr.cc.
References BBR_DRAIN, BBR_STARTUP, EnterDrain(), EnterProbeBW(), InFlight(), m_isPipeFilled, m_state, and NS_LOG_FUNCTION.
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::CheckFullPipe | ( | const TcpRateOps::TcpRateSample & | rs | ) | 
Identifies whether pipe or BDP is already full.
| rs | rate sample. | 
Definition at line 302 of file tcp-bbr.cc.
References m_fullBandwidth, m_fullBandwidthCount, ns3::TcpRateOps::TcpRateSample::m_isAppLimited, m_isPipeFilled, m_maxBwFilter, m_roundStart, NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by UpdateModelAndState().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::CheckProbeRTT | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
This method handles the steps related to the ProbeRTT state.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 447 of file tcp-bbr.cc.
References BBR_PROBE_RTT, EnterProbeRTT(), HandleProbeRTT(), ns3::TcpRateOps::TcpRateSample::m_delivered, m_idleRestart, m_minRttExpired, m_probeRttDoneStamp, m_state, NS_LOG_FUNCTION, SaveCwnd(), and ns3::Seconds().
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | overridevirtual | 
Called when packets are delivered to update cwnd and pacing rate.
This function mimics the function cong_control in Linux. It is allowed to change directly cWnd and pacing rate.
| tcb | internal congestion state | 
| rc | Rate information for the connection | 
| rs | Rate sample (over a period of time) information | 
Reimplemented from ns3::TcpCongestionOps.
Definition at line 707 of file tcp-bbr.cc.
References m_delivered, NS_LOG_FUNCTION, UpdateControlParameters(), and UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overridevirtual | 
Trigger events/calculations specific to a congestion state.
This function mimics the notification function set_state in Linux. The function does not change the congestion state in the tcb; it notifies the congestion control algorithm that this state is about to be changed. The tcb->m_congState variable must be separately set; for example:
| tcb | internal congestion state | 
| newState | new congestion state to which the TCP is going to switch | 
Reimplemented from ns3::TcpCongestionOps.
Definition at line 718 of file tcp-bbr.cc.
References ns3::TcpSocketState::CA_LOSS, ns3::TcpSocketState::CA_OPEN, ns3::TcpSocketState::CA_RECOVERY, EnterStartup(), InitFullPipe(), InitPacingRate(), InitRoundCounting(), m_ackEpochAcked, m_ackEpochTime, m_extraAcked, m_extraAckedIdx, m_extraAckedWinRtt, m_isInitialized, m_minPipeCwnd, m_minRtt, m_minRttStamp, m_packetConservation, m_priorCwnd, m_roundStart, m_sendQuantum, m_targetCWnd, ns3::Time::Max(), ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, and SaveCwnd().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overridevirtual | 
Trigger events/calculations on occurrence of congestion window event.
This function mimics the function cwnd_event in Linux. The function is called in case of congestion window events.
| tcb | internal congestion state | 
| event | the event which triggered this function | 
Reimplemented from ns3::TcpCongestionOps.
Definition at line 761 of file tcp-bbr.cc.
References BBR_PROBE_BW, BBR_PROBE_RTT, ns3::TcpSocketState::CA_EVENT_COMPLETE_CWR, ns3::TcpSocketState::CA_EVENT_TX_START, ExitProbeRTT(), m_ackEpochAcked, m_ackEpochTime, m_idleRestart, m_minRttStamp, m_packetConservation, m_probeRttDoneStamp, m_probeRttRoundDone, m_rateOps, m_state, ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, RestoreCwnd(), and SetPacingRate().
 Here is the call graph for this function:
 Here is the call graph for this function:| void ns3::TcpBbr::EnterDrain | ( | ) | 
Updates variables specific to BBR_DRAIN state.
Definition at line 327 of file tcp-bbr.cc.
References BBR_DRAIN, m_cWndGain, m_highGain, m_pacingGain, NS_LOG_FUNCTION, and SetBbrState().
Referenced by CheckDrain().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::EnterProbeBW | ( | ) | 
Updates variables specific to BBR_PROBE_BW state.
Definition at line 336 of file tcp-bbr.cc.
References AdvanceCyclePhase(), BBR_PROBE_BW, GAIN_CYCLE_LENGTH, m_cWndGain, m_cycleIndex, m_pacingGain, m_uv, NS_LOG_FUNCTION, and SetBbrState().
Referenced by CheckDrain(), and ExitProbeRTT().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::EnterProbeRTT | ( | ) | 
Updates variables specific to BBR_PROBE_RTT state.
Definition at line 375 of file tcp-bbr.cc.
References BBR_PROBE_RTT, m_cWndGain, m_pacingGain, NS_LOG_FUNCTION, and SetBbrState().
Referenced by CheckProbeRTT().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::EnterStartup | ( | ) | 
Updates variables specific to BBR_STARTUP state.
Definition at line 202 of file tcp-bbr.cc.
References BBR_STARTUP, m_cWndGain, m_highGain, m_pacingGain, NS_LOG_FUNCTION, and SetBbrState().
Referenced by CongestionStateSet(), and ExitProbeRTT().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::ExitProbeRTT | ( | ) | 
Called on exiting from BBR_PROBE_RTT state, it eithers invoke EnterProbeBW () or EnterStartup ()
Definition at line 405 of file tcp-bbr.cc.
References EnterProbeBW(), EnterStartup(), m_isPipeFilled, and NS_LOG_FUNCTION.
Referenced by CwndEvent(), and HandleProbeRTT().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | overridevirtual | 
Copy the congestion control algorithm across sockets.
Implements ns3::TcpCongestionOps.
Definition at line 802 of file tcp-bbr.cc.
References ns3::Object::CopyObject.
 Here is the call graph for this function:
 Here is the call graph for this function:| uint32_t ns3::TcpBbr::GetBbrState | ( | ) | 
Gets BBR state.
Definition at line 673 of file tcp-bbr.cc.
References m_state, and NS_LOG_FUNCTION.
| double ns3::TcpBbr::GetCwndGain | ( | ) | 
Gets current cwnd gain.
Definition at line 680 of file tcp-bbr.cc.
References m_cWndGain, and NS_LOG_FUNCTION.
| 
 | overridevirtual | 
Get the name of the congestion control algorithm.
Implements ns3::TcpCongestionOps.
Definition at line 694 of file tcp-bbr.cc.
| double ns3::TcpBbr::GetPacingGain | ( | ) | 
Gets current pacing gain.
Definition at line 687 of file tcp-bbr.cc.
References m_pacingGain, and NS_LOG_FUNCTION.
| 
 | overridevirtual | 
Get the slow start threshold after a loss event.
Is guaranteed that the congestion control state (TcpAckState_t) is changed BEFORE the invocation of this method. The implementer should return the slow start threshold (and not change it directly) because, in the future, the TCP implementation may require to instantly recover from a loss event (e.g. when there is a network with an high reordering factor).
| tcb | internal congestion state | 
| bytesInFlight | total bytes in flight | 
Implements ns3::TcpCongestionOps.
Definition at line 794 of file tcp-bbr.cc.
References NS_LOG_FUNCTION, and SaveCwnd().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | static | 
Get the type ID.
Definition at line 25 of file tcp-bbr.cc.
References ns3::TcpCongestionOps::TcpCongestionOps(), m_ackEpochAckedResetThresh, m_bandwidthWindowLength, m_cWndGain, m_extraAckedWinRttLength, m_highGain, m_minRtt, m_minRttFilterLen, m_pacingGain, m_probeRttDuration, ns3::MakeDoubleAccessor(), ns3::MakeDoubleChecker(), ns3::MakeTimeAccessor(), ns3::MakeTimeChecker(), ns3::MakeTraceSourceAccessor(), ns3::MakeUintegerAccessor(), ns3::MakeUintegerChecker(), ns3::MilliSeconds(), ns3::Seconds(), ns3::TypeId::SetParent(), and SetStream().
 Here is the call graph for this function:
 Here is the call graph for this function:| void ns3::TcpBbr::HandleProbeRTT | ( | Ptr< TcpSocketState > | tcb | ) | 
Handles the steps for BBR_PROBE_RTT state.
| tcb | the socket state. | 
Definition at line 419 of file tcp-bbr.cc.
References ExitProbeRTT(), m_delivered, m_minPipeCwnd, m_minRttStamp, m_nextRoundDelivered, m_probeRttDoneStamp, m_probeRttDuration, m_probeRttRoundDone, m_rateOps, m_roundStart, ns3::Simulator::Now(), NS_LOG_FUNCTION, and RestoreCwnd().
Referenced by CheckProbeRTT().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::HandleRestartFromIdle | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates pacing rate if socket is restarting from idle state.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 211 of file tcp-bbr.cc.
References BBR_PROBE_BW, m_idleRestart, ns3::TcpRateOps::TcpRateSample::m_isAppLimited, m_state, NS_LOG_FUNCTION, and SetPacingRate().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overridevirtual | 
Returns true when Congestion Control Algorithm implements CongControl.
This function is the equivalent in C++ of the C checks that are used in the Linux kernel to see if an optional function has been defined. Since CongControl is optional, not all congestion controls have it. But, from the perspective of TcpSocketBase, the behavior is different if CongControl is present. Therefore, this check should return true for any congestion controls that implements the CongControl optional function.
Reimplemented from ns3::TcpCongestionOps.
Definition at line 700 of file tcp-bbr.cc.
References NS_LOG_FUNCTION.
| uint32_t ns3::TcpBbr::InFlight | ( | Ptr< TcpSocketState > | tcb, | 
| double | gain ) | 
Estimates the target value for congestion window.
| tcb | the socket state. | 
| gain | cwnd gain. | 
Definition at line 245 of file tcp-bbr.cc.
References BBR_PROBE_BW, m_cycleIndex, m_maxBwFilter, m_minRtt, m_sendQuantum, m_state, ns3::Time::Max(), and NS_LOG_FUNCTION.
Referenced by CheckDrain(), IsNextCyclePhase(), and UpdateTargetCwnd().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::InitFullPipe | ( | ) | 
Initializes the full pipe estimator.
Definition at line 164 of file tcp-bbr.cc.
References m_fullBandwidth, m_fullBandwidthCount, m_isPipeFilled, and NS_LOG_FUNCTION.
Referenced by CongestionStateSet().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::InitPacingRate | ( | Ptr< TcpSocketState > | tcb | ) | 
Initializes the pacing rate.
| tcb | the socket state. | 
Definition at line 173 of file tcp-bbr.cc.
References ns3::DataRate::GetBitRate(), ns3::Time::GetSeconds(), m_bandwidthWindowLength, m_hasSeenRtt, m_maxBwFilter, m_pacingGain, ns3::Time::Max(), ns3::MilliSeconds(), NS_LOG_FUNCTION, and NS_LOG_WARN.
Referenced by CongestionStateSet(), and SetPacingRate().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::InitRoundCounting | ( | ) | 
Initializes the round counting related variables.
Definition at line 155 of file tcp-bbr.cc.
References m_nextRoundDelivered, m_roundCount, m_roundStart, and NS_LOG_FUNCTION.
Referenced by CongestionStateSet().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| bool ns3::TcpBbr::IsNextCyclePhase | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Checks whether to move to next value of pacing gain while in BBR_PROBE_BW.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 272 of file tcp-bbr.cc.
References InFlight(), ns3::TcpRateOps::TcpRateSample::m_bytesLoss, m_cycleStamp, m_minRtt, m_pacingGain, ns3::TcpRateOps::TcpRateSample::m_priorInFlight, ns3::Simulator::Now(), and NS_LOG_FUNCTION.
Referenced by CheckCyclePhase().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::ModulateCwndForProbeRTT | ( | Ptr< TcpSocketState > | tcb | ) | 
Modulates congestion window in BBR_PROBE_RTT.
| tcb | the socket state. | 
Definition at line 562 of file tcp-bbr.cc.
References BBR_PROBE_RTT, m_minPipeCwnd, m_state, and NS_LOG_FUNCTION.
Referenced by SetCwnd().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| bool ns3::TcpBbr::ModulateCwndForRecovery | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Modulates congestion window in CA_RECOVERY.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 544 of file tcp-bbr.cc.
References ns3::TcpRateOps::TcpRateSample::m_ackedSacked, ns3::TcpRateOps::TcpRateSample::m_bytesLoss, m_packetConservation, and NS_LOG_FUNCTION.
Referenced by SetCwnd().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::RestoreCwnd | ( | Ptr< TcpSocketState > | tcb | ) | 
Helper to restore the last-known good congestion window.
| tcb | the socket state. | 
Definition at line 398 of file tcp-bbr.cc.
References m_priorCwnd, and NS_LOG_FUNCTION.
Referenced by CwndEvent(), and HandleProbeRTT().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::SaveCwnd | ( | Ptr< const TcpSocketState > | tcb | ) | 
Helper to remember the last-known good congestion window or the latest congestion window unmodulated by loss recovery or ProbeRTT.
| tcb | the socket state. | 
Definition at line 384 of file tcp-bbr.cc.
References BBR_PROBE_RTT, ns3::TcpSocketState::CA_RECOVERY, m_priorCwnd, m_state, and NS_LOG_FUNCTION.
Referenced by CheckProbeRTT(), CongestionStateSet(), and GetSsThresh().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::SetBbrState | ( | BbrMode_t | state | ) | 
Sets BBR state.
| state | BBR state. | 
Definition at line 664 of file tcp-bbr.cc.
References BbrModeName, m_state, ns3::Simulator::Now(), NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by EnterDrain(), EnterProbeBW(), EnterProbeRTT(), and EnterStartup().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::SetCwnd | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates congestion window based on the network model.
| tcb | the socket state. | 
| rs | rate sample | 
Definition at line 572 of file tcp-bbr.cc.
References ns3::TcpSocketState::CA_RECOVERY, ns3::TcpRateOps::TcpRateSample::m_ackedSacked, m_delivered, m_isPipeFilled, m_minPipeCwnd, m_targetCWnd, ModulateCwndForProbeRTT(), ModulateCwndForRecovery(), NS_LOG_DEBUG, NS_LOG_FUNCTION, and UpdateTargetCwnd().
Referenced by UpdateControlParameters().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::SetPacingRate | ( | Ptr< TcpSocketState > | tcb, | 
| double | gain ) | 
Updates pacing rate based on network model.
| tcb | the socket state. | 
| gain | pacing gain. | 
Definition at line 225 of file tcp-bbr.cc.
References InitPacingRate(), m_hasSeenRtt, m_isPipeFilled, m_maxBwFilter, m_pacingMargin, ns3::Time::Max(), NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by CwndEvent(), HandleRestartFromIdle(), and UpdateControlParameters().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | overridevirtual | 
Set rate operation required by the congestion control algorithm.
| rateOps | a pointer to the rate operation object used to manage rate control | 
Reimplemented from ns3::TcpCongestionOps.
Definition at line 135 of file tcp-bbr.cc.
References m_rateOps.
| void ns3::TcpBbr::SetSendQuantum | ( | Ptr< TcpSocketState > | tcb | ) | 
Updates send quantum based on the network model.
| tcb | the socket state. | 
Definition at line 469 of file tcp-bbr.cc.
References m_sendQuantum, and NS_LOG_FUNCTION.
Referenced by UpdateControlParameters().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | virtual | 
Assign a fixed random variable stream number to the random variables used by this model.
| stream | first stream index to use | 
Definition at line 148 of file tcp-bbr.cc.
References m_uv, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateAckAggregation | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Estimates max degree of aggregation.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 499 of file tcp-bbr.cc.
References ns3::Time::GetSeconds(), ns3::TcpRateOps::TcpRateSample::m_ackedSacked, m_ackEpochAcked, m_ackEpochAckedResetThresh, m_ackEpochTime, ns3::TcpRateOps::TcpRateSample::m_delivered, m_extraAcked, m_extraAckedGain, m_extraAckedIdx, m_extraAckedWinRtt, m_extraAckedWinRttLength, m_maxBwFilter, m_roundStart, ns3::Simulator::Now(), and NS_LOG_FUNCTION.
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateBottleneckBandwidth | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates maximum bottleneck.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 624 of file tcp-bbr.cc.
References ns3::Time::IsZero(), ns3::TcpRateOps::TcpRateSample::m_delivered, ns3::TcpRateOps::TcpRateSample::m_deliveryRate, ns3::TcpRateOps::TcpRateSample::m_interval, ns3::TcpRateOps::TcpRateSample::m_isAppLimited, m_maxBwFilter, m_roundCount, NS_LOG_FUNCTION, and UpdateRound().
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateControlParameters | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates control parameters congestion windowm, pacing rate, send quantum.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 655 of file tcp-bbr.cc.
References m_pacingGain, NS_LOG_FUNCTION, SetCwnd(), SetPacingRate(), and SetSendQuantum().
Referenced by CongControl().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateModelAndState | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates BBR network model (Maximum bandwidth and minimum RTT).
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 642 of file tcp-bbr.cc.
References CheckCyclePhase(), CheckDrain(), CheckFullPipe(), CheckProbeRTT(), NS_LOG_FUNCTION, UpdateAckAggregation(), UpdateBottleneckBandwidth(), and UpdateRTprop().
Referenced by CongControl().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateRound | ( | Ptr< TcpSocketState > | tcb, | 
| const TcpRateOps::TcpRateSample & | rs ) | 
Updates round counting related variables.
| tcb | the socket state. | 
| rs | rate sample. | 
Definition at line 607 of file tcp-bbr.cc.
References m_delivered, m_nextRoundDelivered, m_packetConservation, ns3::TcpRateOps::TcpRateSample::m_priorDelivered, m_roundCount, m_roundStart, and NS_LOG_FUNCTION.
Referenced by UpdateBottleneckBandwidth().
 Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateRTprop | ( | Ptr< TcpSocketState > | tcb | ) | 
Updates minimum RTT.
| tcb | the socket state. | 
Definition at line 363 of file tcp-bbr.cc.
References m_minRtt, m_minRttExpired, m_minRttFilterLen, m_minRttStamp, ns3::Simulator::Now(), and NS_LOG_FUNCTION.
Referenced by UpdateModelAndState().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void ns3::TcpBbr::UpdateTargetCwnd | ( | Ptr< TcpSocketState > | tcb | ) | 
Updates target congestion window.
| tcb | the socket state. | 
Definition at line 476 of file tcp-bbr.cc.
References AckAggregationCwnd(), InFlight(), m_cWndGain, m_targetCWnd, and NS_LOG_FUNCTION.
Referenced by SetCwnd().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | friend | 
TcpBbrCheckGainValuesTest friend class (for tests).
| 
 | static | 
Literal names of BBR mode for use in log messages.
Definition at line 84 of file tcp-bbr.h.
Referenced by SetBbrState().
| 
 | static | 
The number of phases in the BBR ProbeBW gain cycle.
Definition at line 40 of file tcp-bbr.h.
Referenced by AdvanceCyclePhase(), and EnterProbeBW().
| 
 | private | 
Bytes ACked in sampling epoch.
Definition at line 389 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), CwndEvent(), and UpdateAckAggregation().
| 
 | private | 
Max allowed val for m_ackEpochAcked, after which sampling epoch is reset.
Definition at line 385 of file tcp-bbr.h.
Referenced by TcpBbr(), GetTypeId(), and UpdateAckAggregation().
| 
 | private | 
Starting of ACK sampling epoch time.
Definition at line 388 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), CwndEvent(), and UpdateAckAggregation().
| 
 | private | 
A constant specifying the length of the BBR.BtlBw max filter window, default 10 packet-timed round trips.
Definition at line 343 of file tcp-bbr.h.
Referenced by TcpBbr(), GetTypeId(), and InitPacingRate().
| 
 | private | 
The dynamic congestion window gain factor.
Definition at line 346 of file tcp-bbr.h.
Referenced by TcpBbr(), EnterDrain(), EnterProbeBW(), EnterProbeRTT(), EnterStartup(), GetCwndGain(), GetTypeId(), and UpdateTargetCwnd().
| 
 | private | 
Current index of gain cycle.
Definition at line 372 of file tcp-bbr.h.
Referenced by TcpBbr(), AdvanceCyclePhase(), EnterProbeBW(), and InFlight().
| 
 | private | 
Last time gain cycle updated.
Definition at line 371 of file tcp-bbr.h.
Referenced by TcpBbr(), AdvanceCyclePhase(), and IsNextCyclePhase().
| 
 | private | 
The total amount of data in bytes delivered so far.
Definition at line 379 of file tcp-bbr.h.
Referenced by TcpBbr(), CongControl(), HandleProbeRTT(), SetCwnd(), and UpdateRound().
| 
 | private | 
Maximum excess data acked in epoch.
Definition at line 382 of file tcp-bbr.h.
Referenced by AckAggregationCwnd(), CongestionStateSet(), and UpdateAckAggregation().
| 
 | private | 
Gain factor for adding extra ack to cwnd.
Definition at line 381 of file tcp-bbr.h.
Referenced by TcpBbr(), AckAggregationCwnd(), and UpdateAckAggregation().
| 
 | private | 
Current index in extra acked array.
Definition at line 387 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), and UpdateAckAggregation().
| 
 | private | 
Age of extra acked in rtt.
Definition at line 383 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), and UpdateAckAggregation().
| 
 | private | 
Window length of extra acked window.
Definition at line 384 of file tcp-bbr.h.
Referenced by TcpBbr(), GetTypeId(), and UpdateAckAggregation().
| 
 | private | 
Value of full bandwidth recorded.
Definition at line 364 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckFullPipe(), and InitFullPipe().
| 
 | private | 
Count of full bandwidth recorded consistently.
Definition at line 365 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckFullPipe(), and InitFullPipe().
| 
 | private | 
Have we seen RTT sample yet?
Definition at line 390 of file tcp-bbr.h.
Referenced by TcpBbr(), InitPacingRate(), and SetPacingRate().
| 
 | private | 
A constant specifying highest gain factor, default is 2.89.
Definition at line 347 of file tcp-bbr.h.
Referenced by TcpBbr(), EnterDrain(), EnterStartup(), and GetTypeId().
| 
 | private | 
When restarting from idle, set it true.
Definition at line 362 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckProbeRTT(), CwndEvent(), and HandleRestartFromIdle().
| 
 | private | 
Set to true after first time initialization variables.
Definition at line 377 of file tcp-bbr.h.
Referenced by TcpBbr(), and CongestionStateSet().
| 
 | private | 
A boolean that records whether BBR has filled the pipe.
Definition at line 348 of file tcp-bbr.h.
Referenced by TcpBbr(), AckAggregationCwnd(), CheckDrain(), CheckFullPipe(), ExitProbeRTT(), InitFullPipe(), SetCwnd(), and SetPacingRate().
| 
 | private | 
Maximum bandwidth filter.
Definition at line 342 of file tcp-bbr.h.
Referenced by AckAggregationCwnd(), CheckFullPipe(), InFlight(), InitPacingRate(), SetPacingRate(), UpdateAckAggregation(), and UpdateBottleneckBandwidth().
| 
 | private | 
The minimal congestion window value BBR tries to target, default 4 Segment size.
Definition at line 349 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), HandleProbeRTT(), ModulateCwndForProbeRTT(), and SetCwnd().
| 
 | private | 
Estimated two-way round-trip propagation delay of the path, estimated from the windowed minimum recent round-trip delay sample.
Definition at line 366 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), GetTypeId(), InFlight(), IsNextCyclePhase(), and UpdateRTprop().
| 
 | private | 
A boolean recording whether the BBR.RTprop has expired.
Definition at line 373 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckProbeRTT(), and UpdateRTprop().
A constant specifying the length of the RTProp min filter window, default 10 secs.
Definition at line 374 of file tcp-bbr.h.
Referenced by TcpBbr(), GetTypeId(), and UpdateRTprop().
| 
 | private | 
The wall clock time at which the current BBR.RTProp sample was obtained.
Definition at line 376 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), CwndEvent(), HandleProbeRTT(), and UpdateRTprop().
| 
 | private | 
Denotes the end of a packet-timed round trip.
Definition at line 353 of file tcp-bbr.h.
Referenced by TcpBbr(), HandleProbeRTT(), InitRoundCounting(), and UpdateRound().
| 
 | private | 
The dynamic pacing gain factor.
Definition at line 345 of file tcp-bbr.h.
Referenced by TcpBbr(), AdvanceCyclePhase(), EnterDrain(), EnterProbeBW(), EnterProbeRTT(), EnterStartup(), GetPacingGain(), GetTypeId(), InitPacingRate(), IsNextCyclePhase(), and UpdateControlParameters().
| 
 | private | 
BBR intentionally reduces the pacing rate by 1% to drain any standing queues.
See bbr_rate_bytes_per_sec in Linux. 
Definition at line 391 of file tcp-bbr.h.
Referenced by SetPacingRate().
| 
 | private | 
Enable/Disable packet conservation mode.
Definition at line 360 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), CwndEvent(), ModulateCwndForRecovery(), and UpdateRound().
| 
 | private | 
The last-known good congestion window.
Definition at line 361 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), RestoreCwnd(), and SaveCwnd().
| 
 | private | 
| 
 | private | 
Time to exit from BBR_PROBE_RTT state.
Definition at line 358 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckProbeRTT(), CwndEvent(), and HandleProbeRTT().
| 
 | private | 
A constant specifying the minimum duration for which ProbeRTT state, default 200 millisecs.
Definition at line 354 of file tcp-bbr.h.
Referenced by TcpBbr(), GetTypeId(), and HandleProbeRTT().
| 
 | private | 
True when it is time to exit BBR_PROBE_RTT.
Definition at line 359 of file tcp-bbr.h.
Referenced by TcpBbr(), CwndEvent(), and HandleProbeRTT().
| 
 | private | 
Rate operations.
Definition at line 380 of file tcp-bbr.h.
Referenced by CwndEvent(), HandleProbeRTT(), and SetRateOps().
| 
 | private | 
Count of packet-timed round trips.
Definition at line 351 of file tcp-bbr.h.
Referenced by TcpBbr(), InitRoundCounting(), UpdateBottleneckBandwidth(), and UpdateRound().
| 
 | private | 
A boolean that BBR sets to true once per packet-timed round trip.
Definition at line 352 of file tcp-bbr.h.
Referenced by TcpBbr(), CheckFullPipe(), CongestionStateSet(), HandleProbeRTT(), InitRoundCounting(), UpdateAckAggregation(), and UpdateRound().
| 
 | private | 
The maximum size of a data aggregate scheduled and transmitted together.
Definition at line 369 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), InFlight(), and SetSendQuantum().
| 
 | private | 
Current state of BBR state machine.
Definition at line 341 of file tcp-bbr.h.
Referenced by CheckCyclePhase(), CheckDrain(), CheckProbeRTT(), CwndEvent(), GetBbrState(), HandleRestartFromIdle(), InFlight(), ModulateCwndForProbeRTT(), SaveCwnd(), and SetBbrState().
| 
 | private | 
Target value for congestion window, adapted to the estimated BDP.
Definition at line 363 of file tcp-bbr.h.
Referenced by TcpBbr(), CongestionStateSet(), SetCwnd(), and UpdateTargetCwnd().
| 
 | private | 
Uniform Random Variable.
Definition at line 378 of file tcp-bbr.h.
Referenced by TcpBbr(), TcpBbr(), EnterProbeBW(), and SetStream().
| 
 | static | 
BBR uses an eight-phase cycle with the given pacing_gain value in the BBR ProbeBW gain cycle.
Definition at line 46 of file tcp-bbr.h.
Referenced by AdvanceCyclePhase().