summaryrefslogtreecommitdiff
path: root/libopie2/opienet
authormickeyl <mickeyl>2004-05-01 16:13:43 (UTC)
committer mickeyl <mickeyl>2004-05-01 16:13:43 (UTC)
commitd5abd7878f553f5ac0a41966b27f4c09389d3cfd (patch) (unidiff)
tree3140d1d1fe012c03c6c26bc587faeea5501f0b28 /libopie2/opienet
parent5a64ec5a21bb254c0e6a57e379cd1afc25259f19 (diff)
downloadopie-d5abd7878f553f5ac0a41966b27f4c09389d3cfd.zip
opie-d5abd7878f553f5ac0a41966b27f4c09389d3cfd.tar.gz
opie-d5abd7878f553f5ac0a41966b27f4c09389d3cfd.tar.bz2
- fix off-by-one bug in OChannelHopper
- fix bug in OPacket which broke everything using it - expose both wireless extension versions (runtime + compile time) through API
Diffstat (limited to 'libopie2/opienet') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opienet/onetwork.cpp12
-rw-r--r--libopie2/opienet/onetwork.h10
-rw-r--r--libopie2/opienet/opcap.cpp4
3 files changed, 18 insertions, 8 deletions
diff --git a/libopie2/opienet/onetwork.cpp b/libopie2/opienet/onetwork.cpp
index b6c9876..e141097 100644
--- a/libopie2/opienet/onetwork.cpp
+++ b/libopie2/opienet/onetwork.cpp
@@ -1,829 +1,835 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer 3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer
4 =. <mickey@Vanille.de> 4 =. <mickey@Vanille.de>
5 .=l. 5 .=l.
6           .>+-= 6           .>+-=
7 _;:,     .>    :=|. This program is free software; you can 7 _;:,     .>    :=|. This program is free software; you can
8.> <`_,   >  .   <= redistribute it and/or modify it under 8.> <`_,   >  .   <= redistribute it and/or modify it under
9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
10.="- .-=="i,     .._ License as published by the Free Software 10.="- .-=="i,     .._ License as published by the Free Software
11 - .   .-<_>     .<> Foundation; either version 2 of the License, 11 - .   .-<_>     .<> Foundation; either version 2 of the License,
12     ._= =}       : or (at your option) any later version. 12     ._= =}       : or (at your option) any later version.
13    .%`+i>       _;_. 13    .%`+i>       _;_.
14    .i_,=:_.      -<s. This program is distributed in the hope that 14    .i_,=:_.      -<s. This program is distributed in the hope that
15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
16    : ..    .:,     . . . without even the implied warranty of 16    : ..    .:,     . . . without even the implied warranty of
17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.=       =       ; Library General Public License for more 19..}^=.=       =       ; Library General Public License for more
20++=   -.     .`     .: details. 20++=   -.     .`     .: details.
21 :     =  ...= . :.=- 21 :     =  ...= . :.=-
22 -.   .:....=;==+<; You should have received a copy of the GNU 22 -.   .:....=;==+<; You should have received a copy of the GNU
23  -_. . .   )=.  = Library General Public License along with 23  -_. . .   )=.  = Library General Public License along with
24    --        :-=` this library; see the file COPYING.LIB. 24    --        :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28 28
29*/ 29*/
30 30
31/* OPIE */ 31/* OPIE */
32 32
33#include <opie2/onetwork.h> 33#include <opie2/onetwork.h>
34#include <opie2/ostation.h> 34#include <opie2/ostation.h>
35#include <opie2/odebug.h> 35#include <opie2/odebug.h>
36 36
37/* QT */ 37/* QT */
38 38
39#include <qfile.h> 39#include <qfile.h>
40#include <qtextstream.h> 40#include <qtextstream.h>
41 41
42/* UNIX */ 42/* UNIX */
43 43
44#include <assert.h> 44#include <assert.h>
45#include <arpa/inet.h> 45#include <arpa/inet.h>
46#include <errno.h> 46#include <errno.h>
47#include <string.h> 47#include <string.h>
48#include <stdlib.h> 48#include <stdlib.h>
49#include <math.h> 49#include <math.h>
50#include <sys/ioctl.h> 50#include <sys/ioctl.h>
51#include <sys/socket.h> 51#include <sys/socket.h>
52#include <sys/types.h> 52#include <sys/types.h>
53#include <unistd.h> 53#include <unistd.h>
54#include <linux/sockios.h> 54#include <linux/sockios.h>
55#include <net/if_arp.h> 55#include <net/if_arp.h>
56#include <stdarg.h> 56#include <stdarg.h>
57 57
58#ifndef NODEBUG 58#ifndef NODEBUG
59#include <opie2/odebugmapper.h> 59#include <opie2/odebugmapper.h>
60 60
61 61
62using namespace Opie::Core; 62using namespace Opie::Core;
63using namespace Opie::Net::Internal; 63using namespace Opie::Net::Internal;
64DebugMapper* debugmapper = new DebugMapper(); 64DebugMapper* debugmapper = new DebugMapper();
65#endif 65#endif
66 66
67/*====================================================================================== 67/*======================================================================================
68 * ONetwork 68 * ONetwork
69 *======================================================================================*/ 69 *======================================================================================*/
70 70
71namespace Opie { 71namespace Opie {
72namespace Net { 72namespace Net {
73ONetwork* ONetwork::_instance = 0; 73ONetwork* ONetwork::_instance = 0;
74 74
75ONetwork::ONetwork() 75ONetwork::ONetwork()
76{ 76{
77 odebug << "ONetwork::ONetwork()" << oendl; 77 odebug << "ONetwork::ONetwork()" << oendl;
78 odebug << "ONetwork: This code has been compiled against Wireless Extensions V" << WIRELESS_EXT << oendl; 78 odebug << "ONetwork: This code has been compiled against Wireless Extensions V" << WIRELESS_EXT << oendl;
79 synchronize(); 79 synchronize();
80} 80}
81 81
82void ONetwork::synchronize() 82void ONetwork::synchronize()
83{ 83{
84 // gather available interfaces by inspecting /proc/net/dev 84 // gather available interfaces by inspecting /proc/net/dev
85 //FIXME: we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices 85 //FIXME: we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices
86 //FIXME: Use SIOCGIFCONF anway, because we can disable listing of aliased devices 86 //FIXME: Use SIOCGIFCONF anway, because we can disable listing of aliased devices
87 //FIXME: Best is use SIOCGIFCONF and if this doesn't work (result=-1), then fallback to parsing /proc/net/dev 87 //FIXME: Best is use SIOCGIFCONF and if this doesn't work (result=-1), then fallback to parsing /proc/net/dev
88 88
89 _interfaces.clear(); 89 _interfaces.clear();
90 QString str; 90 QString str;
91 QFile f( "/proc/net/dev" ); 91 QFile f( "/proc/net/dev" );
92 bool hasFile = f.open( IO_ReadOnly ); 92 bool hasFile = f.open( IO_ReadOnly );
93 if ( !hasFile ) 93 if ( !hasFile )
94 { 94 {
95 odebug << "ONetwork: /proc/net/dev not existing. No network devices available" << oendl; 95 odebug << "ONetwork: /proc/net/dev not existing. No network devices available" << oendl;
96 return; 96 return;
97 } 97 }
98 QTextStream s( &f ); 98 QTextStream s( &f );
99 s.readLine(); 99 s.readLine();
100 s.readLine(); 100 s.readLine();
101 while ( !s.atEnd() ) 101 while ( !s.atEnd() )
102 { 102 {
103 s >> str; 103 s >> str;
104 str.truncate( str.find( ':' ) ); 104 str.truncate( str.find( ':' ) );
105 odebug << "ONetwork: found interface '" << str << "'" << oendl; 105 odebug << "ONetwork: found interface '" << str << "'" << oendl;
106 ONetworkInterface* iface = 0; 106 ONetworkInterface* iface = 0;
107 if ( isWirelessInterface( str ) ) 107 if ( isWirelessInterface( str ) )
108 { 108 {
109 iface = new OWirelessNetworkInterface( this, (const char*) str ); 109 iface = new OWirelessNetworkInterface( this, (const char*) str );
110 odebug << "ONetwork: interface '" << str << "' has Wireless Extensions" << oendl; 110 odebug << "ONetwork: interface '" << str << "' has Wireless Extensions" << oendl;
111 } 111 }
112 else 112 else
113 { 113 {
114 iface = new ONetworkInterface( this, (const char*) str ); 114 iface = new ONetworkInterface( this, (const char*) str );
115 } 115 }
116 _interfaces.insert( str, iface ); 116 _interfaces.insert( str, iface );
117 s.readLine(); 117 s.readLine();
118 } 118 }
119} 119}
120 120
121 121
122short ONetwork::wirelessExtensionVersion() 122short ONetwork::wirelessExtensionCompileVersion()
123{ 123{
124 return WIRELESS_EXT; 124 return WIRELESS_EXT;
125} 125}
126 126
127 127
128int ONetwork::count() const 128int ONetwork::count() const
129{ 129{
130 return _interfaces.count(); 130 return _interfaces.count();
131} 131}
132 132
133 133
134ONetworkInterface* ONetwork::interface( const QString& iface ) const 134ONetworkInterface* ONetwork::interface( const QString& iface ) const
135{ 135{
136 return _interfaces[iface]; 136 return _interfaces[iface];
137} 137}
138 138
139 139
140ONetwork* ONetwork::instance() 140ONetwork* ONetwork::instance()
141{ 141{
142 if ( !_instance ) _instance = new ONetwork(); 142 if ( !_instance ) _instance = new ONetwork();
143 return _instance; 143 return _instance;
144} 144}
145 145
146 146
147ONetwork::InterfaceIterator ONetwork::iterator() const 147ONetwork::InterfaceIterator ONetwork::iterator() const
148{ 148{
149 return ONetwork::InterfaceIterator( _interfaces ); 149 return ONetwork::InterfaceIterator( _interfaces );
150} 150}
151 151
152 152
153bool ONetwork::isPresent( const char* name ) const 153bool ONetwork::isPresent( const char* name ) const
154{ 154{
155 int sfd = socket( AF_INET, SOCK_STREAM, 0 ); 155 int sfd = socket( AF_INET, SOCK_STREAM, 0 );
156 struct ifreq ifr; 156 struct ifreq ifr;
157 memset( &ifr, 0, sizeof( struct ifreq ) ); 157 memset( &ifr, 0, sizeof( struct ifreq ) );
158 strcpy( (char*) &ifr.ifr_name, name ); 158 strcpy( (char*) &ifr.ifr_name, name );
159 int result = ::ioctl( sfd, SIOCGIFFLAGS, &ifr ); 159 int result = ::ioctl( sfd, SIOCGIFFLAGS, &ifr );
160 return result != -1; 160 return result != -1;
161} 161}
162 162
163 163
164bool ONetwork::isWirelessInterface( const char* name ) const 164bool ONetwork::isWirelessInterface( const char* name ) const
165{ 165{
166 int sfd = socket( AF_INET, SOCK_STREAM, 0 ); 166 int sfd = socket( AF_INET, SOCK_STREAM, 0 );
167 struct iwreq iwr; 167 struct iwreq iwr;
168 memset( &iwr, 0, sizeof( struct iwreq ) ); 168 memset( &iwr, 0, sizeof( struct iwreq ) );
169 strcpy( (char*) &iwr.ifr_name, name ); 169 strcpy( (char*) &iwr.ifr_name, name );
170 int result = ::ioctl( sfd, SIOCGIWNAME, &iwr ); 170 int result = ::ioctl( sfd, SIOCGIWNAME, &iwr );
171 return result != -1; 171 return result != -1;
172} 172}
173 173
174/*====================================================================================== 174/*======================================================================================
175 * ONetworkInterface 175 * ONetworkInterface
176 *======================================================================================*/ 176 *======================================================================================*/
177 177
178ONetworkInterface::ONetworkInterface( QObject* parent, const char* name ) 178ONetworkInterface::ONetworkInterface( QObject* parent, const char* name )
179 :QObject( parent, name ), 179 :QObject( parent, name ),
180 _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 ) 180 _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 )
181{ 181{
182 odebug << "ONetworkInterface::ONetworkInterface()" << oendl; 182 odebug << "ONetworkInterface::ONetworkInterface()" << oendl;
183 init(); 183 init();
184} 184}
185 185
186 186
187struct ifreq& ONetworkInterface::ifr() const 187struct ifreq& ONetworkInterface::ifr() const
188{ 188{
189 return _ifr; 189 return _ifr;
190} 190}
191 191
192 192
193void ONetworkInterface::init() 193void ONetworkInterface::init()
194{ 194{
195 odebug << "ONetworkInterface::init()" << oendl; 195 odebug << "ONetworkInterface::init()" << oendl;
196 196
197 memset( &_ifr, 0, sizeof( struct ifreq ) ); 197 memset( &_ifr, 0, sizeof( struct ifreq ) );
198 198
199 if ( _sfd == -1 ) 199 if ( _sfd == -1 )
200 { 200 {
201 odebug << "ONetworkInterface::init(): Warning - can't get socket for device '" << name() << "'" << oendl; 201 odebug << "ONetworkInterface::init(): Warning - can't get socket for device '" << name() << "'" << oendl;
202 return; 202 return;
203 } 203 }
204} 204}
205 205
206 206
207bool ONetworkInterface::ioctl( int call, struct ifreq& ifreq ) const 207bool ONetworkInterface::ioctl( int call, struct ifreq& ifreq ) const
208{ 208{
209 #ifndef NODEBUG 209 #ifndef NODEBUG
210 int result = ::ioctl( _sfd, call, &ifreq ); 210 int result = ::ioctl( _sfd, call, &ifreq );
211 if ( result == -1 ) 211 if ( result == -1 )
212 odebug << "ONetworkInterface::ioctl (" << name() << ") call '" << debugmapper->map( call ) 212 odebug << "ONetworkInterface::ioctl (" << name() << ") call '" << debugmapper->map( call )
213 << "' FAILED! " << result << " (" << strerror( errno ) << ")" << oendl; 213 << "' FAILED! " << result << " (" << strerror( errno ) << ")" << oendl;
214 else 214 else
215 odebug << "ONetworkInterface::ioctl (" << name() << ") call '" << debugmapper->map( call ) 215 odebug << "ONetworkInterface::ioctl (" << name() << ") call '" << debugmapper->map( call )
216 << "' - Status: Ok." << oendl; 216 << "' - Status: Ok." << oendl;
217 return ( result != -1 ); 217 return ( result != -1 );
218 #else 218 #else
219 return ::ioctl( _sfd, call, &ifreq ) != -1; 219 return ::ioctl( _sfd, call, &ifreq ) != -1;
220 #endif 220 #endif
221} 221}
222 222
223 223
224bool ONetworkInterface::ioctl( int call ) const 224bool ONetworkInterface::ioctl( int call ) const
225{ 225{
226 strcpy( _ifr.ifr_name, name() ); 226 strcpy( _ifr.ifr_name, name() );
227 return ioctl( call, _ifr ); 227 return ioctl( call, _ifr );
228} 228}
229 229
230 230
231bool ONetworkInterface::isLoopback() const 231bool ONetworkInterface::isLoopback() const
232{ 232{
233 ioctl( SIOCGIFFLAGS ); 233 ioctl( SIOCGIFFLAGS );
234 return _ifr.ifr_flags & IFF_LOOPBACK; 234 return _ifr.ifr_flags & IFF_LOOPBACK;
235} 235}
236 236
237 237
238bool ONetworkInterface::setUp( bool b ) 238bool ONetworkInterface::setUp( bool b )
239{ 239{
240 ioctl( SIOCGIFFLAGS ); 240 ioctl( SIOCGIFFLAGS );
241 if ( b ) _ifr.ifr_flags |= IFF_UP; 241 if ( b ) _ifr.ifr_flags |= IFF_UP;
242 else _ifr.ifr_flags &= (~IFF_UP); 242 else _ifr.ifr_flags &= (~IFF_UP);
243 return ioctl( SIOCSIFFLAGS ); 243 return ioctl( SIOCSIFFLAGS );
244} 244}
245 245
246 246
247bool ONetworkInterface::isUp() const 247bool ONetworkInterface::isUp() const
248{ 248{
249 ioctl( SIOCGIFFLAGS ); 249 ioctl( SIOCGIFFLAGS );
250 return _ifr.ifr_flags & IFF_UP; 250 return _ifr.ifr_flags & IFF_UP;
251} 251}
252 252
253 253
254void ONetworkInterface::setIPV4Address( const QHostAddress& addr ) 254void ONetworkInterface::setIPV4Address( const QHostAddress& addr )
255{ 255{
256 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; 256 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr;
257 sa->sin_family = AF_INET; 257 sa->sin_family = AF_INET;
258 sa->sin_port = 0; 258 sa->sin_port = 0;
259 sa->sin_addr.s_addr = htonl( addr.ip4Addr() ); 259 sa->sin_addr.s_addr = htonl( addr.ip4Addr() );
260 ioctl( SIOCSIFADDR ); 260 ioctl( SIOCSIFADDR );
261} 261}
262 262
263 263
264QString ONetworkInterface::ipV4Address() const 264QString ONetworkInterface::ipV4Address() const
265{ 265{
266 if ( ioctl( SIOCGIFADDR ) ) 266 if ( ioctl( SIOCGIFADDR ) )
267 { 267 {
268 struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr; 268 struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr;
269 //FIXME: Use QHostAddress here 269 //FIXME: Use QHostAddress here
270 return QString( inet_ntoa( sa->sin_addr ) ); 270 return QString( inet_ntoa( sa->sin_addr ) );
271 } 271 }
272 else 272 else
273 return "<unknown>"; 273 return "<unknown>";
274 274
275} 275}
276 276
277 277
278void ONetworkInterface::setMacAddress( const OMacAddress& addr ) 278void ONetworkInterface::setMacAddress( const OMacAddress& addr )
279{ 279{
280 _ifr.ifr_hwaddr.sa_family = ARPHRD_ETHER; 280 _ifr.ifr_hwaddr.sa_family = ARPHRD_ETHER;
281 memcpy( &_ifr.ifr_hwaddr.sa_data, addr.native(), 6 ); 281 memcpy( &_ifr.ifr_hwaddr.sa_data, addr.native(), 6 );
282 ioctl( SIOCSIFHWADDR ); 282 ioctl( SIOCSIFHWADDR );
283} 283}
284 284
285 285
286OMacAddress ONetworkInterface::macAddress() const 286OMacAddress ONetworkInterface::macAddress() const
287{ 287{
288 if ( ioctl( SIOCGIFHWADDR ) ) 288 if ( ioctl( SIOCGIFHWADDR ) )
289 { 289 {
290 return OMacAddress( _ifr ); 290 return OMacAddress( _ifr );
291 } 291 }
292 else 292 else
293 { 293 {
294 return OMacAddress::unknown; 294 return OMacAddress::unknown;
295 } 295 }
296} 296}
297 297
298 298
299void ONetworkInterface::setIPV4Netmask( const QHostAddress& addr ) 299void ONetworkInterface::setIPV4Netmask( const QHostAddress& addr )
300{ 300{
301 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; 301 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr;
302 sa->sin_family = AF_INET; 302 sa->sin_family = AF_INET;
303 sa->sin_port = 0; 303 sa->sin_port = 0;
304 sa->sin_addr.s_addr = htonl( addr.ip4Addr() ); 304 sa->sin_addr.s_addr = htonl( addr.ip4Addr() );
305 ioctl( SIOCSIFNETMASK ); 305 ioctl( SIOCSIFNETMASK );
306} 306}
307 307
308 308
309QString ONetworkInterface::ipV4Netmask() const 309QString ONetworkInterface::ipV4Netmask() const
310{ 310{
311 if ( ioctl( SIOCGIFNETMASK ) ) 311 if ( ioctl( SIOCGIFNETMASK ) )
312 { 312 {
313 struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr; 313 struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr;
314 //FIXME: Use QHostAddress here 314 //FIXME: Use QHostAddress here
315 return QString( inet_ntoa( sa->sin_addr ) ); 315 return QString( inet_ntoa( sa->sin_addr ) );
316 } 316 }
317 else 317 else
318 return "<unknown>"; 318 return "<unknown>";
319} 319}
320 320
321 321
322int ONetworkInterface::dataLinkType() const 322int ONetworkInterface::dataLinkType() const
323{ 323{
324 if ( ioctl( SIOCGIFHWADDR ) ) 324 if ( ioctl( SIOCGIFHWADDR ) )
325 { 325 {
326 return _ifr.ifr_hwaddr.sa_family; 326 return _ifr.ifr_hwaddr.sa_family;
327 } 327 }
328 else 328 else
329 { 329 {
330 return -1; 330 return -1;
331 } 331 }
332} 332}
333 333
334 334
335void ONetworkInterface::setMonitoring( OMonitoringInterface* m ) 335void ONetworkInterface::setMonitoring( OMonitoringInterface* m )
336{ 336{
337 _mon = m; 337 _mon = m;
338 odebug << "ONetwork::setMonitoring(): Installed monitoring driver '" << m->name() << "' on interface '" << name() << "'" << oendl; 338 odebug << "ONetwork::setMonitoring(): Installed monitoring driver '" << m->name() << "' on interface '" << name() << "'" << oendl;
339} 339}
340 340
341 341
342OMonitoringInterface* ONetworkInterface::monitoring() const 342OMonitoringInterface* ONetworkInterface::monitoring() const
343{ 343{
344 return _mon; 344 return _mon;
345} 345}
346 346
347 347
348ONetworkInterface::~ONetworkInterface() 348ONetworkInterface::~ONetworkInterface()
349{ 349{
350 odebug << "ONetworkInterface::~ONetworkInterface()" << oendl; 350 odebug << "ONetworkInterface::~ONetworkInterface()" << oendl;
351 if ( _sfd != -1 ) ::close( _sfd ); 351 if ( _sfd != -1 ) ::close( _sfd );
352} 352}
353 353
354 354
355bool ONetworkInterface::setPromiscuousMode( bool b ) 355bool ONetworkInterface::setPromiscuousMode( bool b )
356{ 356{
357 ioctl( SIOCGIFFLAGS ); 357 ioctl( SIOCGIFFLAGS );
358 if ( b ) _ifr.ifr_flags |= IFF_PROMISC; 358 if ( b ) _ifr.ifr_flags |= IFF_PROMISC;
359 else _ifr.ifr_flags &= (~IFF_PROMISC); 359 else _ifr.ifr_flags &= (~IFF_PROMISC);
360 return ioctl( SIOCSIFFLAGS ); 360 return ioctl( SIOCSIFFLAGS );
361} 361}
362 362
363 363
364bool ONetworkInterface::promiscuousMode() const 364bool ONetworkInterface::promiscuousMode() const
365{ 365{
366 ioctl( SIOCGIFFLAGS ); 366 ioctl( SIOCGIFFLAGS );
367 return _ifr.ifr_flags & IFF_PROMISC; 367 return _ifr.ifr_flags & IFF_PROMISC;
368} 368}
369 369
370 370
371bool ONetworkInterface::isWireless() const 371bool ONetworkInterface::isWireless() const
372{ 372{
373 return ioctl( SIOCGIWNAME ); 373 return ioctl( SIOCGIWNAME );
374} 374}
375 375
376 376
377/*====================================================================================== 377/*======================================================================================
378 * OChannelHopper 378 * OChannelHopper
379 *======================================================================================*/ 379 *======================================================================================*/
380 380
381OChannelHopper::OChannelHopper( OWirelessNetworkInterface* iface ) 381OChannelHopper::OChannelHopper( OWirelessNetworkInterface* iface )
382 :QObject( 0, "Mickey's funky hopper" ), 382 :QObject( 0, "Mickey's funky hopper" ),
383 _iface( iface ), _interval( 0 ), _tid( 0 ) 383 _iface( iface ), _interval( 0 ), _tid( 0 )
384{ 384{
385 int _maxChannel = iface->channels()+1; 385 int _maxChannel = iface->channels();
386 // generate fancy hopping sequence honoring the device capabilities 386 // generate fancy hopping sequence honoring the device capabilities
387 if ( _maxChannel >= 1 ) _channels.append( 1 ); 387 if ( _maxChannel >= 1 ) _channels.append( 1 );
388 if ( _maxChannel >= 7 ) _channels.append( 7 ); 388 if ( _maxChannel >= 7 ) _channels.append( 7 );
389 if ( _maxChannel >= 13 ) _channels.append( 13 ); 389 if ( _maxChannel >= 13 ) _channels.append( 13 );
390 if ( _maxChannel >= 2 ) _channels.append( 2 ); 390 if ( _maxChannel >= 2 ) _channels.append( 2 );
391 if ( _maxChannel >= 8 ) _channels.append( 8 ); 391 if ( _maxChannel >= 8 ) _channels.append( 8 );
392 if ( _maxChannel >= 3 ) _channels.append( 3 ); 392 if ( _maxChannel >= 3 ) _channels.append( 3 );
393 if ( _maxChannel >= 14 ) _channels.append( 14 ); 393 if ( _maxChannel >= 14 ) _channels.append( 14 );
394 if ( _maxChannel >= 9 ) _channels.append( 9 ); 394 if ( _maxChannel >= 9 ) _channels.append( 9 );
395 if ( _maxChannel >= 4 ) _channels.append( 4 ); 395 if ( _maxChannel >= 4 ) _channels.append( 4 );
396 if ( _maxChannel >= 10 ) _channels.append( 10 ); 396 if ( _maxChannel >= 10 ) _channels.append( 10 );
397 if ( _maxChannel >= 5 ) _channels.append( 5 ); 397 if ( _maxChannel >= 5 ) _channels.append( 5 );
398 if ( _maxChannel >= 11 ) _channels.append( 11 ); 398 if ( _maxChannel >= 11 ) _channels.append( 11 );
399 if ( _maxChannel >= 6 ) _channels.append( 6 ); 399 if ( _maxChannel >= 6 ) _channels.append( 6 );
400 if ( _maxChannel >= 12 ) _channels.append( 12 ); 400 if ( _maxChannel >= 12 ) _channels.append( 12 );
401 _channel = _channels.begin(); 401 _channel = _channels.begin();
402
403} 402}
404 403
405 404
406OChannelHopper::~OChannelHopper() 405OChannelHopper::~OChannelHopper()
407{ 406{
408} 407}
409 408
410 409
411bool OChannelHopper::isActive() const 410bool OChannelHopper::isActive() const
412{ 411{
413 return _tid; 412 return _tid;
414} 413}
415 414
416 415
417int OChannelHopper::channel() const 416int OChannelHopper::channel() const
418{ 417{
419 return *_channel; 418 return *_channel;
420} 419}
421 420
422 421
423void OChannelHopper::timerEvent( QTimerEvent* ) 422void OChannelHopper::timerEvent( QTimerEvent* )
424{ 423{
425 _iface->setChannel( *_channel ); 424 _iface->setChannel( *_channel );
426 emit( hopped( *_channel ) ); 425 emit( hopped( *_channel ) );
427 odebug << "OChannelHopper::timerEvent(): set channel " << *_channel << " on interface '" << _iface->name() << "'" << oendl; 426 odebug << "OChannelHopper::timerEvent(): set channel " << *_channel << " on interface '" << _iface->name() << "'" << oendl;
428 if ( ++_channel == _channels.end() ) _channel = _channels.begin(); 427 if ( ++_channel == _channels.end() ) _channel = _channels.begin();
429} 428}
430 429
431 430
432void OChannelHopper::setInterval( int interval ) 431void OChannelHopper::setInterval( int interval )
433{ 432{
434 if ( interval == _interval ) 433 if ( interval == _interval )
435 return; 434 return;
436 435
437 if ( _interval ) 436 if ( _interval )
438 killTimer( _tid ); 437 killTimer( _tid );
439 438
440 _tid = 0; 439 _tid = 0;
441 _interval = interval; 440 _interval = interval;
442 441
443 if ( _interval ) 442 if ( _interval )
444 { 443 {
445 _tid = startTimer( interval ); 444 _tid = startTimer( interval );
446 } 445 }
447} 446}
448 447
449 448
450int OChannelHopper::interval() const 449int OChannelHopper::interval() const
451{ 450{
452 return _interval; 451 return _interval;
453} 452}
454 453
455 454
456/*====================================================================================== 455/*======================================================================================
457 * OWirelessNetworkInterface 456 * OWirelessNetworkInterface
458 *======================================================================================*/ 457 *======================================================================================*/
459 458
460OWirelessNetworkInterface::OWirelessNetworkInterface( QObject* parent, const char* name ) 459OWirelessNetworkInterface::OWirelessNetworkInterface( QObject* parent, const char* name )
461 :ONetworkInterface( parent, name ), _hopper( 0 ) 460 :ONetworkInterface( parent, name ), _hopper( 0 )
462{ 461{
463 odebug << "OWirelessNetworkInterface::OWirelessNetworkInterface()" << oendl; 462 odebug << "OWirelessNetworkInterface::OWirelessNetworkInterface()" << oendl;
464 init(); 463 init();
465} 464}
466 465
467 466
468OWirelessNetworkInterface::~OWirelessNetworkInterface() 467OWirelessNetworkInterface::~OWirelessNetworkInterface()
469{ 468{
470} 469}
471 470
472 471
473struct iwreq& OWirelessNetworkInterface::iwr() const 472struct iwreq& OWirelessNetworkInterface::iwr() const
474{ 473{
475 return _iwr; 474 return _iwr;
476} 475}
477 476
478 477
479void OWirelessNetworkInterface::init() 478void OWirelessNetworkInterface::init()
480{ 479{
481 odebug << "OWirelessNetworkInterface::init()" << oendl; 480 odebug << "OWirelessNetworkInterface::init()" << oendl;
482 memset( &_iwr, 0, sizeof( struct iwreq ) ); 481 memset( &_iwr, 0, sizeof( struct iwreq ) );
483 buildInformation(); 482 buildInformation();
484 buildPrivateList(); 483 buildPrivateList();
485 dumpInformation(); 484 dumpInformation();
486} 485}
487 486
488 487
489bool OWirelessNetworkInterface::isAssociated() const 488bool OWirelessNetworkInterface::isAssociated() const
490{ 489{
491 //FIXME: handle different modes 490 //FIXME: handle different modes
492 return !(associatedAP() == OMacAddress::unknown); 491 return !(associatedAP() == OMacAddress::unknown);
493} 492}
494 493
495 494
496OMacAddress OWirelessNetworkInterface::associatedAP() const 495OMacAddress OWirelessNetworkInterface::associatedAP() const
497{ 496{
498 if ( ioctl( SIOCGIWAP ) ) 497 if ( ioctl( SIOCGIWAP ) )
499 return (const unsigned char*) &_ifr.ifr_hwaddr.sa_data[0]; 498 return (const unsigned char*) &_ifr.ifr_hwaddr.sa_data[0];
500 else 499 else
501 return OMacAddress::unknown; 500 return OMacAddress::unknown;
502} 501}
503 502
504 503
505void OWirelessNetworkInterface::buildInformation() 504void OWirelessNetworkInterface::buildInformation()
506{ 505{
507 //ML: If you listen carefully enough, you can hear lots of WLAN drivers suck 506 //ML: If you listen carefully enough, you can hear lots of WLAN drivers suck
508 //ML: The HostAP drivers need more than sizeof struct_iw range to complete 507 //ML: The HostAP drivers need more than sizeof struct_iw range to complete
509 //ML: SIOCGIWRANGE otherwise they fail with "Invalid Argument Length". 508 //ML: SIOCGIWRANGE otherwise they fail with "Invalid Argument Length".
510 //ML: The Wlan-NG drivers on the otherside fail (segfault!) if you allocate 509 //ML: The Wlan-NG drivers on the otherside fail (segfault!) if you allocate
511 //ML: _too much_ space. This is damn shitty crap *sigh* 510 //ML: _too much_ space. This is damn shitty crap *sigh*
512 //ML: We allocate a large memory region in RAM and check whether the 511 //ML: We allocate a large memory region in RAM and check whether the
513 //ML: driver pollutes this extra space. The complaint will be made on stdout, 512 //ML: driver pollutes this extra space. The complaint will be made on stdout,
514 //ML: so please forward this... 513 //ML: so please forward this...
515 514
516 struct iwreq wrq; 515 struct iwreq wrq;
517 int len = sizeof( struct iw_range )*2; 516 int len = sizeof( struct iw_range )*2;
518 char *buffer = (char*) malloc( len ); 517 char *buffer = (char*) malloc( len );
519 //FIXME: Validate if we actually got the memory block 518 //FIXME: Validate if we actually got the memory block
520 memset( buffer, 0, len ); 519 memset( buffer, 0, len );
521 memcpy( wrq.ifr_name, name(), IFNAMSIZ); 520 memcpy( wrq.ifr_name, name(), IFNAMSIZ);
522 wrq.u.data.pointer = (caddr_t) buffer; 521 wrq.u.data.pointer = (caddr_t) buffer;
523 wrq.u.data.length = sizeof( struct iw_range ); 522 wrq.u.data.length = sizeof( struct iw_range );
524 wrq.u.data.flags = 0; 523 wrq.u.data.flags = 0;
525 524
526 if ( ::ioctl( _sfd, SIOCGIWRANGE, &wrq ) == -1 ) 525 if ( ::ioctl( _sfd, SIOCGIWRANGE, &wrq ) == -1 )
527 { 526 {
528 owarn << "OWirelessNetworkInterface::buildInformation(): Can't get channel information - using default values." << oendl; 527 owarn << "OWirelessNetworkInterface::buildInformation(): Can't get channel information - using default values." << oendl;
529 _channels.insert( 2412, 1 ); // 2.412 GHz 528 _channels.insert( 2412, 1 ); // 2.412 GHz
530 _channels.insert( 2417, 2 ); // 2.417 GHz 529 _channels.insert( 2417, 2 ); // 2.417 GHz
531 _channels.insert( 2422, 3 ); // 2.422 GHz 530 _channels.insert( 2422, 3 ); // 2.422 GHz
532 _channels.insert( 2427, 4 ); // 2.427 GHz 531 _channels.insert( 2427, 4 ); // 2.427 GHz
533 _channels.insert( 2432, 5 ); // 2.432 GHz 532 _channels.insert( 2432, 5 ); // 2.432 GHz
534 _channels.insert( 2437, 6 ); // 2.437 GHz 533 _channels.insert( 2437, 6 ); // 2.437 GHz
535 _channels.insert( 2442, 7 ); // 2.442 GHz 534 _channels.insert( 2442, 7 ); // 2.442 GHz
536 _channels.insert( 2447, 8 ); // 2.447 GHz 535 _channels.insert( 2447, 8 ); // 2.447 GHz
537 _channels.insert( 2452, 9 ); // 2.452 GHz 536 _channels.insert( 2452, 9 ); // 2.452 GHz
538 _channels.insert( 2457, 10 ); // 2.457 GHz 537 _channels.insert( 2457, 10 ); // 2.457 GHz
539 _channels.insert( 2462, 11 ); // 2.462 GHz 538 _channels.insert( 2462, 11 ); // 2.462 GHz
540 539
541 memset( &_range, 0, sizeof( struct iw_range ) ); 540 memset( &_range, 0, sizeof( struct iw_range ) );
542 } 541 }
543 else 542 else
544 { 543 {
545 // <check if the driver overwrites stuff> 544 // <check if the driver overwrites stuff>
546 int max = 0; 545 int max = 0;
547 for ( int r = sizeof( struct iw_range ); r < len; r++ ) 546 for ( int r = sizeof( struct iw_range ); r < len; r++ )
548 if (buffer[r] != 0) 547 if (buffer[r] != 0)
549 max = r; 548 max = r;
550 if (max > 0) 549 if (max > 0)
551 { 550 {
552 owarn << "OWirelessNetworkInterface::buildInformation(): Driver for wireless interface '" << name() 551 owarn << "OWirelessNetworkInterface::buildInformation(): Driver for wireless interface '" << name()
553 << "' sucks! It overwrote the buffer end with at least " << max - sizeof( struct iw_range ) << " bytes!" << oendl; 552 << "' sucks! It overwrote the buffer end with at least " << max - sizeof( struct iw_range ) << " bytes!" << oendl;
554 } 553 }
555 // </check if the driver overwrites stuff> 554 // </check if the driver overwrites stuff>
556 555
557 struct iw_range range; 556 struct iw_range range;
558 memcpy( &range, buffer, sizeof range ); 557 memcpy( &range, buffer, sizeof range );
559 558
560 odebug << "OWirelessNetworkInterface::buildInformation(): Interface reported to have " << (int) range.num_frequency << " channels." << oendl; 559 odebug << "OWirelessNetworkInterface::buildInformation(): Interface reported to have " << (int) range.num_frequency << " channels." << oendl;
561 for ( int i = 0; i < range.num_frequency; ++i ) 560 for ( int i = 0; i < range.num_frequency; ++i )
562 { 561 {
563 int freq = (int) ( double( range.freq[i].m ) * pow( 10.0, range.freq[i].e ) / 1000000.0 ); 562 int freq = (int) ( double( range.freq[i].m ) * pow( 10.0, range.freq[i].e ) / 1000000.0 );
563 odebug << "OWirelessNetworkInterface::buildInformation: Adding frequency " << freq << " as channel " << i+1 << oendl;
564 _channels.insert( freq, i+1 ); 564 _channels.insert( freq, i+1 );
565 } 565 }
566 } 566 }
567 567
568 memcpy( &_range, buffer, sizeof( struct iw_range ) ); 568 memcpy( &_range, buffer, sizeof( struct iw_range ) );
569 odebug << "OWirelessNetworkInterface::buildInformation(): Information block constructed." << oendl; 569 odebug << "OWirelessNetworkInterface::buildInformation(): Information block constructed." << oendl;
570 free(buffer); 570 free(buffer);
571} 571}
572 572
573 573
574short OWirelessNetworkInterface::wirelessExtensionDriverVersion() const
575{
576 return _range.we_version_compiled;
577}
578
579
574void OWirelessNetworkInterface::buildPrivateList() 580void OWirelessNetworkInterface::buildPrivateList()
575{ 581{
576 odebug << "OWirelessNetworkInterface::buildPrivateList()" << oendl; 582 odebug << "OWirelessNetworkInterface::buildPrivateList()" << oendl;
577 583
578 struct iw_priv_args priv[IW_MAX_PRIV_DEF]; 584 struct iw_priv_args priv[IW_MAX_PRIV_DEF];
579 585
580 _iwr.u.data.pointer = (char*) &priv; 586 _iwr.u.data.pointer = (char*) &priv;
581 _iwr.u.data.length = IW_MAX_PRIV_DEF; // length in terms of number of (sizeof iw_priv_args), not (sizeof iw_priv_args) itself 587 _iwr.u.data.length = IW_MAX_PRIV_DEF; // length in terms of number of (sizeof iw_priv_args), not (sizeof iw_priv_args) itself
582 _iwr.u.data.flags = 0; 588 _iwr.u.data.flags = 0;
583 589
584 if ( !wioctl( SIOCGIWPRIV ) ) 590 if ( !wioctl( SIOCGIWPRIV ) )
585 { 591 {
586 owarn << "OWirelessNetworkInterface::buildPrivateList(): Can't get private ioctl information." << oendl; 592 owarn << "OWirelessNetworkInterface::buildPrivateList(): Can't get private ioctl information." << oendl;
587 return; 593 return;
588 } 594 }
589 595
590 for ( int i = 0; i < _iwr.u.data.length; ++i ) 596 for ( int i = 0; i < _iwr.u.data.length; ++i )
591 { 597 {
592 new OPrivateIOCTL( this, priv[i].name, priv[i].cmd, priv[i].get_args, priv[i].set_args ); 598 new OPrivateIOCTL( this, priv[i].name, priv[i].cmd, priv[i].get_args, priv[i].set_args );
593 } 599 }
594 odebug << "OWirelessNetworkInterface::buildPrivateList(): Private ioctl list constructed." << oendl; 600 odebug << "OWirelessNetworkInterface::buildPrivateList(): Private ioctl list constructed." << oendl;
595} 601}
596 602
597 603
598void OWirelessNetworkInterface::dumpInformation() const 604void OWirelessNetworkInterface::dumpInformation() const
599{ 605{
600 odebug << "OWirelessNetworkInterface::() -------------- dumping information block ----------------" << oendl; 606 odebug << "OWirelessNetworkInterface::() -------------- dumping information block ----------------" << oendl;
601 607
602 qDebug( " - driver's idea of maximum throughput is %d bps = %d byte/s = %d Kb/s = %f.2 Mb/s", 608 qDebug( " - driver's idea of maximum throughput is %d bps = %d byte/s = %d Kb/s = %f.2 Mb/s",
603 _range.throughput, _range.throughput / 8, _range.throughput / 8 / 1024, float( _range.throughput ) / 8.0 / 1024.0 / 1024.0 ); 609 _range.throughput, _range.throughput / 8, _range.throughput / 8 / 1024, float( _range.throughput ) / 8.0 / 1024.0 / 1024.0 );
604 qDebug( " - driver for '%s' (V%d) has been compiled against WE V%d", 610 qDebug( " - driver for '%s' (V%d) has been compiled against WE V%d",
605 name(), _range.we_version_source, _range.we_version_compiled ); 611 name(), _range.we_version_source, _range.we_version_compiled );
606 612
607 if ( _range.we_version_compiled != WIRELESS_EXT ) 613 if ( _range.we_version_compiled != WIRELESS_EXT )
608 { 614 {
609 owarn << "Version mismatch! WE_DRIVER = " << _range.we_version_compiled << " and WE_OPIENET = " << WIRELESS_EXT << oendl; 615 owarn << "Version mismatch! WE_DRIVER = " << _range.we_version_compiled << " and WE_OPIENET = " << WIRELESS_EXT << oendl;
610 } 616 }
611 617
612 odebug << "OWirelessNetworkInterface::() ---------------------------------------------------------" << oendl; 618 odebug << "OWirelessNetworkInterface::() ---------------------------------------------------------" << oendl;
613} 619}
614 620
615 621
616int OWirelessNetworkInterface::channel() const 622int OWirelessNetworkInterface::channel() const
617{ 623{
618 //FIXME: When monitoring enabled, then use it 624 //FIXME: When monitoring enabled, then use it
619 //FIXME: to gather the current RF channel 625 //FIXME: to gather the current RF channel
620 //FIXME: Until then, get active channel from hopper. 626 //FIXME: Until then, get active channel from hopper.
621 if ( _hopper && _hopper->isActive() ) 627 if ( _hopper && _hopper->isActive() )
622 return _hopper->channel(); 628 return _hopper->channel();
623 629
624 if ( !wioctl( SIOCGIWFREQ ) ) 630 if ( !wioctl( SIOCGIWFREQ ) )
625 { 631 {
626 return -1; 632 return -1;
627 } 633 }
628 else 634 else
629 { 635 {
630 return _channels[ static_cast<int>(double( _iwr.u.freq.m ) * pow( 10.0, _iwr.u.freq.e ) / 1000000) ]; 636 return _channels[ static_cast<int>(double( _iwr.u.freq.m ) * pow( 10.0, _iwr.u.freq.e ) / 1000000) ];
631 } 637 }
632} 638}
633 639
634 640
635void OWirelessNetworkInterface::setChannel( int c ) const 641void OWirelessNetworkInterface::setChannel( int c ) const
636{ 642{
637 if ( !c ) 643 if ( !c )
638 { 644 {
639 oerr << "OWirelessNetworkInterface::setChannel( 0 ) called - fix your application!" << oendl; 645 oerr << "OWirelessNetworkInterface::setChannel( 0 ) called - fix your application!" << oendl;
640 return; 646 return;
641 } 647 }
642 648
643 if ( !_mon ) 649 if ( !_mon )
644 { 650 {
645 memset( &_iwr, 0, sizeof( struct iwreq ) ); 651 memset( &_iwr, 0, sizeof( struct iwreq ) );
646 _iwr.u.freq.m = c; 652 _iwr.u.freq.m = c;
647 _iwr.u.freq.e = 0; 653 _iwr.u.freq.e = 0;
648 wioctl( SIOCSIWFREQ ); 654 wioctl( SIOCSIWFREQ );
649 } 655 }
650 else 656 else
651 { 657 {
652 _mon->setChannel( c ); 658 _mon->setChannel( c );
653 } 659 }
654} 660}
655 661
656 662
657double OWirelessNetworkInterface::frequency() const 663double OWirelessNetworkInterface::frequency() const
658{ 664{
659 if ( !wioctl( SIOCGIWFREQ ) ) 665 if ( !wioctl( SIOCGIWFREQ ) )
660 { 666 {
661 return -1.0; 667 return -1.0;
662 } 668 }
663 else 669 else
664 { 670 {
665 return double( _iwr.u.freq.m ) * pow( 10.0, _iwr.u.freq.e ) / 1000000000.0; 671 return double( _iwr.u.freq.m ) * pow( 10.0, _iwr.u.freq.e ) / 1000000000.0;
666 } 672 }
667} 673}
668 674
669 675
670int OWirelessNetworkInterface::channels() const 676int OWirelessNetworkInterface::channels() const
671{ 677{
672 return _channels.count(); 678 return _channels.count();
673} 679}
674 680
675 681
676void OWirelessNetworkInterface::setChannelHopping( int interval ) 682void OWirelessNetworkInterface::setChannelHopping( int interval )
677{ 683{
678 if ( !_hopper ) _hopper = new OChannelHopper( this ); 684 if ( !_hopper ) _hopper = new OChannelHopper( this );
679 _hopper->setInterval( interval ); 685 _hopper->setInterval( interval );
680 //FIXME: When and by whom will the channel hopper be deleted? 686 //FIXME: When and by whom will the channel hopper be deleted?
681 //TODO: rely on QObject hierarchy 687 //TODO: rely on QObject hierarchy
682} 688}
683 689
684 690
685int OWirelessNetworkInterface::channelHopping() const 691int OWirelessNetworkInterface::channelHopping() const
686{ 692{
687 return _hopper->interval(); 693 return _hopper->interval();
688} 694}
689 695
690 696
691OChannelHopper* OWirelessNetworkInterface::channelHopper() const 697OChannelHopper* OWirelessNetworkInterface::channelHopper() const
692{ 698{
693 return _hopper; 699 return _hopper;
694} 700}
695 701
696 702
697void OWirelessNetworkInterface::commit() const 703void OWirelessNetworkInterface::commit() const
698{ 704{
699 wioctl( SIOCSIWCOMMIT ); 705 wioctl( SIOCSIWCOMMIT );
700} 706}
701 707
702 708
703void OWirelessNetworkInterface::setMode( const QString& newMode ) 709void OWirelessNetworkInterface::setMode( const QString& newMode )
704{ 710{
705 #ifdef FINALIZE 711 #ifdef FINALIZE
706 QString currentMode = mode(); 712 QString currentMode = mode();
707 if ( currentMode == newMode ) return; 713 if ( currentMode == newMode ) return;
708 #endif 714 #endif
709 715
710 odebug << "OWirelessNetworkInterface::setMode(): trying to set mode " << newMode << oendl; 716 odebug << "OWirelessNetworkInterface::setMode(): trying to set mode " << newMode << oendl;
711 717
712 _iwr.u.mode = stringToMode( newMode ); 718 _iwr.u.mode = stringToMode( newMode );
713 719
714 if ( _iwr.u.mode != IW_MODE_MONITOR ) 720 if ( _iwr.u.mode != IW_MODE_MONITOR )
715 { 721 {
716 // IWR.U.MODE WIRD DURCH ABFRAGE DES MODE HIER PLATTGEMACHT!!!!!!!!!!!!!!!!!!!!! DEPP! 722 // IWR.U.MODE WIRD DURCH ABFRAGE DES MODE HIER PLATTGEMACHT!!!!!!!!!!!!!!!!!!!!! DEPP!
717 _iwr.u.mode = stringToMode( newMode ); 723 _iwr.u.mode = stringToMode( newMode );
718 wioctl( SIOCSIWMODE ); 724 wioctl( SIOCSIWMODE );
719 725
720 // special iwpriv fallback for monitor mode (check if we're really out of monitor mode now) 726 // special iwpriv fallback for monitor mode (check if we're really out of monitor mode now)
721 727
722 if ( mode() == "monitor" ) 728 if ( mode() == "monitor" )
723 { 729 {
724 odebug << "OWirelessNetworkInterface::setMode(): SIOCSIWMODE not sufficient - trying fallback to iwpriv..." << oendl; 730 odebug << "OWirelessNetworkInterface::setMode(): SIOCSIWMODE not sufficient - trying fallback to iwpriv..." << oendl;
725 if ( _mon ) 731 if ( _mon )
726 _mon->setEnabled( false ); 732 _mon->setEnabled( false );
727 else 733 else
728 odebug << "ONetwork(): can't switch monitor mode without installed monitoring interface" << oendl; 734 odebug << "ONetwork(): can't switch monitor mode without installed monitoring interface" << oendl;
729 } 735 }
730 736
731 } 737 }
732 else // special iwpriv fallback for monitor mode 738 else // special iwpriv fallback for monitor mode
733 { 739 {
734 if ( wioctl( SIOCSIWMODE ) ) 740 if ( wioctl( SIOCSIWMODE ) )
735 { 741 {
736 odebug << "OWirelessNetworkInterface::setMode(): IW_MODE_MONITOR ok" << oendl; 742 odebug << "OWirelessNetworkInterface::setMode(): IW_MODE_MONITOR ok" << oendl;
737 } 743 }
738 else 744 else
739 { 745 {
740 odebug << "OWirelessNetworkInterface::setMode(): SIOCSIWMODE not working - trying fallback to iwpriv..." << oendl; 746 odebug << "OWirelessNetworkInterface::setMode(): SIOCSIWMODE not working - trying fallback to iwpriv..." << oendl;
741 747
742 if ( _mon ) 748 if ( _mon )
743 _mon->setEnabled( true ); 749 _mon->setEnabled( true );
744 else 750 else
745 odebug << "ONetwork(): can't switch monitor mode without installed monitoring interface" << oendl; 751 odebug << "ONetwork(): can't switch monitor mode without installed monitoring interface" << oendl;
746 } 752 }
747 } 753 }
748} 754}
749 755
750 756
751QString OWirelessNetworkInterface::mode() const 757QString OWirelessNetworkInterface::mode() const
752{ 758{
753 memset( &_iwr, 0, sizeof( struct iwreq ) ); 759 memset( &_iwr, 0, sizeof( struct iwreq ) );
754 760
755 if ( !wioctl( SIOCGIWMODE ) ) 761 if ( !wioctl( SIOCGIWMODE ) )
756 { 762 {
757 return "<unknown>"; 763 return "<unknown>";
758 } 764 }
759 765
760 odebug << "OWirelessNetworkInterface::setMode(): WE's idea of current mode seems to be " << modeToString( _iwr.u.mode ) << oendl; 766 odebug << "OWirelessNetworkInterface::setMode(): WE's idea of current mode seems to be " << modeToString( _iwr.u.mode ) << oendl;
761 767
762 // legacy compatible monitor mode check 768 // legacy compatible monitor mode check
763 769
764 if ( dataLinkType() == ARPHRD_IEEE80211 || dataLinkType() == 802 ) 770 if ( dataLinkType() == ARPHRD_IEEE80211 || dataLinkType() == 802 )
765 { 771 {
766 return "monitor"; 772 return "monitor";
767 } 773 }
768 else 774 else
769 { 775 {
770 return modeToString( _iwr.u.mode ); 776 return modeToString( _iwr.u.mode );
771 } 777 }
772} 778}
773 779
774void OWirelessNetworkInterface::setNickName( const QString& nickname ) 780void OWirelessNetworkInterface::setNickName( const QString& nickname )
775{ 781{
776 _iwr.u.essid.pointer = const_cast<char*>( (const char*) nickname ); 782 _iwr.u.essid.pointer = const_cast<char*>( (const char*) nickname );
777 _iwr.u.essid.length = nickname.length(); 783 _iwr.u.essid.length = nickname.length();
778 wioctl( SIOCSIWNICKN ); 784 wioctl( SIOCSIWNICKN );
779} 785}
780 786
781 787
782QString OWirelessNetworkInterface::nickName() const 788QString OWirelessNetworkInterface::nickName() const
783{ 789{
784 char str[IW_ESSID_MAX_SIZE]; 790 char str[IW_ESSID_MAX_SIZE];
785 _iwr.u.data.pointer = &str[0]; 791 _iwr.u.data.pointer = &str[0];
786 _iwr.u.data.length = IW_ESSID_MAX_SIZE; 792 _iwr.u.data.length = IW_ESSID_MAX_SIZE;
787 if ( !wioctl( SIOCGIWNICKN ) ) 793 if ( !wioctl( SIOCGIWNICKN ) )
788 { 794 {
789 return "<unknown>"; 795 return "<unknown>";
790 } 796 }
791 else 797 else
792 { 798 {
793 str[_iwr.u.data.length] = 0x0; // some drivers (e.g. wlan-ng) don't zero-terminate the string 799 str[_iwr.u.data.length] = 0x0; // some drivers (e.g. wlan-ng) don't zero-terminate the string
794 return str; 800 return str;
795 } 801 }
796} 802}
797 803
798 804
799void OWirelessNetworkInterface::setPrivate( const QString& call, int numargs, ... ) 805void OWirelessNetworkInterface::setPrivate( const QString& call, int numargs, ... )
800{ 806{
801 OPrivateIOCTL* priv = static_cast<OPrivateIOCTL*>( child( (const char*) call ) ); 807 OPrivateIOCTL* priv = static_cast<OPrivateIOCTL*>( child( (const char*) call ) );
802 if ( !priv ) 808 if ( !priv )
803 { 809 {
804 owarn << "OWirelessNetworkInterface::setPrivate(): interface '" << name() 810 owarn << "OWirelessNetworkInterface::setPrivate(): interface '" << name()
805 << "' does not support private ioctl '" << call << "'" << oendl; 811 << "' does not support private ioctl '" << call << "'" << oendl;
806 return; 812 return;
807 } 813 }
808 if ( priv->numberSetArgs() != numargs ) 814 if ( priv->numberSetArgs() != numargs )
809 { 815 {
810 owarn << "OWirelessNetworkInterface::setPrivate(): parameter count not matching. '" 816 owarn << "OWirelessNetworkInterface::setPrivate(): parameter count not matching. '"
811 << call << "' expects " << priv->numberSetArgs() << ", but got " << numargs << oendl; 817 << call << "' expects " << priv->numberSetArgs() << ", but got " << numargs << oendl;
812 return; 818 return;
813 } 819 }
814 820
815 odebug << "OWirelessNetworkInterface::setPrivate(): about to call '" << call << "' on interface '" << name() << "'" << oendl; 821 odebug << "OWirelessNetworkInterface::setPrivate(): about to call '" << call << "' on interface '" << name() << "'" << oendl;
816 memset( &_iwr, 0, sizeof _iwr ); 822 memset( &_iwr, 0, sizeof _iwr );
817 va_list argp; 823 va_list argp;
818 va_start( argp, numargs ); 824 va_start( argp, numargs );
819 for ( int i = 0; i < numargs; ++i ) 825 for ( int i = 0; i < numargs; ++i )
820 { 826 {
821 priv->setParameter( i, va_arg( argp, int ) ); 827 priv->setParameter( i, va_arg( argp, int ) );
822 } 828 }
823 va_end( argp ); 829 va_end( argp );
824 priv->invoke(); 830 priv->invoke();
825} 831}
826 832
827 833
828void OWirelessNetworkInterface::getPrivate( const QString& call ) 834void OWirelessNetworkInterface::getPrivate( const QString& call )
829{ 835{
diff --git a/libopie2/opienet/onetwork.h b/libopie2/opienet/onetwork.h
index f5fbe1d..a49c8fb 100644
--- a/libopie2/opienet/onetwork.h
+++ b/libopie2/opienet/onetwork.h
@@ -1,597 +1,601 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer 3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer
4 =. <mickey@Vanille.de> 4 =. <mickey@Vanille.de>
5 .=l. 5 .=l.
6           .>+-= 6           .>+-=
7 _;:,     .>    :=|. This program is free software; you can 7 _;:,     .>    :=|. This program is free software; you can
8.> <`_,   >  .   <= redistribute it and/or modify it under 8.> <`_,   >  .   <= redistribute it and/or modify it under
9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
10.="- .-=="i,     .._ License as published by the Free Software 10.="- .-=="i,     .._ License as published by the Free Software
11 - .   .-<_>     .<> Foundation; either version 2 of the License, 11 - .   .-<_>     .<> Foundation; either version 2 of the License,
12     ._= =}       : or (at your option) any later version. 12     ._= =}       : or (at your option) any later version.
13    .%`+i>       _;_. 13    .%`+i>       _;_.
14    .i_,=:_.      -<s. This program is distributed in the hope that 14    .i_,=:_.      -<s. This program is distributed in the hope that
15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
16    : ..    .:,     . . . without even the implied warranty of 16    : ..    .:,     . . . without even the implied warranty of
17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.=       =       ; Library General Public License for more 19..}^=.=       =       ; Library General Public License for more
20++=   -.     .`     .: details. 20++=   -.     .`     .: details.
21 :     =  ...= . :.=- 21 :     =  ...= . :.=-
22 -.   .:....=;==+<; You should have received a copy of the GNU 22 -.   .:....=;==+<; You should have received a copy of the GNU
23  -_. . .   )=.  = Library General Public License along with 23  -_. . .   )=.  = Library General Public License along with
24    --        :-=` this library; see the file COPYING.LIB. 24    --        :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28 28
29*/ 29*/
30 30
31#ifndef ONETWORK_H 31#ifndef ONETWORK_H
32#define ONETWORK_H 32#define ONETWORK_H
33 33
34#if !defined( OPIE_WE_VERSION ) 34#if !defined( OPIE_WE_VERSION )
35 #warning No wireless extension specified; autodetecting... 35 #warning No wireless extension specified; autodetecting...
36 #include <linux/version.h> 36 #include <linux/version.h>
37 #if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,23) 37 #if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,23)
38 #define OPIE_WE_VERSION 15 38 #define OPIE_WE_VERSION 15
39 #else 39 #else
40 #define OPIE_WE_VERSION 16 40 #define OPIE_WE_VERSION 16
41 #endif // LINUX_VERSION_CODE < KERNEL_VERSION(2.4.23) 41 #endif // LINUX_VERSION_CODE < KERNEL_VERSION(2.4.23)
42#endif // !defined( OPIE_WE_VERSION ) 42#endif // !defined( OPIE_WE_VERSION )
43 43
44#if OPIE_WE_VERSION == 15 44#if OPIE_WE_VERSION == 15
45#include "wireless.15.h" 45#include "wireless.15.h"
46#warning Using WE V15 46#warning Using WE V15
47#endif 47#endif
48#if OPIE_WE_VERSION == 16 48#if OPIE_WE_VERSION == 16
49#include "wireless.16.h" 49#include "wireless.16.h"
50#warning Using WE V16 50#warning Using WE V16
51#endif 51#endif
52 52
53/* OPIE */ 53/* OPIE */
54 54
55#include <opie2/onetutils.h> 55#include <opie2/onetutils.h>
56#include <opie2/ostation.h> 56#include <opie2/ostation.h>
57 57
58/* QT */ 58/* QT */
59 59
60#include <qvaluelist.h> 60#include <qvaluelist.h>
61#include <qdict.h> 61#include <qdict.h>
62#include <qmap.h> 62#include <qmap.h>
63#include <qobject.h> 63#include <qobject.h>
64#include <qhostaddress.h> 64#include <qhostaddress.h>
65 65
66namespace Opie { 66namespace Opie {
67namespace Net { 67namespace Net {
68 68
69class ONetworkInterface; 69class ONetworkInterface;
70class OWirelessNetworkInterface; 70class OWirelessNetworkInterface;
71class OChannelHopper; 71class OChannelHopper;
72class OMonitoringInterface; 72class OMonitoringInterface;
73 73
74/*====================================================================================== 74/*======================================================================================
75 * ONetwork 75 * ONetwork
76 *======================================================================================*/ 76 *======================================================================================*/
77 77
78/** 78/**
79 * @brief A container class for all network interfaces 79 * @brief A container class for all network interfaces
80 * 80 *
81 * This class provides access to all available network interfaces of your computer. 81 * This class provides access to all available network interfaces of your computer.
82 * 82 *
83 * @author Michael 'Mickey' Lauer <mickey@vanille.de> 83 * @author Michael 'Mickey' Lauer <mickey@vanille.de>
84 */ 84 */
85class ONetwork : public QObject 85class ONetwork : public QObject
86{ 86{
87 Q_OBJECT 87 Q_OBJECT
88 88
89 public: 89 public:
90 typedef QDict<ONetworkInterface> InterfaceMap; 90 typedef QDict<ONetworkInterface> InterfaceMap;
91 typedef QDictIterator<ONetworkInterface> InterfaceIterator; 91 typedef QDictIterator<ONetworkInterface> InterfaceIterator;
92 92
93 public: 93 public:
94 /** 94 /**
95 * @returns the number of available interfaces 95 * @returns the number of available interfaces
96 */ 96 */
97 int count() const; 97 int count() const;
98 /** 98 /**
99 * @returns a pointer to the (one and only) @ref ONetwork instance. 99 * @returns a pointer to the (one and only) @ref ONetwork instance.
100 */ 100 */
101 static ONetwork* instance(); 101 static ONetwork* instance();
102 /** 102 /**
103 * @returns an iterator usable for iterating through all network interfaces. 103 * @returns an iterator usable for iterating through all network interfaces.
104 */ 104 */
105 InterfaceIterator iterator() const; 105 InterfaceIterator iterator() const;
106 /** 106 /**
107 * @returns true, if the @a interface is present. 107 * @returns true, if the @a interface is present.
108 */ 108 */
109 bool isPresent( const char* interface ) const; 109 bool isPresent( const char* interface ) const;
110 /** 110 /**
111 * @returns true, if the @a interface supports the wireless extension protocol. 111 * @returns true, if the @a interface supports the wireless extension protocol.
112 */ 112 */
113 bool isWirelessInterface( const char* interface ) const; 113 bool isWirelessInterface( const char* interface ) const;
114 /** 114 /**
115 * @returns a pointer to the @ref ONetworkInterface object for the specified @a interface or 0, if not found. 115 * @returns a pointer to the @ref ONetworkInterface object for the specified @a interface or 0, if not found.
116 * @see ONetworkInterface 116 * @see ONetworkInterface
117 */ 117 */
118 ONetworkInterface* interface( const QString& interface ) const; 118 ONetworkInterface* interface( const QString& interface ) const;
119 /** 119 /**
120 * @internal Rebuild the internal interface database 120 * @internal Rebuild the internal interface database
121 * @note Sometimes it might be useful to call this from client code, 121 * @note Sometimes it might be useful to call this from client code,
122 * e.g. after issuing a cardctl insert 122 * e.g. after issuing a cardctl insert
123 */ 123 */
124 void synchronize(); 124 void synchronize();
125 /** 125 /**
126 * @returns the wireless extension version used at compile time. 126 * @returns the wireless extension version used at compile time.
127 **/ 127 **/
128 static short wirelessExtensionVersion(); 128 static short wirelessExtensionCompileVersion();
129 129
130 protected: 130 protected:
131 ONetwork(); 131 ONetwork();
132 132
133 private: 133 private:
134 static ONetwork* _instance; 134 static ONetwork* _instance;
135 InterfaceMap _interfaces; 135 InterfaceMap _interfaces;
136 class Private; 136 class Private;
137 Private *d; 137 Private *d;
138}; 138};
139 139
140 140
141/*====================================================================================== 141/*======================================================================================
142 * ONetworkInterface 142 * ONetworkInterface
143 *======================================================================================*/ 143 *======================================================================================*/
144 144
145/** 145/**
146 * @brief A network interface wrapper. 146 * @brief A network interface wrapper.
147 * 147 *
148 * This class provides a wrapper for a network interface. All the cumbersume details of 148 * This class provides a wrapper for a network interface. All the cumbersume details of
149 * Linux ioctls are hidden under a convenient high-level interface. 149 * Linux ioctls are hidden under a convenient high-level interface.
150 * @warning Most of the setting methods contained in this class require the appropriate 150 * @warning Most of the setting methods contained in this class require the appropriate
151 * process permissions to work. 151 * process permissions to work.
152 * 152 *
153 * @author Michael 'Mickey' Lauer <mickey@vanille.de> 153 * @author Michael 'Mickey' Lauer <mickey@vanille.de>
154 */ 154 */
155class ONetworkInterface : public QObject 155class ONetworkInterface : public QObject
156{ 156{
157 friend class OMonitoringInterface; 157 friend class OMonitoringInterface;
158 friend class OCiscoMonitoringInterface; 158 friend class OCiscoMonitoringInterface;
159 friend class OWlanNGMonitoringInterface; 159 friend class OWlanNGMonitoringInterface;
160 friend class OHostAPMonitoringInterface; 160 friend class OHostAPMonitoringInterface;
161 friend class OOrinocoMonitoringInterface; 161 friend class OOrinocoMonitoringInterface;
162 162
163 public: 163 public:
164 /** 164 /**
165 * Constructor. Normally you don't create @ref ONetworkInterface objects yourself, 165 * Constructor. Normally you don't create @ref ONetworkInterface objects yourself,
166 * but access them via @ref ONetwork::interface(). 166 * but access them via @ref ONetwork::interface().
167 */ 167 */
168 ONetworkInterface( QObject* parent, const char* name ); 168 ONetworkInterface( QObject* parent, const char* name );
169 /** 169 /**
170 * Destructor. 170 * Destructor.
171 */ 171 */
172 virtual ~ONetworkInterface(); 172 virtual ~ONetworkInterface();
173 /** 173 /**
174 * Associates a @a monitoring interface with this network interface. 174 * Associates a @a monitoring interface with this network interface.
175 * @note This is currently only useful with @ref OWirelessNetworkInterface objects. 175 * @note This is currently only useful with @ref OWirelessNetworkInterface objects.
176 */ 176 */
177 void setMonitoring( OMonitoringInterface* monitoring ); 177 void setMonitoring( OMonitoringInterface* monitoring );
178 /** 178 /**
179 * @returns the currently associated monitoring interface or 0, if no monitoring is associated. 179 * @returns the currently associated monitoring interface or 0, if no monitoring is associated.
180 */ 180 */
181 OMonitoringInterface* monitoring() const; 181 OMonitoringInterface* monitoring() const;
182 /** 182 /**
183 * Setting an interface to promiscuous mode enables the device to receive 183 * Setting an interface to promiscuous mode enables the device to receive
184 * all packets on the shared medium - as opposed to packets which are addressed to this interface. 184 * all packets on the shared medium - as opposed to packets which are addressed to this interface.
185 */ 185 */
186 bool setPromiscuousMode( bool ); 186 bool setPromiscuousMode( bool );
187 /** 187 /**
188 * @returns true if the interface is set to promiscuous mode. 188 * @returns true if the interface is set to promiscuous mode.
189 */ 189 */
190 bool promiscuousMode() const; 190 bool promiscuousMode() const;
191 /** 191 /**
192 * Setting an interface to up enables it to receive packets. 192 * Setting an interface to up enables it to receive packets.
193 */ 193 */
194 bool setUp( bool ); 194 bool setUp( bool );
195 /** 195 /**
196 * @returns true if the interface is up. 196 * @returns true if the interface is up.
197 */ 197 */
198 bool isUp() const; 198 bool isUp() const;
199 /** 199 /**
200 * @returns true if the interface is a loopback interface. 200 * @returns true if the interface is a loopback interface.
201 */ 201 */
202 bool isLoopback() const; 202 bool isLoopback() const;
203 /** 203 /**
204 * @returns true if the interface is featuring supports the wireless extension protocol. 204 * @returns true if the interface is featuring supports the wireless extension protocol.
205 */ 205 */
206 bool isWireless() const; 206 bool isWireless() const;
207 /** 207 /**
208 * Associate the IP address @ addr with the interface. 208 * Associate the IP address @ addr with the interface.
209 */ 209 */
210 void setIPV4Address( const QHostAddress& addr ); 210 void setIPV4Address( const QHostAddress& addr );
211 /** 211 /**
212 * @returns the IPv4 address associated with the interface. 212 * @returns the IPv4 address associated with the interface.
213 */ 213 */
214 QString ipV4Address() const; //TODO: make this return an OHostAddress 214 QString ipV4Address() const; //TODO: make this return an OHostAddress
215 /** 215 /**
216 * Associate the MAC address @a addr with the interface. 216 * Associate the MAC address @a addr with the interface.
217 * @note It can be necessary to shut down the interface prior to calling this method. 217 * @note It can be necessary to shut down the interface prior to calling this method.
218 * @warning This is not supported by all drivers. 218 * @warning This is not supported by all drivers.
219 */ 219 */
220 void setMacAddress( const OMacAddress& addr ); 220 void setMacAddress( const OMacAddress& addr );
221 /** 221 /**
222 * @returns the MAC address associated with the interface. 222 * @returns the MAC address associated with the interface.
223 */ 223 */
224 OMacAddress macAddress() const; 224 OMacAddress macAddress() const;
225 /** 225 /**
226 * Associate the IPv4 @a netmask with the interface. 226 * Associate the IPv4 @a netmask with the interface.
227 */ 227 */
228 void setIPV4Netmask( const QHostAddress& netmask ); 228 void setIPV4Netmask( const QHostAddress& netmask );
229 /** 229 /**
230 * @returns the IPv4 netmask associated with the interface. 230 * @returns the IPv4 netmask associated with the interface.
231 */ 231 */
232 QString ipV4Netmask() const; //TODO: make this return an OHostAddress 232 QString ipV4Netmask() const; //TODO: make this return an OHostAddress
233 /** 233 /**
234 * @returns the data link type currently associated with the interface. 234 * @returns the data link type currently associated with the interface.
235 * @see #include <net/if_arp.h> for possible values. 235 * @see #include <net/if_arp.h> for possible values.
236 */ 236 */
237 int dataLinkType() const; 237 int dataLinkType() const;
238 238
239 protected: 239 protected:
240 const int _sfd; 240 const int _sfd;
241 mutable ifreq _ifr; 241 mutable ifreq _ifr;
242 OMonitoringInterface* _mon; 242 OMonitoringInterface* _mon;
243 243
244 protected: 244 protected:
245 struct ifreq& ifr() const; 245 struct ifreq& ifr() const;
246 virtual void init(); 246 virtual void init();
247 bool ioctl( int call ) const; 247 bool ioctl( int call ) const;
248 bool ioctl( int call, struct ifreq& ) const; 248 bool ioctl( int call, struct ifreq& ) const;
249 private: 249 private:
250 class Private; 250 class Private;
251 Private *d; 251 Private *d;
252}; 252};
253 253
254/*====================================================================================== 254/*======================================================================================
255 * OChannelHopper 255 * OChannelHopper
256 *======================================================================================*/ 256 *======================================================================================*/
257 257
258/** 258/**
259 * @brief A radio frequency channel hopper. 259 * @brief A radio frequency channel hopper.
260 * 260 *
261 * This class provides a channel hopper for radio frequencies. A channel hopper frequently 261 * This class provides a channel hopper for radio frequencies. A channel hopper frequently
262 * changes the radio frequency channel of its associated @ref OWirelessNetworkInterface. 262 * changes the radio frequency channel of its associated @ref OWirelessNetworkInterface.
263 * This is necessary when in monitoring mode and scanning for other devices, because 263 * This is necessary when in monitoring mode and scanning for other devices, because
264 * the radio frequency hardware can only detect packets sent on the same frequency. 264 * the radio frequency hardware can only detect packets sent on the same frequency.
265 * 265 *
266 * @author Michael 'Mickey' Lauer <mickey@vanille.de> 266 * @author Michael 'Mickey' Lauer <mickey@vanille.de>
267 */ 267 */
268class OChannelHopper : public QObject 268class OChannelHopper : public QObject
269{ 269{
270 Q_OBJECT 270 Q_OBJECT
271 271
272 public: 272 public:
273 /** 273 /**
274 * Constructor. 274 * Constructor.
275 */ 275 */
276 OChannelHopper( OWirelessNetworkInterface* ); 276 OChannelHopper( OWirelessNetworkInterface* );
277 /** 277 /**
278 * Destructor. 278 * Destructor.
279 */ 279 */
280 virtual ~OChannelHopper(); 280 virtual ~OChannelHopper();
281 /** 281 /**
282 * @returns true, if the channel hopper is hopping channels 282 * @returns true, if the channel hopper is hopping channels
283 */ 283 */
284 bool isActive() const; 284 bool isActive() const;
285 /** 285 /**
286 * @returns the last hopped channel 286 * @returns the last hopped channel
287 */ 287 */
288 int channel() const; 288 int channel() const;
289 /** 289 /**
290 * Set the channel hopping @a interval. 290 * Set the channel hopping @a interval.
291 * An interval of 0 deactivates the channel hopper. 291 * An interval of 0 deactivates the channel hopper.
292 */ 292 */
293 void setInterval( int interval ); 293 void setInterval( int interval );
294 /** 294 /**
295 * @returns the channel hopping interval 295 * @returns the channel hopping interval
296 */ 296 */
297 int interval() const; 297 int interval() const;
298 298
299 signals: 299 signals:
300 /** 300 /**
301 * This signal is emitted right after the channel hopper performed a hop 301 * This signal is emitted right after the channel hopper performed a hop
302 */ 302 */
303 void hopped( int ); 303 void hopped( int );
304 304
305 protected: 305 protected:
306 virtual void timerEvent( QTimerEvent* ); 306 virtual void timerEvent( QTimerEvent* );
307 307
308 private: 308 private:
309 OWirelessNetworkInterface* _iface; 309 OWirelessNetworkInterface* _iface;
310 int _interval; 310 int _interval;
311 int _tid; 311 int _tid;
312 QValueList<int> _channels; 312 QValueList<int> _channels;
313 QValueList<int>::Iterator _channel; 313 QValueList<int>::Iterator _channel;
314 class Private; 314 class Private;
315 Private *d; 315 Private *d;
316}; 316};
317 317
318 318
319/*====================================================================================== 319/*======================================================================================
320 * OWirelessNetworkInterface 320 * OWirelessNetworkInterface
321 *======================================================================================*/ 321 *======================================================================================*/
322 322
323/** 323/**
324 * @brief A network interface wrapper for interfaces supporting the wireless extensions protocol. 324 * @brief A network interface wrapper for interfaces supporting the wireless extensions protocol.
325 * 325 *
326 * This class provides a high-level encapsulation of the Linux wireless extension API. 326 * This class provides a high-level encapsulation of the Linux wireless extension API.
327 * 327 *
328 * @author Michael 'Mickey' Lauer <mickey@vanille.de> 328 * @author Michael 'Mickey' Lauer <mickey@vanille.de>
329 */ 329 */
330class OWirelessNetworkInterface : public ONetworkInterface 330class OWirelessNetworkInterface : public ONetworkInterface
331{ 331{
332 friend class OMonitoringInterface; 332 friend class OMonitoringInterface;
333 friend class OCiscoMonitoringInterface; 333 friend class OCiscoMonitoringInterface;
334 friend class OWlanNGMonitoringInterface; 334 friend class OWlanNGMonitoringInterface;
335 friend class OHostAPMonitoringInterface; 335 friend class OHostAPMonitoringInterface;
336 friend class OOrinocoMonitoringInterface; 336 friend class OOrinocoMonitoringInterface;
337 337
338 friend class OPrivateIOCTL; 338 friend class OPrivateIOCTL;
339 339
340 public: 340 public:
341 /** 341 /**
342 * Constructor. 342 * Constructor.
343 */ 343 */
344 OWirelessNetworkInterface( QObject* parent, const char* name ); 344 OWirelessNetworkInterface( QObject* parent, const char* name );
345 /** 345 /**
346 * Destructor. 346 * Destructor.
347 */ 347 */
348 virtual ~OWirelessNetworkInterface(); 348 virtual ~OWirelessNetworkInterface();
349 /** 349 /**
350 * Setting the @a channel of the interface changes the radio frequency (RF) 350 * Setting the @a channel of the interface changes the radio frequency (RF)
351 * of the corresponding wireless network device. 351 * of the corresponding wireless network device.
352 * @note Common channel range is within [1-14]. A value of 0 is not allowed. 352 * @note Common channel range is within [1-14]. A value of 0 is not allowed.
353 * @see channels() 353 * @see channels()
354 */ 354 */
355 virtual void setChannel( int channel ) const; 355 virtual void setChannel( int channel ) const;
356 /** 356 /**
357 * @returns the channel index of the current radio frequency. 357 * @returns the channel index of the current radio frequency.
358 */ 358 */
359 virtual int channel() const; 359 virtual int channel() const;
360 /** 360 /**
361 * @returns the current radio frequency (in MHz). 361 * @returns the current radio frequency (in MHz).
362 */ 362 */
363 virtual double frequency() const; 363 virtual double frequency() const;
364 /** 364 /**
365 * @returns the number of radio frequency channels for the 365 * @returns the number of radio frequency channels for the
366 * corresponding wireless network device. 366 * corresponding wireless network device.
367 * @note European devices usually have 14 channels, while American typically feature 11 channels. 367 * @note European devices usually have 14 channels, while American typically feature 11 channels.
368 */ 368 */
369 virtual int channels() const; 369 virtual int channels() const;
370 /** 370 /**
371 * Set the IEEE 802.11 operation @a mode. 371 * Set the IEEE 802.11 operation @a mode.
372 * Valid values are <ul><li>adhoc<li>managed<li>monitor<li>master 372 * Valid values are <ul><li>adhoc<li>managed<li>monitor<li>master
373 * @warning Not all drivers support the all modes. 373 * @warning Not all drivers support the all modes.
374 * @note You might have to change the SSID to get the operation mode change into effect. 374 * @note You might have to change the SSID to get the operation mode change into effect.
375 */ 375 */
376 virtual void setMode( const QString& mode ); 376 virtual void setMode( const QString& mode );
377 /** 377 /**
378 * @returns the current IEEE 802.11 operation mode. 378 * @returns the current IEEE 802.11 operation mode.
379 * Possible values are <ul><li>adhoc<li>managed<li>monitor<li>master or <li>unknown 379 * Possible values are <ul><li>adhoc<li>managed<li>monitor<li>master or <li>unknown
380 * 380 *
381 * @note: Important note concerning the 'monitor' mode: 381 * @note: Important note concerning the 'monitor' mode:
382 * Setting the monitor mode on a wireless network interface enables 382 * Setting the monitor mode on a wireless network interface enables
383 * listening to IEEE 802.11 data and management frames which normally 383 * listening to IEEE 802.11 data and management frames which normally
384 * are handled by the device firmware. This can be used to detect 384 * are handled by the device firmware. This can be used to detect
385 * other wireless network devices, e.g. Access Points or Ad-hoc stations. 385 * other wireless network devices, e.g. Access Points or Ad-hoc stations.
386 * @warning Standard wireless network drives don't support the monitor mode. 386 * @warning Standard wireless network drives don't support the monitor mode.
387 * @warning You need a patched driver for this to work. 387 * @warning You need a patched driver for this to work.
388 * @note Enabling the monitor mode is highly driver dependent and requires 388 * @note Enabling the monitor mode is highly driver dependent and requires
389 * the proper @ref OMonitoringInterface to be associated with the interface. 389 * the proper @ref OMonitoringInterface to be associated with the interface.
390 * @see OMonitoringInterface 390 * @see OMonitoringInterface
391 */ 391 */
392 virtual QString mode() const; 392 virtual QString mode() const;
393 /** 393 /**
394 * Set the channel hopping @a interval. An @a interval of 0 disables channel hopping. 394 * Set the channel hopping @a interval. An @a interval of 0 disables channel hopping.
395 * @see OChannelHopper 395 * @see OChannelHopper
396 */ 396 */
397 virtual void setChannelHopping( int interval = 0 ); 397 virtual void setChannelHopping( int interval = 0 );
398 /** 398 /**
399 * @returns the channel hopping interval or 0, if channel hopping is disabled. 399 * @returns the channel hopping interval or 0, if channel hopping is disabled.
400 */ 400 */
401 virtual int channelHopping() const; 401 virtual int channelHopping() const;
402 /** 402 /**
403 * @returns the @ref OChannelHopper of this interface or 0, if channel hopping has not been activated before 403 * @returns the @ref OChannelHopper of this interface or 0, if channel hopping has not been activated before
404 */ 404 */
405 virtual OChannelHopper* channelHopper() const; 405 virtual OChannelHopper* channelHopper() const;
406 /** 406 /**
407 * Set the station @a nickname. 407 * Set the station @a nickname.
408 */ 408 */
409 virtual void setNickName( const QString& nickname ); 409 virtual void setNickName( const QString& nickname );
410 /** 410 /**
411 * @returns the current station nickname. 411 * @returns the current station nickname.
412 */ 412 */
413 virtual QString nickName() const; 413 virtual QString nickName() const;
414 /** 414 /**
415 * Invoke the private IOCTL @a command with a @number of parameters on the network interface. 415 * Invoke the private IOCTL @a command with a @number of parameters on the network interface.
416 * @see OPrivateIOCTL 416 * @see OPrivateIOCTL
417 */ 417 */
418 virtual void setPrivate( const QString& command, int number, ... ); 418 virtual void setPrivate( const QString& command, int number, ... );
419 /** 419 /**
420 * @returns true if the interface is featuring the private IOCTL @command. 420 * @returns true if the interface is featuring the private IOCTL @command.
421 */ 421 */
422 virtual bool hasPrivate( const QString& command ); 422 virtual bool hasPrivate( const QString& command );
423 virtual void getPrivate( const QString& command ); //FIXME: Implement and document this 423 virtual void getPrivate( const QString& command ); //FIXME: Implement and document this
424 /** 424 /**
425 * @returns true if the interface is associated to an access point 425 * @returns true if the interface is associated to an access point
426 * @note: This information is only valid if the interface is in managed mode. 426 * @note: This information is only valid if the interface is in managed mode.
427 */ 427 */
428 virtual bool isAssociated() const; 428 virtual bool isAssociated() const;
429 /** 429 /**
430 * @returns the MAC address of the Access Point if the device is in infrastructure mode. 430 * @returns the MAC address of the Access Point if the device is in infrastructure mode.
431 * @returns a (more or less random) cell ID address if the device is in adhoc mode. 431 * @returns a (more or less random) cell ID address if the device is in adhoc mode.
432 */ 432 */
433 virtual OMacAddress associatedAP() const; 433 virtual OMacAddress associatedAP() const;
434 /** 434 /**
435 * Set the @a ssid (Service Set ID) string. This is used to decide 435 * Set the @a ssid (Service Set ID) string. This is used to decide
436 * which network to associate with (use "any" to let the driver decide). 436 * which network to associate with (use "any" to let the driver decide).
437 */ 437 */
438 virtual void setSSID( const QString& ssid ); 438 virtual void setSSID( const QString& ssid );
439 /** 439 /**
440 * @returns the current SSID (Service Set ID). 440 * @returns the current SSID (Service Set ID).
441 */ 441 */
442 virtual QString SSID() const; 442 virtual QString SSID() const;
443 /** 443 /**
444 * Perform scanning the wireless network neighbourhood. 444 * Perform scanning the wireless network neighbourhood.
445 * @note: UNSTABLE API - UNDER CONSTRUCTION - DON'T USE! 445 * @note: UNSTABLE API - UNDER CONSTRUCTION - DON'T USE!
446 */ 446 */
447 virtual OStationList* scanNetwork(); 447 virtual OStationList* scanNetwork();
448 /** 448 /**
449 * @return signal strength to associated neighbour (in percent). 449 * @return signal strength to associated neighbour (in percent).
450 * In infrastructure mode, this is the signal strength of the Access Point. 450 * In infrastructure mode, this is the signal strength of the Access Point.
451 * In other modes the result is driver dependent. 451 * In other modes the result is driver dependent.
452 */ 452 */
453 virtual int signalStrength() const; 453 virtual int signalStrength() const;
454 /** @internal commit pending changes to the driver 454 /**
455 * 455 * @returns the wireless extension version used by the interface driver.
456 **/
457 short wirelessExtensionDriverVersion() const;
458 /**
459 * @internal commit pending changes to the driver
456 */ 460 */
457 void commit() const; 461 void commit() const;
458 462
459 protected: 463 protected:
460 void buildInformation(); 464 void buildInformation();
461 void buildPrivateList(); 465 void buildPrivateList();
462 void dumpInformation() const; 466 void dumpInformation() const;
463 virtual void init(); 467 virtual void init();
464 struct iwreq& iwr() const; 468 struct iwreq& iwr() const;
465 bool wioctl( int call ) const; 469 bool wioctl( int call ) const;
466 bool wioctl( int call, struct iwreq& ) const; 470 bool wioctl( int call, struct iwreq& ) const;
467 471
468 protected: 472 protected:
469 mutable struct iwreq _iwr; 473 mutable struct iwreq _iwr;
470 QMap<int,int> _channels; 474 QMap<int,int> _channels;
471 struct iw_range _range; 475 struct iw_range _range;
472 476
473 private: 477 private:
474 OChannelHopper* _hopper; 478 OChannelHopper* _hopper;
475 class Private; 479 class Private;
476 Private *d; 480 Private *d;
477}; 481};
478 482
479 483
480/*====================================================================================== 484/*======================================================================================
481 * OMonitoringInterface 485 * OMonitoringInterface
482 *======================================================================================*/ 486 *======================================================================================*/
483 487
484 488
485class OMonitoringInterface 489class OMonitoringInterface
486{ 490{
487 public: 491 public:
488 OMonitoringInterface(); 492 OMonitoringInterface();
489 OMonitoringInterface( ONetworkInterface*, bool _prismHeader ); 493 OMonitoringInterface( ONetworkInterface*, bool _prismHeader );
490 virtual ~OMonitoringInterface(); 494 virtual ~OMonitoringInterface();
491 495
492 public: 496 public:
493 virtual void setEnabled( bool ); 497 virtual void setEnabled( bool );
494 virtual void setChannel( int ); 498 virtual void setChannel( int );
495 499
496 virtual QString name() const = 0; 500 virtual QString name() const = 0;
497 501
498 protected: 502 protected:
499 OWirelessNetworkInterface* _if; 503 OWirelessNetworkInterface* _if;
500 bool _prismHeader; 504 bool _prismHeader;
501 private: 505 private:
502 class Private; 506 class Private;
503 Private *d; 507 Private *d;
504 508
505}; 509};
506 510
507 511
508/*====================================================================================== 512/*======================================================================================
509 * OCiscoMonitoring 513 * OCiscoMonitoring
510 *======================================================================================*/ 514 *======================================================================================*/
511 515
512 516
513class OCiscoMonitoringInterface : public OMonitoringInterface 517class OCiscoMonitoringInterface : public OMonitoringInterface
514{ 518{
515 public: 519 public:
516 OCiscoMonitoringInterface( ONetworkInterface*, bool _prismHeader ); 520 OCiscoMonitoringInterface( ONetworkInterface*, bool _prismHeader );
517 virtual ~OCiscoMonitoringInterface(); 521 virtual ~OCiscoMonitoringInterface();
518 522
519 virtual void setEnabled( bool ); 523 virtual void setEnabled( bool );
520 virtual QString name() const; 524 virtual QString name() const;
521 virtual void setChannel( int ); 525 virtual void setChannel( int );
522 private: 526 private:
523 class Private; 527 class Private;
524 Private *d; 528 Private *d;
525 529
526}; 530};
527 531
528 532
529/*====================================================================================== 533/*======================================================================================
530 * OWlanNGMonitoringInterface 534 * OWlanNGMonitoringInterface
531 *======================================================================================*/ 535 *======================================================================================*/
532 536
533 537
534class OWlanNGMonitoringInterface : public OMonitoringInterface 538class OWlanNGMonitoringInterface : public OMonitoringInterface
535{ 539{
536 public: 540 public:
537 OWlanNGMonitoringInterface( ONetworkInterface*, bool _prismHeader ); 541 OWlanNGMonitoringInterface( ONetworkInterface*, bool _prismHeader );
538 virtual ~OWlanNGMonitoringInterface(); 542 virtual ~OWlanNGMonitoringInterface();
539 543
540 public: 544 public:
541 virtual void setEnabled( bool ); 545 virtual void setEnabled( bool );
542 virtual QString name() const; 546 virtual QString name() const;
543 virtual void setChannel( int ); 547 virtual void setChannel( int );
544 private: 548 private:
545 class Private; 549 class Private;
546 Private *d; 550 Private *d;
547 551
548}; 552};
549 553
550 554
551/*====================================================================================== 555/*======================================================================================
552 * OHostAPMonitoringInterface 556 * OHostAPMonitoringInterface
553 *======================================================================================*/ 557 *======================================================================================*/
554 558
555 559
556class OHostAPMonitoringInterface : public OMonitoringInterface 560class OHostAPMonitoringInterface : public OMonitoringInterface
557{ 561{
558 public: 562 public:
559 OHostAPMonitoringInterface( ONetworkInterface*, bool _prismHeader ); 563 OHostAPMonitoringInterface( ONetworkInterface*, bool _prismHeader );
560 virtual ~OHostAPMonitoringInterface(); 564 virtual ~OHostAPMonitoringInterface();
561 565
562 public: 566 public:
563 virtual void setEnabled( bool ); 567 virtual void setEnabled( bool );
564 virtual QString name() const; 568 virtual QString name() const;
565 569
566 private: 570 private:
567 class Private; 571 class Private;
568 Private *d; 572 Private *d;
569 }; 573 };
570 574
571 575
572/*====================================================================================== 576/*======================================================================================
573 * OOrinocoMonitoringInterface 577 * OOrinocoMonitoringInterface
574 *======================================================================================*/ 578 *======================================================================================*/
575 579
576 580
577class OOrinocoMonitoringInterface : public OMonitoringInterface 581class OOrinocoMonitoringInterface : public OMonitoringInterface
578{ 582{
579 public: 583 public:
580 OOrinocoMonitoringInterface( ONetworkInterface*, bool _prismHeader ); 584 OOrinocoMonitoringInterface( ONetworkInterface*, bool _prismHeader );
581 virtual ~OOrinocoMonitoringInterface(); 585 virtual ~OOrinocoMonitoringInterface();
582 586
583 public: 587 public:
584 virtual void setChannel( int ); 588 virtual void setChannel( int );
585 virtual void setEnabled( bool ); 589 virtual void setEnabled( bool );
586 virtual QString name() const; 590 virtual QString name() const;
587 591
588 private: 592 private:
589 class Private; 593 class Private;
590 Private *d; 594 Private *d;
591}; 595};
592 596
593} 597}
594} 598}
595 599
596#endif // ONETWORK_H 600#endif // ONETWORK_H
597 601
diff --git a/libopie2/opienet/opcap.cpp b/libopie2/opienet/opcap.cpp
index f8ebe6b..a9dc577 100644
--- a/libopie2/opienet/opcap.cpp
+++ b/libopie2/opienet/opcap.cpp
@@ -1,319 +1,319 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer <mickey@Vanille.de> 3              Copyright (C) 2003-2004 by Michael 'Mickey' Lauer <mickey@Vanille.de>
4 =. 4 =.
5 .=l. 5 .=l.
6           .>+-= 6           .>+-=
7 _;:,     .>    :=|. This program is free software; you can 7 _;:,     .>    :=|. This program is free software; you can
8.> <`_,   >  .   <= redistribute it and/or modify it under 8.> <`_,   >  .   <= redistribute it and/or modify it under
9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
10.="- .-=="i,     .._ License as published by the Free Software 10.="- .-=="i,     .._ License as published by the Free Software
11 - .   .-<_>     .<> Foundation; either version 2 of the License, 11 - .   .-<_>     .<> Foundation; either version 2 of the License,
12     ._= =}       : or (at your option) any later version. 12     ._= =}       : or (at your option) any later version.
13    .%`+i>       _;_. 13    .%`+i>       _;_.
14    .i_,=:_.      -<s. This program is distributed in the hope that 14    .i_,=:_.      -<s. This program is distributed in the hope that
15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
16    : ..    .:,     . . . without even the implied warranty of 16    : ..    .:,     . . . without even the implied warranty of
17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.=       =       ; Library General Public License for more 19..}^=.=       =       ; Library General Public License for more
20++=   -.     .`     .: details. 20++=   -.     .`     .: details.
21 :     =  ...= . :.=- 21 :     =  ...= . :.=-
22 -.   .:....=;==+<; You should have received a copy of the GNU 22 -.   .:....=;==+<; You should have received a copy of the GNU
23  -_. . .   )=.  = Library General Public License along with 23  -_. . .   )=.  = Library General Public License along with
24    --        :-=` this library; see the file COPYING.LIB. 24    --        :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28 28
29*/ 29*/
30 30
31#include "udp_ports.h" 31#include "udp_ports.h"
32#include "opcap.h" 32#include "opcap.h"
33 33
34/* OPIE */ 34/* OPIE */
35#include <opie2/odebug.h> 35#include <opie2/odebug.h>
36using namespace Opie::Core; 36using namespace Opie::Core;
37 37
38/* QT */ 38/* QT */
39#include <qapplication.h> // don't use oapplication here (will decrease reusability in other projects) 39#include <qapplication.h> // don't use oapplication here (will decrease reusability in other projects)
40#include <qsocketnotifier.h> 40#include <qsocketnotifier.h>
41#include <qobjectlist.h> 41#include <qobjectlist.h>
42 42
43/* STD */ 43/* STD */
44#include <sys/time.h> 44#include <sys/time.h>
45#include <sys/types.h> 45#include <sys/types.h>
46#include <assert.h> 46#include <assert.h>
47#include <unistd.h> 47#include <unistd.h>
48#include <string.h> 48#include <string.h>
49 49
50namespace Opie { 50namespace Opie {
51namespace Net { 51namespace Net {
52 52
53/*====================================================================================== 53/*======================================================================================
54 * OPacket 54 * OPacket
55 *======================================================================================*/ 55 *======================================================================================*/
56 56
57OPacket::OPacket( int datalink, packetheaderstruct header, const unsigned char* data, QObject* parent ) 57OPacket::OPacket( int datalink, packetheaderstruct header, const unsigned char* data, QObject* parent )
58 :QObject( parent, "Generic" ), _hdr( header ), _data( 0 ) 58 :QObject( parent, "Generic" ), _hdr( header ), _data( 0 )
59{ 59{
60 60
61 _data = new unsigned char[sizeof data]; 61 _data = new unsigned char[ header.len ];
62 assert( _data ); 62 assert( _data );
63 memcpy( const_cast<unsigned char*>(_data), data, sizeof data ); 63 memcpy( const_cast<unsigned char*>(_data), data, header.len );
64 // We have to copy the data structure here, because the 'data' pointer handed by libpcap 64 // We have to copy the data structure here, because the 'data' pointer handed by libpcap
65 // points to an internal region which is reused by lipcap. 65 // points to an internal region which is reused by lipcap.
66 odebug << "OPacket: Length = " << header.len << ", Caplen = " << header.caplen << oendl; 66 odebug << "OPacket: Length = " << header.len << ", Caplen = " << header.caplen << oendl;
67 _end = (unsigned char*) _data + header.len; 67 _end = (unsigned char*) _data + header.len;
68 68
69 switch ( datalink ) 69 switch ( datalink )
70 { 70 {
71 case DLT_EN10MB: 71 case DLT_EN10MB:
72 odebug << "OPacket::OPacket(): Received Packet. Datalink = ETHERNET" << oendl; 72 odebug << "OPacket::OPacket(): Received Packet. Datalink = ETHERNET" << oendl;
73 new OEthernetPacket( _end, (const struct ether_header*) _data, this ); 73 new OEthernetPacket( _end, (const struct ether_header*) _data, this );
74 break; 74 break;
75 75
76 case DLT_IEEE802_11: 76 case DLT_IEEE802_11:
77 odebug << "OPacket::OPacket(): Received Packet. Datalink = IEEE802.11" << oendl; 77 odebug << "OPacket::OPacket(): Received Packet. Datalink = IEEE802.11" << oendl;
78 new OWaveLanPacket( _end, (const struct ieee_802_11_header*) _data, this ); 78 new OWaveLanPacket( _end, (const struct ieee_802_11_header*) _data, this );
79 break; 79 break;
80 80
81 case DLT_PRISM_HEADER: 81 case DLT_PRISM_HEADER:
82 odebug << "OPacket::OPacket(): Received Packet. Datalink = PRISM_HEADER" << oendl; 82 odebug << "OPacket::OPacket(): Received Packet. Datalink = PRISM_HEADER" << oendl;
83 new OPrismHeaderPacket( _end, (const struct prism_hdr*) (unsigned char*) _data, this ); 83 new OPrismHeaderPacket( _end, (const struct prism_hdr*) (unsigned char*) _data, this );
84 break; 84 break;
85 85
86 default: 86 default:
87 owarn << "OPacket::OPacket(): Received Packet over unsupported datalink, type " << datalink << "!" << oendl; 87 owarn << "OPacket::OPacket(): Received Packet over unsupported datalink, type " << datalink << "!" << oendl;
88 } 88 }
89} 89}
90 90
91 91
92OPacket::~OPacket() 92OPacket::~OPacket()
93{ 93{
94 odebug << "~OPacket( " << name() << " )" << oendl; 94 odebug << "~OPacket( " << name() << " )" << oendl;
95 delete _data; 95 delete _data;
96} 96}
97 97
98 98
99timevalstruct OPacket::timeval() const 99timevalstruct OPacket::timeval() const
100{ 100{
101 return _hdr.ts; 101 return _hdr.ts;
102} 102}
103 103
104 104
105int OPacket::caplen() const 105int OPacket::caplen() const
106{ 106{
107 return _hdr.caplen; 107 return _hdr.caplen;
108} 108}
109 109
110 110
111void OPacket::updateStats( QMap<QString,int>& stats, QObjectList* l ) 111void OPacket::updateStats( QMap<QString,int>& stats, QObjectList* l )
112{ 112{
113 if (!l) return; 113 if (!l) return;
114 QObject* o = l->first(); 114 QObject* o = l->first();
115 while ( o ) 115 while ( o )
116 { 116 {
117 stats[o->name()]++; 117 stats[o->name()]++;
118 updateStats( stats, const_cast<QObjectList*>( o->children() ) ); 118 updateStats( stats, const_cast<QObjectList*>( o->children() ) );
119 o = l->next(); 119 o = l->next();
120 } 120 }
121} 121}
122 122
123 123
124QString OPacket::dumpStructure() const 124QString OPacket::dumpStructure() const
125{ 125{
126 return "[ |" + _dumpStructure( const_cast<QObjectList*>( this->children() ) ) + " ]"; 126 return "[ |" + _dumpStructure( const_cast<QObjectList*>( this->children() ) ) + " ]";
127} 127}
128 128
129 129
130QString OPacket::_dumpStructure( QObjectList* l ) const 130QString OPacket::_dumpStructure( QObjectList* l ) const
131{ 131{
132 if (!l) return QString::null; 132 if (!l) return QString::null;
133 QObject* o = l->first(); 133 QObject* o = l->first();
134 QString str(" "); 134 QString str(" ");
135 135
136 while ( o ) 136 while ( o )
137 { 137 {
138 str.append( o->name() ); 138 str.append( o->name() );
139 str.append( " |" ); 139 str.append( " |" );
140 str += _dumpStructure( const_cast<QObjectList*>( o->children() ) ); 140 str += _dumpStructure( const_cast<QObjectList*>( o->children() ) );
141 o = l->next(); 141 o = l->next();
142 } 142 }
143 return str; 143 return str;
144} 144}
145 145
146QString OPacket::dump( int bpl ) const 146QString OPacket::dump( int bpl ) const
147{ 147{
148 static int index = 0; 148 static int index = 0;
149 index++; 149 index++;
150 int len = _hdr.caplen; 150 int len = _hdr.caplen;
151 QString str; 151 QString str;
152 str.sprintf( "\n<----- Packet #%04d Len = 0x%X (%d) ----->\n\n", index, len, len ); 152 str.sprintf( "\n<----- Packet #%04d Len = 0x%X (%d) ----->\n\n", index, len, len );
153 str.append( "0000: " ); 153 str.append( "0000: " );
154 QString tmp; 154 QString tmp;
155 QString bytes; 155 QString bytes;
156 QString chars; 156 QString chars;
157 157
158 for ( int i = 0; i < len; ++i ) 158 for ( int i = 0; i < len; ++i )
159 { 159 {
160 tmp.sprintf( "%02X ", _data[i] ); bytes.append( tmp ); 160 tmp.sprintf( "%02X ", _data[i] ); bytes.append( tmp );
161 if ( (_data[i] > 31) && (_data[i]<128) ) chars.append( _data[i] ); 161 if ( (_data[i] > 31) && (_data[i]<128) ) chars.append( _data[i] );
162 else chars.append( '.' ); 162 else chars.append( '.' );
163 163
164 if ( !((i+1) % bpl) ) 164 if ( !((i+1) % bpl) )
165 { 165 {
166 str.append( bytes ); 166 str.append( bytes );
167 str.append( ' ' ); 167 str.append( ' ' );
168 str.append( chars ); 168 str.append( chars );
169 str.append( '\n' ); 169 str.append( '\n' );
170 tmp.sprintf( "%04X: ", i+1 ); str.append( tmp ); 170 tmp.sprintf( "%04X: ", i+1 ); str.append( tmp );
171 bytes = ""; 171 bytes = "";
172 chars = ""; 172 chars = "";
173 } 173 }
174 174
175 } 175 }
176 if ( (len % bpl) ) 176 if ( (len % bpl) )
177 { 177 {
178 str.append( bytes.leftJustify( 1 + 3*bpl ) ); 178 str.append( bytes.leftJustify( 1 + 3*bpl ) );
179 str.append( chars ); 179 str.append( chars );
180 } 180 }
181 str.append( '\n' ); 181 str.append( '\n' );
182 return str; 182 return str;
183} 183}
184 184
185 185
186int OPacket::len() const 186int OPacket::len() const
187{ 187{
188 return _hdr.len; 188 return _hdr.len;
189} 189}
190 190
191 191
192QTextStream& operator<<( QTextStream& s, const OPacket& p ) 192QTextStream& operator<<( QTextStream& s, const OPacket& p )
193{ 193{
194 s << p.dumpStructure(); 194 s << p.dumpStructure();
195} 195}
196 196
197 197
198/*====================================================================================== 198/*======================================================================================
199 * OEthernetPacket 199 * OEthernetPacket
200 *======================================================================================*/ 200 *======================================================================================*/
201 201
202OEthernetPacket::OEthernetPacket( const unsigned char* end, const struct ether_header* data, QObject* parent ) 202OEthernetPacket::OEthernetPacket( const unsigned char* end, const struct ether_header* data, QObject* parent )
203 :QObject( parent, "Ethernet" ), _ether( data ) 203 :QObject( parent, "Ethernet" ), _ether( data )
204{ 204{
205 205
206 odebug << "Source = " << sourceAddress().toString(); 206 odebug << "Source = " << sourceAddress().toString();
207 odebug << "Destination = " << destinationAddress().toString(); 207 odebug << "Destination = " << destinationAddress().toString();
208 208
209 if ( sourceAddress() == OMacAddress::broadcast ) 209 if ( sourceAddress() == OMacAddress::broadcast )
210 odebug << "Source is broadcast address" << oendl; 210 odebug << "Source is broadcast address" << oendl;
211 if ( destinationAddress() == OMacAddress::broadcast ) 211 if ( destinationAddress() == OMacAddress::broadcast )
212 odebug << "Destination is broadcast address" << oendl; 212 odebug << "Destination is broadcast address" << oendl;
213 213
214 switch ( type() ) 214 switch ( type() )
215 { 215 {
216 case ETHERTYPE_IP: new OIPPacket( end, (const struct iphdr*) (data+1), this ); break; 216 case ETHERTYPE_IP: new OIPPacket( end, (const struct iphdr*) (data+1), this ); break;
217 case ETHERTYPE_ARP: new OARPPacket( end, (const struct myarphdr*) (data+1), this ); break; 217 case ETHERTYPE_ARP: new OARPPacket( end, (const struct myarphdr*) (data+1), this ); break;
218 case ETHERTYPE_REVARP: { odebug << "OPacket::OPacket(): Received Ethernet Packet : Type = RARP" << oendl; break; } 218 case ETHERTYPE_REVARP: { odebug << "OPacket::OPacket(): Received Ethernet Packet : Type = RARP" << oendl; break; }
219 default: odebug << "OPacket::OPacket(): Received Ethernet Packet : Type = UNKNOWN" << oendl; 219 default: odebug << "OPacket::OPacket(): Received Ethernet Packet : Type = UNKNOWN" << oendl;
220 } 220 }
221 221
222} 222}
223 223
224 224
225OEthernetPacket::~OEthernetPacket() 225OEthernetPacket::~OEthernetPacket()
226{ 226{
227} 227}
228 228
229 229
230OMacAddress OEthernetPacket::sourceAddress() const 230OMacAddress OEthernetPacket::sourceAddress() const
231{ 231{
232 return OMacAddress( _ether->ether_shost ); 232 return OMacAddress( _ether->ether_shost );
233} 233}
234 234
235 235
236OMacAddress OEthernetPacket::destinationAddress() const 236OMacAddress OEthernetPacket::destinationAddress() const
237{ 237{
238 return OMacAddress( _ether->ether_dhost ); 238 return OMacAddress( _ether->ether_dhost );
239} 239}
240 240
241int OEthernetPacket::type() const 241int OEthernetPacket::type() const
242{ 242{
243 return ntohs( _ether->ether_type ); 243 return ntohs( _ether->ether_type );
244} 244}
245 245
246 246
247/*====================================================================================== 247/*======================================================================================
248 * OIPPacket 248 * OIPPacket
249 *======================================================================================*/ 249 *======================================================================================*/
250 250
251 251
252OIPPacket::OIPPacket( const unsigned char* end, const struct iphdr* data, QObject* parent ) 252OIPPacket::OIPPacket( const unsigned char* end, const struct iphdr* data, QObject* parent )
253 :QObject( parent, "IP" ), _iphdr( data ) 253 :QObject( parent, "IP" ), _iphdr( data )
254{ 254{
255 odebug << "OIPPacket::OIPPacket(): decoding IP header..." << oendl; 255 odebug << "OIPPacket::OIPPacket(): decoding IP header..." << oendl;
256 256
257 odebug << "FromAddress = " << fromIPAddress().toString() << oendl; 257 odebug << "FromAddress = " << fromIPAddress().toString() << oendl;
258 odebug << " toAddress = " << toIPAddress().toString() << oendl; 258 odebug << " toAddress = " << toIPAddress().toString() << oendl;
259 259
260 switch ( protocol() ) 260 switch ( protocol() )
261 { 261 {
262 case IPPROTO_UDP: new OUDPPacket( end, (const struct udphdr*) (data+1), this ); break; 262 case IPPROTO_UDP: new OUDPPacket( end, (const struct udphdr*) (data+1), this ); break;
263 case IPPROTO_TCP: new OTCPPacket( end, (const struct tcphdr*) (data+1), this ); break; 263 case IPPROTO_TCP: new OTCPPacket( end, (const struct tcphdr*) (data+1), this ); break;
264 default: odebug << "OIPPacket::OIPPacket(): unknown IP protocol, type = " << protocol() << oendl; 264 default: odebug << "OIPPacket::OIPPacket(): unknown IP protocol, type = " << protocol() << oendl;
265 } 265 }
266 266
267} 267}
268 268
269OIPPacket::~OIPPacket() 269OIPPacket::~OIPPacket()
270{ 270{
271} 271}
272 272
273 273
274QHostAddress OIPPacket::fromIPAddress() const 274QHostAddress OIPPacket::fromIPAddress() const
275{ 275{
276 return EXTRACT_32BITS( &_iphdr->saddr ); 276 return EXTRACT_32BITS( &_iphdr->saddr );
277} 277}
278 278
279 279
280QHostAddress OIPPacket::toIPAddress() const 280QHostAddress OIPPacket::toIPAddress() const
281{ 281{
282 return EXTRACT_32BITS( &_iphdr->saddr ); 282 return EXTRACT_32BITS( &_iphdr->saddr );
283} 283}
284 284
285 285
286int OIPPacket::tos() const 286int OIPPacket::tos() const
287{ 287{
288 return _iphdr->tos; 288 return _iphdr->tos;
289} 289}
290 290
291 291
292int OIPPacket::len() const 292int OIPPacket::len() const
293{ 293{
294 return EXTRACT_16BITS( &_iphdr->tot_len ); 294 return EXTRACT_16BITS( &_iphdr->tot_len );
295} 295}
296 296
297 297
298int OIPPacket::id() const 298int OIPPacket::id() const
299{ 299{
300 return EXTRACT_16BITS( &_iphdr->id ); 300 return EXTRACT_16BITS( &_iphdr->id );
301} 301}
302 302
303 303
304int OIPPacket::offset() const 304int OIPPacket::offset() const
305{ 305{
306 return EXTRACT_16BITS( &_iphdr->frag_off ); 306 return EXTRACT_16BITS( &_iphdr->frag_off );
307} 307}
308 308
309 309
310int OIPPacket::ttl() const 310int OIPPacket::ttl() const
311{ 311{
312 return _iphdr->ttl; 312 return _iphdr->ttl;
313} 313}
314 314
315 315
316int OIPPacket::protocol() const 316int OIPPacket::protocol() const
317{ 317{
318 return _iphdr->protocol; 318 return _iphdr->protocol;
319} 319}