*/
#include "parse.h"
-//#include "802.11b.h"
#include "main.h"
/* all the parsing stuff will go here
t_info *info;
int i;
t_sta new_sta;
+ t_frame4_hdr *f4hdr;
+ t_frame3_hdr *f3hdr;
+ t_frame2_hdr *f2hdr;
+ t_frame1_hdr *f1hdr;
+ t_beacon_fb *beacon_fb;
int ret;
info=(t_info *)ptr;
info->count++;
+ memset(&new_sta,0,sizeof(t_sta));
+
if(info->dump_fd!=0) {
ret=write(info->dump_fd,pcap_header,sizeof(struct pcap_pkthdr));
if(ret!=sizeof(struct pcap_pkthdr))
/* maybe there is offset to the actual ieee802.11 frame,
for example prism header ... */
- /* debug log */
- dprintf(info->log_fd,"new package -> %02x/n",package[0]);
+ if(FCTL_TYPE(package[0])==FCTL_TYPE_MGMT) {
+ info->count_m++;
+ if(FCTL_STYPE(package[0])==FCTL_STYPE_BEACON) {
+ f3hdr=(t_frame3_hdr *)package;
+ beacon_fb=(t_beacon_fb *)(package+sizeof(t_frame3_hdr));
+ // new_sta.
+ /* debug output */
+ dprintf(info->log_fd,"beacon: ");
+ for(i=0;i<ADDR_LEN;i++) dprintf(info->log_fd,"%02x ",*((f3hdr->addr2)+i));
+ dprintf(info->log_fd," essid: (len=%x) ",beacon_fb->ssid_length);
+ for(i=0;i<beacon_fb->ssid_length;i++)
+ dprintf(info->log_fd,"%c ",*(u8 *)(beacon_fb->ssid+i));
+ dprintf(info->log_fd,"\n");
+ }
+ }
+ else if(FCTL_TYPE(package[0])==FCTL_TYPE_CTRL) {
+ info->count_c++;
+ }
+ else if(FCTL_TYPE(package[0])==FCTL_TYPE_DATA) {
+ info->count_d++;
+ }
- /* go on parsing frame ctl header here ... */
+ display_console(info,"");
}