[PATCH] D124765: [libunwind][SystemZ] Unwind out of signal handlers
Fangrui Song via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon May 2 13:55:16 PDT 2022
MaskRay added inline comments.
================
Comment at: libunwind/src/UnwindCursor.hpp:2667
+ // specific instruction (see below). Typically the trampoline comes from the
+ // vDSO (i.e. the __kernel_[rt_]sigreturn function). A libc might provide its
+ // own restorer function, though, or user-mode QEMU might write a trampoline
----------------
Does s390 use both `__kernel_[rt_]sigreturn`? It seems that the Linux kernel source references both. For aarch64 there is only the `rt_` version.
Just a note for you to double check the comment:)
================
Comment at: libunwind/src/UnwindCursor.hpp:2684
+int UnwindCursor<A, R>::stepThroughSigReturn(Registers_s390x &) {
+ // Determine current SP and CFA (offset by 160).
+ const pint_t sp = static_cast<pint_t>(this->getReg(UNW_REG_SP));
----------------
Best to leave a comment where 160 comes from. It can be a kernel source filename.
================
Comment at: libunwind/src/UnwindCursor.hpp:2691
+ const pint_t pc = static_cast<pint_t>(this->getReg(UNW_REG_IP));
+ uint16_t inst = _addressSpace.get16(pc);
+
----------------
================
Comment at: libunwind/src/UnwindCursor.hpp:2731
+ // Restore all registers.
+ for (int i = 0; i <= 15; ++i) {
+ uint64_t value = _addressSpace.get64(pSigctx + kOffsetGprs +
----------------
Prefer [a,b) ranges
================
Comment at: libunwind/src/UnwindCursor.hpp:2736
+ }
+ for (int i = 0; i <= 15; ++i) {
+ static int fpr[16] = {
----------------
Prefer [a,b) ranges
================
Comment at: libunwind/src/UnwindCursor.hpp:2737
+ for (int i = 0; i <= 15; ++i) {
+ static int fpr[16] = {
+ UNW_S390X_F0, UNW_S390X_F1, UNW_S390X_F2, UNW_S390X_F3,
----------------
================
Comment at: libunwind/test/signal_unwind.pass.cpp:11
// Ensure that the unwinder can cope with the signal handler.
-// REQUIRES: linux && (target={{aarch64-.+}} || target={{x86_64-.+}})
+// REQUIRES: linux && (target={{aarch64-.+}} || target={{x86_64-.+}} || target={{s390x-.+}})
----------------
Use an alphabetical order: aarch64, s390x, x86_64
================
Comment at: libunwind/test/unwind_leaffunction.pass.cpp:11
// Ensure that leaf function can be unwund.
-// REQUIRES: linux && (target={{aarch64-.+}} || target={{x86_64-.+}})
+// REQUIRES: linux && (target={{aarch64-.+}} || target={{x86_64-.+}} || target={{s390x-.+}})
----------------
Use an alphabetical order: aarch64, s390x, x86_64
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124765/new/
https://reviews.llvm.org/D124765
More information about the llvm-commits
mailing list