mirror of
https://github.com/intel/llvm.git
synced 2026-01-20 10:58:11 +08:00
When testing with sanitizers enabled, we need to link against a plethora of system libraries. Using `-nodefaultlibs` like we used to breaks this, and we would have to add all these system libraries manually, which is not portable and error prone. Instead, stop using `-nodefaultlibs` so that we get the libraries added by default by the compiler. The only caveat with this approach is that we are now relying on the fact that `-L <path-to-local-libunwind>` will cause the just built libunwind to be selected before the system implementation (either of libunwind or libgcc_s.so), which is somewhat fragile. This patch also turns the 32 bit multilib build into a soft failure since we are in the process of removing it anyway, see D114473 for details. This patch is incompatible with the 32 bit multilib build because Ubuntu does not provide a proper libstdc++ for 32 bits, and that is required when running with sanitizers enabled. Differential Revision: https://reviews.llvm.org/D114385
40 lines
655 B
C++
40 lines
655 B
C++
#include <assert.h>
|
|
#include <stdlib.h>
|
|
#include <unwind.h>
|
|
|
|
#define EXPECTED_NUM_FRAMES 50
|
|
#define NUM_FRAMES_UPPER_BOUND 100
|
|
|
|
_Unwind_Reason_Code callback(_Unwind_Context *context, void *cnt) {
|
|
(void)context;
|
|
int *i = (int *)cnt;
|
|
++*i;
|
|
if (*i > NUM_FRAMES_UPPER_BOUND) {
|
|
abort();
|
|
}
|
|
return _URC_NO_REASON;
|
|
}
|
|
|
|
void test_backtrace() {
|
|
int n = 0;
|
|
_Unwind_Backtrace(&callback, &n);
|
|
if (n < EXPECTED_NUM_FRAMES) {
|
|
abort();
|
|
}
|
|
}
|
|
|
|
int test(int i) {
|
|
if (i == 0) {
|
|
test_backtrace();
|
|
return 0;
|
|
} else {
|
|
return i + test(i - 1);
|
|
}
|
|
}
|
|
|
|
int main(int, char**) {
|
|
int total = test(50);
|
|
assert(total == 1275);
|
|
return 0;
|
|
}
|