src/wifi/model/wifi-remote-station-manager.h
author Nicola Baldo <nbaldo@cttc.es>
Fri, 06 May 2011 18:34:24 +0200
changeset 7139 79dd02ed46ec
parent 6852 8f1a53d3f6ca
child 7141 072fb225b714
permissions -rw-r--r--
doxygen wifi module grouping all wifi classes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
1912
028e1945d5b2 fix copyright statement
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1911
diff changeset
     3
 * Copyright (c) 2005,2006,2007 INRIA
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    20
#ifndef WIFI_REMOTE_STATION_MANAGER_H
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    21
#define WIFI_REMOTE_STATION_MANAGER_H
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
1930
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
    23
#include <vector>
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
#include <utility>
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
#include "ns3/mac48-address.h"
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
    26
#include "ns3/traced-callback.h"
2268
0e57ac711220 introduce a low latency parameter for rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2003
diff changeset
    27
#include "ns3/packet.h"
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    28
#include "ns3/object.h"
6069
c21754b56036 change airtime metric to work with new wifi remote station manager
Kirill Andreev <andreev@iitp.ru>
parents: 6065
diff changeset
    29
#include "ns3/nstime.h"
1911
e24ae66c6918 use WifiMode rather than mode indexes in MacStations API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1908
diff changeset
    30
#include "wifi-mode.h"
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    31
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
namespace ns3 {
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    33
6339
84cbcc1a3f16 fixed bug 922
Nicola Baldo <nbaldo@cttc.es>
parents: 6166
diff changeset
    34
struct WifiRemoteStation;
84cbcc1a3f16 fixed bug 922
Nicola Baldo <nbaldo@cttc.es>
parents: 6166
diff changeset
    35
struct WifiRemoteStationState;
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    36
class WifiPhy;
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
    37
class WifiMacHeader;
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
2602
d9262bff6df2 add back support for introspected doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2530
diff changeset
    39
/**
6071
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    40
 * \brief Tid independent remote station statistics
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    41
 *
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    42
 * Structure is similar to struct sta_info in Linux kernel (see
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    43
 * net/mac80211/sta_info.h)
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    44
 */
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    45
class WifiRemoteStationInfo
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    46
{
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    47
public:
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    48
  WifiRemoteStationInfo ();
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    49
  /**
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    50
   * \brief Updates average frame error rate when data or RTS
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    51
   * was transmitted successfully.
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    52
   * \param retryCounter is slrc or ssrc value at the moment of
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    53
   * success transmission.
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    54
   */
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    55
  void NotifyTxSuccess (uint32_t retryCounter);
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    56
  /// Updates average frame error rate when final data or RTS has failed.
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    57
  void NotifyTxFailed ();
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    58
  /// Returns frame error rate (probability that frame is corrupted due to transmission error).
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    59
  double GetFrameErrorRate () const;
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    60
private:
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    61
  /**
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    62
   * \brief Calculate averaging coefficient for frame error rate. Depends on time of the last update.
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    63
   * \attention Calling this method twice gives different results,
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    64
   * because it resets time of last update.
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    65
   */
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    66
  double CalculateAveragingCoefficient ();
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    67
  ///averaging coefficient depends on the memory time
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    68
  Time m_memoryTime;
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    69
  ///when last update has occured
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    70
  Time m_lastUpdate;
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    71
  /// moving percentage of failed frames
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    72
  double m_failAvg;
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    73
};
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    74
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
    75
/**
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
    76
 * \brief hold a list of per-remote-station state.
7139
79dd02ed46ec doxygen wifi module grouping all wifi classes
Nicola Baldo <nbaldo@cttc.es>
parents: 6852
diff changeset
    77
 * \ingroup wifi
2602
d9262bff6df2 add back support for introspected doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2530
diff changeset
    78
 *
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
    79
 * \sa ns3::WifiRemoteStation.
2602
d9262bff6df2 add back support for introspected doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2530
diff changeset
    80
 */
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    81
class WifiRemoteStationManager : public Object
1930
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
    82
{
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
public:
2524
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    84
  static TypeId GetTypeId (void);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    85
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    86
  WifiRemoteStationManager ();
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    87
  virtual ~WifiRemoteStationManager ();
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    88
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    89
  virtual void SetupPhy (Ptr<WifiPhy> phy);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    90
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    91
  uint32_t GetMaxSsrc (void) const;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    92
  uint32_t GetMaxSlrc (void) const;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    93
  uint32_t GetRtsCtsThreshold (void) const;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    94
  uint32_t GetFragmentationThreshold (void) const;
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    95
  void SetMaxSsrc (uint32_t maxSsrc);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    96
  void SetMaxSlrc (uint32_t maxSlrc);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    97
  void SetRtsCtsThreshold (uint32_t threshold);
db72c0e7743e port wifi model to Attributes
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2508
diff changeset
    98
  void SetFragmentationThreshold (uint32_t threshold);
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
  
1930
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   100
  // Invoked in a STA upon dis-association
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   101
  // or in an AP upon reboot
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   102
  void Reset (void);
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   103
  // Invoked in a STA upon association to store
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   104
  // the set of rates which belong to the 
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   105
  // BSSBasicRateSet of the associated AP
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   106
  // and which are supported locally.
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   107
  // Invoked in an AP to configure the BSSBasicRateSet
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   108
  void AddBasicMode (WifiMode mode);
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   109
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   110
  WifiMode GetDefaultMode (void) const;
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   111
  uint32_t GetNBasicModes (void) const;
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   112
  WifiMode GetBasicMode (uint32_t i) const;
ec22299cf6bb rework MacStations to handle correctly Supported vs Basic rate sets and add IdealMacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1913
diff changeset
   113
4324
951aec5a7b9a bug 531: Adds NonUnicastMode attribute to WifiRemoteStationManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents: 3745
diff changeset
   114
  WifiMode GetNonUnicastMode (void) const;
951aec5a7b9a bug 531: Adds NonUnicastMode attribute to WifiRemoteStationManager
Timo Bingmann <timo.bingmann@student.kit.edu>
parents: 3745
diff changeset
   115
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   116
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   117
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   118
   * Invoked in an AP upon disassociation of a
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   119
   * specific STA.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   120
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   121
  void Reset (Mac48Address address);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   122
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   123
   * Invoked in a STA or AP to store the set of 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   124
   * modes supported by a destination which is
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   125
   * also supported locally.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   126
   * The set of supported modes includes
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   127
   * the BSSBasicRateSet.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   128
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   129
  void AddSupportedMode (Mac48Address address, WifiMode mode);
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   130
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   131
  bool IsBrandNew (Mac48Address address) const;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   132
  bool IsAssociated (Mac48Address address) const;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   133
  bool IsWaitAssocTxOk (Mac48Address address) const;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   134
  void RecordWaitAssocTxOk (Mac48Address address);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   135
  void RecordGotAssocTxOk (Mac48Address address);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   136
  void RecordGotAssocTxFailed (Mac48Address address);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   137
  void RecordDisassociated (Mac48Address address);
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   138
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   139
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   140
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   141
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   142
   * \param packet the packet to queue
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   143
   * \param fullPacketSize the size of the packet after its 802.11 MAC header has been added.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   144
   *
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   145
   * This method is typically invoked just before queuing a packet for transmission.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   146
   * It is a no-op unless the IsLowLatency attribute of the attached ns3::WifiRemoteStationManager
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   147
   * is set to false, in which case, the tx parameters of the packet are calculated and stored in
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   148
   * the packet as a tag. These tx parameters are later retrieved from GetDadaMode and GetRtsMode.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   149
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   150
  void PrepareForQueue (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   151
                        Ptr<const Packet> packet, uint32_t fullPacketSize);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   152
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   153
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   154
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   155
   * \param packet the packet to send
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   156
   * \param fullPacketSize the size of the packet after its 802.11 MAC header has been added.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   157
   * \returns the transmission mode to use to send this packet
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   158
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   159
  WifiMode GetDataMode (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   160
                        Ptr<const Packet> packet, uint32_t fullPacketSize);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   161
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   162
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   163
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   164
   * \param packet the packet to send
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   165
   * \returns the transmission mode to use to send the RTS prior to the
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   166
   *          transmission of the data packet itself.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   167
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   168
  WifiMode GetRtsMode (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   169
                       Ptr<const Packet> packet);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   170
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   171
   * Should be invoked whenever the RtsTimeout associated to a transmission
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   172
   * attempt expires.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   173
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   174
  void ReportRtsFailed (Mac48Address address, const WifiMacHeader *header);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   175
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   176
   * Should be invoked whenever the AckTimeout associated to a transmission
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   177
   * attempt expires.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   178
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   179
  void ReportDataFailed (Mac48Address address, const WifiMacHeader *header);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   180
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   181
   * Should be invoked whenever we receive the Cts associated to an RTS 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   182
   * we just sent.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   183
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   184
  void ReportRtsOk (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   185
                    double ctsSnr, WifiMode ctsMode, double rtsSnr);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   186
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   187
   * Should be invoked whenever we receive the Ack associated to a data packet
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   188
   * we just sent.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   189
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   190
  void ReportDataOk (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   191
                     double ackSnr, WifiMode ackMode, double dataSnr);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   192
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   193
   * Should be invoked after calling ReportRtsFailed if 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   194
   * NeedRtsRetransmission returns false
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   195
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   196
  void ReportFinalRtsFailed (Mac48Address address, const WifiMacHeader *header);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   197
  /**
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   198
   * Should be invoked after calling ReportDataFailed if 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   199
   * NeedDataRetransmission returns false
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   200
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   201
  void ReportFinalDataFailed (Mac48Address address, const WifiMacHeader *header);
2268
0e57ac711220 introduce a low latency parameter for rate control algorithms
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2003
diff changeset
   202
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   203
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   204
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   205
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   206
   * \param rxSnr the snr of the packet received
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   207
   * \param txMode the transmission mode used for the packet received.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   208
   *
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   209
   * Should be invoked whenever a packet is successfully received.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   210
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   211
  void ReportRxOk (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   212
                   double rxSnr, WifiMode txMode);
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   213
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   214
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   215
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   216
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   217
   * \param packet the packet to send
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   218
   * \returns true if we want to use an RTS/CTS handshake for this
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   219
   *          packet before sending it, false otherwise.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   220
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   221
  bool NeedRts (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   222
                Ptr<const Packet> packet);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   223
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   224
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   225
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   226
   * \param packet the packet to send
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   227
   * \returns true if we want to restart a failed RTS/CTS 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   228
   *          handshake, false otherwise.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   229
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   230
  bool NeedRtsRetransmission (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   231
                              Ptr<const Packet> packet);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   232
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   233
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   234
   * \param header MAC header
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   235
   * \param packet the packet to send
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   236
   * \returns true if we want to resend a packet 
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   237
   *          after a failed transmission attempt, false otherwise.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   238
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   239
  bool NeedDataRetransmission (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   240
                               Ptr<const Packet> packet);
2784
49006cbbfac7 GetMaxSsrc -> NeedRtsTransmission and GetMaxSlrc -> NeedDataRetransmission
Federico Maguolo <maguolof@dei.unipd.it>
parents: 2602
diff changeset
   241
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   242
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   243
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   244
   * \param header MAC header
3185
c859e129a934 fix dox warnings
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3154
diff changeset
   245
   * \param packet the packet to send
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   246
   * \returns true if this packet should be fragmented, false otherwise.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   247
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   248
  bool NeedFragmentation (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   249
                                  Ptr<const Packet> packet);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   250
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   251
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   252
   * \param header MAC header
3185
c859e129a934 fix dox warnings
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3154
diff changeset
   253
   * \param packet the packet to send
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   254
   * \param fragmentNumber the fragment index of the next fragment to send (starts at zero).
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   255
   * \returns the size of the corresponding fragment.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   256
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   257
  uint32_t GetFragmentSize (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   258
                            Ptr<const Packet> packet, uint32_t fragmentNumber);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   259
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   260
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   261
   * \param header MAC header
3185
c859e129a934 fix dox warnings
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3154
diff changeset
   262
   * \param packet the packet to send
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   263
   * \param fragmentNumber the fragment index of the next fragment to send (starts at zero).
3745
73e7bb607014 bug 372: fragmentation is broken
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3185
diff changeset
   264
   * \returns the offset within the original packet where this fragment starts.
73e7bb607014 bug 372: fragmentation is broken
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3185
diff changeset
   265
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   266
  uint32_t GetFragmentOffset (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   267
                              Ptr<const Packet> packet, uint32_t fragmentNumber);
3745
73e7bb607014 bug 372: fragmentation is broken
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3185
diff changeset
   268
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   269
   * \param address remote address
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   270
   * \param header MAC header
3745
73e7bb607014 bug 372: fragmentation is broken
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3185
diff changeset
   271
   * \param packet the packet to send
73e7bb607014 bug 372: fragmentation is broken
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3185
diff changeset
   272
   * \param fragmentNumber the fragment index of the next fragment to send (starts at zero).
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   273
   * \returns true if this is the last fragment, false otherwise.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   274
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   275
  bool IsLastFragment (Mac48Address address, const WifiMacHeader *header,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   276
                       Ptr<const Packet> packet, uint32_t fragmentNumber);
1911
e24ae66c6918 use WifiMode rather than mode indexes in MacStations API.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1908
diff changeset
   277
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   278
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   279
   * \param address remote address
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   280
   * \param rtsMode the transmission mode used to send an RTS we just received
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   281
   * \returns the transmission mode to use for the CTS to complete the RTS/CTS
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   282
   *          handshake.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   283
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   284
  WifiMode GetCtsMode (Mac48Address address, WifiMode rtsMode);
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   285
  /**
6166
0590ed1bdcfb fix some doxygen errors
Josh Pelkey <jpelkey@gatech.edu>
parents: 6071
diff changeset
   286
   * \param address
3185
c859e129a934 fix dox warnings
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3154
diff changeset
   287
   * \param dataMode the transmission mode used to send an ACK we just received
3154
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   288
   * \returns the transmission mode to use for the ACK to complete the data/ACK
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   289
   *          handshake.
aa61e5f85334 doxygen.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2784
diff changeset
   290
   */
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   291
  WifiMode GetAckMode (Mac48Address address, WifiMode dataMode);
6071
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
   292
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
   293
  WifiRemoteStationInfo GetInfo (Mac48Address address);
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   294
protected:
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   295
  virtual void DoDispose (void);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   296
  // for convenience
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   297
  WifiMode GetSupported (const WifiRemoteStation *station, uint32_t i) const;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   298
  uint32_t GetNSupported (const WifiRemoteStation *station) const;
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   299
private:
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   300
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   301
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   302
   * \param packet the packet to send
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   303
   * \param normally indicates whether the normal 802.11 rts enable mechanism would
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   304
   *        request that the rts is sent or not.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   305
   * \returns true if we want to use an RTS/CTS handshake for this
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   306
   *          packet before sending it, false otherwise.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   307
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   308
   * Note: This method is called before a unicast packet is sent on the medium.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   309
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   310
  virtual bool DoNeedRts (WifiRemoteStation *station, 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   311
                          Ptr<const Packet> packet, bool normally);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   312
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   313
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   314
   * \param packet the packet to send
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   315
   * \param normally indicates whether the normal 802.11 rts enable mechanism would
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   316
   *        request that the rts is retransmitted or not.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   317
   * \returns true if we want to restart a failed RTS/CTS 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   318
   *          handshake, false otherwise.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   319
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   320
   * Note: This method is called after an rts/cts handshake has been attempted
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   321
   *       and has failed.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   322
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   323
  virtual bool DoNeedRtsRetransmission (WifiRemoteStation *station, 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   324
                                        Ptr<const Packet> packet, bool normally);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   325
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   326
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   327
   * \param packet the packet to send
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   328
   * \param normally indicates whether the normal 802.11 data retransmission mechanism
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   329
   *        would request that the data is retransmitted or not.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   330
   * \returns true if we want to resend a packet 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   331
   *          after a failed transmission attempt, false otherwise.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   332
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   333
   * Note: This method is called after a unicast packet transmission has been attempted
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   334
   *       and has failed.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   335
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   336
  virtual bool DoNeedDataRetransmission (WifiRemoteStation *station, 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   337
                                         Ptr<const Packet> packet, bool normally);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   338
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   339
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   340
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   341
   * \param packet the packet to send
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   342
   * \param normally indicates whether the normal 802.11 data fragmentation mechanism
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   343
   *        would request that the data packet is fragmented or not.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   344
   * \returns true if this packet should be fragmented, false otherwise.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   345
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   346
   * Note: This method is called before sending a unicast packet.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   347
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   348
  virtual bool DoNeedFragmentation (WifiRemoteStation *station, 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   349
                                    Ptr<const Packet> packet, bool normally);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   350
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   351
   * \returns whether this manager is a manager designed to work in low-latency
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   352
   *          environments.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   353
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   354
   * Note: In this context, low vs high latency is defined in <i>IEEE 802.11 Rate Adaptation:
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   355
   * A Practical Approach</i>, by M. Lacage, M.H. Manshaei, and T. Turletti.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   356
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   357
  virtual bool IsLowLatency (void) const = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   358
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   359
   * \return a new station data structure
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   360
   */
6339
84cbcc1a3f16 fixed bug 922
Nicola Baldo <nbaldo@cttc.es>
parents: 6166
diff changeset
   361
  virtual WifiRemoteStation *DoCreateStation (void) const = 0;
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   362
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   363
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   364
   * \param size size of the packet or fragment we want to send
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   365
   * \returns the transmission mode to use to send a packet to the station
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   366
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   367
   * Note: This method is called before sending a unicast packet or a fragment
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   368
   *       of a unicast packet to decide which transmission mode to use.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   369
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   370
  virtual WifiMode DoGetDataMode (WifiRemoteStation *station,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   371
                                  uint32_t size) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   372
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   373
   * \param station the station with which we need to communicate
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   374
   * \returns the transmission mode to use to send an rts to the station
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   375
   *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   376
   * Note: This method is called before sending an rts to a station
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   377
   *       to decide which transmission mode to use for the rts.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   378
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   379
  virtual WifiMode DoGetRtsMode (WifiRemoteStation *station) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   380
  virtual void DoReportRtsFailed (WifiRemoteStation *station) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   381
  virtual void DoReportDataFailed (WifiRemoteStation *station) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   382
  virtual void DoReportRtsOk (WifiRemoteStation *station,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   383
                              double ctsSnr, WifiMode ctsMode, double rtsSnr) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   384
  virtual void DoReportDataOk (WifiRemoteStation *station,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   385
                               double ackSnr, WifiMode ackMode, double dataSnr) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   386
  virtual void DoReportFinalRtsFailed (WifiRemoteStation *station) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   387
  virtual void DoReportFinalDataFailed (WifiRemoteStation *station) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   388
  virtual void DoReportRxOk (WifiRemoteStation *station,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   389
                             double rxSnr, WifiMode txMode) = 0;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   390
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   391
  WifiRemoteStationState *LookupState (Mac48Address address) const;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   392
  WifiRemoteStation *Lookup (Mac48Address address, uint8_t tid) const;
6071
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
   393
  /// Find a remote station by its remote address and TID taken from MAC header
6a25c600c450 tweak slightly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 6070
diff changeset
   394
  WifiRemoteStation *Lookup (Mac48Address address, const WifiMacHeader *header) const;
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   395
  WifiMode GetControlAnswerMode (Mac48Address address, WifiMode reqMode);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   396
  uint32_t GetNFragments (Ptr<const Packet> packet);
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   397
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   398
  typedef std::vector <WifiRemoteStation *> Stations;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   399
  typedef std::vector <WifiRemoteStationState *> StationStates;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   400
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   401
  StationStates m_states;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   402
  Stations m_stations;
6372
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   403
  /**
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   404
   * This is a pointer to the WifiPhy associated with this
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   405
   * WifiRemoteStationManager that is set on call to
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   406
   * WifiRemoteStationManager::SetupPhy(). Through this pointer the
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   407
   * station manager can determine PHY characteristics, such as the
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   408
   * set of all transmission rates that may be supported (the
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   409
   * "DeviceRateSet").
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   410
   */
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   411
  Ptr<WifiPhy> m_wifiPhy;
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   412
  WifiMode m_defaultTxMode;
6372
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   413
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   414
  /**
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   415
   * This member is the list of WifiMode objects that comprise the
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   416
   * BSSBasicRateSet parameter. This list is constructed through calls
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   417
   * to WifiRemoteStationManager::AddBasicMode(), and an API that
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   418
   * allows external access to it is available through
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   419
   * WifiRemoteStationManager::GetNBasicModes() and
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   420
   * WifiRemoteStationManager::GetBasicMode().
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   421
   */
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   422
  WifiModeList m_bssBasicRateSet;
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   423
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   424
  bool m_isLowLatency;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   425
  uint32_t m_maxSsrc;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   426
  uint32_t m_maxSlrc;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   427
  uint32_t m_rtsCtsThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   428
  uint32_t m_fragmentationThreshold;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   429
  WifiMode m_nonUnicastMode;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   430
  double m_avgSlrcCoefficient;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   431
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   432
   * The trace source fired when the transmission of a single RTS has failed
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   433
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   434
  TracedCallback<Mac48Address> m_macTxRtsFailed;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   435
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   436
   * The trace source fired when the transmission of a single data packet has failed 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   437
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   438
  TracedCallback<Mac48Address> m_macTxDataFailed;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   439
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   440
   * The trace source fired when the transmission of a RTS has
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   441
   * exceeded the maximum number of attempts
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   442
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   443
  TracedCallback<Mac48Address> m_macTxFinalRtsFailed;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   444
  /**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   445
   * The trace source fired when the transmission of a data packet has
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   446
   * exceeded the maximum number of attempts
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   447
   */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   448
  TracedCallback<Mac48Address> m_macTxFinalDataFailed;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   449
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   450
};
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   451
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   452
struct WifiRemoteStationState
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   453
{
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   454
  enum 
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   455
    {
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   456
      BRAND_NEW,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   457
      DISASSOC,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   458
      WAIT_ASSOC_TX_OK,
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   459
      GOT_ASSOC_TX_OK
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   460
    } m_state;
6372
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   461
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   462
  /**
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   463
   * This member is the list of WifiMode objects that comprise the
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   464
   * OperationalRateSet parameter for this remote station. This list
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   465
   * is constructed through calls to
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   466
   * WifiRemoteStationManager::AddSupportedMode(), and an API that
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   467
   * allows external access to it is available through
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   468
   * WifiRemoteStationManager::GetNSupported() and
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   469
   * WifiRemoteStationManager::GetSupported().
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   470
   */
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   471
  WifiModeList m_operationalRateSet;
0fafd9716f44 Bug 853: Consider mandatory rates for Wi-Fi control responses
Dean Armstrong <deanarm@gmail.com>
parents: 6339
diff changeset
   472
4733
96a3881940c4 new trace sources for WifiRemoteStationManager
Nicola Baldo <nbaldo@cttc.es>
parents: 4692
diff changeset
   473
  Mac48Address m_address;
6069
c21754b56036 change airtime metric to work with new wifi remote station manager
Kirill Andreev <andreev@iitp.ru>
parents: 6065
diff changeset
   474
  WifiRemoteStationInfo m_info;
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   475
};
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   476
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   477
/**
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   478
 * \brief hold per-remote-station state.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   479
 *
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   480
 * The state in this class is used to keep track
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   481
 * of association status if we are in an infrastructure
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   482
 * network and to perform the selection of tx parameters
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   483
 * on a per-packet basis.
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   484
 */
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   485
struct WifiRemoteStation
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   486
{
6339
84cbcc1a3f16 fixed bug 922
Nicola Baldo <nbaldo@cttc.es>
parents: 6166
diff changeset
   487
  WifiRemoteStationState *m_state;
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   488
  uint32_t m_ssrc;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   489
  uint32_t m_slrc;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   490
  uint8_t m_tid;
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   491
};
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   492
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   493
1906
c0901f40bd7e move mac-station code in mac-stations
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1893
diff changeset
   494
} // namespace ns3 
1893
d72388b06b22 add MacStations to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   495
6065
0f012e7d9128 bug 602
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 5166
diff changeset
   496
#endif /* WIFI_REMOTE_STATION_MANAGER_H */