Correctly add unwinding info in manifestSp and makeFixupBlocks
In `manifestSp` the unwind info was before the relevant instruction, not after. I added some notes to establish semantics. Also removes redundant annotation in stg_catch_frame. For `makeFixupBlocks` it looks like we were off by `wORD_SIZE dflags`. I'm not sure why, but it lines up with `manifestSp`. In fact it lines up so well so that I can consolidate the Sp unwind logic in `maybeAddUnwind`. I detected the problems with `makeFixupBlocks` by running T14779b after patching D4559. Test Plan: added a new test Reviewers: bgamari, scpmw, simonmar, erikd Reviewed By: bgamari Subscribers: thomie, carter GHC Trac Issues: #14999 Differential Revision: https://phabricator.haskell.org/D4606
Showing
- compiler/cmm/CmmLayoutStack.hs 28 additions, 34 deletionscompiler/cmm/CmmLayoutStack.hs
- compiler/cmm/Debug.hs 88 additions, 3 deletionscompiler/cmm/Debug.hs
- compiler/nativeGen/Dwarf/Types.hs 6 additions, 0 deletionscompiler/nativeGen/Dwarf/Types.hs
- rts/Exception.cmm 0 additions, 1 deletionrts/Exception.cmm
- testsuite/driver/testglobals.py 6 additions, 0 deletionstestsuite/driver/testglobals.py
- testsuite/driver/testlib.py 6 additions, 0 deletionstestsuite/driver/testlib.py
- testsuite/mk/test.mk 14 additions, 0 deletionstestsuite/mk/test.mk
- testsuite/tests/codeGen/should_compile/Makefile 5 additions, 0 deletionstestsuite/tests/codeGen/should_compile/Makefile
- testsuite/tests/codeGen/should_compile/T14999.cmm 11 additions, 0 deletionstestsuite/tests/codeGen/should_compile/T14999.cmm
- testsuite/tests/codeGen/should_compile/T14999.stdout 16 additions, 0 deletionstestsuite/tests/codeGen/should_compile/T14999.stdout
- testsuite/tests/codeGen/should_compile/all.T 5 additions, 0 deletionstestsuite/tests/codeGen/should_compile/all.T
Loading
Please register or sign in to comment