Skip to content

AzzOnFire/emuit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EmuIt - easy-to-use IDA emulator plugin

Use cases

  • Run code without starting debug session (broken dump, driver, firmware...)
  • Find decryption function in malware and get all decrypted strings
  • Automate process of config extraction

Quick example

QuickExample

Installation

Copy emuit.py and emuit directory to plugins directory in %IDA_HOME% or %IDA_USER%

Examples

from emuit import EmuItX86_64
emu = EmuItX86_64(bitness=64)

Memory and registers manipulations:

buffer = emu[0x400000:0x401000]  # read memory region
emu[0x1002F0C8] = "string"       # write string at address

ip = emu['EIP']         # get EIP value
emu['RDX'] = 0xABCDEF   # access by register name
emu['*DX'] = 0xABCDEF   # asterisk mean 'R' for x64 or 'E' for x86

emu.push(0xABCDEF)      # push value to stack
value = emu.pop()

Emulate arbitrary code chunk:

result = emu.run(0x100000, 0x100020)
print(result)   # has helper methods `pretty`, `range`, `printable`
>>> {0x3000: 'decrypted string...', 0x24000: 'stack junk...', ...}

Call function:

buffer for ASCII string 'some_str_buffer' will be allocated automatic, buffer ptr will be provided as an argument.

start_ea, end_ea = 0x10021050, 0x10023010 
emu.stdcall(start_ea, end_ea, 'some_str_buffer', 0x6)
emu.fastcall(start_ea, end_ea, rcx='some_str_buffer', rdx=0x6)

IDA Pro specific features

from emuit import EmuItIda
emu = EmuItIda(skip_api_calls=True) # Try skip calls to API

Use IDA names

emu['dword_1002F0C8'] = "string"           # access by location name
emu.stdcall('fn_Decrypt', 'enc_str', 0x6)  # call by name

Emulate all function call's with automatic substitution of arguments (from idaapi.get_arg_addrs)

Important: function must have finalized prototype (black 'T' flag in IDA functions view or function name black highlight)

for xref in idautils.XrefsTo(0x10021050):
    call_ea = xref.frm
    emu.luckycall(call_ea)

For skipping unnecessary API calls enable that feature in context (right click) menu. For example, following call will be skipped with stack restoring.

// SetErrorMode(0x8001u);
push    8001h
call    SetErrorMode

Limitations

  • Emulate code with API calls, syscalls
  • Access to internal structures (PEB, SEH, ...)

TODO

  • (?) partial PEB emulation to deal with malware API resolve by hash
  • ARM support
  • More calling conventions
  • More tests (ELF/Mach-O binaries)
  • Instruction tracing with detailed error report

Releases

No releases published

Packages

No packages published

Languages