src/devices/wifi/mac-high-nqap.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Mon, 15 Oct 2007 16:47:53 +0200
changeset 1964 041240a915f8
parent 1940 6c62be5cf73a
child 2010 e2e16c1712c8
permissions -rw-r--r--
build and link
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2005,2006 INRIA
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
#include "mac-high-nqap.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
#include "mac-stations.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
#include "dca-txop.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    23
#include "wifi-net-device.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
#include "wifi-mac-header.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
#include "mgt-headers.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
#include "ns3/assert.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
#define noNQAP_DEBUG 1
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
#ifdef NQAP_DEBUG
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    31
#include <iostream>
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
#include "ns3/simulator.h"
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    33
#  define TRACE(x) \
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
std::cout << "NQAP now=" << Simulator::NowUs () << "us " << x << std::endl;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    35
#else
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
#  define TRACE(x)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    37
#endif
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
namespace ns3 {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
MacHighNqap::MacHighNqap ()
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    43
  : m_beaconIntervalUs (500000)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
{}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
MacHighNqap::~MacHighNqap ()
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
{}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    47
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
MacHighNqap::SetDcaTxop (DcaTxop *dca)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    51
  m_dca = dca;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    52
  m_dca->SetTxOkCallback (MakeCallback (&MacHighNqap::TxOk, this));
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
  m_dca->SetTxFailedCallback (MakeCallback (&MacHighNqap::TxFailed, this));
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    55
void 
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
    56
MacHighNqap::SetDevice (WifiNetDevice *device)
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    57
{
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
    58
  m_device = device;
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    59
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    60
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    61
MacHighNqap::SetStations (MacStations *stations)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    62
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    63
  m_stations = stations;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    64
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    65
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    66
MacHighNqap::SetForwardCallback (ForwardCallback callback)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    67
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    68
  m_forwardUp = callback;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    69
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
MacHighNqap::SetSupportedRates (SupportedRates rates)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    72
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
  m_rates = rates;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
MacHighNqap::SetBeaconIntervalUs (uint64_t us)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
  m_beaconIntervalUs = us;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    81
MacHighNqap::ForwardDown (Packet packet, Mac48Address from, Mac48Address to)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    82
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    83
  WifiMacHeader hdr;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    84
  hdr.SetTypeData ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    85
  hdr.SetAddr1 (to);
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
    86
  hdr.SetAddr2 (m_device->GetSelfAddress ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    87
  hdr.SetAddr3 (from);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    88
  hdr.SetDsFrom ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    89
  hdr.SetDsNotTo ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    90
  m_dca->Queue (packet, hdr);  
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    91
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    92
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    93
MacHighNqap::Queue (Packet packet, Mac48Address to)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    94
{
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
    95
  ForwardDown (packet, m_device->GetSelfAddress (), to);
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    96
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    97
SupportedRates
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    98
MacHighNqap::GetSupportedRates (void)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    99
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   100
  return m_rates;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   101
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   102
void
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   103
MacHighNqap::SendProbeResp (Mac48Address to)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   104
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   105
  TRACE ("send probe response to="<<to);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   106
  WifiMacHeader hdr;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   107
  hdr.SetProbeResp ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   108
  hdr.SetAddr1 (to);
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   109
  hdr.SetAddr2 (m_device->GetSelfAddress ());
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   110
  hdr.SetAddr3 (m_device->GetSelfAddress ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   111
  hdr.SetDsNotFrom ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   112
  hdr.SetDsNotTo ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   113
  Packet packet;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   114
  MgtProbeResponseHeader probe;
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   115
  probe.SetSsid (m_device->GetSsid ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   116
  SupportedRates rates = GetSupportedRates ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   117
  probe.SetSupportedRates (rates);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   118
  probe.SetBeaconIntervalUs (m_beaconIntervalUs);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   119
  packet.AddHeader (probe);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   120
  
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   121
  m_dca->Queue (packet, hdr);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   122
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   123
void
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   124
MacHighNqap::SendAssocResp (Mac48Address to)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   125
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   126
  TRACE ("send assoc response to="<<to);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   127
  WifiMacHeader hdr;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   128
  hdr.SetAssocResp ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   129
  hdr.SetAddr1 (to);
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   130
  hdr.SetAddr2 (m_device->GetSelfAddress ());
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   131
  hdr.SetAddr3 (m_device->GetSelfAddress ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   132
  hdr.SetDsNotFrom ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   133
  hdr.SetDsNotTo ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   134
  Packet packet;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   135
  MgtAssocResponseHeader assoc;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   136
  StatusCode code;
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   137
  code.SetSuccess ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   138
  assoc.SetStatusCode (code);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   139
  packet.AddHeader (assoc);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   140
  
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   141
  m_dca->Queue (packet, hdr);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   142
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   143
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   144
MacHighNqap::TxOk (WifiMacHeader const &hdr)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   145
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   146
  MacStation *station = m_stations->Lookup (hdr.GetAddr1 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   147
  if (hdr.IsAssocResp () && 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   148
      station->IsWaitAssocTxOk ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   149
    {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   150
      TRACE ("associated with sta="<<hdr.GetAddr1 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   151
      station->RecordGotAssocTxOk ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   152
    }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   153
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   154
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   155
MacHighNqap::TxFailed (WifiMacHeader const &hdr)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   156
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   157
  MacStation *station = m_stations->Lookup (hdr.GetAddr1 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   158
  if (hdr.IsAssocResp () && 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   159
      station->IsWaitAssocTxOk ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   160
    {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   161
      TRACE ("assoc failed with sta="<<hdr.GetAddr1 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   162
      station->RecordGotAssocTxFailed ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   163
    }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   164
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   165
void 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   166
MacHighNqap::Receive (Packet packet, WifiMacHeader const *hdr)
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   167
{
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   168
  MacStation *station = m_stations->Lookup (hdr->GetAddr2 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   169
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   170
  if (hdr->IsData ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   171
    {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   172
      if (!hdr->IsFromDs () && 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   173
          hdr->IsToDs () &&
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   174
          hdr->GetAddr1 () == m_device->GetSelfAddress () &&
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   175
          station->IsAssociated ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   176
        {
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   177
          if (hdr->GetAddr3 () == m_device->GetSelfAddress ()) 
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   178
            {
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   179
              m_forwardUp (packet, hdr->GetAddr2 ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   180
            } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   181
          else 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   182
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   183
              ForwardDown (packet,
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   184
                           hdr->GetAddr2 (), 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   185
                           hdr->GetAddr3 ());
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   186
              m_forwardUp (packet, hdr->GetAddr2 ());
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   187
            }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   188
        } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   189
      else if (hdr->IsFromDs () &&
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   190
               hdr->IsToDs ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   191
        {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   192
          // this is an AP-to-AP frame
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   193
          // we ignore for now.
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   194
        } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   195
      else 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   196
        {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   197
          // we can ignore these frames since 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   198
          // they are not targeted at the AP
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   199
        }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   200
    } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   201
  else if (hdr->IsMgt ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   202
    {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   203
      if (hdr->IsProbeReq ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   204
        {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   205
          NS_ASSERT (hdr->GetAddr1 ().IsBroadcast ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   206
          SendProbeResp (hdr->GetAddr2 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   207
        } 
1964
041240a915f8 build and link
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1940
diff changeset
   208
      else if (hdr->GetAddr1 () == m_device->GetSelfAddress ()) 
1940
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   209
        {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   210
          if (hdr->IsAssocReq ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   211
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   212
              station->RecordWaitAssocTxOk ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   213
              SendAssocResp (hdr->GetAddr2 ());
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   214
            } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   215
          else if (hdr->IsDisassociation ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   216
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   217
              station->RecordDisassociated ();
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   218
            } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   219
          else if (hdr->IsReassocReq ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   220
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   221
              /* we don't support reassoc frames for now */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   222
            } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   223
          else if (hdr->IsAuthentication () ||
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   224
                   hdr->IsDeauthentication ()) 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   225
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   226
              /*
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   227
               */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   228
            } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   229
          else 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   230
            {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   231
              /* unknown mgt frame
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   232
               */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   233
            }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   234
        }
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   235
    } 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   236
  else 
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   237
    {
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   238
    /* damn, what could this be ? a control frame ?
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   239
     * control frames should never reach the MacHigh so,
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   240
     * this is likely to be a bug. assert.
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   241
     */
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   242
      NS_ASSERT (false);
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   243
    }  
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   244
}
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   245
6c62be5cf73a add NQap to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   246
} // namespace ns3