author | Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
Sat, 01 Mar 2008 21:21:53 +0100 | |
changeset 2524 | db72c0e7743e |
parent 2282 | 6320b3a7f382 |
child 3905 | 99c9346b5d71 |
permissions | -rw-r--r-- |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
1 |
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
2 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
3 |
#include "ns3/nstime.h" |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
4 |
#include "ns3/event-id.h" |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
5 |
#include <vector> |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
6 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
7 |
namespace ns3 { |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
8 |
|
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
9 |
class WifiPhy; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
10 |
class WifiMac; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
11 |
class MacLow; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
12 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
13 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
14 |
* \brief keep track of the state needed for a single DCF |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
15 |
* function. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
16 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
17 |
* Multiple instances of a DcfState can be registered in a single |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
18 |
* DcfManager to implement 802.11e-style relative QoS. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
19 |
* DcfState::SetAifsn and DcfState::SetCwBounds allow the user to |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
20 |
* control the relative QoS differentiation. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
21 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
22 |
class DcfState |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
23 |
{ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
24 |
public: |
2100
1b8cc486edd9
initialize more state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2099
diff
changeset
|
25 |
DcfState (); |
1b8cc486edd9
initialize more state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2099
diff
changeset
|
26 |
|
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
27 |
virtual ~DcfState (); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
28 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
29 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
30 |
* \param aifsn the number of slots which make up an AIFS for a specific DCF. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
31 |
* a DIFS corresponds to an AIFSN = 2. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
32 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
33 |
* Calling this method after DcfManager::Add has been called is not recommended. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
34 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
35 |
void SetAifsn (uint32_t aifsn); |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
36 |
void SetCwMin (uint32_t minCw); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
37 |
void SetCwMax (uint32_t maxCw); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
38 |
uint32_t GetAifsn (void) const; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
39 |
uint32_t GetCwMin (void) const; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
40 |
uint32_t GetCwMax (void) const; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
41 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
42 |
* Update the value of the CW variable to take into account |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
43 |
* a transmission success or a transmission abort (stop transmission |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
44 |
* of a packet after the maximum number of retransmissions has been |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
45 |
* reached). By default, this resets the CW variable to minCW. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
46 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
47 |
void ResetCw (void); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
48 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
49 |
* Update the value of the CW variable to take into account |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
50 |
* a transmission failure. By default, this triggers a doubling |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
51 |
* of CW (capped by maxCW). |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
52 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
53 |
void UpdateFailedCw (void); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
54 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
55 |
* \param nSlots the number of slots of the backoff. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
56 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
57 |
* Start a backoff by initializing the backoff counter to the number of |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
58 |
* slots specified. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
59 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
60 |
void StartBackoffNow (uint32_t nSlots); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
61 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
62 |
* \returns the current value of the CW variable. The initial value is |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
63 |
* minCW. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
64 |
*/ |
2138
0e57bc8e2f94
make the GetCw method public to allow DcaTxop to pick a random backoff duration
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2123
diff
changeset
|
65 |
uint32_t GetCw (void) const; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
66 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
67 |
* \returns true if access has been requested for this DcfState and |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
68 |
* has not been granted already, false otherwise. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
69 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
70 |
bool IsAccessRequested (void) const; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
71 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
72 |
private: |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
73 |
friend class DcfManager; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
74 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
75 |
uint32_t GetBackoffSlots (void) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
76 |
Time GetBackoffStart (void) const; |
2122
ee136bc4f214
keep track of the last time a backoff was updated.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2107
diff
changeset
|
77 |
void UpdateBackoffSlotsNow (uint32_t nSlots, Time backoffUpdateBound); |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
78 |
void NotifyAccessRequested (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
79 |
void NotifyAccessGranted (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
80 |
void NotifyCollision (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
81 |
void NotifyInternalCollision (void); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
82 |
|
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
83 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
84 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
85 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
86 |
* that access to the medium is granted and can |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
87 |
* start immediately. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
88 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
89 |
virtual void DoNotifyAccessGranted (void) = 0; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
90 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
91 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
92 |
* that an 'internal' collision occured, that is, that |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
93 |
* the backoff timer of a higher priority DcfState expired |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
94 |
* at the same time and that access was granted to this |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
95 |
* higher priority DcfState. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
96 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
97 |
* The subclass is expected to start a new backoff by |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
98 |
* calling DcfState::StartBackoffNow and DcfManager::RequestAccess |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
99 |
* is access is still needed. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
100 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
101 |
virtual void DoNotifyInternalCollision (void) = 0; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
102 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
103 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
104 |
* that a normal collision occured, that is, that |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
105 |
* the medium was busy when access was requested. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
106 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
107 |
* The subclass is expected to start a new backoff by |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
108 |
* calling DcfState::StartBackoffNow and DcfManager::RequestAccess |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
109 |
* is access is still needed. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
110 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
111 |
virtual void DoNotifyCollision (void) = 0; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
112 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
113 |
uint32_t m_aifsn; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
114 |
uint32_t m_backoffSlots; |
2123
af94e972806a
add a small comment
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2122
diff
changeset
|
115 |
// the backoffStart variable is used to keep track of the |
af94e972806a
add a small comment
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2122
diff
changeset
|
116 |
// time at which a backoff was started or the time at which |
af94e972806a
add a small comment
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2122
diff
changeset
|
117 |
// the backoff counter was last updated. |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
118 |
Time m_backoffStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
119 |
uint32_t m_cwMin; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
120 |
uint32_t m_cwMax; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
121 |
uint32_t m_cw; |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
122 |
bool m_accessRequested; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
123 |
}; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
124 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
125 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
126 |
* \brief Manage a set of ns3::DcfState |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
127 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
128 |
* Handle a set of independent ns3::DcfState, each of which represents |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
129 |
* a single DCF within a MAC stack. Each ns3::DcfState has a priority |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
130 |
* implicitely associated with it (the priority is determined when the |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
131 |
* ns3::DcfState is added to the DcfManager: the first DcfState to be |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
132 |
* added gets the highest priority, the second, the second highest |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
133 |
* priority, and so on.) which is used to handle "internal" collisions. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
134 |
* i.e., when two local DcfState are expected to get access to the |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
135 |
* medium at the same time, the highest priority local DcfState wins |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
136 |
* access to the medium and the other DcfState suffers a "internal" |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
137 |
* collision. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
138 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
139 |
class DcfManager |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
140 |
{ |
2096 | 141 |
public: |
2099
de25c6d81572
initialize state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2096
diff
changeset
|
142 |
DcfManager (); |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
143 |
~DcfManager (); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
144 |
|
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
145 |
void SetupPhyListener (Ptr<WifiPhy> phy); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
146 |
void SetupLowListener (Ptr<MacLow> low); |
2099
de25c6d81572
initialize state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2096
diff
changeset
|
147 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
148 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
149 |
* \param slotTime the duration of a slot. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
150 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
151 |
* It is a bad idea to call this method after RequestAccess or |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
152 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
153 |
*/ |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
154 |
void SetSlot (Time slotTime); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
155 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
156 |
* \param sifs the duration of a SIFS. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
157 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
158 |
* It is a bad idea to call this method after RequestAccess or |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
159 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
160 |
*/ |
2105
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
161 |
void SetSifs (Time sifs); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
162 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
163 |
/** |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
164 |
* \param eifsNoDifs the duration of a EIFS minus the duration of DIFS. |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
165 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
166 |
* It is a bad idea to call this method after RequestAccess or |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
167 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
168 |
*/ |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
169 |
void SetEifsNoDifs (Time eifsNoDifs); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
170 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
171 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
172 |
* \param dcf a new DcfState. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
173 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
174 |
* The DcfManager does not take ownership of this pointer so, the callee |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
175 |
* must make sure that the DcfState pointer will stay valid as long |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
176 |
* as the DcfManager is valid. Note that the order in which DcfState |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
177 |
* objects are added to a DcfManager matters: the first DcfState added |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
178 |
* has the highest priority, the second DcfState added, has the second |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
179 |
* highest priority, etc. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
180 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
181 |
void Add (DcfState *dcf); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
182 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
183 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
184 |
* \param state a DcfState |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
185 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
186 |
* Notify the DcfManager that a specific DcfState needs access to the |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
187 |
* medium. The DcfManager is then responsible for starting an access |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
188 |
* timer and, invoking DcfState::DoNotifyAccessGranted when the access |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
189 |
* is granted if it ever gets granted. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
190 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
191 |
void RequestAccess (DcfState *state); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
192 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
193 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
194 |
* \param duration expected duration of reception |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
195 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
196 |
* Notify the DCF that a packet reception started |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
197 |
* for the expected duration. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
198 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
199 |
void NotifyRxStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
200 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
201 |
* Notify the DCF that a packet reception was just |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
202 |
* completed successfully. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
203 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
204 |
void NotifyRxEndOkNow (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
205 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
206 |
* Notify the DCF that a packet reception was just |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
207 |
* completed unsuccessfully. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
208 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
209 |
void NotifyRxEndErrorNow (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
210 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
211 |
* \param duration expected duration of transmission |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
212 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
213 |
* Notify the DCF that a packet transmission was |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
214 |
* just started and is expected to last for the specified |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
215 |
* duration. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
216 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
217 |
void NotifyTxStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
218 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
219 |
* \param duration expected duration of cca busy period |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
220 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
221 |
* Notify the DCF that a CCA busy period has just started. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
222 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
223 |
void NotifyCcaBusyStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
224 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
225 |
* \param duration the value of the received NAV. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
226 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
227 |
* Called at end of rx |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
228 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
229 |
void NotifyNavResetNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
230 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
231 |
* \param duration the value of the received NAV. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
232 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
233 |
* Called at end of rx |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
234 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
235 |
void NotifyNavStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
236 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
237 |
private: |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
238 |
void UpdateBackoff (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
239 |
Time MostRecent (Time a, Time b) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
240 |
Time MostRecent (Time a, Time b, Time c) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
241 |
Time MostRecent (Time a, Time b, Time c, Time d) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
242 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
243 |
* Access will never be granted to the medium _before_ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
244 |
* the time returned by this method. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
245 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
246 |
* \returns the absolute time at which access could start to |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
247 |
* be granted |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
248 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
249 |
Time GetAccessGrantStart (void) const; |
2107
9adb9e6d7bc7
improve debugging output. introduce GetBackoffStartFor and GetBackoffEndFor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2105
diff
changeset
|
250 |
Time GetBackoffStartFor (DcfState *state); |
9adb9e6d7bc7
improve debugging output. introduce GetBackoffStartFor and GetBackoffEndFor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2105
diff
changeset
|
251 |
Time GetBackoffEndFor (DcfState *state); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
252 |
void DoRestartAccessTimeoutIfNeeded (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
253 |
void AccessTimeout (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
254 |
void DoGrantAccess (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
255 |
bool IsBusy (void) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
256 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
257 |
typedef std::vector<DcfState *> States; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
258 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
259 |
States m_states; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
260 |
Time m_lastNavStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
261 |
Time m_lastNavDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
262 |
Time m_lastRxStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
263 |
Time m_lastRxDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
264 |
bool m_lastRxReceivedOk; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
265 |
Time m_lastRxEnd; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
266 |
Time m_lastTxStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
267 |
Time m_lastTxDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
268 |
Time m_lastBusyStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
269 |
Time m_lastBusyDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
270 |
bool m_rxing; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
271 |
bool m_sleeping; |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
272 |
Time m_eifsNoDifs; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
273 |
EventId m_accessTimeout; |
2105
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
274 |
Time m_slotTime; |
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
275 |
Time m_sifs; |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
276 |
class PhyListener *m_phyListener; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
277 |
class LowNavListener *m_lowListener; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
278 |
}; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
279 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
280 |
} // namespace ns3 |