diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2022-07-30 13:54:37 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2022-07-31 17:18:48 +0000 |
commit | 3c10c44304608e72d2d23f6a35998b21b2e195ee (patch) | |
tree | 88d513e2be7c7be769631a35aa8f3ce685e20f51 | |
parent | 9df810702720505fcf281d619515cd99f9b02b88 (diff) | |
download | ports-3c10c44304608e72d2d23f6a35998b21b2e195ee.tar.gz ports-3c10c44304608e72d2d23f6a35998b21b2e195ee.zip |
devel/libunwind: fix build with clang 15
Building libunwind with clang results in multiple errors:
setjmp/siglongjmp.c:111:48: error: incompatible pointer to integer conversion passing 'unw_word_t *' (aka 'unsigned long *') to parameter of type 'unw_word_t' (aka 'unsigned long'); remove & [-Wint-conversion]
if (unw_set_reg (&c, UNW_REG_EH + 2, &wp[JB_MASK]) < 0)
^~~~~~~~~~~~
../include/libunwind-common.h:283:56: note: passing argument to parameter here
extern int unw_set_reg (unw_cursor_t *, int, unw_word_t);
^
dwarf/Gparser.c:901:5: error: call to undeclared function '_Ux86_64_stash_frame'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
tdep_stash_frame (c, rs);
^
../include/tdep-x86_64/libunwind_i.h:246:41: note: expanded from macro 'tdep_stash_frame'
#define tdep_stash_frame UNW_OBJ(stash_frame)
^
The first error is because the syntax is indeed wrong, the '&' should be
removed.
The second error is because tdep_stash_frame() is only declared for
Linux in libunwind_i.h, but it is used in Gparser.c. Declare it
unconditionally to fix the problem.
PR: 265519
Approved by: sunpoet (maintainer)
MFH: 2022Q3
-rw-r--r-- | devel/libunwind/files/patch-include_tdep-x86__64_libunwind__i.h | 13 | ||||
-rw-r--r-- | devel/libunwind/files/patch-src_setjmp_siglongjmp.c | 11 |
2 files changed, 24 insertions, 0 deletions
diff --git a/devel/libunwind/files/patch-include_tdep-x86__64_libunwind__i.h b/devel/libunwind/files/patch-include_tdep-x86__64_libunwind__i.h new file mode 100644 index 000000000000..51d4a15c8757 --- /dev/null +++ b/devel/libunwind/files/patch-include_tdep-x86__64_libunwind__i.h @@ -0,0 +1,13 @@ +--- include/tdep-x86_64/libunwind_i.h.orig 2021-11-26 16:58:55 UTC ++++ include/tdep-x86_64/libunwind_i.h +@@ -288,9 +288,9 @@ extern void tdep_reuse_frame (struct dwarf_cursor *c, + extern int tdep_cache_frame (struct dwarf_cursor *c); + extern void tdep_reuse_frame (struct dwarf_cursor *c, + int frame); ++#endif + extern void tdep_stash_frame (struct dwarf_cursor *c, + struct dwarf_reg_state *rs); +-#endif + + extern int tdep_getcontext_trace (unw_tdep_context_t *); + extern int tdep_trace (unw_cursor_t *cursor, void **addresses, int *n); diff --git a/devel/libunwind/files/patch-src_setjmp_siglongjmp.c b/devel/libunwind/files/patch-src_setjmp_siglongjmp.c new file mode 100644 index 000000000000..61728ff11f02 --- /dev/null +++ b/devel/libunwind/files/patch-src_setjmp_siglongjmp.c @@ -0,0 +1,11 @@ +--- src/setjmp/siglongjmp.c.orig 2020-11-10 16:14:18 UTC ++++ src/setjmp/siglongjmp.c +@@ -108,7 +108,7 @@ siglongjmp (sigjmp_buf env, int val) + && unw_set_reg (&c, UNW_REG_EH + 3, wp[JB_MASK + 1]) < 0)) + abort (); + #elif defined(__FreeBSD__) +- if (unw_set_reg (&c, UNW_REG_EH + 2, &wp[JB_MASK]) < 0) ++ if (unw_set_reg (&c, UNW_REG_EH + 2, wp[JB_MASK]) < 0) + abort(); + #else + #error Port me |