cfallin edited PR #2462 from fix-sorted-debug-addr-transform
to main
:
Sort by generated-code offset to maintain invariant and avoid gimli
panic.Fix srcloc interaction with branch peephole optimization in
MachBuffer: if a srcloc range overlaps with a branch that is
truncated, remove that srcloc range.These issues were found while fuzzing the new backend (#2453); I suspect
that they arise with the new backend because we can sink instructions
(e.g. loads or extends) in more interesting ways than before, but I'm
not entirely sure.Test coverage will be via the fuzz corpus once #2453 lands.
alexcrichton submitted PR Review.
alexcrichton submitted PR Review.
alexcrichton created PR Review Comment:
Out of curiosity, is there a speedier accesssor for non-sorted? If we do our own sort afterwards the sort here shouldn't matter too much.
yurydelendik submitted PR Review.
yurydelendik created PR Review Comment:
As documented:
MachBufferFinalized::get_srclocs_sorted
produces sorted-by-start-offset tuples. Do we need to move this logic to theMachBuffer::finish
?
cfallin updated PR #2462 from fix-sorted-debug-addr-transform
to main
:
Sort by generated-code offset to maintain invariant and avoid gimli
panic.Fix srcloc interaction with branch peephole optimization in
MachBuffer: if a srcloc range overlaps with a branch that is
truncated, remove that srcloc range.These issues were found while fuzzing the new backend (#2453); I suspect
that they arise with the new backend because we can sink instructions
(e.g. loads or extends) in more interesting ways than before, but I'm
not entirely sure.Test coverage will be via the fuzz corpus once #2453 lands.
cfallin submitted PR Review.
cfallin created PR Review Comment:
Ah, yes, good call; for some reason I had assumed that this was sorted by srcloc, not offset. After fixing that (with a sort in
MachBuffer::finish()
the sort here is not needed anymore. Thanks!
cfallin submitted PR Review.
cfallin created PR Review Comment:
Fixed instead by actually sorting by the right thing in
get_srclocs_sorted()
!
cfallin updated PR #2462 from fix-sorted-debug-addr-transform
to main
:
Sort by generated-code offset to maintain invariant and avoid gimli
panic.Fix srcloc interaction with branch peephole optimization in
MachBuffer: if a srcloc range overlaps with a branch that is
truncated, remove that srcloc range.These issues were found while fuzzing the new backend (#2453); I suspect
that they arise with the new backend because we can sink instructions
(e.g. loads or extends) in more interesting ways than before, but I'm
not entirely sure.Test coverage will be via the fuzz corpus once #2453 lands.
yurydelendik submitted PR Review.
cfallin merged PR #2462.
Last updated: Jan 24 2025 at 00:11 UTC