Diffstat (limited to 'noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc') (more/less context) (ignore whitespace changes)
-rw-r--r-- | noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc b/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc index d868438..697d182 100644 --- a/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc +++ b/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc @@ -64,6 +64,16 @@ int card_into_monitormode (pcap_t **orighandle, char *device, int cardtype) return 0; } } + else if (cardtype == CARD_TYPE_ORINOCCO) + { + char lucentcmd[62]; + snprintf(lucentcmd, sizeof(lucentcmd) - 1, "$(which iwpriv) %s monitor 2 %d", device, 1); + if (system(lucentcmd) != 0) + { + wl_logerr("Could not set %s in raw mode, check cardtype", device); + return 0; + } + } /* Setting the promiscous and up flag to the interface */ if (!card_check_rfmon_datalink(device)) @@ -142,3 +152,36 @@ int card_set_promisc_up (const char *device) return 0; } } + +/* Set channel (Wireless frequency) of the device */ +int card_set_channel (const char *device, int channel, int cardtype) +{ + + if (cardtype == CARD_TYPE_CISCO) + { + /* Cisco cards don't need channelswitching */ + return 1; + } + /* If it is a lucent orinocco card */ + else if (cardtype == CARD_TYPE_ORINOCCO) + { + char lucentreset[63]; + char lucentcmd[62]; + snprintf(lucentreset, sizeof(lucentreset) -1,"$(which iwpriv) %s card_reset", device); + if (system(lucentreset) != 0) + { + wl_logerr("Could not reset the card %s",device); + return 0; + } + snprintf(lucentcmd, sizeof(lucentcmd) - 1, "$(which iwpriv) %s monitor 2 %d", device, channel); + if (system(lucentcmd) != 0) + { + wl_logerr("Could not set %s in raw mode, check cardtype", device); + return 0; + } + } + + /* For undefined situations */ + return 0; +} + |