Sync doc with repo wiki
This commit is contained in:
parent
e382ca102a
commit
5b2c610527
@ -52,7 +52,7 @@ msbuild unicorn.sln -p:Plaform=Win32 -p:Configuration=Release
|
|||||||
|
|
||||||
## Cross build with NDK
|
## Cross build with NDK
|
||||||
|
|
||||||
To build Unicorn2 on the Android platform, firstly you need to download [NDK](https://developer.android.com/ndk/downloads).
|
To cross-build and run Unicorn2 on the Android platform, firstly you need to download [NDK](https://developer.android.com/ndk/downloads).
|
||||||
|
|
||||||
For newer NDK, please make sure your cmake version is above 3.19.
|
For newer NDK, please make sure your cmake version is above 3.19.
|
||||||
|
|
||||||
@ -68,7 +68,7 @@ You may get the possible values from this [page](https://developer.android.com/n
|
|||||||
|
|
||||||
Unicorn2 support cross-build for `armeabi-v7a`, `arm64-v8a`, `x86` and `x86_64`.
|
Unicorn2 support cross-build for `armeabi-v7a`, `arm64-v8a`, `x86` and `x86_64`.
|
||||||
|
|
||||||
Note the build is only tested and guaranteed to work under Linux, however, other systems may still work.
|
Note the build is only tested and guaranteed to work under Linux and macOS, however, other systems may still work.
|
||||||
|
|
||||||
## Cross build from Linux host to Windows, with Mingw
|
## Cross build from Linux host to Windows, with Mingw
|
||||||
|
|
||||||
@ -97,15 +97,16 @@ This requires MSYS2 to be installed on the Windows machine. You need to download
|
|||||||
Then from MSYS2 console, install packages below:
|
Then from MSYS2 console, install packages below:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
pacman -S mingw-w64-x86_64-toolchain mingw-w64-x86_64-cmake
|
pacman -S mingw-w64-x86_64-toolchain mingw-w64-x86_64-cmake mingw-w64-x86_64-ninja
|
||||||
```
|
```
|
||||||
|
|
||||||
- Build Unicorn and samples with the following commands.
|
- Build Unicorn and samples with the following commands.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
|
export PATH=/mingw64/bin:$PATH
|
||||||
mkdir build; cd build
|
mkdir build; cd build
|
||||||
/mingw64/bin/cmake .. -G "MSYS Makefiles" -DCMAKE_C_COMPILER=/mingw64/bin/gcc.exe -DCMAKE_MAKE_PROGRAM=/mingw64/bin/mingw32-make.exe -DCMAKE_AR=/mingw64/bin/ar.exe -DUNICORN_ARCH=x86
|
/mingw64/bin/cmake .. -G "Ninja"
|
||||||
mingw32-make
|
ninja -C .
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that the way to build on MSYS changes as time goes, please keep in mind that always use the cmake shipped with mingw64 and choose MSYS Makefiles.
|
Note that the way to build on MSYS changes as time goes, please keep in mind that always use the cmake shipped with mingw64 and choose MSYS Makefiles.
|
||||||
|
68
docs/FAQ.md
Normal file
68
docs/FAQ.md
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
## Why is my execution so slow?
|
||||||
|
|
||||||
|
Typically, it’s due to
|
||||||
|
|
||||||
|
- Instrumenting every instruction executed.
|
||||||
|
- Instrumenting every memory access.
|
||||||
|
|
||||||
|
Optimize your program with less instrumentation.
|
||||||
|
|
||||||
|
## Why do I get a wrong PC after emulation stops?
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
## I get an “Unhandled CPU Exception”, why?
|
||||||
|
|
||||||
|
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](https://github.com/qilingframework/qiling).
|
||||||
|
|
||||||
|
## I would like to instrument a specific instruction but get a `UC_ERR_HOOK`, why?
|
||||||
|
|
||||||
|
Currently, only a small subset of the instructions can be instrumented.
|
||||||
|
|
||||||
|
On x86, all available instructions are: `in` `out` `syscall` `sysenter` `cpuid`.
|
||||||
|
|
||||||
|
## Emulating some instructions gives an error, what should I do?
|
||||||
|
|
||||||
|
1. Some instructions are not enabled by default on some architectures. For example, you have to setup CSR on RISC-V or VFP on ARM before emulating floating-point instructions. Refer to the corresponding manual to check if you leave out possible switches in special registers.
|
||||||
|
2. If you are on ARM, please check whether you are emulating a THUMB instruction. If so, please use `UC_MODE_THUMB` and make sure the starting address is odd.
|
||||||
|
3. If either is 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.
|
||||||
|
|
||||||
|
## I can't recover from unmapped read/write even I return `true` in the hook, why?
|
||||||
|
|
||||||
|
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](https://github.com/unicorn-engine/unicorn/blob/c05fbb7e63aed0b60fc2888e08beceb17bce8ac4/samples/sample_x86.c#L1379-L1393) for details.
|
||||||
|
|
||||||
|
## How to emulate interrupts (or ticks) with Unicorn?
|
||||||
|
|
||||||
|
As stated, Unicorn is a pure CPU emulator. For such emulation, you have two choices:
|
||||||
|
|
||||||
|
- Use the `timeout` parameter of `uc_emu_start`
|
||||||
|
- Use the `count` parameter of `uc_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.
|
||||||
|
|
||||||
|
## Why not keep up the upstream qemu?
|
||||||
|
|
||||||
|
To provide end users with simple API, Unicorn does lots of dirty hacks within qemu code which prevents it from sync painlessly.
|
||||||
|
|
||||||
|
## Is there anyway to disable softmmu to speed up execution?
|
||||||
|
|
||||||
|
Yes, it’s possible but that is not Unicorn’s goal and there is no simple switch in qemu to disable softmmu.
|
||||||
|
|
||||||
|
## I'd like to make contributions, where do I start?
|
||||||
|
|
||||||
|
See [milestones](https://github.com/unicorn-engine/unicorn/milestones) and [coding convention](https://github.com/unicorn-engine/unicorn/wiki/Coding-Convention
|
||||||
|
).
|
||||||
|
|
||||||
|
Be sure to send pull requests for our **dev** branch only.
|
||||||
|
|
||||||
|
## Which qemu version is Unicorn based on?
|
||||||
|
|
||||||
|
Prior to 2.0.0, Unicorn is based on qemu 2.2.1. After that, Unicorn is based on qemu 5.0.1.
|
Loading…
Reference in New Issue
Block a user