author | max <max> | 2003-02-12 01:05:29 (UTC) |
---|---|---|
committer | max <max> | 2003-02-12 01:05:29 (UTC) |
commit | 8072f9767faaf606c5bb0c6dd936ff895a9d189c (patch) (side-by-side diff) | |
tree | 7861b276122d12d94c814c808b7352b85ac10fcb | |
parent | c7fe028f53eb676c9ce619840c0d0a4603a9301f (diff) | |
download | opie-8072f9767faaf606c5bb0c6dd936ff895a9d189c.zip opie-8072f9767faaf606c5bb0c6dd936ff895a9d189c.tar.gz opie-8072f9767faaf606c5bb0c6dd936ff895a9d189c.tar.bz2 |
MAXCHANNEL dynamic detection
-rw-r--r-- | noncore/net/wellenreiter/daemon/source/daemon.cc | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/noncore/net/wellenreiter/daemon/source/daemon.cc b/noncore/net/wellenreiter/daemon/source/daemon.cc index 46a50ed..d77d987 100644 --- a/noncore/net/wellenreiter/daemon/source/daemon.cc +++ b/noncore/net/wellenreiter/daemon/source/daemon.cc @@ -137,57 +137,66 @@ int main(int argc, char **argv) if(FD_ISSET(pcap_fileno(handletopcap), &rset)) { /* Grab one single packet */ packet = pcap_next(handletopcap, &header); /* process the packet */ process_packets(&header,*&packet, GUIADDR, GUIPORT); } } /* while(1) */ close(sock); exit(EXIT_SUCCESS); } void usage(void) { fprintf(stderr, "Usage: wellenreiter <device> <cardtype>\n" \ "\t<device> = Wirelessdevice (e.g. wlan0)\n" \ "\t<cardtype> = Cardtype:\tCisco\t= 1\n" \ "\t\t\t\tNG\t= 2\n" \ "\t\t\t\tHOSTAP\t= 3\n" \ "\t\t\t\tLUCENT\t= 4\n"); exit(EXIT_FAILURE); } void * channel_switcher(void *cardtypeptr) { wl_cardtype_t *cardtype; + int maxchan=0; int channel=1; - /* Get card info struct */ cardtype = (wl_cardtype_t *)cardtypeptr; - + /* Get from the wireless extension the amount of available channels + this prevents a fail in switching on us cards */ + maxchan = card_detect_channels(cardtype->iface); + + if (maxchan < MAXCHANNEL) + { + #undef MAXCHANNEL + #define MAXCHANNEL maxchan + } + while(1) { /* If channel bigger than maxchannel, set to 1 */ if(channel > MAXCHANNEL) channel=1; /* Set channel */ if(!card_set_channel(cardtype->iface, channel, cardtype->type)) { wl_logerr("Cannot set channel, thread exiting"); pthread_exit(NULL); } /* sleep */ usleep(CHANINTERVAL); channel++; } /* while */ } |