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