Esempio n. 1
0
 def translate_v2ksym(self, addr):
     ctx = ffi.new("access_context_t *")
     ctx.translate_mechanism = lib.VMI_TM_PROCESS_PID
     symbol = lib.vmi_translate_v2ksym(self.vmi, ctx, addr)
     if symbol == ffi.NULL:
         raise LibvmiError('VMI_FAILURE')
     return ffi.string(symbol).decode()
Esempio n. 2
0
 def read_unicode_str_va(self, vaddr, pid):
     value = lib.vmi_read_unicode_str_va(self.vmi, vaddr, pid)
     if value == ffi.NULL:
         raise LibvmiError('VMI_FAILURE')
     encoding = ffi.string(value.encoding).decode()
     buffer = ffi.buffer(value.contents, value.length)[:]
     self.free_unicode_str(value)
     return buffer.decode(encoding)
Esempio n. 3
0
 def get_winver_str(self):
     value = lib.vmi_get_winver_str(self.vmi)
     if value == ffi.NULL:
         raise LibvmiError('VMI_FAILURE')
     return ffi.string(value).decode()
Esempio n. 4
0
 def read_str_pa(self, paddr):
     value = lib.vmi_read_str_pa(self.vmi, paddr)
     if value == ffi.NULL:
         raise LibvmiError('VMI_FAILURE')
     return ffi.string(value).decode()
Esempio n. 5
0
 def translate_v2sym(self, ctx, addr):
     symbol = lib.vmi_translate_v2sym(self.vmi, ctx, addr)
     if symbol == ffi.NULL:
         raise LibvmiError('VMI_FAILURE')
     return ffi.string(symbol).decode()
Esempio n. 6
0
 def get_rekall_path(self):
     value = lib.vmi_get_rekall_path(self.vmi)
     if value == ffi.NULL:
         return None
     return ffi.string(value).decode()