summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc9
1 files changed, 7 insertions, 2 deletions
diff --git a/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc b/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc
index 626b28c..e5a20d6 100644
--- a/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc
+++ b/noncore/net/wellenreiter/libwellenreiter/source/cardmode.cc
@@ -34,64 +34,69 @@ int card_into_monitormode (pcap_t **orighandle, const char *device, int cardtype
34 /* bring the sniffer into rfmon mode */ 34 /* bring the sniffer into rfmon mode */
35 snprintf(CiscoRFMON, sizeof(CiscoRFMON) - 1, DEFAULT_PATH, device); 35 snprintf(CiscoRFMON, sizeof(CiscoRFMON) - 1, DEFAULT_PATH, device);
36 if((CISCO_CONFIG_FILE = fopen(CiscoRFMON,"w")) == NULL) 36 if((CISCO_CONFIG_FILE = fopen(CiscoRFMON,"w")) == NULL)
37 { 37 {
38 wl_logerr("Cannot open config file: %s", strerror(errno)); 38 wl_logerr("Cannot open config file: %s", strerror(errno));
39 return 0; 39 return 0;
40 } 40 }
41 fputs ("Mode: r",CISCO_CONFIG_FILE); 41 fputs ("Mode: r",CISCO_CONFIG_FILE);
42 fputs ("Mode: y",CISCO_CONFIG_FILE); 42 fputs ("Mode: y",CISCO_CONFIG_FILE);
43 fputs ("XmitPower: 1",CISCO_CONFIG_FILE); 43 fputs ("XmitPower: 1",CISCO_CONFIG_FILE);
44 fclose(CISCO_CONFIG_FILE); 44 fclose(CISCO_CONFIG_FILE);
45 } 45 }
46 else if (cardtype == CARD_TYPE_NG) 46 else if (cardtype == CARD_TYPE_NG)
47 { 47 {
48 char wlanngcmd[80]; 48 char wlanngcmd[80];
49 snprintf(wlanngcmd, sizeof(wlanngcmd) - 1, "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=true", device, 1); 49 snprintf(wlanngcmd, sizeof(wlanngcmd) - 1, "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=true", device, 1);
50 if (system(wlanngcmd) != 0) 50 if (system(wlanngcmd) != 0)
51 { 51 {
52 wl_logerr("Could not set %s in raw mode, check cardtype", device); 52 wl_logerr("Could not set %s in raw mode, check cardtype", device);
53 return 0; 53 return 0;
54 } 54 }
55 } 55 }
56 else if (cardtype == CARD_TYPE_HOSTAP) 56 else if (cardtype == CARD_TYPE_HOSTAP)
57 { 57 {
58 int skfd; 58#if WIRELESS_EXT < 14
59 skfd = socket(AF_INET, SOCK_STREAM, 0); 59 int skfd;
60 skfd = socket(AF_INET, SOCK_STREAM, 0);
60 struct iwreq wrq; 61 struct iwreq wrq;
61 wrq.u.mode = IW_MODE_MONITOR; 62 wrq.u.mode = IW_MODE_MONITOR;
62 63
63 if(iw_set_ext(skfd,(char *) device,SIOCSIWMODE,&wrq)<0) 64 if(iw_set_ext(skfd,(char *) device,SIOCSIWMODE,&wrq)<0)
64 { 65 {
65 wl_logerr("Could not set hostap card %s to raw mode, check cardtype", device); 66 wl_logerr("Could not set hostap card %s to raw mode, check cardtype", device);
66 return 0; 67 return 0;
67 } 68 }
68 else 69 else
69 { 70 {
70 wl_loginfo("Successfully set hostap card %s into raw mode",device); 71 wl_loginfo("Successfully set hostap card %s into raw mode",device);
71 return 1; 72 return 1;
72 } 73 }
73 return 1; 74 return 1;
75#else
76#warning Hi _MAX_, please use a system call for hostap with wireless extensions < 14
77 // TODO: Implement switching HOSTAP into monitor mode with system call
78#endif
74 } 79 }
75 else if (cardtype == CARD_TYPE_ORINOCCO ) 80 else if (cardtype == CARD_TYPE_ORINOCCO )
76 { 81 {
77 if (!card_set_channel (device, 1, CARD_TYPE_ORINOCCO)) 82 if (!card_set_channel (device, 1, CARD_TYPE_ORINOCCO))
78 { 83 {
79 wl_logerr("Could not set %s in raw mode, check cardtype", device); 84 wl_logerr("Could not set %s in raw mode, check cardtype", device);
80 return 0; 85 return 0;
81 } 86 }
82 else 87 else
83 { 88 {
84 wl_loginfo("Successfully set %s into raw mode",device); 89 wl_loginfo("Successfully set %s into raw mode",device);
85 } 90 }
86 } 91 }
87 92
88 /* Setting the promiscous and up flag to the interface */ 93 /* Setting the promiscous and up flag to the interface */
89 if (!card_check_rfmon_datalink(device)) 94 if (!card_check_rfmon_datalink(device))
90 { 95 {
91 wl_logerr("Cannot set interface to rfmon mode"); 96 wl_logerr("Cannot set interface to rfmon mode");
92 return 0; 97 return 0;
93 } 98 }
94 else 99 else
95 { 100 {
96 wl_loginfo("Interface set to rfmon mode"); 101 wl_loginfo("Interface set to rfmon mode");
97 } 102 }