Defines the TCP option of kind 3 (window scale option) as in RFC 1323 More...
#include "tcp-option-winscale.h"
Public Member Functions | |
| TcpOptionWinScale () | |
| ~TcpOptionWinScale () override | |
| uint32_t | Deserialize (Buffer::Iterator start) override |
| Deserialize the Option from a buffer iterator. | |
| uint8_t | GetKind () const override |
| Get the ‘kind’ (as in RFC 793) of this option. | |
| uint8_t | GetScale () const |
| Get the scale value (uint8_t) | |
| uint32_t | GetSerializedSize () const override |
| Returns number of bytes required for Option serialization. | |
| void | Print (std::ostream &os) const override |
| Print the Option contents. | |
| void | Serialize (Buffer::Iterator start) const override |
| Serialize the Option to a buffer iterator. | |
| void | SetScale (uint8_t scale) |
| Set the scale option. | |
| Public Member Functions inherited from ns3::TcpOption | |
| TcpOption () | |
| ~TcpOption () override | |
| 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. | |
| 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::TcpOption | |
| static Ptr< TcpOption > | CreateOption (uint8_t kind) |
| Creates an option. | |
| static TypeId | GetTypeId () |
| Get the type ID. | |
| static bool | IsKindKnown (uint8_t kind) |
| Check if the option is implemented. | |
| 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. | |
Protected Attributes | |
| uint8_t | m_scale |
| Window scaling in number of bit shift. | |
Additional Inherited Members | |
| Public Types inherited from ns3::TcpOption | |
| enum | Kind { END = 0 , NOP = 1 , MSS = 2 , WINSCALE = 3 , SACKPERMITTED = 4 , SACK = 5 , TS = 8 , UNKNOWN = 255 } |
| The option Kind, as defined in the respective RFCs. More... | |
| 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. | |
Defines the TCP option of kind 3 (window scale option) as in RFC 1323
For more efficient use of high bandwidth networks, a larger TCP window size may be used. The TCP window size field controls the flow of data and its value is limited to between 2 and 65,535 bytes.
Since the size field cannot be expanded, a scaling factor is used. The TCP window scale option, as defined in RFC 1323, is an option used to increase the maximum window size from 65,535 bytes to 1 gigabyte. Scaling up to larger window sizes is a part of what is necessary for TCP Tuning.
The window scale option is used only during the TCP 3-way handshake. The window scale value represents the number of bits to left-shift the 16-bit window size field. The window scale value can be set from 0 (no shift) to 14 for each direction independently. Both sides must send the option in their SYN segments to enable window scaling in either direction.
Definition at line 39 of file tcp-option-winscale.h.
| ns3::TcpOptionWinScale::TcpOptionWinScale | ( | ) |
Definition at line 21 of file tcp-option-winscale.cc.
References ns3::TcpOption::TcpOption(), and m_scale.
Referenced by GetTypeId().
|
override |
Definition at line 27 of file tcp-option-winscale.cc.
|
overridevirtual |
Deserialize the Option from a buffer iterator.
| start | the buffer iterator |
Implements ns3::TcpOption.
Definition at line 63 of file tcp-option-winscale.cc.
References GetKind(), GetSerializedSize(), m_scale, NS_LOG_WARN, and ns3::Buffer::Iterator::ReadU8().
Referenced by TcpOptionWSTestCase::TestDeserialize().
|
overridevirtual |
Get the ‘kind’ (as in RFC 793) of this option.
Implements ns3::TcpOption.
Definition at line 84 of file tcp-option-winscale.cc.
References ns3::TcpOption::WINSCALE.
Referenced by Deserialize(), and Serialize().
| uint8_t ns3::TcpOptionWinScale::GetScale | ( | ) | const |
Get the scale value (uint8_t)
Definition at line 90 of file tcp-option-winscale.cc.
References m_scale, and NS_ASSERT.
Referenced by TcpOptionWSTestCase::TestDeserialize(), and TcpOptionWSTestCase::TestSerialize().
|
overridevirtual |
Returns number of bytes required for Option serialization.
Implements ns3::TcpOption.
Definition at line 48 of file tcp-option-winscale.cc.
Referenced by Deserialize(), and TcpOptionWSTestCase::TestSerialize().
|
static |
Get the type ID.
Definition at line 32 of file tcp-option-winscale.cc.
References ns3::TcpOption::TcpOption(), TcpOptionWinScale(), and ns3::TypeId::SetParent().
Referenced by ns3::TcpOption::CreateOption().
|
overridevirtual |
Print the Option contents.
| os | the output stream |
Implements ns3::TcpOption.
Definition at line 42 of file tcp-option-winscale.cc.
References m_scale.
|
overridevirtual |
Serialize the Option to a buffer iterator.
| start | the buffer iterator |
Implements ns3::TcpOption.
Definition at line 54 of file tcp-option-winscale.cc.
References GetKind(), m_scale, and ns3::Buffer::Iterator::WriteU8().
Referenced by TcpOptionWSTestCase::TestSerialize().
| void ns3::TcpOptionWinScale::SetScale | ( | uint8_t | scale | ) |
Set the scale option.
The scale option SHOULD be <= 14 (as RFC 1323).
| scale | Scale factor |
Definition at line 98 of file tcp-option-winscale.cc.
References m_scale, and NS_ASSERT.
Referenced by TcpOptionWSTestCase::TestSerialize().
|
protected |
Window scaling in number of bit shift.
Definition at line 74 of file tcp-option-winscale.h.
Referenced by TcpOptionWinScale(), Deserialize(), GetScale(), Print(), Serialize(), and SetScale().