Next: Frag 3 Configuration
Up: Preprocessors
Previous: Preprocessors
Contents
Frag3
The frag3 preprocessor is a target-based IP defragmentation module for Snort.
Frag3 is intended as a replacement for the frag2 defragmentation module and
was designed with the following goals:
- 1.
- Faster execution than frag2 with less complex data management.
- 2.
- Target-based host modeling anti-evasion techniques.
The frag2 preprocessor used splay trees extensively for managing the data
structures associated with defragmenting packets. Splay trees are excellent
data structures to use when you have some assurance of locality of reference
for the data that you are handling but in high speed, heavily fragmented
environments the nature of the splay trees worked against the system and
actually hindered performance. Frag3 uses the sfxhash data structure and
linked lists for data handling internally which allows it to have much more
predictable and deterministic performance in any environment which should
aid us in managing heavily fragmented environments.
Target-based analysis is a relatively new concept in network-based intrusion
detection. The idea of a target-based system is to model the actual targets
on the network instead of merely modeling the protocols and looking for
attacks within them. When IP stacks are written for different operating
systems, they are usually implemented by people who read the RFCs and then
write their interpretation of what the RFC outlines into code. Unfortunately, there
are ambiguities in the way that the RFCs define some of the edge conditions
that may occurr and when this happens different people implement certain aspects
of their IP stacks differently. For an IDS this is a big problem.
In an environment where the attacker can determine what style of IP
defragmentation is being used on a particular target, the attacker can try to
fragment packets such that the target will put them back together in a
specific manner while any passive systems trying to model the host traffic
have to guess which way the target OS is going to handle the overlaps and
retransmits. As I like to say, if the attacker has more information about the
targets on a network than the IDS does, it is possible to evade the IDS. This
is where the idea for ``target-based IDS'' came from. For more detail on this
issue and how it affects IDS, check out the famous Ptacek & Newsham paper at
http://www.snort.org/docs/idspaper/.
The basic idea behind target-based IDS is that we tell the IDS information
about hosts on the network so that it can avoid Ptacek & Newsham style evasion
attacks based on information about how an individual target IP stack operates.
Vern Paxson and Umesh Shankar did a great paper on this very topic in 2003 that
detailed mapping the hosts on a network and determining how their various IP
stack implementations handled the types of problems seen in IP defragmentation
and TCP stream reassembly. Check it out at http://www.icir.org/vern/papers/activemap-oak03.pdf.
We can also present the IDS with topology information to avoid TTL-based
evasions and a variety of other issues, but that's a topic for another day.
Once we have this information we can start to really change the game for these
complex modeling problems.
Frag3 was implemented to showcase and prototype a target-based module within
Snort to test this idea.
Subsections
Next: Frag 3 Configuration
Up: Preprocessors
Previous: Preprocessors
Contents
Steven Sturges
2007-10-04
|