[libunwind] [libunwind] fix unwinding from signal handler (PR #92291)

Azat Khuzhin via cfe-commits cfe-commits at lists.llvm.org
Sun Jul 7 23:30:18 PDT 2024


================
@@ -365,7 +365,12 @@ int DwarfInstructions<A, R>::stepWithDwarf(A &addressSpace, pint_t pc,
 
       // Return address is address after call site instruction, so setting IP to
       // that does simulates a return.
-      newRegisters.setIP(returnAddress);
+      //
+      // In case of this is frame of signal handler, the IP should be
+      // incremented, because the IP saved in the signal handler points to
+      // first non-executed instruction, while FDE/CIE expects IP to be after
+      // the first non-executed instruction.
+      newRegisters.setIP(returnAddress + cieInfo.isSignalFrame);
----------------
azat wrote:

OK, I see, thanks.
I can move this logic into `DwarfInstructions<A, R>::stepWithDwarf`, but still, the IP will be different in case of regular unwind (after first non executed instruction) and unwind from signal (before first non-executed instruction)

https://github.com/llvm/llvm-project/pull/92291


More information about the cfe-commits mailing list