diff options
| author | Yuta Saito <kateinoigakukun@gmail.com> | 2023-11-23 01:59:54 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-11-22 16:59:54 +0000 |
| commit | c1fc1a00ea9633961153451d0e927db49c1b268d (patch) | |
| tree | a11b07dd11b3ca98a0e42bded5d66802a11fb49c /test/ruby/test_variable.rb | |
| parent | 94144801ebd9d25d02697b921858f99cd99bd9a8 (diff) | |
[wasm] Fix Asyncify loop exit condition for normal return (#9007)
[wasm] Fix Asyncify loop exit condition for normal return
Stop calling `asyncify_stop_unwind` when the main function returns
without any unwinding. In the era when Asyncify buffers were allocated
on the stack, the `top` and `end` fields were remained in the stack
space even after the main function returned, so buffer-overflow check in
the `asyncify_stop_unwind` function passed. But now, the `top` and `end`
fields are part of the jump buffer allocated on the heap and they are
deallocated with `free` when the corresponding VM tag is popped. So, the
buffer-overflow check in the `asyncify_stop_unwind` function failed when
the main fuction returned without any unwinding, and we have to break
the asyncify loop before calling `asyncify_stop_unwind`.
Related commit: https://github.com/ruby/ruby.wasm/commit/bc46b12b127e4b6625a100f373504ed5ea45ae66
Diffstat (limited to 'test/ruby/test_variable.rb')
0 files changed, 0 insertions, 0 deletions
