4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 // Competence Center NETwork research (NET), St. Augustin, GERMANY
6 // Christian Niephaus <cni@berlios.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
25 #include "WLANPacket.hh"
26 //#include "WLANPacket.ih"
29 #include <boost/io/ios_state.hpp>
32 ///////////////////////////////cc.p///////////////////////////////////////
35 void dumpBase(senf::WLANPacketParser const & p, std::ostream & os)
37 os << " version : " << unsigned(p.version()) <<"\n"
38 << " type : " << unsigned(p.type()) << "\n"
39 << " subtype : " << unsigned(p.subtype()) << "\n"
41 if ( p.toDS() ) os << " toDS";
42 if ( p.fromDS() ) os << " fromDS";
43 if ( p.moreFrag() ) os << " moreFrag";
44 if ( p.retry() ) os << " retry";
45 if ( p.pwrMgt() ) os << " pwrMgt";
46 if ( p.moreData() ) os << " moreData";
47 if ( p.protectedFrame() ) os << " protected";
48 if ( p.order() ) os << " order";
50 if ( !(p.toDS() || p.fromDS() || p.moreFrag() || p.retry() || p.pwrMgt() ||
51 p.moreData() || p.protectedFrame() || p.order()) )
54 << " duration : " << unsigned(p.duration()) << "\n";
58 prefix_ void senf::WLANPacket_MgtFrameType::dump(packet p, std::ostream &os)
60 boost::io::ios_all_saver ias(os);
61 os << "802.11 MAC Mangement Frame:\n";
62 dumpBase(p.parser(), os);
63 os << senf::fieldName("destination") << p->destinationAddress() << "\n"
64 << senf::fieldName("source") << p->sourceAddress() << "\n"
65 << senf::fieldName("bss id") << p->bssid() << "\n"
66 << senf::fieldName("sequence number") << p->sequenceNumber() << "\n"
67 << senf::fieldName("fragment number") << p->fragmentNumber() << "\n";
70 prefix_ void senf::WLANPacket_CtrlFrameType::dump(packet p, std::ostream &os)
72 boost::io::ios_all_saver ias(os);
73 os << "802.11 MAC Control Frame:\n";
74 dumpBase(p.parser(), os);
75 os << senf::fieldName("receiver") << p->receiverAddress() << "\n";
77 os << senf::fieldName("source") << p->sourceAddress() << "\n";
80 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::destinationAddress()
92 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::sourceAddress()
100 // case 3 : return addr4();
106 prefix_ senf::MACAddressParser senf::WLANPacket_DataFrameParser::bssid()
119 prefix_ void senf::WLANPacket_DataFrameType::dump(packet p, std::ostream &os)
121 boost::io::ios_all_saver ias(os);
122 os << "802.11 MAC Data Frame:\n";
123 dumpBase(p.parser(), os);
124 os << senf::fieldName("destination") << p->destinationAddress();
125 if (p->dsBits()==0 || p->dsBits()==2) os << " (receiver)";
127 << senf::fieldName("source") << p->sourceAddress();
128 if (p->dsBits()==0 || p->dsBits()==1) os << " (transmitter)";
130 << senf::fieldName("bss id") << p->bssid();
131 if (p->dsBits()==1) os << " (receiver)";
132 else if (p->dsBits()!=0) os << " (transmitter)";
134 << senf::fieldName("sequence number") << p->sequenceNumber() << "\n"
135 << senf::fieldName("fragment number") << p->fragmentNumber() << "\n";
136 if (p->has_qosField())
137 os << senf::fieldName("QOS data") << p->qosField() << "\n";
140 ///////////////////////////////cc.e////////////////////////////////////////
147 // c-file-style: "senf"
148 // indent-tabs-mode: nil
149 // ispell-local-dictionary: "american"
150 // compile-command: "scons -u test"
151 // comment-column: 40