From f1463cb7a6d6003e5c69cfa394dff67d8d4cc58a Mon Sep 17 00:00:00 2001 From: Keno Fischer Date: Tue, 9 Feb 2021 15:25:21 -0500 Subject: [PATCH] freebsd: Register JIT unwind info (#39581) I noticed in https://github.com/JuliaLang/julia/pull/39553 that JIT unwind info didn't actually work on FreeBSD. As a general policy, we should register our frame info to make sure that our unwind is accurate. Libunwind has some heuristics to fall back to, but they can break e.g. for large stack frames. --- src/debuginfo.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/debuginfo.cpp b/src/debuginfo.cpp index cc7993390e0ee..b0243b2f3f4ff 100644 --- a/src/debuginfo.cpp +++ b/src/debuginfo.cpp @@ -1244,7 +1244,7 @@ extern "C" jl_method_instance_t *jl_gdblookuplinfo(void *p) JL_NOTSAFEPOINT return jl_jit_events->lookupLinfo((size_t)p); } -#if (defined(_OS_LINUX_) || (defined(_OS_DARWIN_) && defined(LLVM_SHLIB))) +#if (defined(_OS_LINUX_) || defined(_OS_FREEBSD_) || (defined(_OS_DARWIN_) && defined(LLVM_SHLIB))) extern "C" void __register_frame(void*); extern "C" void __deregister_frame(void*); @@ -1315,7 +1315,7 @@ void deregister_eh_frames(uint8_t *Addr, size_t Size) }); } -#elif defined(_OS_LINUX_) && \ +#elif (defined(_OS_LINUX_) || defined(_OS_FREEBSD_)) && \ defined(JL_UNW_HAS_FORMAT_IP) && \ !defined(_CPU_ARM_) // ARM does not have/use .eh_frame, so we handle this elsewhere #include