author | Lalith Suresh <suresh.lalith@gmail.com> |
Fri, 04 Mar 2011 01:26:54 +0000 | |
changeset 6852 | 8f1a53d3f6ca |
parent 6848 | src/devices/wifi/model/onoe-wifi-manager.cc@1f453ad50ef3 |
child 7141 | 072fb225b714 |
permissions | -rw-r--r-- |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
1 |
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */ |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
2 |
/* |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
3 |
* Copyright (c) 2003,2007 INRIA |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
4 |
* |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
5 |
* This program is free software; you can redistribute it and/or modify |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
6 |
* it under the terms of the GNU General Public License version 2 as |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation; |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
8 |
* |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
9 |
* This program is distributed in the hope that it will be useful, |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
12 |
* GNU General Public License for more details. |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
13 |
* |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
14 |
* You should have received a copy of the GNU General Public License |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
15 |
* along with this program; if not, write to the Free Software |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
17 |
* |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
19 |
*/ |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
20 |
|
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
21 |
#include "onoe-wifi-manager.h" |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
22 |
#include "ns3/simulator.h" |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
23 |
#include "ns3/log.h" |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
24 |
#include "ns3/uinteger.h" |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
25 |
|
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
26 |
NS_LOG_COMPONENT_DEFINE ("OnoeWifiRemoteStation"); |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
27 |
|
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
28 |
namespace ns3 { |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
29 |
|
6065 | 30 |
struct OnoeWifiRemoteStation : public WifiRemoteStation |
31 |
{ |
|
32 |
Time m_nextModeUpdate; |
|
33 |
uint32_t m_shortRetry; |
|
34 |
uint32_t m_longRetry; |
|
35 |
uint32_t m_tx_ok; |
|
36 |
uint32_t m_tx_err; |
|
37 |
uint32_t m_tx_retr; |
|
38 |
uint32_t m_tx_upper; |
|
39 |
uint32_t m_txrate; |
|
40 |
}; |
|
41 |
||
42 |
||
2624
17172ab64e3f
get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2544
diff
changeset
|
43 |
NS_OBJECT_ENSURE_REGISTERED (OnoeWifiManager); |
17172ab64e3f
get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2544
diff
changeset
|
44 |
|
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
45 |
TypeId |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
46 |
OnoeWifiManager::GetTypeId (void) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
47 |
{ |
2624
17172ab64e3f
get the typename right. make sure the object is registered with our type system.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2544
diff
changeset
|
48 |
static TypeId tid = TypeId ("ns3::OnoeWifiManager") |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
49 |
.SetParent<WifiRemoteStationManager> () |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
50 |
.AddConstructor<OnoeWifiManager> () |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
51 |
.AddAttribute ("UpdatePeriod", |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
52 |
"The interval between decisions about rate control changes", |
2965
4b28e9740e3b
get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2784
diff
changeset
|
53 |
TimeValue (Seconds (1.0)), |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
54 |
MakeTimeAccessor (&OnoeWifiManager::m_updatePeriod), |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
55 |
MakeTimeChecker ()) |
3212
0c00342d6a73
improve attribute documentation
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2965
diff
changeset
|
56 |
.AddAttribute ("RaiseThreshold", "Attempt to raise the rate if we hit that threshold", |
2965
4b28e9740e3b
get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2784
diff
changeset
|
57 |
UintegerValue (10), |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
58 |
MakeUintegerAccessor (&OnoeWifiManager::m_raiseThreshold), |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
59 |
MakeUintegerChecker<uint32_t> ()) |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
60 |
.AddAttribute ("AddCreditThreshold", "Add credit threshold", |
2965
4b28e9740e3b
get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2784
diff
changeset
|
61 |
UintegerValue (10), |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
62 |
MakeUintegerAccessor (&OnoeWifiManager::m_addCreditThreshold), |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
63 |
MakeUintegerChecker<uint32_t> ()) |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
64 |
; |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
65 |
return tid; |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
66 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
67 |
|
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
68 |
OnoeWifiManager::OnoeWifiManager () |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
69 |
{} |
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
70 |
WifiRemoteStation * |
6065 | 71 |
OnoeWifiManager::DoCreateStation (void) const |
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
72 |
{ |
6065 | 73 |
OnoeWifiRemoteStation *station = new OnoeWifiRemoteStation (); |
74 |
station->m_nextModeUpdate = Simulator::Now () + m_updatePeriod; |
|
75 |
station->m_shortRetry = 0; |
|
76 |
station->m_longRetry = 0; |
|
77 |
station->m_tx_ok = 0; |
|
78 |
station->m_tx_err = 0; |
|
79 |
station->m_tx_retr = 0; |
|
80 |
station->m_tx_upper = 0; |
|
81 |
station->m_txrate = 0; |
|
82 |
return station; |
|
2544
2e6e1a6e0d94
port last rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2277
diff
changeset
|
83 |
} |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
84 |
void |
6065 | 85 |
OnoeWifiManager::DoReportRxOk (WifiRemoteStation *station, |
86 |
double rxSnr, WifiMode txMode) |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
87 |
{} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
88 |
void |
6065 | 89 |
OnoeWifiManager::DoReportRtsFailed (WifiRemoteStation *st) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
90 |
{ |
6065 | 91 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
92 |
station->m_shortRetry++; |
|
93 |
} |
|
94 |
void |
|
95 |
OnoeWifiManager::DoReportDataFailed (WifiRemoteStation *st) |
|
96 |
{ |
|
97 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
|
98 |
station->m_longRetry++; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
99 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
100 |
void |
6065 | 101 |
OnoeWifiManager::DoReportRtsOk (WifiRemoteStation *station, |
102 |
double ctsSnr, WifiMode ctsMode, double rtsSnr) |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
103 |
{} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
104 |
void |
6065 | 105 |
OnoeWifiManager::DoReportDataOk (WifiRemoteStation *st, |
106 |
double ackSnr, WifiMode ackMode, double dataSnr) |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
107 |
{ |
6065 | 108 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
109 |
UpdateRetry (station); |
|
110 |
station->m_tx_ok++; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
111 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
112 |
void |
6065 | 113 |
OnoeWifiManager::DoReportFinalRtsFailed (WifiRemoteStation *st) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
114 |
{ |
6065 | 115 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
116 |
UpdateRetry (station); |
|
117 |
station->m_tx_err++; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
118 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
119 |
void |
6065 | 120 |
OnoeWifiManager::DoReportFinalDataFailed (WifiRemoteStation *st) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
121 |
{ |
6065 | 122 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
123 |
UpdateRetry (station); |
|
124 |
station->m_tx_err++; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
125 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
126 |
void |
6065 | 127 |
OnoeWifiManager::UpdateRetry (OnoeWifiRemoteStation *station) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
128 |
{ |
6065 | 129 |
station->m_tx_retr += station->m_shortRetry + station->m_longRetry; |
130 |
station->m_shortRetry = 0; |
|
131 |
station->m_longRetry = 0; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
132 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
133 |
void |
6065 | 134 |
OnoeWifiManager::UpdateMode (OnoeWifiRemoteStation *station) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
135 |
{ |
6065 | 136 |
if (Simulator::Now () < station->m_nextModeUpdate) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
137 |
{ |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
138 |
return; |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
139 |
} |
6065 | 140 |
station->m_nextModeUpdate = Simulator::Now () + m_updatePeriod; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
141 |
/** |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
142 |
* The following 20 lines of code were copied from the Onoe |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
143 |
* rate control kernel module used in the madwifi driver. |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
144 |
*/ |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
145 |
|
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
146 |
int dir = 0, enough; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
147 |
uint32_t nrate; |
6065 | 148 |
enough = (station->m_tx_ok + station->m_tx_err >= 10); |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
149 |
|
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
150 |
/* no packet reached -> down */ |
6065 | 151 |
if (station->m_tx_err > 0 && station->m_tx_ok == 0) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
152 |
dir = -1; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
153 |
|
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
154 |
/* all packets needs retry in average -> down */ |
6065 | 155 |
if (enough && station->m_tx_ok < station->m_tx_retr) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
156 |
dir = -1; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
157 |
|
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
158 |
/* no error and less than rate_raise% of packets need retry -> up */ |
6065 | 159 |
if (enough && station->m_tx_err == 0 && |
160 |
station->m_tx_retr < (station->m_tx_ok * m_addCreditThreshold) / 100) |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
161 |
dir = 1; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
162 |
|
6065 | 163 |
NS_LOG_DEBUG (this << " ok " << station->m_tx_ok << " err " << station->m_tx_err << " retr " << station->m_tx_retr << |
164 |
" upper " << station->m_tx_upper << " dir " << dir); |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
165 |
|
6065 | 166 |
nrate = station->m_txrate; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
167 |
switch (dir) { |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
168 |
case 0: |
6065 | 169 |
if (enough && station->m_tx_upper > 0) |
170 |
station->m_tx_upper--; |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
171 |
break; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
172 |
case -1: |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
173 |
if (nrate > 0) { |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
174 |
nrate--; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
175 |
} |
6065 | 176 |
station->m_tx_upper = 0; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
177 |
break; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
178 |
case 1: |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
179 |
/* raise rate if we hit rate_raise_threshold */ |
6065 | 180 |
if (++station->m_tx_upper < m_raiseThreshold) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
181 |
break; |
6065 | 182 |
station->m_tx_upper = 0; |
183 |
if (nrate + 1 < GetNSupported (station)) { |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
184 |
nrate++; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
185 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
186 |
break; |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
187 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
188 |
|
6065 | 189 |
if (nrate != station->m_txrate) { |
190 |
NS_ASSERT (nrate < GetNSupported (station)); |
|
191 |
station->m_txrate = nrate; |
|
192 |
station->m_tx_ok = station->m_tx_err = station->m_tx_retr = station->m_tx_upper = 0; |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
193 |
} else if (enough) |
6065 | 194 |
station->m_tx_ok = station->m_tx_err = station->m_tx_retr = 0; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
195 |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
196 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
197 |
|
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
198 |
WifiMode |
6065 | 199 |
OnoeWifiManager::DoGetDataMode (WifiRemoteStation *st, |
200 |
uint32_t size) |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
201 |
{ |
6065 | 202 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
203 |
UpdateMode (station); |
|
204 |
NS_ASSERT (station->m_txrate < GetNSupported (station)); |
|
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
205 |
uint32_t rateIndex; |
6065 | 206 |
if (station->m_longRetry < 4) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
207 |
{ |
6065 | 208 |
rateIndex = station->m_txrate; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
209 |
} |
6065 | 210 |
else if (station->m_longRetry < 6) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
211 |
{ |
6065 | 212 |
if (station->m_txrate > 0) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
213 |
{ |
6065 | 214 |
rateIndex = station->m_txrate - 1; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
215 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
216 |
else |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
217 |
{ |
6065 | 218 |
rateIndex = station->m_txrate; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
219 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
220 |
} |
6065 | 221 |
else if (station->m_longRetry < 8) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
222 |
{ |
6065 | 223 |
if (station->m_txrate > 1) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
224 |
{ |
6065 | 225 |
rateIndex = station->m_txrate - 2; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
226 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
227 |
else |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
228 |
{ |
6065 | 229 |
rateIndex = station->m_txrate; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
230 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
231 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
232 |
else |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
233 |
{ |
6065 | 234 |
if (station->m_txrate > 2) |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
235 |
{ |
6065 | 236 |
rateIndex = station->m_txrate - 3; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
237 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
238 |
else |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
239 |
{ |
6065 | 240 |
rateIndex = station->m_txrate; |
2272
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
241 |
} |
ae2bbdbfc161
the meat of the onoe rate control algorithm.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2271
diff
changeset
|
242 |
} |
6065 | 243 |
return GetSupported (station, rateIndex); |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
244 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
245 |
WifiMode |
6065 | 246 |
OnoeWifiManager::DoGetRtsMode (WifiRemoteStation *st) |
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
247 |
{ |
6065 | 248 |
OnoeWifiRemoteStation *station = (OnoeWifiRemoteStation *)st; |
249 |
UpdateMode (station); |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
250 |
// XXX: can we implement something smarter ? |
6065 | 251 |
return GetSupported (station, 0); |
252 |
} |
|
253 |
||
254 |
bool |
|
255 |
OnoeWifiManager::IsLowLatency (void) const |
|
256 |
{ |
|
257 |
return false; |
|
2271
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
258 |
} |
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
259 |
|
85724b1cbb1a
Onoe rate control
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
260 |
} // namespace ns3 |