A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
msdu-standard-aggregator.cc
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2009 MIRKO BANCHI
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Mirko Banchi <mk.banchi@gmail.com>
19  */
20 #include "ns3/log.h"
21 #include "ns3/uinteger.h"
22 
23 #include "amsdu-subframe-header.h"
24 #include "msdu-standard-aggregator.h"
25 
26 NS_LOG_COMPONENT_DEFINE ("MsduStandardAggregator");
27 
28 namespace ns3 {
29 
30 NS_OBJECT_ENSURE_REGISTERED (MsduStandardAggregator);
31 
32 TypeId
33 MsduStandardAggregator::GetTypeId (void)
34 {
35  static TypeId tid = TypeId ("ns3::MsduStandardAggregator")
36  .SetParent<MsduAggregator> ()
37  .AddConstructor<MsduStandardAggregator> ()
38  .AddAttribute ("MaxAmsduSize", "Max length in byte of an A-MSDU",
39  UintegerValue (7935),
40  MakeUintegerAccessor (&MsduStandardAggregator::m_maxAmsduLength),
41  MakeUintegerChecker<uint32_t> ())
42  ;
43  return tid;
44 }
45 
46 MsduStandardAggregator::MsduStandardAggregator ()
47 {
48 }
49 
50 MsduStandardAggregator::~MsduStandardAggregator ()
51 {
52 }
53 
54 bool
56  Mac48Address src, Mac48Address dest)
57 {
58  NS_LOG_FUNCTION (this);
59  Ptr<Packet> currentPacket;
60  AmsduSubframeHeader currentHdr;
61 
62  uint32_t padding = CalculatePadding (aggregatedPacket);
63  uint32_t actualSize = aggregatedPacket->GetSize ();
64 
65  if ((14 + packet->GetSize () + actualSize + padding) <= m_maxAmsduLength)
66  {
67  if (padding)
68  {
69  Ptr<Packet> pad = Create<Packet> (padding);
70  aggregatedPacket->AddAtEnd (pad);
71  }
72  currentHdr.SetDestinationAddr (dest);
73  currentHdr.SetSourceAddr (src);
74  currentHdr.SetLength (packet->GetSize ());
75  currentPacket = packet->Copy ();
76 
77  currentPacket->AddHeader (currentHdr);
78  aggregatedPacket->AddAtEnd (currentPacket);
79  return true;
80  }
81  return false;
82 }
83 
84 uint32_t
85 MsduStandardAggregator::CalculatePadding (Ptr<const Packet> packet)
86 {
87  return (4 - (packet->GetSize () % 4 )) % 4;
88 }
89 
90 } // namespace ns3
#define NS_LOG_FUNCTION(parameters)
Definition: log.h:311
#define NS_LOG_COMPONENT_DEFINE(name)
Definition: log.h:122
uint32_t GetSize(void) const
Definition: packet.h:620
virtual bool Aggregate(Ptr< const Packet > packet, Ptr< Packet > aggregatedPacket, Mac48Address src, Mac48Address dest)
void AddAtEnd(Ptr< const Packet > packet)
Definition: packet.cc:334
Ptr< Packet > Copy(void) const
Definition: packet.cc:131
an EUI-48 address
Definition: mac48-address.h:41
void AddHeader(const Header &header)
Definition: packet.cc:270