Unicorn CPU emulator framework (ARM, AArch64, M68K, Mips, Sparc, X86)
Go to file
farmdve 7f3c567ae5 X86 zero-byte opcode causes Unicorn to crash.
The opcode 0x00 translates as `add byte ptr ds:[eax],al`, which leads to
a segfault in Unicorn.

Using a debugger, I believe the crash is located in
`qemu/translate-all.c` in function `page_flush_tb_1`, more specifically
this code `pd[i].first_tb = NULL;`
2015-11-05 14:41:15 +02:00
bindings python bindings: use relative paths for imports to support py3 2015-11-02 09:34:58 -05:00
docs docs/README: copy&paste error 2015-10-17 01:27:37 +08:00
include support memory redirection, so the issue #217 is fixed 2015-10-27 14:37:03 +08:00
qemu do not free MemoryRegion in memory_unmap() because it will be unref later in memory_region_unref(). this fixes issue #202 2015-10-28 01:26:59 +08:00
samples Remove trailing whitespace. 2015-10-30 22:34:35 +01:00
tests X86 zero-byte opcode causes Unicorn to crash. 2015-11-05 14:41:15 +02:00
.gitignore tests: add mips_kseg0_1 to Makefile to compile it 2015-10-27 11:25:34 +08:00
AUTHORS.TXT import 2015-08-21 15:04:50 +08:00
ChangeLog add ChangeLog 2015-10-15 23:54:39 +08:00
COMPILE.TXT COMPILE.TXT: fix typo 2015-11-01 00:54:54 -04:00
config.mk import 2015-08-21 15:04:50 +08:00
COPYING import 2015-08-21 15:04:50 +08:00
CREDITS.TXT update CREDITS.TXT 2015-10-03 16:02:49 +08:00
hook.c fix #165 2015-10-05 23:30:54 -07:00
LEAK_VALGRIND import 2015-08-21 15:04:50 +08:00
make.sh Fixing compile on windows with mingw 2015-08-29 17:04:48 +02:00
Makefile Makefile: overwrite existent library for install target with 'ln -sf' 2015-10-25 09:44:01 +08:00
pkgconfig.mk Remove trailing whitespace. 2015-10-30 22:34:35 +01:00
README.md Little README change 2015-10-17 11:37:53 +02:00
uc.c Fix segfault-on-emu_stop() bug. 2015-11-03 14:34:31 +01:00

Unicorn Engine

Unicorn is a lightweight, multi-platform, multi-architecture CPU emulator framework based on QEMU.

Unicorn offers some unparalleled features:

  • Multi-architecture: ARM, ARM64 (ARMv8), M68K, MIPS, SPARC, and X86 (16, 32, 64-bit)
  • Clean/simple/lightweight/intuitive architecture-neutral API
  • Implemented in pure C language, with bindings for Python, Java, and Go
  • Native support for Windows & *nix (with Mac OSX, Linux, *BSD & Solaris confirmed)
  • High performance via Just-In-Time compilation
  • Support for fine-grained instrumentation at various levels
  • Thread-safety by design
  • Distributed under free software license GPLv2

Further information is available at http://www.unicorn-engine.org

Compilation

See COMPILE.TXT file for how to compile and install Unicorn.

License

This project is released under the GPL license.