32#include "ns3/buffer.h"
36#include "ns3/packet.h"
37#include "ns3/pointer.h"
38#include "ns3/simulator.h"
50 m_maxDsaRspRetries(100)
112std::vector<ServiceFlow*>
135 SSRecord* ssRecord = bs->GetSSManager()->GetSSRecord(cid);
136 if (ssRecord ==
nullptr)
138 NS_LOG_INFO(
"SS not registered with the BS CID:" << cid);
144 ssRecord->AddServiceFlow(serviceFlow);
146 bs->GetUplinkScheduler()->SetupServiceFlow(ssRecord, serviceFlow);
151 if (ssRecord->GetDsaRspRetries() == 0)
153 dsaRsp =
CreateDsaRsp(serviceFlow, ssRecord->GetSfTransactionId());
154 p->AddHeader(dsaRsp);
155 ssRecord->SetDsaRsp(dsaRsp);
161 p->AddHeader(ssRecord->GetDsaRsp());
165 NS_LOG_DEBUG(
"Service flows could not be initialized!");
169 ssRecord->IncrementDsaRspRetries();
192 SSRecord* ssRecord = bs->GetSSManager()->GetSSRecord(cid);
194 NS_LOG_INFO(
"BsServiceFlowManager: Processing DSA-REQ...");
195 if (ssRecord->GetSfTransactionId() != 0)
200 "Error while processing DSA request:the received transaction ID is not expected");
208 transportConnection = BsConManager->CreateConnection(
Cid::TRANSPORT);
210 transportConnection->SetServiceFlow(serviceFlow);
217 NS_LOG_INFO(
"BsServiceFlowManager: Creating a new Service flow: SFID = "
218 << serviceFlow->
GetSfid() <<
" CID = " << serviceFlow->
GetCid());
237 bs->GetUplinkScheduler()->SetupServiceFlow(
nullptr, serviceFlow);
250 NS_LOG_INFO(
"No service Flow. Could not connect.");
258 SSRecord* ssRecord = bs->GetSSManager()->GetSSRecord(cid);
265 ssRecord->SetDsaRspRetries(0);
266 ssRecord->SetSfTransactionId(0);
271 ssRecord->SetAreServiceFlowsAllocated(
true);
ServiceFlow * GetServiceFlow(uint32_t sfid) const
uint8_t m_maxDsaRspRetries
maximum number of DSA response retries
void AllocateServiceFlows(const DsaReq &dsaReq, Cid cid)
allocate service flows
void DoDispose() override
Destructor implementation.
~BsServiceFlowManager() override
Cid m_inuseScheduleDsaRspCid
in use schedule DSA response CID
void AddMulticastServiceFlow(ServiceFlow sf, WimaxPhy::ModulationType modulation)
add a multicast service flow
Ptr< WimaxNetDevice > m_device
the device
void ScheduleDsaRsp(ServiceFlow *serviceFlow, Cid cid)
Create DSA response function.
@ CONFIRMATION_CODE_SUCCESS
void ProcessDsaAck(const DsaAck &dsaAck, Cid cid)
process a DSA-ACK message
std::vector< ServiceFlow * > GetServiceFlows(ServiceFlow::SchedulingType schedulingType) const
static TypeId GetTypeId()
Register this type.
void AddServiceFlow(ServiceFlow *serviceFlow)
Add a new service flow.
uint8_t GetMaxDsaRspRetries() const
void SetMaxDsaRspRetries(uint8_t maxDsaRspRetries)
set the maximum Dynamic ServiceFlow Add (DSA) retries
DsaRsp CreateDsaRsp(const ServiceFlow *serviceFlow, uint16_t transactionId)
Create DSA response function.
EventId m_dsaAckTimeoutEvent
DSA ack timeout event.
EventId GetDsaAckTimeoutEvent() const
BsServiceFlowManager(Ptr< BaseStationNetDevice > device)
Constructor.
uint32_t m_sfidIndex
SFID index.
ServiceFlow * ProcessDsaReq(const DsaReq &dsaReq, Cid cid)
process a DSA-Req message
static Cid InitialRanging()
This class implements the DSA-ACK message described by "IEEE Standard for Local and metropolitan area...
uint16_t GetTransactionId() const
Get transaction ID field.
This class implements the DSA-REQ message described by "IEEE Standard for Local and metropolitan area...
ServiceFlow GetServiceFlow() const
uint16_t GetTransactionId() const
This class implements the DSA-RSP message described by "IEEE Standard for Local and metropolitan ar...
void SetConfirmationCode(uint16_t confirmationCode)
set the confirmation code
void SetServiceFlow(ServiceFlow sf)
specify a service flow to be requested by this message
void SetTransactionId(uint16_t transactionId)
set the transaction ID
An identifier for simulation events.
bool IsRunning() const
This method is syntactic sugar for !IsExpired().
Mac Management messages Section 6.3.2.3 MAC Management messages page 42, Table 14 page 43.
Smart pointer class similar to boost::intrusive_ptr.
This class is used by the base station to store some information related to subscriber station in the...
This class implements service flows as described by the IEEE-802.16 standard.
uint32_t GetSfid() const
Get SFID.
void SetModulation(WimaxPhy::ModulationType modulationType)
Set modulation.
SchedulingType
section 11.13.11 Service flow scheduling type, page 701
void SetConvergenceSublayerParam(CsParameters csparam)
Set convergence sublayer parameters.
uint16_t GetCid() const
Get CID.
void CopyParametersFrom(ServiceFlow sf)
Copy parameters from another service flow.
void SetIsMulticast(bool isMulticast)
Set is multicast.
void SetUnsolicitedGrantInterval(uint16_t unsolicitedGrantInterval)
Set unsolicited grant interval.
void SetUnsolicitedPollingInterval(uint16_t unsolicitedPollingInterval)
Set unsolicited polling interval.
void SetType(Type type)
Set type of service flow.
Direction GetDirection() const
Get direction.
CsParameters GetConvergenceSublayerParam() const
Get convergence sublayer.
void SetConnection(Ptr< WimaxConnection > connection)
Set connection.
void SetIsEnabled(bool isEnabled)
Set is enabled flag.
The same service flow manager class serves both for BS and SS though some functions are exclusive to ...
void AddServiceFlow(ServiceFlow *serviceFlow)
Add service flow function.
ServiceFlow * GetServiceFlow(uint32_t sfid) const
Get service flow by flow id.
std::vector< ServiceFlow * > GetServiceFlows(ServiceFlow::SchedulingType schedulingType) const
Get service flows function.
void DoDispose() override
Destructor implementation.
bool AreServiceFlowsAllocated()
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Cancel(const EventId &id)
Set the cancel bit on this event: the event's associated function will not be invoked when it expires...
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
ModulationType
ModulationType enumeration.
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Every class exported by the ns3 library is enclosed in the ns3 namespace.