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-- |
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 |