author | Ramon Bauza |
Tue, 15 Sep 2009 10:47:02 +0200 | |
changeset 5189 | 8fcdf87a790a |
parent 5053 | 87648432f1ca |
child 5192 | fb3d57fd97e4 |
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; -*- */ |
4511
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
2 |
/* |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
3 |
* Copyright (c) 2005,2006 INRIA |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
4 |
* |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
5 |
* This program is free software; you can redistribute it and/or modify |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
6 |
* it under the terms of the GNU General Public License version 2 as |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
7 |
* published by the Free Software Foundation; |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
8 |
* |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
9 |
* This program is distributed in the hope that it will be useful, |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
12 |
* GNU General Public License for more details. |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
13 |
* |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
14 |
* You should have received a copy of the GNU General Public License |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
15 |
* along with this program; if not, write to the Free Software |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
17 |
* |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
19 |
*/ |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
20 |
|
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
21 |
#ifndef DCF_MANAGER_H |
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
22 |
#define DCF_MANAGER_H |
2095
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 |
#include "ns3/nstime.h" |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
25 |
#include "ns3/event-id.h" |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
26 |
#include <vector> |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
27 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
28 |
namespace ns3 { |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
29 |
|
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
30 |
class WifiPhy; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
31 |
class WifiMac; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
32 |
class MacLow; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
33 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
34 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
35 |
* \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
|
36 |
* function. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
37 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
38 |
* 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
|
39 |
* DcfManager to implement 802.11e-style relative QoS. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
40 |
* DcfState::SetAifsn and DcfState::SetCwBounds allow the user to |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
41 |
* control the relative QoS differentiation. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
42 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
43 |
class DcfState |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
44 |
{ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
45 |
public: |
2100
1b8cc486edd9
initialize more state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2099
diff
changeset
|
46 |
DcfState (); |
1b8cc486edd9
initialize more state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2099
diff
changeset
|
47 |
|
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
48 |
virtual ~DcfState (); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
49 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
50 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
51 |
* \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
|
52 |
* a DIFS corresponds to an AIFSN = 2. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
53 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
54 |
* 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
|
55 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
56 |
void SetAifsn (uint32_t aifsn); |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
57 |
void SetCwMin (uint32_t minCw); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
58 |
void SetCwMax (uint32_t maxCw); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
59 |
uint32_t GetAifsn (void) const; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
60 |
uint32_t GetCwMin (void) const; |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
61 |
uint32_t GetCwMax (void) const; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
62 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
63 |
* 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
|
64 |
* a transmission success or a transmission abort (stop transmission |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
65 |
* 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
|
66 |
* 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
|
67 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
68 |
void ResetCw (void); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
69 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
70 |
* 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
|
71 |
* a transmission failure. By default, this triggers a doubling |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
72 |
* of CW (capped by maxCW). |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
73 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
74 |
void UpdateFailedCw (void); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
75 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
76 |
* \param nSlots the number of slots of the backoff. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
77 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
78 |
* 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
|
79 |
* slots specified. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
80 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
81 |
void StartBackoffNow (uint32_t nSlots); |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
82 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
83 |
* \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
|
84 |
* minCW. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
85 |
*/ |
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
|
86 |
uint32_t GetCw (void) const; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
87 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
88 |
* \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
|
89 |
* has not been granted already, false otherwise. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
90 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
91 |
bool IsAccessRequested (void) const; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
92 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
93 |
private: |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
94 |
friend class DcfManager; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
95 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
96 |
uint32_t GetBackoffSlots (void) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
97 |
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
|
98 |
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
|
99 |
void NotifyAccessRequested (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
100 |
void NotifyAccessGranted (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
101 |
void NotifyCollision (void); |
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
102 |
void NotifyInternalCollision (void); |
5189 | 103 |
void NotifyChannelSwitching (void); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
104 |
|
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
105 |
|
2282
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 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
108 |
* that access to the medium is granted and can |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
109 |
* start immediately. |
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 DoNotifyAccessGranted (void) = 0; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
112 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
113 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
114 |
* that an 'internal' collision occured, that is, that |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
115 |
* the backoff timer of a higher priority DcfState expired |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
116 |
* 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
|
117 |
* higher priority DcfState. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
118 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
119 |
* 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
|
120 |
* calling DcfState::StartBackoffNow and DcfManager::RequestAccess |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
121 |
* is access is still needed. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
122 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
123 |
virtual void DoNotifyInternalCollision (void) = 0; |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
124 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
125 |
* Called by DcfManager to notify a DcfState subclass |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
126 |
* that a normal collision occured, that is, that |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
127 |
* the medium was busy when access was requested. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
128 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
129 |
* 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
|
130 |
* calling DcfState::StartBackoffNow and DcfManager::RequestAccess |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
131 |
* is access is still needed. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
132 |
*/ |
2145
8f3c8ef34b0a
use a simple request/grant scheme for dcf accesses
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2138
diff
changeset
|
133 |
virtual void DoNotifyCollision (void) = 0; |
5189 | 134 |
/** |
135 |
* Called by DcfManager to notify a DcfState subclass |
|
136 |
* that a channel switching occured. |
|
137 |
* |
|
138 |
* The subclass is expected to flush the queue of |
|
139 |
* packets. |
|
140 |
*/ |
|
141 |
virtual void DoNotifyChannelSwitching () = 0; |
|
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
142 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
143 |
uint32_t m_aifsn; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
144 |
uint32_t m_backoffSlots; |
2123
af94e972806a
add a small comment
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2122
diff
changeset
|
145 |
// 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
|
146 |
// 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
|
147 |
// the backoff counter was last updated. |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
148 |
Time m_backoffStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
149 |
uint32_t m_cwMin; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
150 |
uint32_t m_cwMax; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
151 |
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
|
152 |
bool m_accessRequested; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
153 |
}; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
154 |
|
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 |
* \brief Manage a set of ns3::DcfState |
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 |
* 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
|
159 |
* 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
|
160 |
* 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
|
161 |
* 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
|
162 |
* 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
|
163 |
* 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
|
164 |
* 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
|
165 |
* 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
|
166 |
* 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
|
167 |
* collision. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
168 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
169 |
class DcfManager |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
170 |
{ |
2096 | 171 |
public: |
2099
de25c6d81572
initialize state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2096
diff
changeset
|
172 |
DcfManager (); |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
173 |
~DcfManager (); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
174 |
|
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
175 |
void SetupPhyListener (Ptr<WifiPhy> phy); |
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
176 |
void SetupLowListener (Ptr<MacLow> low); |
2099
de25c6d81572
initialize state variables
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2096
diff
changeset
|
177 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
178 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
179 |
* \param slotTime the duration of a slot. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
180 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
181 |
* 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
|
182 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
183 |
*/ |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
184 |
void SetSlot (Time slotTime); |
2282
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 |
* \param sifs the duration of a SIFS. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
187 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
188 |
* 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
|
189 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
190 |
*/ |
2105
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
191 |
void SetSifs (Time sifs); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
192 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
193 |
/** |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
194 |
* \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
|
195 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
196 |
* 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
|
197 |
* one of the Notify methods has been invoked. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
198 |
*/ |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
199 |
void SetEifsNoDifs (Time eifsNoDifs); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
200 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
201 |
/** |
4460
d7ad6e210086
move GetEifsNoDifs to DcfManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents:
3905
diff
changeset
|
202 |
* \return value set previously using SetEifsNoDifs. |
d7ad6e210086
move GetEifsNoDifs to DcfManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents:
3905
diff
changeset
|
203 |
*/ |
d7ad6e210086
move GetEifsNoDifs to DcfManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents:
3905
diff
changeset
|
204 |
Time GetEifsNoDifs () const; |
d7ad6e210086
move GetEifsNoDifs to DcfManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents:
3905
diff
changeset
|
205 |
|
d7ad6e210086
move GetEifsNoDifs to DcfManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents:
3905
diff
changeset
|
206 |
/** |
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
207 |
* \param dcf a new DcfState. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
208 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
209 |
* 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
|
210 |
* 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
|
211 |
* 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
|
212 |
* 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
|
213 |
* 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
|
214 |
* highest priority, etc. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
215 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
216 |
void Add (DcfState *dcf); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
217 |
|
2282
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
218 |
/** |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
219 |
* \param state a DcfState |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
220 |
* |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
221 |
* 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
|
222 |
* 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
|
223 |
* timer and, invoking DcfState::DoNotifyAccessGranted when the access |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
224 |
* is granted if it ever gets granted. |
6320b3a7f382
add some doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2145
diff
changeset
|
225 |
*/ |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
226 |
void RequestAccess (DcfState *state); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
227 |
|
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 |
* \param duration expected duration of reception |
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 |
* Notify the DCF that a packet reception started |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
232 |
* for the expected duration. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
233 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
234 |
void NotifyRxStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
235 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
236 |
* Notify the DCF that a packet reception was just |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
237 |
* completed successfully. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
238 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
239 |
void NotifyRxEndOkNow (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
240 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
241 |
* Notify the DCF that a packet reception was just |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
242 |
* completed unsuccessfully. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
243 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
244 |
void NotifyRxEndErrorNow (void); |
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 |
* \param duration expected duration of transmission |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
247 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
248 |
* Notify the DCF that a packet transmission was |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
249 |
* just started and is expected to last for the specified |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
250 |
* duration. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
251 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
252 |
void NotifyTxStartNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
253 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
254 |
* \param duration expected duration of cca busy period |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
255 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
256 |
* 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
|
257 |
*/ |
3905
99c9346b5d71
split interference calculation from YansWifiPhy. Move them to InterferenceHelper
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2524
diff
changeset
|
258 |
void NotifyMaybeCcaBusyStartNow (Time duration); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
259 |
/** |
5189 | 260 |
* \param duration expected duration of channel switching period |
261 |
* |
|
262 |
* Notify the DCF that a channel switching period has just started. |
|
263 |
*/ |
|
264 |
void NotifySwitchingStartNow (Time duration); |
|
265 |
/** |
|
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
266 |
* \param duration the value of the received NAV. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
267 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
268 |
* Called at end of rx |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
269 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
270 |
void NotifyNavResetNow (Time duration); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
271 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
272 |
* \param duration the value of the received NAV. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
273 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
274 |
* Called at end of rx |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
275 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
276 |
void NotifyNavStartNow (Time duration); |
4509
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
277 |
void NotifyAckTimeoutStartNow (Time duration); |
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
278 |
void NotifyAckTimeoutResetNow (); |
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
279 |
void NotifyCtsTimeoutStartNow (Time duration); |
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
280 |
void NotifyCtsTimeoutResetNow (); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
281 |
private: |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
282 |
void UpdateBackoff (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
283 |
Time MostRecent (Time a, Time b) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
284 |
Time MostRecent (Time a, Time b, Time c) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
285 |
Time MostRecent (Time a, Time b, Time c, Time d) const; |
4509
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
286 |
Time MostRecent (Time a, Time b, Time c, Time d, Time e, Time f) const; |
5189 | 287 |
Time MostRecent (Time a, Time b, Time c, Time d, Time e, Time f, Time g) const; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
288 |
/** |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
289 |
* Access will never be granted to the medium _before_ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
290 |
* the time returned by this method. |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
291 |
* |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
292 |
* \returns the absolute time at which access could start to |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
293 |
* be granted |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
294 |
*/ |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
295 |
Time GetAccessGrantStart (void) const; |
2107
9adb9e6d7bc7
improve debugging output. introduce GetBackoffStartFor and GetBackoffEndFor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2105
diff
changeset
|
296 |
Time GetBackoffStartFor (DcfState *state); |
9adb9e6d7bc7
improve debugging output. introduce GetBackoffStartFor and GetBackoffEndFor
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2105
diff
changeset
|
297 |
Time GetBackoffEndFor (DcfState *state); |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
298 |
void DoRestartAccessTimeoutIfNeeded (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
299 |
void AccessTimeout (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
300 |
void DoGrantAccess (void); |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
301 |
bool IsBusy (void) const; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
302 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
303 |
typedef std::vector<DcfState *> States; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
304 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
305 |
States m_states; |
4509
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
306 |
Time m_lastAckTimeoutEnd; |
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
307 |
Time m_lastCtsTimeoutEnd; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
308 |
Time m_lastNavStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
309 |
Time m_lastNavDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
310 |
Time m_lastRxStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
311 |
Time m_lastRxDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
312 |
bool m_lastRxReceivedOk; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
313 |
Time m_lastRxEnd; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
314 |
Time m_lastTxStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
315 |
Time m_lastTxDuration; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
316 |
Time m_lastBusyStart; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
317 |
Time m_lastBusyDuration; |
5189 | 318 |
Time m_lastSwitchingStart; |
319 |
Time m_lastSwitchingDuration; |
|
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
320 |
bool m_rxing; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
321 |
bool m_sleeping; |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
322 |
Time m_eifsNoDifs; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
323 |
EventId m_accessTimeout; |
2105
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
324 |
Time m_slotTime; |
e883a100109a
get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2100
diff
changeset
|
325 |
Time m_sifs; |
2524
db72c0e7743e
port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2282
diff
changeset
|
326 |
class PhyListener *m_phyListener; |
4509
b2654e0f071d
bug 556: DcfManager does not handle AckTimeout properly when there are multiple queues
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4460
diff
changeset
|
327 |
class LowDcfListener *m_lowListener; |
2095
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
328 |
}; |
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
329 |
|
f6ec39e97e4b
a new (wholy untested) Dcf implementation
mlacage@thira.inria.fr
parents:
diff
changeset
|
330 |
} // namespace ns3 |
4511
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
331 |
|
d373c2f06a29
bug 581: error in double include of dcf-manager.h
Kirill V. Andreev <kirillano@yandex.ru>
parents:
4509
diff
changeset
|
332 |
#endif /* DCF_MANAGER_H */ |