bpfc: fix hla lexer
[netsniff-ng.git] / TODO
blobe03ce74dde70a34b732ecdfc3ad84be86936929e
1 Here's a list of things we need to do (contributions are welcome and highly
2 appreciated, please also read Documentation/SubmittingPatches about how to
3 submit your contributions, items marked with '!' are of high importance):
5  0! Improve manpages, extend the documentation or write useful howtos.
6         @TODO: Jon Schipp, Daniel Borkmann
8  1! Highest prio: Cleanup and refactor the code and build system to make it
9     more maintainable, stable, and probably faster! mausezahn: clean it up
10     add fork + fanout mode, remove libpcap dependency, let it also store
11     pcap files e.g. on a network filesystem of the mausezahn box.
12         @TODO: Daniel Borkmann
14  3! Add full IPv6 support for flowtop, test IPv6 on curvetun and mausezahn.
15         @TODO: Daniel Borkmann
17  5) Make trafgen also write to a pcap instead to a device.
19  6) Let netsniff-ng and trafgen support pcap and pcap-ng!
21 10! Add a proper 802.11 dissector for netsniff-ng.
22         @TODO: Markus Amend
24 12) Add new dissectors (e.g. BGP, DNS, DCCP, SCTP, RSVP, IPsec, LISP, RADIUS,
25     LLC, fix MPLS?, improve ARP, BPDU, PVST, CDP, LLDP, RTP, Syslog, NTP,
26     OpenFlow, ...), add new protocols to mausezahn.
28 13! Easier language (bpf-hla) for /fast/ filtering (e.g. on top of BPF so
29     that it can run in the kernel), include this into bpfc (bpfc-hla).
30         @TODO: Tobias Kalbitz, Markus Amend, Daniel Borkmann
32 16) Further micro-optimize netsniff-ng, trafgen, mausezahn's performance. Use
33     Oprofile for optimize tools!
35 17) Security review of curvetun.
37 21) Obfuscate curvetun's protocol to make it hard/resource-intensive for DPIs.
39 22! Add different timing models to trafgen, not just a static interpacket gap.
40         @TODO: Daniel Borkmann
42 25) Do performance tests with 10 Gigabit cards.
43         @TODO: Sibir Chakraborty
45 29) Improve the Linux kernel's net/packet/af_packet.c (that we rely on)
47 30! Fix UDP+TCP tracking in flowtop.
48         @TODO: Daniel Borkmann
50 31) astraceroute: implement DNS traceroute with AS/Geo information
52 32) ifpps: add option for --dev eth0,eth1,eth2 and accumulate stats
54 33) flowtop: can we get per socket pps, bytes per sec without sniffing?
56 34) Are there other interesting (e.g. ethtool) stats for ifpps? E.g. backlog
57     queue statistics in ifpps (discussion with Jon Schipp).
59 35) Build a generic interface that is somewhat transparant to RX_RING/TX_RING
60     where we can user uio-dma, integrate uio-ixgbe and probably port others.
61     This could be invoked through a special build option. Default should always
62     be RX_RING / TX_RING.
63     [1] http://pub.netsniff-ng.org/misc/uio-dma.tar.bz2
64     [2] http://pub.netsniff-ng.org/misc/uio-ixgbe.tar.bz2
65         @TODO: Sibir Chakraborty
67 38! netsniff-ng (and others): if interface goes down, properly exit
68         @TODO: Daniel Borkmann
70 39! Add a pcap indexing utility fo a faster retrival, analysis on huge
71     pcap files. Write the index file out for each pcap capture.
72         @TODO: Daniel Borkmann, Francesco Fusco
74 42) Flowtop: add interesting things from socket diag (e.g. socket states, ...)?
76 45! fix sll struct / hdr->s_ll.sll_ifindex in TPACKETv2 (provides
77     wrong information in dissector output)
79 46) QoS for curvetun.
81 47) ifpps show timestamps in CSV file.
83 48! Hand-include patchset from Sibir Chakraborty:
84         - Replay all files from directory (dir as --in paramter)
85         - Replay with correct timing information
86         - Replay with Gbps / pps rate limit
88 49! Add Gbps / pps rate limit to trafgen