24 #include "ns3/simulator.h"
25 #include "ns3/packet.h"
31 #include "ns3/pointer.h"
38 #include "ns3/buffer.h"
48 m_maxDsaRspRetries (100)
63 .SetGroupName (
"Wifi")
111 std::vector<ServiceFlow*>
134 SSRecord *ssRecord = bs->GetSSManager ()->GetSSRecord (cid);
137 NS_LOG_INFO (
"SS not registered with the BS CID:" << cid);
143 ssRecord->AddServiceFlow (serviceFlow);
146 bs->GetUplinkScheduler ()->SetupServiceFlow (ssRecord, serviceFlow);
151 if (ssRecord->GetDsaRspRetries () == 0)
153 dsaRsp =
CreateDsaRsp (serviceFlow, ssRecord->GetSfTransactionId ());
155 ssRecord->SetDsaRsp (dsaRsp);
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)
199 "Error while processing DSA request:the received transaction ID is not expected");
207 transportConnection = BsConManager->CreateConnection (
Cid::TRANSPORT);
209 transportConnection->SetServiceFlow (serviceFlow);
216 NS_LOG_INFO (
"BsServiceFlowManager: Creating a new Service flow: SFID = " << serviceFlow->
GetSfid () <<
" CID = "
217 << serviceFlow->
GetCid ());
235 bs->GetUplinkScheduler ()->SetupServiceFlow (0, serviceFlow);
245 NS_LOG_INFO (
"No service Flow. Could not connect.");
253 SSRecord *ssRecord = bs->GetSSManager ()->GetSSRecord (cid);
260 ssRecord->SetDsaRspRetries (0);
261 ssRecord->SetSfTransactionId (0);
266 ssRecord->SetAreServiceFlowsAllocated (
true);
ServiceFlow * GetServiceFlow(uint32_t sfid) const
uint8_t m_maxDsaRspRetries
maximum number of DSA response retries
void DoDispose(void)
Destructor implementation.
uint8_t GetMaxDsaRspRetries(void) const
void AllocateServiceFlows(const DsaReq &dsaReq, Cid cid)
allocate service flows
Cid m_inuseScheduleDsaRspCid
in use schedule DSA response CID
void AddMulticastServiceFlow(ServiceFlow sf, enum 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
void AddServiceFlow(ServiceFlow *serviceFlow)
Add a new service flow.
void SetMaxDsaRspRetries(uint8_t maxDsaRspRetries)
set the maximum Dynamic ServiceFlow Add (DSA) retries
~BsServiceFlowManager(void)
EventId GetDsaAckTimeoutEvent(void) const
DsaRsp CreateDsaRsp(const ServiceFlow *serviceFlow, uint16_t transactionId)
Create DSA response function.
EventId m_dsaAckTimeoutEvent
DSA ack timeout event.
static TypeId GetTypeId(void)
Register this type.
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(void)
This class implements the DSA-ACK message described by "IEEE Standard for Local and metropolitan area...
uint16_t GetTransactionId(void) const
Get transaction ID field.
This class implements the DSA-REQ message described by "IEEE Standard for Local and metropolitan area...
uint16_t GetTransactionId(void) const
ServiceFlow GetServiceFlow(void) 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(void) 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.
void AddHeader(const Header &header)
Add header to this packet.
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.
void SetType(enum Type type)
Set type of service flow.
void SetModulation(enum WimaxPhy::ModulationType modulationType)
Set modulation.
enum Direction GetDirection(void) const
Get direction.
SchedulingType
section 11.13.11 Service flow scheduling type, page 701
void SetConvergenceSublayerParam(CsParameters csparam)
Set convergence sublayer parameters.
uint16_t GetCid(void) const
Get CID.
void CopyParametersFrom(ServiceFlow sf)
Copy parameters from another service flow.
void SetIsMulticast(bool isMulticast)
Set is multicast.
CsParameters GetConvergenceSublayerParam(void) const
Get convergence sublayer.
void SetUnsolicitedGrantInterval(uint16_t unsolicitedGrantInterval)
Set unsolicied grant interval.
void SetUnsolicitedPollingInterval(uint16_t unsolicitedPollingInterval)
Set unsolicited polling interval.
uint32_t GetSfid(void) const
Get SFID.
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 ...
std::vector< ServiceFlow * > GetServiceFlows(enum ServiceFlow::SchedulingType schedulingType) const
Get service flows function.
void AddServiceFlow(ServiceFlow *serviceFlow)
Add service flow function.
ServiceFlow * GetServiceFlow(uint32_t sfid) const
Get service flow by flow id.
bool AreServiceFlowsAllocated()
void DoDispose(void)
Destructor implementation.
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...
static EventId Schedule(Time const &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
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.