src/wifi/model/mpdu-aggregator.h
author Sébastien Deronne <sebastien.deronne@gmail.com>
Thu, 03 Sep 2015 22:16:49 +0200
changeset 11628 243b71de25a0
parent 11450 9f4ae69f12b7
permissions -rw-r--r--
add support for IEEE 802.11ac
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     2
/*
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     3
 * Copyright (c) 2013
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     4
 *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     7
 * published by the Free Software Foundation;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     8
 *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    12
 * GNU General Public License for more details.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    13
 *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    14
 * You should have received a copy of the GNU General Public License
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    15
 * along with this program; if not, write to the Free Software
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    17
 *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    18
 * Author: Ghada Badawy <gbadawy@gmail.com>
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    19
 */
11450
9f4ae69f12b7 cleanup wifi module
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11431
diff changeset
    20
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    21
#ifndef MPDU_AGGREGATOR_H
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    22
#define MPDU_AGGREGATOR_H
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    23
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    24
#include "ns3/ptr.h"
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    25
#include "ns3/packet.h"
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    26
#include "ns3/object.h"
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    27
#include "ampdu-subframe-header.h"
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    28
#include <list>
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    29
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    30
namespace ns3 {
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    31
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    32
class WifiMacHeader;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    33
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    34
/**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    35
 * \brief Abstract class that concrete mpdu aggregators have to implement
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    36
 * \ingroup wifi
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    37
 */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    38
class MpduAggregator : public Object
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    39
{
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    40
public:
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    41
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    42
   * A list of deaggregated packets and their A-MPDU subframe headers.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    43
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    44
  typedef std::list<std::pair<Ptr<Packet>, AmpduSubframeHeader> > DeaggregatedMpdus;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    45
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    46
   * A constant iterator for a list of deaggregated packets and their A-MPDU subframe headers.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    47
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    48
  typedef std::list<std::pair<Ptr<Packet>, AmpduSubframeHeader> >::const_iterator DeaggregatedMpdusCI;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    49
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    50
  static TypeId GetTypeId (void);
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    51
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    52
   * \param packet Packet we have to insert into <i>aggregatedPacket</i>.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    53
   * \param aggregatedPacket Packet that will contain <i>packet</i>, if aggregation is possible.
11450
9f4ae69f12b7 cleanup wifi module
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11431
diff changeset
    54
   *
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    55
   * \return true if <i>packet</i> can be aggregated to <i>aggregatedPacket</i>, false otherwise.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    56
   *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    57
   * Adds <i>packet</i> to <i>aggregatedPacket</i>. In concrete aggregator's implementation is
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    58
   * specified how and if <i>packet</i> can be added to <i>aggregatedPacket</i>.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    59
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    60
  virtual bool Aggregate (Ptr<const Packet> packet, Ptr<Packet> aggregatedPacket) = 0;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    61
  /**
11628
243b71de25a0 add support for IEEE 802.11ac
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11450
diff changeset
    62
  * This method performs a VHT single MPDU aggregation.
243b71de25a0 add support for IEEE 802.11ac
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11450
diff changeset
    63
  */
243b71de25a0 add support for IEEE 802.11ac
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11450
diff changeset
    64
  virtual void AggregateVhtSingleMpdu (Ptr<const Packet> packet, Ptr<Packet> aggregatedPacket) = 0;
243b71de25a0 add support for IEEE 802.11ac
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11450
diff changeset
    65
  /**
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    66
   * Adds A-MPDU subframe header and padding to each MPDU that is part of an A-MPDU before it is sent.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    67
   */
11628
243b71de25a0 add support for IEEE 802.11ac
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11450
diff changeset
    68
  virtual void AddHeaderAndPad (Ptr<Packet> packet, bool last, bool vhtSingleMpdu) = 0;
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    69
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    70
   * \param packetSize size of the packet we want to insert into <i>aggregatedPacket</i>.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    71
   * \param aggregatedPacket packet that will contain the packet of size <i>packetSize</i>, if aggregation is possible.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    72
   * \param blockAckSize size of the piggybacked block ack request
11450
9f4ae69f12b7 cleanup wifi module
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11431
diff changeset
    73
   *
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    74
   * \return true if the packet of size <i>packetSize</i> can be aggregated to <i>aggregatedPacket</i>, false otherwise.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    75
   *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    76
   * This method is used to determine if a packet could be aggregated to an A-MPDU without exceeding the maximum packet size.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    77
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    78
  virtual bool CanBeAggregated (uint32_t packetSize, Ptr<Packet> aggregatedPacket, uint8_t blockAckSize) = 0;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    79
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    80
   * \return padding that must be added to the end of an aggregated packet
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    81
   *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    82
   * Calculates how much padding must be added to the end of an aggregated packet, after that a new packet is added.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    83
   * Each A-MPDU subframe is padded so that its length is multiple of 4 octets.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    84
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    85
  virtual uint32_t CalculatePadding (Ptr<const Packet> packet) = 0;
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    86
  /**
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    87
   * Deaggregates an A-MPDU by removing the A-MPDU subframe header and padding.
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    88
   *
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    89
   * \return list of deaggragted packets and their A-MPDU subframe headers
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    90
   */
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    91
  static DeaggregatedMpdus Deaggregate (Ptr<Packet> aggregatedPacket);
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    92
};
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    93
11450
9f4ae69f12b7 cleanup wifi module
Sébastien Deronne <sebastien.deronne@gmail.com>
parents: 11431
diff changeset
    94
}  //namespace ns3
11431
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    95
7457d8c80db9 Convert to unix line endings.
Peter D. Barnes, Jr. <barnes26@llnl.gov>
parents: 11174
diff changeset
    96
#endif /* MPDU_AGGREGATOR_H */