summaryrefslogtreecommitdiff
path: root/node.h
diff options
context:
space:
mode:
authorAlan Wu <[email protected]>2021-12-01 14:15:23 -0500
committerAlan Wu <[email protected]>2021-12-03 20:02:25 -0500
commitf41b4d44f95978dfa97af04af00055dc3fbf7978 ()
tree744a3d5e2d8f1ef0b3a4ab00a7cd99df0353f6b8 /node.h
parent3be067234f156d75e6143cca5037df7eef1bd112 (diff)
YJIT: Bounds check every byte in the assembler
Previously, YJIT assumed that basic blocks never consume more than 1 KiB of memory. This assumption does not hold for long Ruby methods such as the one in the following: ```ruby eval(<<RUBY) def set_local_a_lot #{'_=0;'*0x40000} end RUBY set_local_a_lot ``` For low `--yjit-exec-mem-size` values, one basic block could exhaust the entire buffer. Introduce a new field `codeblock_t::dropped_bytes` that the assembler sets whenever it runs out of space. Check this field in gen_single_block() to respond to out of memory situations and other error conditions. This design avoids making the control flow graph of existing code generation functions more complex. Use POSIX shell in misc/test_yjit_asm.sh since bash is expanding `0%/*/*` differently. Co-authored-by: Aaron Patterson <[email protected]>
Notes: Merged: https://.com/ruby/ruby/pull/5209
0 files changed, 0 insertions, 0 deletions