summaryrefslogtreecommitdiffhomepage
path: root/main.c
diff options
context:
space:
mode:
authorJo-Philipp Wich <jo@mein.io>2022-04-06 20:22:16 +0200
committerJo-Philipp Wich <jo@mein.io>2022-04-07 15:13:02 +0200
commit2b59140b2c00987b9d8c2c908d2d44c67786e71e (patch)
treeab8093e9997a4c2b10772e3e8f600c27f9ff0858 /main.c
parent7d7e95006fa70e3f348ce118e756207d57040d93 (diff)
vm: fix callframe double free on unhanded exceptions
When invoking a native function as toplevel VM call which indirectly triggers an unhandled exception in managed code, the callframes are completely reset before the C function returns, leading to invalid memory accesses when `uc_vm_call_native()` subsequently popped it's own callframe again. This issue did not surface by executing script code through the interpreter since in this case the VM will always execute a managed code as toplevel call, but it could be triggered by invoking a native function triggering an exception through the C API using `uc_vm_call()` on a fresh `uc_vm_t` context or by utilizing the CLI interpreters `-l` flag to preload a native code library triggering an exception. Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Diffstat (limited to 'main.c')
0 files changed, 0 insertions, 0 deletions