src/devices/wifi/mac-high-nqsta.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Wed, 21 Nov 2007 11:11:27 +0100
changeset 2156 754a843db672
parent 2090 3622fda1717b
child 2159 20f882e85b4a
permissions -rw-r--r--
improve log output
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2005,2006 INRIA
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
#include "ns3/packet.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
#include "ns3/simulator.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    23
#include "ns3/assert.h"
2012
54dd9789c670 enable logging
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2009
diff changeset
    24
#include "ns3/log.h"
2156
754a843db672 improve log output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2090
diff changeset
    25
#include "ns3/node.h"
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
#include "mac-high-nqsta.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
#include "wifi-mac-header.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
#include "wifi-net-device.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
#include "mgt-headers.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    31
#include "wifi-phy.h"
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
#include "dca-txop.h"
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
    33
#include "mac-stations.h"
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
2012
54dd9789c670 enable logging
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2009
diff changeset
    35
NS_LOG_COMPONENT_DEFINE ("MacHighNqsta");
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
2012
54dd9789c670 enable logging
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2009
diff changeset
    37
#define TRACE(x) \
2156
754a843db672 improve log output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2090
diff changeset
    38
  NS_LOG_DEBUG (Simulator::Now () << " " << m_phy->GetDevice ()->GetNode ()->GetId () << ":" << \
754a843db672 improve log output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2090
diff changeset
    39
                m_phy->GetDevice ()->GetIfIndex () << " " << x);
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
/*
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
 * The state machine for this NQSTA is:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    43
 --------------            -----------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
 | Associated |   <--------------------      ------->    | Refused |
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
 --------------      \    /      -----------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
    \           \  /
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    47
     \    -----------------     -----------------------------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
      \-> | Beacon Missed | --> | Wait Association Response |
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
    -----------------     -----------------------------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
    \           ^
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    51
     \          |
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    52
      \    -----------------------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
       \-> | Wait Probe Response |
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
           -----------------------
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    55
 */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    56
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    57
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    58
namespace ns3 {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    59
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    60
MacHighNqsta::MacHighNqsta ()
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    61
  : m_state (BEACON_MISSED),
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    62
    m_probeRequestTimeout (Seconds (0.5)),
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    63
    m_assocRequestTimeout (Seconds (0.5)),
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    64
    m_probeRequestEvent (),
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    65
    m_assocRequestEvent (),
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
    66
    m_beaconWatchdogEnd (Seconds (0.0))
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    67
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    68
  // this is the default value for the number of beacons missed 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    69
  // before attempting to reassociate.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
  m_maxMissedBeacons = 10;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    72
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
MacHighNqsta::~MacHighNqsta ()
2054
ba8e810bae4c derive WifiPhy from Object and manage it with a Ptr<>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2012
diff changeset
    74
{
ba8e810bae4c derive WifiPhy from Object and manage it with a Ptr<>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2012
diff changeset
    75
  m_phy = 0;
ba8e810bae4c derive WifiPhy from Object and manage it with a Ptr<>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2012
diff changeset
    76
}
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
MacHighNqsta::SetDcaTxop (DcaTxop *dca)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    81
  m_dca = dca;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
void 
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
    84
MacHighNqsta::SetDevice (WifiNetDevice *device)
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    85
{
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
    86
  m_device = device;
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    87
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    88
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    89
MacHighNqsta::SetForwardCallback (ForwardCallback callback)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    90
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    91
  m_forward = callback;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    93
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    94
MacHighNqsta::SetAssociatedCallback (AssociatedCallback callback)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    95
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    96
  m_associatedCallback = callback;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    97
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    98
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
MacHighNqsta::SetDisAssociatedCallback (DisAssociatedCallback callback)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   100
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   101
  m_disAssociatedCallback = callback;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   102
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   103
void 
2054
ba8e810bae4c derive WifiPhy from Object and manage it with a Ptr<>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2012
diff changeset
   104
MacHighNqsta::SetPhy (Ptr<WifiPhy> phy)
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   105
{
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   106
  m_phy = phy;
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   107
}
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   108
void 
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   109
MacHighNqsta::SetStations (MacStations *stations)
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   110
{
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   111
  m_stations = stations;
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   112
}
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   113
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   114
void 
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   115
MacHighNqsta::SetMaxMissedBeacons (uint32_t missed)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   116
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   117
  m_maxMissedBeacons = missed;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   118
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   119
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   120
MacHighNqsta::SetProbeRequestTimeout (Time timeout)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   121
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   122
  m_probeRequestTimeout = timeout;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   123
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   124
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   125
MacHighNqsta::SetAssocRequestTimeout (Time timeout)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   126
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   127
  m_assocRequestTimeout = timeout;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   128
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   129
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   130
Mac48Address 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   131
MacHighNqsta::GetBssid (void) const
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   132
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   133
  return m_bssid;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   134
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   135
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   136
MacHighNqsta::SetBssid (Mac48Address bssid)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   137
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   138
  m_bssid = bssid;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   139
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   140
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   141
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   142
MacHighNqsta::StartActiveAssociation (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   143
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   144
  TryToEnsureAssociated ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   145
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   146
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   147
Mac48Address
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   148
MacHighNqsta::GetBroadcastBssid (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   149
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   150
  return Mac48Address::GetBroadcast ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   151
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   152
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   153
void
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   154
MacHighNqsta::SendProbeRequest (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   155
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   156
  TRACE ("send probe request");
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   157
  WifiMacHeader hdr;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   158
  hdr.SetProbeReq ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   159
  hdr.SetAddr1 (GetBroadcastBssid ());
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   160
  hdr.SetAddr2 (m_device->GetSelfAddress ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   161
  hdr.SetAddr3 (GetBroadcastBssid ());
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   162
  hdr.SetDsNotFrom ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   163
  hdr.SetDsNotTo ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   164
  Packet packet;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   165
  MgtProbeRequestHeader probe;
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   166
  probe.SetSsid (m_device->GetSsid ());
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   167
  probe.SetSupportedRates (GetSupportedRates ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   168
  packet.AddHeader (probe);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   169
  
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   170
  m_dca->Queue (packet, hdr);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   171
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   172
  m_probeRequestEvent = Simulator::Schedule (m_probeRequestTimeout,
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   173
                                             &MacHighNqsta::ProbeRequestTimeout, this);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   174
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   175
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   176
void
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   177
MacHighNqsta::SendAssociationRequest (void)
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   178
{
2012
54dd9789c670 enable logging
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2009
diff changeset
   179
  TRACE ("send assoc request to=" << GetBssid ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   180
  WifiMacHeader hdr;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   181
  hdr.SetAssocReq ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   182
  hdr.SetAddr1 (GetBssid ());
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   183
  hdr.SetAddr2 (m_device->GetSelfAddress ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   184
  hdr.SetAddr3 (GetBssid ());
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   185
  hdr.SetDsNotFrom ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   186
  hdr.SetDsNotTo ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   187
  Packet packet;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   188
  MgtAssocRequestHeader assoc;
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   189
  assoc.SetSsid (m_device->GetSsid ());
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   190
  assoc.SetSupportedRates (GetSupportedRates ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   191
  packet.AddHeader (assoc);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   192
  
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   193
  m_dca->Queue (packet, hdr);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   194
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   195
  m_assocRequestEvent = Simulator::Schedule (m_assocRequestTimeout,
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   196
                                             &MacHighNqsta::AssocRequestTimeout, this);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   197
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   198
void
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   199
MacHighNqsta::TryToEnsureAssociated (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   200
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   201
  switch (m_state) {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   202
  case ASSOCIATED:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   203
    return;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   204
    break;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   205
  case WAIT_PROBE_RESP:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   206
    /* we have sent a probe request earlier so we
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   207
       do not need to re-send a probe request immediately.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   208
       We just need to wait until probe-request-timeout
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   209
       or until we get a probe response
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   210
     */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   211
    break;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   212
  case BEACON_MISSED:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   213
    /* we were associated but we missed a bunch of beacons
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   214
     * so we should assume we are not associated anymore.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   215
     * We try to initiate a probe request now.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   216
     */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   217
    m_disAssociatedCallback ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   218
    m_state = WAIT_PROBE_RESP;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   219
    SendProbeRequest ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   220
    break;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   221
  case WAIT_ASSOC_RESP:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   222
    /* we have sent an assoc request so we do not need to
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   223
       re-send an assoc request right now. We just need to
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   224
       wait until either assoc-request-timeout or until
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   225
       we get an assoc response.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   226
     */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   227
    break;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   228
  case REFUSED:
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   229
    /* we have sent an assoc request and received a negative
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   230
       assoc resp. We wait until someone restarts an 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   231
       association with a given ssid.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   232
     */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   233
    break;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   234
  }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   235
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   236
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   237
void
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   238
MacHighNqsta::AssocRequestTimeout (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   239
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   240
  TRACE ("assoc request timeout");
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   241
  m_state = WAIT_ASSOC_RESP;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   242
  SendAssociationRequest ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   243
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   244
void
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   245
MacHighNqsta::ProbeRequestTimeout (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   246
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   247
  TRACE ("probe request timeout");
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   248
  m_state = WAIT_PROBE_RESP;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   249
  SendProbeRequest ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   250
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   251
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   252
MacHighNqsta::MissedBeacons (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   253
{
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   254
  if (m_beaconWatchdogEnd > Simulator::Now ())
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   255
    {
2090
3622fda1717b calculate the delay, not -delay.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2054
diff changeset
   256
      m_beaconWatchdog = Simulator::Schedule (m_beaconWatchdogEnd - Simulator::Now (),
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   257
                                              &MacHighNqsta::MissedBeacons, this);
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   258
      return;
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   259
    }
2156
754a843db672 improve log output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2090
diff changeset
   260
  TRACE ("beacon missed");
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   261
  m_state = BEACON_MISSED;
2156
754a843db672 improve log output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2090
diff changeset
   262
  TryToEnsureAssociated ();
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   263
}
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   264
void 
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   265
MacHighNqsta::RestartBeaconWatchdog (Time delay)
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   266
{
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   267
  m_beaconWatchdogEnd = std::max (Simulator::Now () + delay, m_beaconWatchdogEnd);
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   268
  if (Simulator::GetDelayLeft (m_beaconWatchdog) < delay &&
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   269
      m_beaconWatchdog.IsExpired ())
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   270
    {
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   271
      m_beaconWatchdog = Simulator::Schedule (delay, &MacHighNqsta::MissedBeacons, this);
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   272
    }
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   273
}
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   274
bool
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   275
MacHighNqsta::IsAssociated (void)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   276
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   277
  return (m_state == ASSOCIATED)?true:false;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   278
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   279
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   280
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   281
MacHighNqsta::Queue (Packet packet, Mac48Address to)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   282
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   283
  if (!IsAssociated ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   284
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   285
      TryToEnsureAssociated ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   286
      return;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   287
    }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   288
  //TRACE ("enqueue size="<<packet.GetSize ()<<", to="<<to);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   289
  WifiMacHeader hdr;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   290
  hdr.SetTypeData ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   291
  hdr.SetAddr1 (GetBssid ());
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   292
  hdr.SetAddr2 (m_device->GetSelfAddress ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   293
  hdr.SetAddr3 (to);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   294
  hdr.SetDsNotFrom ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   295
  hdr.SetDsTo ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   296
  m_dca->Queue (packet, hdr);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   297
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   298
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   299
void 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   300
MacHighNqsta::Receive (Packet packet, WifiMacHeader const *hdr)
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   301
{
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   302
  NS_ASSERT (!hdr->IsCtl ());
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   303
  if (hdr->GetAddr1 () != m_device->GetSelfAddress () &&
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   304
      !hdr->GetAddr1 ().IsBroadcast ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   305
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   306
      // packet is not for us
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   307
    } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   308
  else if (hdr->IsData ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   309
    {
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1952
diff changeset
   310
      m_forward (packet, hdr->GetAddr2 ());
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   311
    } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   312
  else if (hdr->IsProbeReq () ||
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   313
           hdr->IsAssocReq ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   314
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   315
      /* this is a frame aimed at an AP.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   316
       * so we can safely ignore it.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   317
       */
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   318
    } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   319
  else if (hdr->IsBeacon ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   320
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   321
      MgtBeaconHeader beacon;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   322
      packet.RemoveHeader (beacon);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   323
      bool goodBeacon = false;
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   324
      if (m_device->GetSsid ().IsBroadcast () ||
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   325
          beacon.GetSsid ().IsEqual (m_device->GetSsid ()))
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   326
        {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   327
          Time delay = MicroSeconds (beacon.GetBeaconIntervalUs () * m_maxMissedBeacons);
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   328
          RestartBeaconWatchdog (delay);
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   329
          goodBeacon = true;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   330
        }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   331
      if (goodBeacon) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   332
        {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   333
          SetBssid (hdr->GetAddr3 ());
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   334
        }
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   335
      if (goodBeacon && m_state == BEACON_MISSED) 
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   336
        {
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   337
          m_state = WAIT_ASSOC_RESP;
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   338
          SendAssociationRequest ();
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   339
        }
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   340
  } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   341
  else if (hdr->IsProbeResp ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   342
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   343
      if (m_state == WAIT_PROBE_RESP) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   344
        {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   345
          MgtProbeResponseHeader probeResp;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   346
          packet.RemoveHeader (probeResp);
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   347
          if (!probeResp.GetSsid ().IsEqual (m_device->GetSsid ()))
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   348
            {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   349
              //not a probe resp for our ssid.
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   350
              return;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   351
            }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   352
          SetBssid (hdr->GetAddr3 ());
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   353
          Time delay = MicroSeconds (probeResp.GetBeaconIntervalUs () * m_maxMissedBeacons);
1952
2ad2630756e3 do not use the Watchdog class
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1951
diff changeset
   354
          RestartBeaconWatchdog (delay);
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   355
          if (m_probeRequestEvent.IsRunning ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   356
            {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   357
              m_probeRequestEvent.Cancel ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   358
            }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   359
          m_state = WAIT_ASSOC_RESP;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   360
          SendAssociationRequest ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   361
        }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   362
    } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   363
  else if (hdr->IsAssocResp ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   364
    {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   365
      if (m_state == WAIT_ASSOC_RESP) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   366
        {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   367
          MgtAssocResponseHeader assocResp;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   368
          packet.RemoveHeader (assocResp);
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   369
          if (m_assocRequestEvent.IsRunning ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   370
            {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   371
              m_assocRequestEvent.Cancel ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   372
            }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   373
          if (assocResp.GetStatusCode ().IsSuccess ()) 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   374
            {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   375
              m_state = ASSOCIATED;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   376
              TRACE ("assoc completed"); 
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   377
              SupportedRates rates = assocResp.GetSupportedRates ();
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   378
              MacStation *ap = m_stations->Lookup (hdr->GetAddr2 ());
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   379
              for (uint32_t i = 0; i < m_phy->GetNModes (); i++)
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   380
                {
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   381
                  WifiMode mode = m_phy->GetMode (i);
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   382
                  if (rates.IsSupportedRate (mode.GetPhyRate ()))
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   383
                    {
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   384
                      ap->AddSupportedMode (mode);
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   385
                      if (rates.IsBasicRate (mode.GetPhyRate ()))
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   386
                        {
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   387
                          m_stations->AddBasicMode (mode);
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   388
                        }
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   389
                    }
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   390
                }
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   391
              m_associatedCallback ();
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   392
            } 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   393
          else 
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   394
            {
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   395
              TRACE ("assoc refused");
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   396
              m_state = REFUSED;
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   397
            }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   398
        }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   399
    }
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   400
}
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   401
2009
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   402
SupportedRates
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   403
MacHighNqsta::GetSupportedRates (void) const
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   404
{
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   405
  SupportedRates rates;
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   406
  for (uint32_t i = 0; i < m_phy->GetNModes (); i++)
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   407
    {
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   408
      WifiMode mode = m_phy->GetMode (i);
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   409
      rates.AddSupportedRate (mode.GetPhyRate ());
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   410
    }
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   411
  return rates;
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   412
}
afed751cc0b5 dynamically update the list of supported rates based on the ap supported rates
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1964
diff changeset
   413
1948
0559cd5e7a11 build STA code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   414
} // namespace ns3