src/wifi/model/aarfcd-wifi-manager.cc
author Lalith Suresh <suresh.lalith@gmail.com>
Fri, 04 Mar 2011 01:26:54 +0000
changeset 6852 8f1a53d3f6ca
parent 6848 src/devices/wifi/model/aarfcd-wifi-manager.cc@1f453ad50ef3
child 7141 072fb225b714
permissions -rw-r--r--
Moves devices/* and routing/* to src/
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     2
/*
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     3
 * Copyright (c) 2004,2005,2006 INRIA
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     4
 *
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     8
 *
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    12
 * GNU General Public License for more details.
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    13
 *
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    17
 *
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    18
 * Author: Federico Maguolo <maguolof@dei.unipd.it>
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    19
 */
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    20
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    21
#include "aarfcd-wifi-manager.h"
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    22
#include "ns3/assert.h"
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    23
#include "ns3/log.h"
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    24
#include "ns3/simulator.h"
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    25
#include "ns3/boolean.h"
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    26
#include "ns3/double.h"
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    27
#include "ns3/uinteger.h"
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    28
#include <algorithm>
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    29
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    30
#define Min(a,b) ((a<b)?a:b)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    31
#define Max(a,b) ((a>b)?a:b)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    32
4336
6886a39dfc47 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4334
diff changeset
    33
NS_LOG_COMPONENT_DEFINE ("Aarfcd");
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    34
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    35
namespace ns3 {
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    36
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    37
struct AarfcdWifiRemoteStation : public WifiRemoteStation
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    38
{
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    39
  uint32_t m_timer;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    40
  uint32_t m_success;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    41
  uint32_t m_failed;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    42
  bool m_recovery;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    43
  bool m_justModifyRate;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    44
  uint32_t m_retry;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    45
  
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    46
  uint32_t m_successThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    47
  uint32_t m_timerTimeout;
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    48
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    49
  uint32_t m_rate;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    50
  bool m_rtsOn;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    51
  uint32_t m_rtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    52
  uint32_t m_rtsCounter;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    53
  bool m_haveASuccess;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    54
};
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    55
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
    56
NS_OBJECT_ENSURE_REGISTERED(AarfcdWifiManager);
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    57
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    58
TypeId 
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    59
AarfcdWifiManager::GetTypeId (void)
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    60
{
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    61
  static TypeId tid = TypeId ("ns3::AarfcdWifiManager")
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    62
    .SetParent<WifiRemoteStationManager> ()
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    63
    .AddConstructor<AarfcdWifiManager> ()
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    64
    .AddAttribute ("SuccessK", "Multiplication factor for the success threshold in the AARF algorithm.",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    65
                   DoubleValue (2.0),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    66
                   MakeDoubleAccessor (&AarfcdWifiManager::m_successK),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    67
                   MakeDoubleChecker<double> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    68
    .AddAttribute ("TimerK",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    69
                   "Multiplication factor for the timer threshold in the AARF algorithm.",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    70
                   DoubleValue (2.0),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    71
                   MakeDoubleAccessor (&AarfcdWifiManager::m_timerK),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    72
                   MakeDoubleChecker<double> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    73
    .AddAttribute ("MaxSuccessThreshold",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    74
                   "Maximum value of the success threshold in the AARF algorithm.",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    75
                   UintegerValue (60),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    76
                   MakeUintegerAccessor (&AarfcdWifiManager::m_maxSuccessThreshold),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    77
                   MakeUintegerChecker<uint32_t> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    78
    .AddAttribute ("MinTimerThreshold",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    79
                   "The minimum value for the 'timer' threshold in the AARF algorithm.",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    80
                   UintegerValue (15),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    81
                   MakeUintegerAccessor (&AarfcdWifiManager::m_minTimerThreshold),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    82
                   MakeUintegerChecker<uint32_t> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    83
    .AddAttribute ("MinSuccessThreshold",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    84
                   "The minimum value for the success threshold in the AARF algorithm.",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    85
                   UintegerValue (10),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    86
                   MakeUintegerAccessor (&AarfcdWifiManager::m_minSuccessThreshold),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    87
                   MakeUintegerChecker<uint32_t> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    88
    .AddAttribute ("MinRtsWnd", 
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    89
                   "Minimum value for Rts window of Aarf-CD",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    90
                   UintegerValue (1),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    91
                   MakeUintegerAccessor (&AarfcdWifiManager::m_minRtsWnd),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    92
                   MakeUintegerChecker<uint32_t> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    93
    .AddAttribute ("MaxRtsWnd", 
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    94
                   "Maximum value for Rts window of Aarf-CD",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    95
                   UintegerValue (40),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    96
                   MakeUintegerAccessor (&AarfcdWifiManager::m_maxRtsWnd),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    97
                   MakeUintegerChecker<uint32_t> ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    98
    .AddAttribute ("TurnOffRtsAfterRateDecrease",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    99
                   "If true the RTS mechanism will be turned off when the rate will be decreased",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   100
                   BooleanValue (true),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   101
                   MakeBooleanAccessor (&AarfcdWifiManager::m_turnOffRtsAfterRateDecrease),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   102
                   MakeBooleanChecker ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   103
    .AddAttribute ("TurnOnRtsAfterRateIncrease",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   104
                   "If true the RTS mechanism will be turned on when the rate will be increased",
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   105
                   BooleanValue (true),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   106
                   MakeBooleanAccessor (&AarfcdWifiManager::m_turnOnRtsAfterRateIncrease),
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   107
                   MakeBooleanChecker ())
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   108
    ;
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   109
  return tid;
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   110
}
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   111
AarfcdWifiManager::AarfcdWifiManager ()
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   112
  : WifiRemoteStationManager ()
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   113
{}
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   114
AarfcdWifiManager::~AarfcdWifiManager ()
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   115
{}
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   116
WifiRemoteStation *
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   117
AarfcdWifiManager::DoCreateStation (void) const
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   118
{
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   119
  AarfcdWifiRemoteStation *station = new AarfcdWifiRemoteStation ();
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   120
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   121
  // aarf fields below
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   122
  station->m_successThreshold = m_minSuccessThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   123
  station->m_timerTimeout = m_minTimerThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   124
  station->m_rate = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   125
  station->m_success = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   126
  station->m_failed = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   127
  station->m_recovery = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   128
  station->m_retry = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   129
  station->m_timer = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   130
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   131
  // aarf-cd specific fields below
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   132
  station->m_rtsOn = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   133
  station->m_rtsWnd = m_minRtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   134
  station->m_rtsCounter = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   135
  station->m_justModifyRate = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   136
  station->m_haveASuccess = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   137
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   138
  return station;
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   139
}
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   140
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   141
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   142
AarfcdWifiManager::DoReportRtsFailed (WifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   143
{}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   144
/**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   145
 * It is important to realize that "recovery" mode starts after failure of
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   146
 * the first transmission after a rate increase and ends at the first successful
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   147
 * transmission. Specifically, recovery mode transcends retransmissions boundaries.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   148
 * Fundamentally, ARF handles each data transmission independently, whether it
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   149
 * is the initial transmission of a packet or the retransmission of a packet.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   150
 * The fundamental reason for this is that there is a backoff between each data
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   151
 * transmission, be it an initial transmission or a retransmission.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   152
 */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   153
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   154
AarfcdWifiManager::DoReportDataFailed (WifiRemoteStation *st)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   155
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   156
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   157
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *)st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   158
  station->m_timer++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   159
  station->m_failed++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   160
  station->m_retry++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   161
  station->m_success = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   162
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   163
  if (!station->m_rtsOn) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   164
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   165
      TurnOnRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   166
      if (!station->m_justModifyRate && !station->m_haveASuccess) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   167
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   168
          IncreaseRtsWnd (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   169
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   170
      else 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   171
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   172
          ResetRtsWnd (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   173
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   174
      station->m_rtsCounter = station->m_rtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   175
      if (station->m_retry >= 2) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   176
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   177
          station->m_timer = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   178
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   179
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   180
  else if (station->m_recovery) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   181
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   182
      NS_ASSERT (station->m_retry >= 1);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   183
      station->m_justModifyRate = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   184
      station->m_rtsCounter = station->m_rtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   185
      if (station->m_retry == 1)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   186
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   187
          // need recovery fallback
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   188
          if (m_turnOffRtsAfterRateDecrease) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   189
            {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   190
              TurnOffRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   191
            }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   192
          station->m_justModifyRate = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   193
          station->m_successThreshold = (int)(Min (station->m_successThreshold * m_successK,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   194
                                                   m_maxSuccessThreshold));
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   195
          station->m_timerTimeout = (int)(Max (station->m_timerTimeout * m_timerK,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   196
                                               m_minSuccessThreshold));
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   197
          if (station->m_rate != 0)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   198
            {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   199
              station->m_rate--;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   200
            }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   201
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   202
      station->m_timer = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   203
    } 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   204
  else 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   205
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   206
      NS_ASSERT (station->m_retry >= 1);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   207
      station->m_justModifyRate = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   208
      station->m_rtsCounter = station->m_rtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   209
      if (((station->m_retry - 1) % 2) == 1)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   210
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   211
          // need normal fallback
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   212
          if (m_turnOffRtsAfterRateDecrease) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   213
            {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   214
              TurnOffRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   215
            }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   216
          station->m_justModifyRate = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   217
          station->m_timerTimeout = m_minTimerThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   218
          station->m_successThreshold = m_minSuccessThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   219
          if (station->m_rate != 0)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   220
            {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   221
              station->m_rate--;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   222
            }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   223
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   224
      if (station->m_retry >= 2) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   225
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   226
          station->m_timer = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   227
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   228
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   229
  CheckRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   230
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   231
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   232
AarfcdWifiManager::DoReportRxOk (WifiRemoteStation *station,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   233
                              double rxSnr, WifiMode txMode)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   234
{}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   235
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   236
AarfcdWifiManager::DoReportRtsOk (WifiRemoteStation *st,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   237
                                double ctsSnr, WifiMode ctsMode, double rtsSnr)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   238
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   239
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *) st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   240
  NS_LOG_DEBUG ("station=" << station << " rts ok");
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   241
  station->m_rtsCounter--;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   242
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   243
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   244
AarfcdWifiManager::DoReportDataOk (WifiRemoteStation *st,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   245
                                 double ackSnr, WifiMode ackMode, double dataSnr)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   246
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   247
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *) st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   248
  station->m_timer++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   249
  station->m_success++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   250
  station->m_failed = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   251
  station->m_recovery = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   252
  station->m_retry = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   253
  station->m_justModifyRate = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   254
  station->m_haveASuccess = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   255
  NS_LOG_DEBUG ("station=" << station << " data ok success=" << station->m_success << ", timer=" << station->m_timer);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   256
  if ((station->m_success == station->m_successThreshold ||
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   257
       station->m_timer == station->m_timerTimeout) &&
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   258
      (station->m_rate < (GetNSupported (station) - 1))) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   259
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   260
      NS_LOG_DEBUG ("station="<<station<<" inc rate");
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   261
      station->m_rate++;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   262
      station->m_timer = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   263
      station->m_success = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   264
      station->m_recovery = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   265
      station->m_justModifyRate = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   266
      if (m_turnOnRtsAfterRateIncrease) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   267
        {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   268
          TurnOnRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   269
          ResetRtsWnd (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   270
          station->m_rtsCounter = station->m_rtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   271
        }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   272
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   273
  CheckRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   274
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   275
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   276
AarfcdWifiManager::DoReportFinalRtsFailed (WifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   277
{}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   278
void 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   279
AarfcdWifiManager::DoReportFinalDataFailed (WifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   280
{}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   281
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   282
WifiMode
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   283
AarfcdWifiManager::DoGetDataMode (WifiRemoteStation *st, uint32_t size)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   284
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   285
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *) st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   286
  return GetSupported (station, station->m_rate);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   287
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   288
WifiMode
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   289
AarfcdWifiManager::DoGetRtsMode (WifiRemoteStation *st)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   290
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   291
  // XXX: we could/should implement the Aarf algorithm for
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   292
  // RTS only by picking a single rate within the BasicRateSet.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   293
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *) st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   294
  return GetSupported (station, 0);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   295
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   296
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   297
bool
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   298
AarfcdWifiManager::DoNeedRts (WifiRemoteStation *st,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   299
                              Ptr<const Packet> packet, bool normally)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   300
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   301
  AarfcdWifiRemoteStation *station = (AarfcdWifiRemoteStation *) st;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   302
  NS_LOG_INFO ("" << station << " rate=" << station->m_rate << " rts=" << (station->m_rtsOn?"RTS":"BASIC") << 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   303
               " rtsCounter=" << station->m_rtsCounter);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   304
  return station->m_rtsOn;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   305
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   306
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   307
bool 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   308
AarfcdWifiManager::IsLowLatency (void) const
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   309
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   310
  return true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   311
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   312
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   313
void
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   314
AarfcdWifiManager::CheckRts (AarfcdWifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   315
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   316
  if (station->m_rtsCounter == 0 && station->m_rtsOn) 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   317
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   318
      TurnOffRts (station);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   319
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   320
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   321
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   322
void
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   323
AarfcdWifiManager::TurnOffRts (AarfcdWifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   324
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   325
  station->m_rtsOn = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   326
  station->m_haveASuccess = false;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   327
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   328
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   329
void
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   330
AarfcdWifiManager::TurnOnRts (AarfcdWifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   331
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   332
  station->m_rtsOn = true;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   333
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   334
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   335
void
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   336
AarfcdWifiManager::IncreaseRtsWnd (AarfcdWifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   337
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   338
  if (station->m_rtsWnd == m_maxRtsWnd)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   339
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   340
      return;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   341
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   342
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   343
  station->m_rtsWnd *= 2;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   344
  if (station->m_rtsWnd > m_maxRtsWnd)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   345
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   346
      station->m_rtsWnd = m_maxRtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   347
    }
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   348
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   349
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   350
void
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   351
AarfcdWifiManager::ResetRtsWnd (AarfcdWifiRemoteStation *station)
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   352
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   353
  station->m_rtsWnd = m_minRtsWnd;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   354
}
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   355
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4346
diff changeset
   356
4334
12b3fcf84fc5 bug 536: aarf-cd rate control
Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   357
} // namespace ns3