4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
6 // The contents of this file are subject to the Fraunhofer FOKUS Public License
7 // Version 1.0 (the "License"); you may not use this file except in compliance
8 // with the License. You may obtain a copy of the License at
9 // http://senf.berlios.de/license.html
11 // The Fraunhofer FOKUS Public License Version 1.0 is based on,
12 // but modifies the Mozilla Public License Version 1.1.
13 // See the full license text for the amendments.
15 // Software distributed under the License is distributed on an "AS IS" basis,
16 // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
17 // for the specific language governing rights and limitations under the License.
19 // The Original Code is Fraunhofer FOKUS code.
21 // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V.
22 // (registered association), Hansastraße 27 c, 80686 Munich, Germany.
23 // All Rights Reserved.
26 // Christian Niephaus <cni@berlios.de>
29 // Definition of non-inline non-template functions
31 #include "WLANPacket.hh"
32 //#include "WLANPacket.ih"
35 #include <boost/io/ios_state.hpp>
38 //-/////////////////////////////////////////////////////////////////////////////////////////////////
41 void dumpBase(senf::WLANPacketParser const & p, std::ostream & os)
43 os << " version : " << unsigned(p.version()) <<"\n"
44 << " type : " << unsigned(p.type()) << "\n"
45 << " subtype : " << unsigned(p.subtype()) << "\n"
47 if ( p.toDS() ) os << " toDS";
48 if ( p.fromDS() ) os << " fromDS";
49 if ( p.moreFrag() ) os << " moreFrag";
50 if ( p.retry() ) os << " retry";
51 if ( p.pwrMgt() ) os << " pwrMgt";
52 if ( p.moreData() ) os << " moreData";
53 if ( p.protectedFrame() ) os << " protected";
54 if ( p.order() ) os << " order";
56 if ( !(p.toDS() || p.fromDS() || p.moreFrag() || p.retry() || p.pwrMgt() ||
57 p.moreData() || p.protectedFrame() || p.order()) )
60 << " duration : " << unsigned(p.duration()) << "\n";
64 prefix_ void senf::WLANPacket_MgtFrameParser::sequenceNumber(boost::uint16_t sn)
66 seqNumber_2() = 0u | (sn >> 4 ) ;
67 seqNumber_1() = 0u | sn;
70 prefix_ void senf::WLANPacket_MgtFrameType::dump(packet p, std::ostream & os)
72 boost::io::ios_all_saver ias(os);
73 os << "802.11 MAC Management Frame:\n";
74 dumpBase(p.parser(), os);
75 os << senf::fieldName("destination") << p->destinationAddress() << "\n"
76 << senf::fieldName("source") << p->sourceAddress() << "\n"
77 << senf::fieldName("bss id") << p->bssid() << "\n"
78 << senf::fieldName("sequence number") << p->sequenceNumber() << "\n"
79 << senf::fieldName("fragment number") << p->fragmentNumber() << "\n";
82 prefix_ void senf::WLANPacket_CtrlFrameType::dump(packet p, std::ostream & os)
84 boost::io::ios_all_saver ias(os);
85 os << "802.11 MAC Control Frame:\n";
86 dumpBase(p.parser(), os);
87 os << senf::fieldName("receiver") << p->receiverAddress() << "\n";
89 os << senf::fieldName("source") << p->sourceAddress() << "\n";
92 prefix_ void senf::WLANPacket_DataFrameParser::sequenceNumber(boost::uint16_t sn)
94 seqNumber_2() = 0u | (sn >> 4 ) ;
95 seqNumber_1() = 0u | sn;
98 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::destinationAddress()
110 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::sourceAddress()
118 // case 3 : return addr4();
124 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::bssid()
137 prefix_ void senf::WLANPacket_DataFrameType::dump(packet p, std::ostream & os)
139 boost::io::ios_all_saver ias(os);
140 os << "802.11 MAC Data Frame:\n";
141 dumpBase(p.parser(), os);
142 os << senf::fieldName("destination") << p->destinationAddress();
143 if (p->dsBits()==0 || p->dsBits()==2) os << " (receiver)";
145 << senf::fieldName("source") << p->sourceAddress();
146 if (p->dsBits()==0 || p->dsBits()==1) os << " (transmitter)";
148 << senf::fieldName("bss id") << p->bssid();
149 if (p->dsBits()==1) os << " (receiver)";
150 else if (p->dsBits()!=0) os << " (transmitter)";
152 << senf::fieldName("sequence number") << p->sequenceNumber() << "\n"
153 << senf::fieldName("fragment number") << p->fragmentNumber() << "\n";
154 if (p->has_qosField())
155 os << senf::fieldName("QOS data") << p->qosField() << "\n";
158 //-/////////////////////////////////////////////////////////////////////////////////////////////////
165 // c-file-style: "senf"
166 // indent-tabs-mode: nil
167 // ispell-local-dictionary: "american"
168 // compile-command: "scons -u test"
169 // comment-column: 40