src/wifi/model/mac-tx-middle.cc
author Stefano Avallone <stefano.avallone@unina.it>
Fri, 05 Sep 2014 16:33:57 -0700
changeset 10883 d919e7194e23
parent 7385 10beb0e53130
child 11174 780a43e4980c
permissions -rw-r--r--
add support for a Wifi sleep mode
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7385
10beb0e53130 standardize emacs c++ mode comments
Vedran Miletić <rivanvx@gmail.com>
parents: 7141
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
     3
 * Copyright (c) 2005, 2009 INRIA
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
     4
 * Copyright (c) 2009 MIRKO BANCHI
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 *
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * This program is free software; you can redistribute it and/or modify
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
     7
 * it under the terms of the GNU General Public License version 2 as
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 * published by the Free Software Foundation;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 *
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * This program is distributed in the hope that it will be useful,
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 * GNU General Public License for more details.
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 *
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * along with this program; if not, write to the Free Software
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 *
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    20
 * Author: Mirko Banchi <mk.banchi@gmail.com>
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
 */
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1925
diff changeset
    23
#include "ns3/assert.h"
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
#include "mac-tx-middle.h"
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
#include "wifi-mac-header.h"
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
namespace ns3 {
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
MacTxMiddle::MacTxMiddle ()
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    31
  : m_sequence (0)
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    32
{
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    33
}
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    34
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    35
MacTxMiddle::~MacTxMiddle ()
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
{
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    37
  for (std::map<Mac48Address,uint16_t*>::iterator i = m_qosSequences.begin (); i != m_qosSequences.end (); i++)
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
    {
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    39
      delete [] i->second;
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
    }
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
}
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    43
uint16_t
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
MacTxMiddle::GetNextSequenceNumberfor (const WifiMacHeader *hdr)
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
{
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
  uint16_t retval;
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    47
  if (hdr->IsQosData ()
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    48
      && !hdr->GetAddr1 ().IsGroup ())
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
    {
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
      uint8_t tid = hdr->GetQosTid ();
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1925
diff changeset
    51
      NS_ASSERT (tid < 16);
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    52
      std::map<Mac48Address, uint16_t*>::iterator it = m_qosSequences.find (hdr->GetAddr1 ());
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    53
      if (it != m_qosSequences.end ())
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    54
        {
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    55
          retval = it->second[tid];
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    56
          it->second[tid]++;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    57
          it->second[tid] %= 4096;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    58
        }
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    59
      else
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    60
        {
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    61
          retval = 0;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    62
          std::pair <Mac48Address,uint16_t*> newSeq (hdr->GetAddr1 (), new uint16_t[16]);
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    63
          std::pair <std::map<Mac48Address,uint16_t*>::iterator,bool> newIns = m_qosSequences.insert (newSeq);
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    64
          NS_ASSERT (newIns.second == true);
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    65
          for (uint8_t i = 0; i < 16; i++)
4400
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    66
            {
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    67
              newIns.first->second[i] = 0;
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    68
            }
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    69
          newIns.first->second[tid]++;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    70
        }
7141
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    71
    }
072fb225b714 run check-style.py on src/wifi
Nicola Baldo <nicola@baldo.biz>
parents: 6852
diff changeset
    72
  else
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
    {
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
      retval = m_sequence;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
      m_sequence++;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
      m_sequence %= 4096;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
    }
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
  return retval;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
}
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    80
5960
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    81
uint16_t
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    82
MacTxMiddle::GetNextSeqNumberByTidAndAddress (uint8_t tid, Mac48Address addr) const
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    83
{
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    84
  NS_ASSERT (tid < 16);
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    85
  uint16_t seq = 0;
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    86
  std::map <Mac48Address,uint16_t*>::const_iterator it = m_qosSequences.find (addr);
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    87
  if (it != m_qosSequences.end ())
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    88
    {
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    89
      return it->second[tid];
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    90
    }
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    91
  return seq;
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    92
}
111680cdfa52 retrieve next sequence number without increment it
Mirko Banchi <mk.banchi@gmail.com>
parents: 4400
diff changeset
    93
1977
4303409f3d8e remove uneeded trailing ';'
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1974
diff changeset
    94
} // namespace ns3