A Discrete-Event Network Simulator
API
channel-scheduler.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * This program is free software; you can redistribute it and/or modify
4  * it under the terms of the GNU General Public License version 2 as
5  * published by the Free Software Foundation;
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software
14  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
15  *
16  * Author: Junling Bu <linlinjavaer@gmail.com>
17  */
18 #ifndef CHANNEL_SCHEDULER_H
19 #define CHANNEL_SCHEDULER_H
20 
21 #include <map>
22 #include "wave-net-device.h"
23 namespace ns3 {
24 class WaveNetDevice;
25 
31 {
32  uint32_t cwmin;
33  uint32_t cwmax;
34  uint32_t aifsn;
35 };
36 
41 typedef std::map<AcIndex,EdcaParameter> EdcaParameters;
42 
47 typedef std::map<AcIndex,EdcaParameter>::const_iterator EdcaParametersI;
48 
49 #define EXTENDED_ALTERNATING 0x00
50 #define EXTENDED_CONTINUOUS 0xff
51 
65 struct SchInfo
66 {
67  uint32_t channelNumber;
68  //OperationalRateSet operationalRateSet; // not supported
70  uint8_t extendedAccess;
72  SchInfo ()
74  : channelNumber (SCH1),
75  immediateAccess (false),
77  {
78 
79  }
86  SchInfo (uint32_t channel, bool immediate, uint32_t channelAccess)
88  immediateAccess (immediate),
89  extendedAccess (channelAccess)
90  {
91 
92  }
100  SchInfo (uint32_t channel, bool immediate, uint32_t channelAccess, EdcaParameters edca)
102  immediateAccess (immediate),
103  extendedAccess (channelAccess),
104  edcaParameters (edca)
105  {
106 
107  }
108 };
109 
112 {
113  ContinuousAccess, // continuous access for SCHs
114  AlternatingAccess, //alternating CCH and SCH access
115  ExtendedAccess, // extended access in SCHs
116  DefaultCchAccess, // default continuous CCH access
117  NoAccess, // no channel access assigned
118 };
119 
129 class ChannelScheduler : public Object
130 {
131 public:
136  static TypeId GetTypeId (void);
137  ChannelScheduler ();
138  virtual ~ChannelScheduler ();
139 
143  virtual void SetWaveNetDevice (Ptr<WaveNetDevice> device);
147  bool IsCchAccessAssigned (void) const;
151  bool IsSchAccessAssigned (void) const;
156  bool IsChannelAccessAssigned (uint32_t channelNumber) const;
161  bool IsContinuousAccessAssigned (uint32_t channelNumber) const;
166  bool IsAlternatingAccessAssigned (uint32_t channelNumber) const;
171  bool IsExtendedAccessAssigned (uint32_t channelNumber) const;
175  bool IsDefaultCchAccessAssigned (void) const;
180  virtual enum ChannelAccess GetAssignedAccessType (uint32_t channelNumber) const = 0;
181 
188  bool StartSch (const SchInfo & schInfo);
194  bool StopSch (uint32_t channelNumber);
195 
196 protected:
197  virtual void DoInitialize (void);
198  virtual void DoDispose (void);
199 
207  virtual bool AssignAlternatingAccess (uint32_t channelNumber, bool immediate) = 0;
215  virtual bool AssignContinuousAccess (uint32_t channelNumber, bool immediate) = 0;
224  virtual bool AssignExtendedAccess (uint32_t channelNumber, uint32_t extends, bool immediate) = 0;
229  virtual bool AssignDefaultCchAccess (void) = 0;
235  virtual bool ReleaseAccess (uint32_t channelNumber) = 0;
236 
238 };
239 
240 }
241 #endif /* CHANNEL_SCHEDULER_H */
ns3::EdcaParameter::aifsn
uint32_t aifsn
AIFSN.
Definition: channel-scheduler.h:34
ns3::TypeId
a unique identifier for an interface.
Definition: type-id.h:59
ns3::ChannelScheduler::IsSchAccessAssigned
bool IsSchAccessAssigned(void) const
Definition: channel-scheduler.cc:80
ns3::ExtendedAccess
@ ExtendedAccess
Definition: channel-scheduler.h:115
ns3::ChannelScheduler::~ChannelScheduler
virtual ~ChannelScheduler()
Definition: channel-scheduler.cc:46
ns3::EdcaParameters
std::map< AcIndex, EdcaParameter > EdcaParameters
EDCA parameters typedef.
Definition: channel-scheduler.h:41
EXTENDED_ALTERNATING
#define EXTENDED_ALTERNATING
Definition: channel-scheduler.h:49
ns3::ContinuousAccess
@ ContinuousAccess
Definition: channel-scheduler.h:113
ns3
Every class exported by the ns3 library is enclosed in the ns3 namespace.
ns3::SchInfo::extendedAccess
uint8_t extendedAccess
extended access
Definition: channel-scheduler.h:70
ns3::AlternatingAccess
@ AlternatingAccess
Definition: channel-scheduler.h:114
ns3::ChannelScheduler::IsContinuousAccessAssigned
bool IsContinuousAccessAssigned(uint32_t channelNumber) const
Definition: channel-scheduler.cc:89
SCH1
#define SCH1
Definition: channel-manager.h:49
third.channel
channel
Definition: third.py:92
ns3::SchInfo::immediateAccess
bool immediateAccess
immediate access
Definition: channel-scheduler.h:69
ns3::EdcaParametersI
std::map< AcIndex, EdcaParameter >::const_iterator EdcaParametersI
EDCA parameters iterator typedef.
Definition: channel-scheduler.h:47
ns3::ChannelScheduler::DoInitialize
virtual void DoInitialize(void)
Initialize() implementation.
Definition: channel-scheduler.cc:52
ns3::ChannelScheduler::ChannelScheduler
ChannelScheduler()
Definition: channel-scheduler.cc:42
wave-net-device.h
ns3::SchInfo::edcaParameters
EdcaParameters edcaParameters
EDCA parameters.
Definition: channel-scheduler.h:71
ns3::SchInfo
Definition: channel-scheduler.h:66
ns3::ChannelScheduler::IsChannelAccessAssigned
bool IsChannelAccessAssigned(uint32_t channelNumber) const
Definition: channel-scheduler.cc:66
ns3::ChannelScheduler::AssignExtendedAccess
virtual bool AssignExtendedAccess(uint32_t channelNumber, uint32_t extends, bool immediate)=0
ns3::EdcaParameter::cwmax
uint32_t cwmax
maximum
Definition: channel-scheduler.h:33
ns3::ChannelScheduler
This class will assign channel access for requests from higher layers.
Definition: channel-scheduler.h:130
ns3::Ptr< WaveNetDevice >
ns3::ChannelAccess
ChannelAccess
ChannelAccess enumeration.
Definition: channel-scheduler.h:112
ns3::NoAccess
@ NoAccess
Definition: channel-scheduler.h:117
ns3::Object
A base class which provides memory management and object aggregation.
Definition: object.h:88
ns3::SchInfo::SchInfo
SchInfo(uint32_t channel, bool immediate, uint32_t channelAccess)
Initializer.
Definition: channel-scheduler.h:86
ns3::SchInfo::SchInfo
SchInfo(uint32_t channel, bool immediate, uint32_t channelAccess, EdcaParameters edca)
Initializer.
Definition: channel-scheduler.h:100
ns3::ChannelScheduler::IsCchAccessAssigned
bool IsCchAccessAssigned(void) const
Definition: channel-scheduler.cc:73
ns3::ChannelScheduler::SetWaveNetDevice
virtual void SetWaveNetDevice(Ptr< WaveNetDevice > device)
Definition: channel-scheduler.cc:59
ns3::SchInfo::channelNumber
uint32_t channelNumber
channel number
Definition: channel-scheduler.h:67
ns3::ChannelScheduler::IsAlternatingAccessAssigned
bool IsAlternatingAccessAssigned(uint32_t channelNumber) const
Definition: channel-scheduler.cc:95
ns3::ChannelScheduler::DoDispose
virtual void DoDispose(void)
Destructor implementation.
Definition: channel-scheduler.cc:164
ns3::ChannelScheduler::ReleaseAccess
virtual bool ReleaseAccess(uint32_t channelNumber)=0
ns3::ChannelScheduler::StartSch
bool StartSch(const SchInfo &schInfo)
Definition: channel-scheduler.cc:113
ns3::ChannelScheduler::GetAssignedAccessType
virtual enum ChannelAccess GetAssignedAccessType(uint32_t channelNumber) const =0
ns3::ChannelScheduler::AssignAlternatingAccess
virtual bool AssignAlternatingAccess(uint32_t channelNumber, bool immediate)=0
ns3::ChannelScheduler::StopSch
bool StopSch(uint32_t channelNumber)
Definition: channel-scheduler.cc:147
ns3::SchInfo::SchInfo
SchInfo()
Initializer.
Definition: channel-scheduler.h:73
ns3::ChannelScheduler::IsDefaultCchAccessAssigned
bool IsDefaultCchAccessAssigned(void) const
Definition: channel-scheduler.cc:107
ns3::ChannelScheduler::m_device
Ptr< WaveNetDevice > m_device
the device
Definition: channel-scheduler.h:237
ns3::EdcaParameter
EdcaParameter structure.
Definition: channel-scheduler.h:31
ns3::ChannelScheduler::GetTypeId
static TypeId GetTypeId(void)
Get the type ID.
Definition: channel-scheduler.cc:33
ns3::DefaultCchAccess
@ DefaultCchAccess
Definition: channel-scheduler.h:116
ns3::ChannelScheduler::IsExtendedAccessAssigned
bool IsExtendedAccessAssigned(uint32_t channelNumber) const
Definition: channel-scheduler.cc:101
ns3::ChannelScheduler::AssignDefaultCchAccess
virtual bool AssignDefaultCchAccess(void)=0
This method will assign default CCH access for CCH.
ns3::EdcaParameter::cwmin
uint32_t cwmin
minimum
Definition: channel-scheduler.h:32
ns3::ChannelScheduler::AssignContinuousAccess
virtual bool AssignContinuousAccess(uint32_t channelNumber, bool immediate)=0