afonso360 opened PR #5155 from interp-fix-heapaddr
to main
:
:wave: Hey,
This PR fixes an issue with the
heap_addr
instruction in the interpreter. We were accidentally including the size as part of the offset when computing heap addresses.This failed when one tries to load the top n bytes of the heap, the interpreter incorrectly reported a HeapOutOfBounds error.
afonso360 updated PR #5155 from interp-fix-heapaddr
to main
.
afonso360 edited PR #5155 from interp-fix-heapaddr
to main
:
:wave: Hey,
This PR fixes an issue with the
heap_addr
instruction in the interpreter. We were accidentally including the size as part of the offset when computing heap addresses.This failed when trying to load the top n bytes of the heap, the interpreter incorrectly reported a HeapOutOfBounds error.
afonso360 edited PR #5155 from interp-fix-heapaddr
to main
:
:wave: Hey,
This PR fixes an issue with the
heap_addr
instruction in the interpreter. We were accidentally including the size as part of the offset when computing heap addresses.This failed when trying to load the top n bytes of the heap, the interpreter incorrectly reported a HeapOutOfBounds error.
jameysharp created PR review comment:
Why is this a
saturating_sub
? I haven't checked the instruction definition but I'd have expected that aload_size
would be 1 at minimum. Sinceoffset
is unsigned and we're apparently assuming the addition can't overflow, that would mean the subtraction can't underflow.Related: subtracting 1 from
load_size
_before_ adding it tooffset
would avoid overflow if we're accessing valid heap addresses near 2^64. But I assume the interpreter would run out of memory long before growing a heap big enough for that to matter.
jameysharp submitted PR review.
jameysharp submitted PR review.
jameysharp merged PR #5155.
afonso360 created PR review comment:
Why is this a saturating_sub? I haven't checked the instruction definition but I'd have expected that a load_size would be 1 at minimum.
I originally did this because we have a zero sized
heap_addr
in the runtest test suite, which was panicking!I then tried to fix it by making that properly sized. And then I had the idea, "Hey lets put a verifier rule for this!". And it turns out our test suite is full of zero sized
heap_addr
's, I've opened #5167 with the exact changes, but we should probably discuss if zero sizedheap_addr
's are legal there.
afonso360 submitted PR review.
afonso360 edited PR review comment.
Last updated: Jan 24 2025 at 00:11 UTC