src/devices/wifi/mac-tx-middle.cc
author Pavel Boyko <boyko@iitp.ru>
Tue, 16 Jun 2009 17:58:16 +0400
changeset 5074 355de6af8ea9
parent 4400 18ba3459e177
child 5960 111680cdfa52
permissions -rw-r--r--
merged with nsnam
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
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
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * it under the terms of the GNU General Public License version 2 as 
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)
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    32
{}
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    33
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    34
MacTxMiddle::~MacTxMiddle ()
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    35
{
4400
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    36
  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
    37
    {
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    38
      delete [] i->second;
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
    }
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
uint16_t 
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    43
MacTxMiddle::GetNextSequenceNumberfor (const WifiMacHeader *hdr)
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
{
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
  uint16_t retval;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
  if (hdr->IsQosData () &&
4079
210d64d11998 add wifi multicast support. Based on patch by Mauchle Fabian.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1977
diff changeset
    47
      !hdr->GetAddr1 ().IsGroup ()) 
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
    {
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
      uint8_t tid = hdr->GetQosTid ();
1974
0d6b3bead74a replace cassert by ns3/assert.h
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1925
diff changeset
    50
      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
    51
      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
    52
      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
    53
        {
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    54
          retval = it->second[tid];
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    55
          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] %= 4096;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    57
        }
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    58
      else
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    59
        {
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    60
          retval = 0;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    61
          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
    62
          std::pair <std::map<Mac48Address,uint16_t*>::iterator,bool> newIns = m_qosSequences.insert (newSeq);
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    63
          NS_ASSERT(newIns.second == true);
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    64
          for (uint8_t i = 0; i < 16; i++)
4400
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    65
            {
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    66
              newIns.first->second[i] = 0;
18ba3459e177 coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4399
diff changeset
    67
            }
4399
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    68
          newIns.first->second[tid]++;
3858687497ce keep track of sequence number on per-destination basis
Mirko Banchi <mk.banchi@gmail.com>
parents: 4079
diff changeset
    69
        }
1925
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    70
    } 
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    71
  else 
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    72
    {
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    73
      retval = m_sequence;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    74
      m_sequence++;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    75
      m_sequence %= 4096;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    76
    }
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    77
  return retval;
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    78
}
12faa084fe5b add MacTxMiddle to build
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    79
1977
4303409f3d8e remove uneeded trailing ';'
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1974
diff changeset
    80
} // namespace ns3