-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Typically, it’s due to
- Instrumenting every instruction executed.
- Instrumenting every memory access.
Optimize your program with less instrumentation.
PC is only guaranteed to be correct if you install UC_HOOK_CODE
. This is due to the fact that updating PC is a big performance overhead during emulation.
Unicorn is a pure CPU emulator and usually it’s due to no handler registered for instructions like syscall
and SVC
. If you expect system emulation, you probably would like qiling framework.
Currently, only a small subset of the instructions can be instrumented.
On x86, all available instructions are: in
out
syscall
sysenter
cpuid
.
Firstly, please check whether you are emulating a THUMB insturtion. If so, please use UC_MODE_THUMB
and make sure the starting address is odd. If it’s not the case, it might be some newer instruction sets that qemu5 doesn’t support.
If you are still using Unicorn1, please upgrade to Unicorn2 for better support.
As stated, Unicorn is a pure CPU emulator. For such emulation, you have two choices:
- Use the
timeout
parameter ofuc_emu_start
- Use the
count
parameter ofuc_emu_start
After emulation stops, you may check anything you feel interested and resume emulation accordingly.
Note that for cortex-m exec_return
, Unicorn has a magic software exception with interrupt number 8. You may register a hook to handle that.
To provide end users with simple API, Unicorn does lots of dirty hacks within qemu code which prevents it from sync painlessly.
Yes, it’s possible but that is not Unicorn’s goal and there is no simple switch in qemu to disable softmmu.
See milestones and coding convention.
Be sure to send pull requests for our dev branch only.
This is a minor change in memory hooks behavior between Unicorn1 and Unicorn2. To gracefully recover from memory read/write error, you have to map the invalid memory before you return true.
It is due to the fact that, if users return true
without memory mapping set up correctly, we don't know what to do next. In Unicorn1, the behavior is undefined in this case but in Unicorn2 we would like to force users to set up memory mapping in the hook to continue execution.
See the sample for details.
Prior to 2.0.0, Unicorn is based on qemu 2.2.1. After that, Unicorn is based on qemu 5.0.1.