680 likes | 944 Views
Windows Memory Forensics: Down the Rabbit Hole. Professor James L. Antonakos Computer Science Department. Overview.
E N D
WindowsMemoryForensics:Down the Rabbit Hole Professor James L. Antonakos Computer Science Department
Overview This session presents techniques to capture live memory data from a Windows 7 system and process it for relevant forensics information. Techniques to search the captured memory data using regular expressions are covered, as is the nature of protected-mode memory operation, including virtual memory.
Topics • My Teaching Goals • Building the Memory Image • Acquiring the Memory Image • First Step: Using STRINGS • Second Step: Looking for Stuff • Regular Expressions • Searching with GREP
Topics (continued) • Analyzing Memory • 80x86 Real Mode • 80x86 Protected Mode • Virtual (Linear) Addressing • Paging • Demand Paging • Malware Analysis • Anti-Memory Forensics
My Teaching Goals • Get students interested, excited, and curious about computer forensics. • Explain why we want to do memory forensics. • Show students how to use different software tools. • Reinforce knowledge from other courses. • Show students how to learn. • Propose strategies that work (and that do not work). • Increase my own knowledge by learning from students.
Building the Memory Image • Do some typical work on a Windows 7 laptop: • Open web-based email and send a message. • Open Internet Explorer and log into Yahoo email. • Open DOS window and get a directory listing. • Do Yahoo search for “win7-memory-forensics.” • Look at Task Manager and NETSTAT. • Check Computer Properties.
Acquiring the Memory Image • Consider the memory footprint of the capture tool: • win64dd.exe 108 KB • FTKImager.exe 6.9 MB • Other software tools: Nigilant32, ProDiscover IR, KntDD • How about no memory footprint via hardware acquisition? • Use FireWire’s DMA capability. • Tribble, CoPilot, RAM Capture Tool PCI cards… must be preinstalled.
First Step: Using STRINGS • Use the STRINGS program to extract ASCII strings from memory dump file. • Command line: • Strings physmem.dmp > memstr.txt • Resulting output file is 173 MB in size. • Open memstr.txt with Microsoft Word: • Over 18,000 pages of text… but we will see this is a false indicator of the actual page count.
Splitting the Results Giving one file to each student to examine as a semester project and allowing for 10 seconds to view each page requires an average of 17 hours per document for review.
Regular Expressions • Regular expressions are powerful tools for representing and matching strings. • There are three basic ways to form a regular expression: • AB (concatenation, A followed by B) • A | B (selection, A or B) • A* (0 or more occurrences of A) • A+ (1 or more occurrences of A) • Depending on the tool, the actual regular expression will be different.
Regular Expressions • Some examples: • antonakosjl • abc | def • a (b | c)*d • The third example can match an infinite number of strings, such as ad, abd, acd, abbd, accd, abcd, acbd, abbbd, acccd, abcbd, abbcd, abcbcbcbcbccbcbbcbcbbcbcbcbbcbcbccd, etc.
Regular Expressions • In the Windows GREP tool there are additional ways of representing regular expressions: • Use square brackets to represent a group of symbols, such as [0-9] or [a-z] or [A-Z] • Use . to match a single character • Use + to match 1 or more characters • Use \ to match a special symbol • Example: to match the string iontransfer@yahoo.com we use the expression iontransfer\@yahoo\.com
Searching with GREP • The first thing to do is enter the regular expression you wish to search for:
Searching with GREP • Then select the folder:
Searching with GREP • Then the type of file to search:
Searching with GREP • Now click Finish to begin the search:
Searching with GREP • The result of the search, with line numbers:
Searching with GREP • Searching for an email address:
Searching with GREP • Email address found in two places:
Analyzing Memory • One tool for analyzing memory is Mandiant’s Memoryze (and its Audit Viewer front end):
Analyzing Memory • Another tool is FTK from AccessData. Here we see a sample of 819 images recovered from the memory image. Note that many images are broken.
Analyzing Memory • FTK contains two powerful search tools. This is the Index search window:
Analyzing Memory • This is the Live search window. These searches take more time. Ability to use Regular Expressions is built in, along with large list of expressions.
Analyzing Memory • Other tools: • EnCase • PTFinder • FTimes • Volatility • Windows Debugging Tools
80x86 Real Mode • The architecture of the 8x06 protected mode is significantly different from that of real mode. • Real-mode operation refers to the original 8086 (or 8088) architecture, which provided four 16-bit segment registers (CS, DS, ES, and SS), and a 20-bit address bus. • In real mode, addresses are generated by shifting 16-bit segment registers to the left by four bits, and adding a 16-bit offset to create a 20-bit physical address. • The 20-bit address supports a 1 MB real-mode addressing space.
80x86 Protected Mode • In protected-mode, memory addresses are generated in a totally different way. • Segment registers are now called segment selectors, and point to a structure called a segment descriptor. • The segment descriptor contains addressing and control information which is used to control how a 32-bit linear address is generated. • These addresses may then be further translated by a paging mechanism before emerging as a physical address somewhere in the Pentium's 4 GB addressing space.
Paging • The 80x86 protected mode supports translation of virtual (linear) addressesinto physical addresses. • This is done through the use of special tables that map portions of the virtual address into actual physical memory locations. • Physical memory is divided into fixed-size page frames of 4KB each. • 32-bit virtual (linear) addresses generated by a running task select entries in the systems page directory and page table, which translate the upper 20 bits of the virtual address into the actual physical address where a page frame is located. • The lower 12 bits of the virtual address are not translated and point to one of 4,096 byte locations within a page frame.
Paging • How is a 32-bit virtual address translated into a physical address? • The upper 10 bits of the virtual address select one of 1,024 entries in the page directory. • The base address of the page directory is stored in the page directory base register (PDBR). • Each entry in the page directory is 4 bytes wide and contains the base address of a page table.
Paging • The next 10 bits from the virtual address select one of 1,024 entries in the page table pointed to by the page directory entry. • This entry is also 4 bytes wide and contains the base address of the actual physical memory page frame. • This address is combined with the lower 12 bits of the virtual address to access the desired location in memory.