Hi,

I get a totally bogus output with -e and -X flags set on a wlan0
interface in monitor mode.  I have spent a lot of time looking into this
and I have finally figured out what I needed to do here.  Last I'll
paste my patch, it's easy.  I know it isn't via github but I don't have
a github login and can't even write an issue wihtout having logged in,
so I resorted to this sane historical way.

I want to show you the outputs of tcpdump with the -e flag (which is now
correct):

root@epsilon:/home/pi/tcpdump/tcpdump-4.9.2# ./tcpdump -X -e  -c 1  -n
-s 100 -i
 wlan0 -l  'ether[10] == 0x18 and ether[2] == 0x0 and ether[3] ==
0x0'         
tcpdump: verbose output suppressed, use -v or -vv for full protocol
decode     
listening on wlan0, link-type IEEE802_11_RADIO (802.11 plus radiotap
header), ca
pture size 100
bytes                                                           
21:57:51.598450 1.0 Mb/s 2472 MHz 11b -58dBm signal antenna 0
BSSID:18:d6:c7:51:
55:86 DA:ff:ff:ff:ff:ff:ff SA:18:d6:c7:51:55:86 Beacon () [1.0* 2.0 5.5
11.0 6.0
 9.0 12.0 18.0 Mbit] IBSS CH:
13[|802.11]                                      
        0x0000:  8000 0000 ffff ffff ffff 18d6 c751 5586 
.............QU.     
        0x0010:  18d6 c751 5586 c0fa 8061 bb4b 0200 0000 
...QU....a.K....    
        0x0020:  6400 0000 0000 0108 8204 0b16 0c12 1824  d..............$
        0x0030:  0301 0d05 0401 0200 0032 0430 4860 6c2d  .........2.0H`l-
        0x0040:  1aee 111b ffff ff00 0000                 ..........
1 packet captured
1 packet received by filter
0 packets dropped by kernel

and without the -e flag (which is probably everythign after the wlan
header):

root@epsilon:/home/pi/tcpdump/tcpdump-4.9.2# ./tcpdump -X  -c 1  -n -s
100 -i wl
an0 -l  'ether[10] == 0x18 and ether[2] == 0x0 and ether[3] ==
0x0'            
tcpdump: verbose output suppressed, use -v or -vv for full protocol
decode     
listening on wlan0, link-type IEEE802_11_RADIO (802.11 plus radiotap
header), ca
pture size 100
bytes                                                           
21:58:05.627380 1.0 Mb/s 2472 MHz 11b -58dBm signal antenna 0 Beacon ()
[1.0* 2.
0 5.5 11.0 6.0 9.0 12.0 18.0 Mbit] IBSS CH:
13[|802.11]                        
        0x0000:  8071 914c 0200 0000 6400 0000 0000 0108 
.q.L....d.......     
        0x0010:  8204 0b16 0c12 1824 0301 0d05 0400 0200 
.......$........    
        0x0020:  0032 0430 4860 6c2d 1aee 111b ffff ff00  .2.0H`l-........
        0x0030:  0000                                     ..             
1 packet captured                                                  
2 packets received by filter
0 packets dropped by kernel

Lastly as indicated here is my small patch:

--- print-802_11.c.old  2018-04-04 19:40:56.458530097
+0200                   
+++ print-802_11.c      2018-04-04 21:44:15.494773874
+0200                   
@@ -3349,7 +3360,18 @@
 ieee802_11_radio_if_print(netdissect_options
*ndo,                           
                           const struct pcap_pkthdr *h, const u_char
*p)      
 {
-       return ieee802_11_radio_print(ndo, p, h->len,
h->caplen);             
+       const struct ieee80211_radiotap_header
*hdr;                          
+       u_int hdrlen, len;
+
+        hdr = (const struct ieee80211_radiotap_header
*)p;                   
+        len =
EXTRACT_LE_16BITS(&hdr->it_len);                               
+
+       hdrlen = ieee802_11_radio_print(ndo, p, h->len,
h->caplen);           
+       if (ndo->ndo_eflag && hdrlen > len)
{                                 
+               return len;
+       }
+
+       return hdrlen;
 }

 /*


Regards,

-peter

_______________________________________________
tcpdump-workers mailing list
tcpdump-workers@lists.tcpdump.org
https://lists.sandelman.ca/mailman/listinfo/tcpdump-workers

Reply via email to