4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 // Competence Center NETwork research (NET), St. Augustin, GERMANY
6 // Christian Niephaus <christian.niephaus@fokus.fraunhofer.de>
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 2 of the License, or
11 // (at your option) any later version.
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 // GNU General Public License for more details.
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the
20 // Free Software Foundation, Inc.,
21 // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 // Definition of non-inline non-template functions
26 #include "WLANPacket.hh"
27 #include "../../Packets/Packets.hh"
28 #include "../DefaultBundle/LlcSnapPacket.hh"
29 #include <boost/io/ios_state.hpp>
38 prefix_ senf::MACAddressParser senf::WLANPacketParser_DataFrameParser::da()
54 prefix_ senf::MACAddressParser senf::WLANPacketParser_DataFrameParser::sa()
72 prefix_ senf::MACAddressParser senf::WLANPacketParser_DataFrameParser::bssid()
88 //shift some bits to read the 12bit sequence number bit field in LSB byte order
89 prefix_ boost::uint16_t senf::WLANPacketParser_MgtFrameParser::sequenceNumber()
92 boost::uint16_t seqN = 0;
93 seqN |= seqNumber_2();
95 seqN |= seqNumber_1();
99 //shift some bits to read the 12bit sequence number bit field in LSB byte order
100 prefix_ boost::uint16_t senf::WLANPacketParser_DataFrameParser::sequenceNumber()
103 boost::uint16_t seqN = 0;
104 seqN |= seqNumber_2();
106 seqN |= seqNumber_1();
110 prefix_ void senf::WLANPacketType::dump(packet p, std::ostream &os)
112 boost::io::ios_all_saver ias(os);
113 os << "802.11 MAC Frame:\n"
114 << " Type : " << unsigned (p->type()) << "\n"
115 << " Subtype : " << unsigned (p->subtype()) << "\n"
116 << " Retransmission : " << unsigned (p->retry()) << "\n"
117 << " Duration : " << unsigned (p->duration()) << "\n";
119 if (p->has_mgtFrame())
121 os << " BSSID : " << p->mgtFrame().bssid() << "\n";
122 os << " Destination Addr. : " << p->mgtFrame().da() << "\n";
123 os << " Source Addr. : " << p->mgtFrame().sa() << "\n";