A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
ns3::GenericMacHeader Class Reference

This class implements the Generic mac Header as described by IEEE Standard for Local and metropolitan area networks Part 16: Air Interface for Fixed Broadband Wireless Access Systems 6.3.2.1.1 Generic MAC header, page 36. More...

#include "wimax-mac-header.h"

+ Inheritance diagram for ns3::GenericMacHeader:
+ Collaboration diagram for ns3::GenericMacHeader:

Public Member Functions

 GenericMacHeader ()
 
 ~GenericMacHeader () override
 
bool check_hcs () const
 Check HCS.
 
uint32_t Deserialize (Buffer::Iterator start) override
 
uint8_t GetCi () const
 Get CI field.
 
Cid GetCid () const
 Get CID field.
 
uint8_t GetEc () const
 Get EC field.
 
uint8_t GetEks () const
 Get EKS field.
 
uint8_t GetHcs () const
 Get HCS field.
 
uint8_t GetHt () const
 Get HT field.
 
TypeId GetInstanceTypeId () const override
 Get the most derived TypeId for this Object.
 
uint16_t GetLen () const
 Get length field.
 
std::string GetName () const
 Get name field.
 
uint32_t GetSerializedSize () const override
 
uint8_t GetType () const
 Get type field.
 
void Print (std::ostream &os) const override
 
void Serialize (Buffer::Iterator start) const override
 
void SetCi (uint8_t ci)
 Set CI field.
 
void SetCid (Cid cid)
 Set CID field.
 
void SetEc (uint8_t ec)
 Set EC field.
 
void SetEks (uint8_t eks)
 Set EKS field.
 
void SetHcs (uint8_t hcs)
 Set HCS field.
 
void SetHt (uint8_t ht)
 Set HT field.
 
void SetLen (uint16_t len)
 Set length field.
 
void SetType (uint8_t type)
 Set type field.
 
- Public Member Functions inherited from ns3::Header
 ~Header () override
 
virtual uint32_t Deserialize (Buffer::Iterator start, Buffer::Iterator end)
 Deserialize the object from a buffer iterator.
 
- 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::Header
static TypeId GetTypeId ()
 Get the type ID.
 
- Static Public Member Functions inherited from ns3::Chunk
static TypeId GetTypeId ()
 Get the type ID.
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId ()
 Get the type ID.
 

Private Attributes

uint8_t c_hcs
 calculated header check sequence; this is used to check if the received header is correct or not
 
uint8_t m_ci
 CRC Indicator.
 
Cid m_cid
 CID.
 
uint8_t m_ec
 Encryption Control.
 
uint8_t m_eks
 Encryption Key Sequence.
 
uint8_t m_esf
 ESF.
 
uint8_t m_hcs
 Header Check Sequence.
 
uint8_t m_ht
 Header type.
 
uint16_t m_len
 length
 
uint8_t m_rsv1
 RSV.
 
uint8_t m_type
 type
 

Additional Inherited Members

- 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.
 

Detailed Description

This class implements the Generic mac Header as described by IEEE Standard for Local and metropolitan area networks Part 16: Air Interface for Fixed Broadband Wireless Access Systems 6.3.2.1.1 Generic MAC header, page 36.

Definition at line 102 of file wimax-mac-header.h.

Constructor & Destructor Documentation

◆ GenericMacHeader()

ns3::GenericMacHeader::GenericMacHeader ( )

Definition at line 95 of file wimax-mac-header.cc.

References c_hcs, m_esf, m_hcs, and m_rsv1.

◆ ~GenericMacHeader()

ns3::GenericMacHeader::~GenericMacHeader ( )
override

Definition at line 110 of file wimax-mac-header.cc.

Member Function Documentation

◆ check_hcs()

bool ns3::GenericMacHeader::check_hcs ( ) const

Check HCS.

Returns
true if HCS is validated

Definition at line 315 of file wimax-mac-header.cc.

References c_hcs, and m_hcs.

Referenced by ns3::BaseStationNetDevice::DoReceive(), and ns3::SubscriberStationNetDevice::DoReceive().

+ Here is the caller graph for this function:

◆ Deserialize()

uint32_t ns3::GenericMacHeader::Deserialize ( Buffer::Iterator start)
overridevirtual
Parameters
startan iterator which points to where the header should read from.
Returns
the number of bytes read.

This method is used by Packet::RemoveHeader to re-create a header from the byte buffer of a packet. The data read is expected to match bit-for-bit the representation of this header in real networks.

Note that data is not actually removed from the buffer to which the iterator points. Both Packet::RemoveHeader() and Packet::PeekHeader() call Deserialize(), but only the RemoveHeader() has additional statements to remove the header bytes from the underlying buffer and associated metadata.

Implements ns3::Header.

Definition at line 278 of file wimax-mac-header.cc.

References c_hcs, ns3::CRC8Calculate(), ns3::Buffer::Iterator::GetDistanceFrom(), m_ci, m_cid, m_ec, m_eks, m_esf, m_hcs, m_ht, m_len, m_rsv1, m_type, and ns3::Buffer::Iterator::ReadU8().

+ Here is the call graph for this function:

◆ GetCi()

uint8_t ns3::GenericMacHeader::GetCi ( ) const

Get CI field.

Returns
the CI

Definition at line 181 of file wimax-mac-header.cc.

References m_ci.

◆ GetCid()

◆ GetEc()

uint8_t ns3::GenericMacHeader::GetEc ( ) const

Get EC field.

Returns
the EC

Definition at line 169 of file wimax-mac-header.cc.

References m_ec.

◆ GetEks()

uint8_t ns3::GenericMacHeader::GetEks ( ) const

Get EKS field.

Returns
the EKS

Definition at line 187 of file wimax-mac-header.cc.

References m_eks.

◆ GetHcs()

uint8_t ns3::GenericMacHeader::GetHcs ( ) const

Get HCS field.

Returns
the HCS

Definition at line 205 of file wimax-mac-header.cc.

References m_hcs.

◆ GetHt()

uint8_t ns3::GenericMacHeader::GetHt ( ) const

Get HT field.

Returns
the HT

Definition at line 163 of file wimax-mac-header.cc.

References m_ht.

Referenced by ns3::BaseStationNetDevice::DoReceive(), and ns3::SubscriberStationNetDevice::DoReceive().

+ Here is the caller graph for this function:

◆ GetInstanceTypeId()

TypeId ns3::GenericMacHeader::GetInstanceTypeId ( ) const
overridevirtual

Get the most derived TypeId for this Object.

This method is typically implemented by ns3::Object::GetInstanceTypeId but some classes which derive from ns3::ObjectBase directly have to implement it themselves.

Returns
The TypeId associated to the most-derived type of this instance.

Implements ns3::ObjectBase.

Definition at line 227 of file wimax-mac-header.cc.

References GetTypeId().

+ Here is the call graph for this function:

◆ GetLen()

uint16_t ns3::GenericMacHeader::GetLen ( ) const

Get length field.

Returns
the length

Definition at line 193 of file wimax-mac-header.cc.

References m_len.

◆ GetName()

std::string ns3::GenericMacHeader::GetName ( ) const

Get name field.

Returns
the name

Definition at line 211 of file wimax-mac-header.cc.

◆ GetSerializedSize()

uint32_t ns3::GenericMacHeader::GetSerializedSize ( ) const
overridevirtual
Returns
the expected size of the header.

This method is used by Packet::AddHeader to store a header into the byte buffer of a packet. This method should return the number of bytes which are needed to store the full header data by Serialize.

Implements ns3::Header.

Definition at line 242 of file wimax-mac-header.cc.

Referenced by ns3::WimaxMacQueue::Dequeue(), ns3::WimaxMacQueue::Dequeue(), Ns3WimaxFragmentationTestCase::DoRun(), ns3::BaseStationNetDevice::Enqueue(), ns3::SubscriberStationNetDevice::Enqueue(), and ns3::WimaxMacQueue::GetFirstPacketHdrSize().

+ Here is the caller graph for this function:

◆ GetType()

uint8_t ns3::GenericMacHeader::GetType ( ) const

Get type field.

Returns
the type

Definition at line 175 of file wimax-mac-header.cc.

References m_type.

Referenced by ns3::WimaxMacQueue::Dequeue(), ns3::WimaxMacQueue::Dequeue(), ns3::BaseStationNetDevice::DoReceive(), ns3::SubscriberStationNetDevice::DoReceive(), and Ns3WimaxFragmentationTestCase::DoRun().

+ Here is the caller graph for this function:

◆ GetTypeId()

TypeId ns3::GenericMacHeader::GetTypeId ( )
static

Get the type ID.

Returns
the object TypeId

Definition at line 217 of file wimax-mac-header.cc.

References ns3::TypeId::SetParent().

Referenced by GetInstanceTypeId().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ Print()

void ns3::GenericMacHeader::Print ( std::ostream & os) const
overridevirtual
Parameters
osoutput stream This method is used by Packet::Print to print the content of a header as ascii data to a c++ output stream. Although the header is free to format its output as it wishes, it is recommended to follow a few rules to integrate with the packet pretty printer: start with flags, small field values located between a pair of parens. Values should be separated by whitespace. Follow the parens with the important fields, separated by whitespace. i.e.: (field1 val1 field2 val2 field3 val3) field4 val4 field5 val5

Implements ns3::Header.

Definition at line 233 of file wimax-mac-header.cc.

References m_ci, m_cid, m_ec, m_eks, m_hcs, m_len, and m_type.

◆ Serialize()

void ns3::GenericMacHeader::Serialize ( Buffer::Iterator start) const
overridevirtual
Parameters
startan iterator which points to where the header should be written.

This method is used by Packet::AddHeader to store a header into the byte buffer of a packet. The data written is expected to match bit-for-bit the representation of this header in a real network.

Implements ns3::Header.

Definition at line 248 of file wimax-mac-header.cc.

References ns3::CRC8Calculate(), ns3::Cid::GetIdentifier(), m_ci, m_cid, m_ec, m_eks, m_esf, m_ht, m_len, m_rsv1, m_type, and ns3::Buffer::Iterator::WriteU8().

+ Here is the call graph for this function:

◆ SetCi()

void ns3::GenericMacHeader::SetCi ( uint8_t ci)

Set CI field.

Parameters
cithe CI

Definition at line 133 of file wimax-mac-header.cc.

References m_ci.

◆ SetCid()

void ns3::GenericMacHeader::SetCid ( Cid cid)

Set CID field.

Parameters
cidthe CID

Definition at line 151 of file wimax-mac-header.cc.

References m_cid.

Referenced by Ns3WimaxFragmentationTestCase::DoRun(), ns3::BaseStationNetDevice::Enqueue(), and ns3::SubscriberStationNetDevice::Enqueue().

+ Here is the caller graph for this function:

◆ SetEc()

void ns3::GenericMacHeader::SetEc ( uint8_t ec)

Set EC field.

Parameters
ecthe EC

Definition at line 121 of file wimax-mac-header.cc.

References m_ec.

◆ SetEks()

void ns3::GenericMacHeader::SetEks ( uint8_t eks)

Set EKS field.

Parameters
eksthe EKS

Definition at line 139 of file wimax-mac-header.cc.

References m_eks.

◆ SetHcs()

void ns3::GenericMacHeader::SetHcs ( uint8_t hcs)

Set HCS field.

Parameters
hcsthe HCS

Definition at line 157 of file wimax-mac-header.cc.

References m_hcs.

◆ SetHt()

void ns3::GenericMacHeader::SetHt ( uint8_t ht)

Set HT field.

Parameters
htthe HT

Definition at line 115 of file wimax-mac-header.cc.

References m_ht.

◆ SetLen()

void ns3::GenericMacHeader::SetLen ( uint16_t len)

Set length field.

Parameters
lenthe length

Definition at line 145 of file wimax-mac-header.cc.

References m_len.

Referenced by ns3::WimaxMacQueue::Dequeue(), ns3::WimaxMacQueue::Dequeue(), Ns3WimaxFragmentationTestCase::DoRun(), ns3::BaseStationNetDevice::Enqueue(), and ns3::SubscriberStationNetDevice::Enqueue().

+ Here is the caller graph for this function:

◆ SetType()

void ns3::GenericMacHeader::SetType ( uint8_t type)

Set type field.

Parameters
typethe type

Definition at line 127 of file wimax-mac-header.cc.

References m_type.

Referenced by ns3::WimaxMacQueue::Dequeue(), and ns3::WimaxMacQueue::Dequeue().

+ Here is the caller graph for this function:

Member Data Documentation

◆ c_hcs

uint8_t ns3::GenericMacHeader::c_hcs
private

calculated header check sequence; this is used to check if the received header is correct or not

Definition at line 221 of file wimax-mac-header.h.

Referenced by GenericMacHeader(), check_hcs(), and Deserialize().

◆ m_ci

uint8_t ns3::GenericMacHeader::m_ci
private

CRC Indicator.

Definition at line 215 of file wimax-mac-header.h.

Referenced by Deserialize(), GetCi(), Print(), Serialize(), and SetCi().

◆ m_cid

Cid ns3::GenericMacHeader::m_cid
private

CID.

Definition at line 219 of file wimax-mac-header.h.

Referenced by Deserialize(), GetCid(), Print(), Serialize(), and SetCid().

◆ m_ec

uint8_t ns3::GenericMacHeader::m_ec
private

Encryption Control.

Definition at line 212 of file wimax-mac-header.h.

Referenced by Deserialize(), GetEc(), Print(), Serialize(), and SetEc().

◆ m_eks

uint8_t ns3::GenericMacHeader::m_eks
private

Encryption Key Sequence.

Definition at line 216 of file wimax-mac-header.h.

Referenced by Deserialize(), GetEks(), Print(), Serialize(), and SetEks().

◆ m_esf

uint8_t ns3::GenericMacHeader::m_esf
private

ESF.

Definition at line 214 of file wimax-mac-header.h.

Referenced by GenericMacHeader(), Deserialize(), and Serialize().

◆ m_hcs

uint8_t ns3::GenericMacHeader::m_hcs
private

Header Check Sequence.

Definition at line 220 of file wimax-mac-header.h.

Referenced by GenericMacHeader(), check_hcs(), Deserialize(), GetHcs(), Print(), and SetHcs().

◆ m_ht

uint8_t ns3::GenericMacHeader::m_ht
private

Header type.

Definition at line 211 of file wimax-mac-header.h.

Referenced by Deserialize(), GetHt(), Serialize(), and SetHt().

◆ m_len

uint16_t ns3::GenericMacHeader::m_len
private

length

Definition at line 218 of file wimax-mac-header.h.

Referenced by Deserialize(), GetLen(), Print(), Serialize(), and SetLen().

◆ m_rsv1

uint8_t ns3::GenericMacHeader::m_rsv1
private

RSV.

Definition at line 217 of file wimax-mac-header.h.

Referenced by GenericMacHeader(), Deserialize(), and Serialize().

◆ m_type

uint8_t ns3::GenericMacHeader::m_type
private

type

Definition at line 213 of file wimax-mac-header.h.

Referenced by Deserialize(), GetType(), Print(), Serialize(), and SetType().


The documentation for this class was generated from the following files: