Skip to content

Latest commit

 

History

History
70 lines (49 loc) · 3.58 KB

README.md

File metadata and controls

70 lines (49 loc) · 3.58 KB

Introduction

ML2T is a multi-layer tracing tool to analyse data exchange (unidirectional TCP connexion) over a 60GHz mmWave link at both the TCP and MAC layer on the same graph.

Requirement

Our tool requires a valid capture file which can produced using tcpdump. Monitor mode is required to capture data.

The capture file should start with a TCP data segment, excluding TCP handshake segments (i.e. syn, syn-ack, ack) This can be done by using wireshark build-in filtering:

  • For example, if the starting TCP segment is captured at t = 49.1 seconds, frame.time_relative >= 49.1 extracts all the trafic starting t= 49.1 s.
  • Use file -> Export specified Packets ... to save the resulting filtered trafic to a new file.

Usage

The capture.pcap given in this repository is an example of a partial capture obtained using TP-Link Talon AD6200.

Use ./extract xxxxx.pcap to extract necessary information from your pcap file.

For plotting:

  • python plot.py --h
  • python plot.py --encap-segs or --s to plot mac frames and their associated block ack that encapsulate TCP segments
  • or python plot.py --encap-acks or --a to plot mac frames and their associated block ack that encapsulate TCP acks

The following variables in plot.py can be used to shift the TCP or MAC traffic in order to have one close to the other:

  • tcp_shift
  • mac_shift
  • mac_scale

Folder's description

ML2T take as an input a pre-processed tcpdump capture (.pcap) to produces a set of data which can be used -- e.g. using python -- to create a Time/Sequence plot.

Files and folders relevent to how ML2T works are described bellow:

  • ./tcp_sender: Contains two capture files, one for block acks frames and the other one for packets sent by the TCP sender. The string version of each pcap files is also given

  • ./tcp_receiver: Contains two capture files, one for block acks frames and the other one for packets sent by the TCP receiver. The string version of each pcap files is also given

  • ./sequences: Contains MAC sequence numbers of all data frames sent by both the sender and receiver (frame_tcpxxx.seq), MAC sequence numbers and the content of the bitmap of block acks sent by both TCP sender and receiver (back_tcpxxx.seq) and finally the TCP sequence numbers of TCP sender segments (seg_tcpsnd.seq) and TCP receiver acks (ack_tcprcv.seq)

  • ./extractors: a set of scripts that use the string version of the captures in ./tcp_sender and ./tcp_receiver to extract sequences at the MAC and TCP layer and store them in the ./sequence folder

Limitations

For now, only uniderectional TCP traffic is supported since a biderectionnal trafic is messy to visualize on the same graph. In case the captured TCP trafic is bidirectionnal, one could extract 2 unidirectional trafics, one in each direction, using wireshark build-in regex then apply our tool.

By default only IEEE 802.11ad strafic is supported. This can be improved by changing hex values that identify specific IEEE 802.11 frame types (see extract.sh). Here is a non-exhaustive list of MAC ids (on-going work):

  • IEEE 802.11ad:
    • data frames: wlan[0:1]==0x88
    • block acks: wlan[0:1] == 0x94 && wlan[16:1] == 0x05
  • IEEE 802.11ac:
    • data frames:
    • block acks:
  • IEEE 802.11n:
    • data frames:
    • block acks:
  • IEEE 802.11a:
    • data frames:
    • acks:
  • IEEE 802.11b:
    • data frames:
    • acks:

Another limitation is the moduloToLinear() function in plot.py. The current one does not make a difference between a retransmitted frame and a new frame whose sequence number modulo [4096] is lower than the frame before it.