A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::DsaReq Class Reference

#include <mac-messages.h>

+ Inheritance diagram for ns3::DsaReq:
+ Collaboration diagram for ns3::DsaReq:

Public Member Functions

 DsaReq ()
 This class implements the ranging request message described by "IEEE Standard for Local and metropolitan area networks Part 16: Air Interface for Fixed Broadband Wireless Access Systems" 6.3.2.3.7 Registration request (REG-REQ) message, page 51.
 DsaReq (ServiceFlow sf)
 ~DsaReq ()
uint32_t Deserialize (Buffer::Iterator start)
Cid GetCid (void) const
virtual TypeId GetInstanceTypeId (void) const
std::string GetName (void) const
uint32_t GetSerializedSize (void) const
ServiceFlow GetServiceFlow (void) const
uint32_t GetSfid (void) const
uint16_t GetTransactionId (void) const
void Print (std::ostream &os) const
void Serialize (Buffer::Iterator start) const
void SetCid (Cid cid)
 set the connection identifier
void SetServiceFlow (ServiceFlow sf)
 specify a service flow to be requested by this message
void SetSfid (uint32_t sfid)
 set the service flow identifier
void SetTransactionId (uint16_t transactionId)
- Public Member Functions inherited from ns3::Header
virtual ~Header ()

Static Public Member Functions

static TypeId GetTypeId (void)
 This method returns the TypeId associated to ns3::DsaReq.

Private Attributes

Cid m_cid
ServiceFlow m_serviceFlow
uint32_t m_sfid
uint16_t m_transactionId

Additional Inherited Members

- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
virtual void NotifyConstructionCompleted (void)

Detailed Description

Definition at line 262 of file mac-messages.h.

Constructor & Destructor Documentation

ns3::DsaReq::DsaReq ( void  )

This class implements the ranging request message described by "IEEE Standard for Local and metropolitan area networks Part 16: Air Interface for Fixed Broadband Wireless Access Systems" 6.3.2.3.7 Registration request (REG-REQ) message, page 51.

Definition at line 502 of file mac-messages.cc.

ns3::DsaReq::~DsaReq ( void  )

Definition at line 516 of file mac-messages.cc.

ns3::DsaReq::DsaReq ( ServiceFlow  sf)

Definition at line 510 of file mac-messages.cc.

References m_serviceFlow, and m_transactionId.

Member Function Documentation

uint32_t ns3::DsaReq::Deserialize ( Buffer::Iterator  start)
virtual
Parameters
startan iterator which points to where the header should written.
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.

Implements ns3::Header.

Definition at line 610 of file mac-messages.cc.

References ns3::Tlv::Deserialize(), m_serviceFlow, m_transactionId, ns3::Buffer::Iterator::ReadU16(), and visualizer.core::start().

+ Here is the call graph for this function:

Cid ns3::DsaReq::GetCid ( void  ) const
Returns
the connection identifier

Definition at line 551 of file mac-messages.cc.

References m_cid.

TypeId ns3::DsaReq::GetInstanceTypeId ( void  ) const
virtual
Returns
the TypeId associated to the most-derived type of this instance.

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

Implements ns3::ObjectBase.

Definition at line 571 of file mac-messages.cc.

References GetTypeId().

+ Here is the call graph for this function:

std::string ns3::DsaReq::GetName ( void  ) const

Definition at line 558 of file mac-messages.cc.

uint32_t ns3::DsaReq::GetSerializedSize ( void  ) const
virtual
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 593 of file mac-messages.cc.

References ns3::Tlv::GetSerializedSize(), m_serviceFlow, and ns3::ServiceFlow::ToTlv().

+ Here is the call graph for this function:

ServiceFlow ns3::DsaReq::GetServiceFlow ( void  ) const
Returns
the service flow requested by this message

Definition at line 621 of file mac-messages.cc.

References m_serviceFlow.

Referenced by DsaRequestTestCase::DoRun(), and ns3::BsServiceFlowManager::ProcessDsaReq().

+ Here is the caller graph for this function:

uint32_t ns3::DsaReq::GetSfid ( void  ) const
Returns
the service flow identifier

Definition at line 539 of file mac-messages.cc.

References m_sfid.

uint16_t ns3::DsaReq::GetTransactionId ( void  ) const

Definition at line 527 of file mac-messages.cc.

References m_transactionId.

Referenced by ns3::SsServiceFlowManager::CreateDsaAck(), and ns3::BsServiceFlowManager::ProcessDsaReq().

+ Here is the caller graph for this function:

TypeId ns3::DsaReq::GetTypeId ( void  )
static

This method returns the TypeId associated to ns3::DsaReq.

No Attributes defined for this type.
No TraceSources defined for this type.

Reimplemented from ns3::Header.

Definition at line 564 of file mac-messages.cc.

References ns3::TypeId::SetParent().

Referenced by GetInstanceTypeId().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::DsaReq::Print ( std::ostream &  os) const
virtual
Parameters
osoutput stream This method is used by Packet::Print to print the content of a trailer as ascii data to a c++ output stream. Although the trailer 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 577 of file mac-messages.cc.

References m_cid, m_sfid, and m_transactionId.

void ns3::DsaReq::Serialize ( Buffer::Iterator  start) const
virtual
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 601 of file mac-messages.cc.

References m_serviceFlow, m_transactionId, ns3::Tlv::Serialize(), visualizer.core::start(), ns3::ServiceFlow::ToTlv(), and ns3::Buffer::Iterator::WriteU16().

+ Here is the call graph for this function:

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

set the connection identifier

Parameters
cidthe connection identifier

Definition at line 545 of file mac-messages.cc.

References m_cid.

void ns3::DsaReq::SetServiceFlow ( ServiceFlow  sf)

specify a service flow to be requested by this message

Parameters
sfthe service flow

Definition at line 627 of file mac-messages.cc.

References m_serviceFlow.

Referenced by ns3::SsServiceFlowManager::CreateDsaReq().

+ Here is the caller graph for this function:

void ns3::DsaReq::SetSfid ( uint32_t  sfid)

set the service flow identifier

Parameters
sfidthe service flow identifier

Definition at line 533 of file mac-messages.cc.

References m_sfid.

void ns3::DsaReq::SetTransactionId ( uint16_t  transactionId)

Definition at line 521 of file mac-messages.cc.

References m_transactionId.

Referenced by ns3::SsServiceFlowManager::CreateDsaReq().

+ Here is the caller graph for this function:

Member Data Documentation

Cid ns3::DsaReq::m_cid
private

Definition at line 315 of file mac-messages.h.

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

ServiceFlow ns3::DsaReq::m_serviceFlow
private
uint32_t ns3::DsaReq::m_sfid
private

Definition at line 314 of file mac-messages.h.

Referenced by GetSfid(), Print(), and SetSfid().

uint16_t ns3::DsaReq::m_transactionId
private

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