Browse Source

[Minor] Support `backtrace` where libunwind is not supported

tags/3.7.1
Vsevolod Stakhov 9 months ago
parent
commit
96db4ae5ce
No account linked to committer's email address
3 changed files with 21 additions and 5 deletions
  1. 3
    1
      CMakeLists.txt
  2. 1
    0
      config.h.in
  3. 17
    4
      src/libserver/worker_util.c

+ 3
- 1
CMakeLists.txt View File

ProcessPackage(LIBUNWIND LIBRARY unwind INCLUDE libunwind.h INCLUDE_SUFFIXES include/libunwind ProcessPackage(LIBUNWIND LIBRARY unwind INCLUDE libunwind.h INCLUDE_SUFFIXES include/libunwind
ROOT ${LIBUNWIND_ROOT_DIR} MODULES libunwind) ROOT ${LIBUNWIND_ROOT_DIR} MODULES libunwind)
SET(WITH_LIBUNWIND "1") SET(WITH_LIBUNWIND "1")
ELSE ()
CHECK_SYMBOL_EXISTS(backtrace "execinfo.h" HAVE_BACKTRACE)
ENDIF () ENDIF ()


ProcessPackage(GLIB2 LIBRARY glib-2.0 INCLUDE glib.h ProcessPackage(GLIB2 LIBRARY glib-2.0 INCLUDE glib.h
ADD_CUSTOM_TARGET(check DEPENDS rspamd-test-cxx rspamd-test) ADD_CUSTOM_TARGET(check DEPENDS rspamd-test-cxx rspamd-test)
ADD_CUSTOM_TARGET(run-test DEPENDS check ADD_CUSTOM_TARGET(run-test DEPENDS check
COMMAND test/rspamd-test-cxx COMMAND test/rspamd-test-cxx
COMMAND sh -c 'LUA_PATH="${CMAKE_SOURCE_DIR}/lualib/?.lua\;${CMAKE_SOURCE_DIR}/lualib/?/?.lua\;${CMAKE_SOURCE_DIR}/lualib/?/init.lua\;${CMAKE_SOURCE_DIR}/contrib/lua-?/?.lua"
COMMAND sh -c 'LUA_PATH= "${CMAKE_SOURCE_DIR}/lualib/?.lua\;${CMAKE_SOURCE_DIR}/lualib/?/?.lua\;${CMAKE_SOURCE_DIR}/lualib/?/init.lua\;${CMAKE_SOURCE_DIR}/contrib/lua-?/?.lua"
test/rspamd-test -p /rspamd/lua') test/rspamd-test -p /rspamd/lua')
ENDIF (NOT DEBIAN_BUILD) ENDIF (NOT DEBIAN_BUILD)



+ 1
- 0
config.h.in View File

#cmakedefine WITH_LUA_TRACE 1 #cmakedefine WITH_LUA_TRACE 1
#cmakedefine WITH_LUA_REPL 1 #cmakedefine WITH_LUA_REPL 1
#cmakedefine WITH_FASTTEXT 1 #cmakedefine WITH_FASTTEXT 1
#cmakedefine HAVE_BACKTRACE 1


#cmakedefine DISABLE_PTHREAD_MUTEX 1 #cmakedefine DISABLE_PTHREAD_MUTEX 1



+ 17
- 4
src/libserver/worker_util.c View File

/*-
* Copyright 2016 Vsevolod Stakhov
/*
* Copyright 2023 Vsevolod Stakhov
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
* You may obtain a copy of the License at * You may obtain a copy of the License at
* *
* http://www.apache.org/licenses/LICENSE-2.0
* http://www.apache.org/licenses/LICENSE-2.0
* *
* Unless required by applicable law or agreed to in writing, software * Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, * distributed under the License is distributed on an "AS IS" BASIS,
msg_err("unw_step_ptr: %d", ret); msg_err("unw_step_ptr: %d", ret);
} }
} }
#elif defined(HAVE_BACKTRACE)
#include <execinfo.h>
static void
rspamd_print_crash(ucontext_t *_uap)
{
void *callstack[128];
int i, frames = backtrace(callstack, 128);
char **strs = backtrace_symbols(callstack, frames);
for (i = 0; i < frames; ++i) {
msg_err("%d: %s", i, strs[i]);
}
free(strs);
}
#endif #endif


static struct rspamd_main *saved_main = NULL; static struct rspamd_main *saved_main = NULL;
"pid: %P, trace: ", "pid: %P, trace: ",
sig, strsignal(sig), pid); sig, strsignal(sig), pid);
(void) uap; (void) uap;
#ifdef WITH_LIBUNWIND
#if defined(WITH_LIBUNWIND) || defined(HAVE_BACKTRACE)
rspamd_print_crash(uap); rspamd_print_crash(uap);
#endif #endif
msg_err("please see Rspamd FAQ to learn how to dump core files and how to " msg_err("please see Rspamd FAQ to learn how to dump core files and how to "

Loading…
Cancel
Save