[sanitizer] Fix suffix-log-path_test.c on arm-linux-gnu
The recent suffix-log-path_test.c checks for a full stacktrace and
since on some arm-linux-gnu configuration the slow unwinder is used
on default (when the compiler emits thumb code as default), it
requires -funwind-tables on tests.
It also seems to fix the issues disable by d025df3c1de.
Reviewed By: ostannard
Differential Revision: https://reviews.llvm.org/D96337
GitOrigin-RevId: 88d1724d9b5615fd2e7acf808aac69eeadf7eae7
diff --git a/test/lsan/TestCases/Linux/cleanup_in_tsd_destructor.c b/test/lsan/TestCases/Linux/cleanup_in_tsd_destructor.c
index c26d33d..18476d5 100644
--- a/test/lsan/TestCases/Linux/cleanup_in_tsd_destructor.c
+++ b/test/lsan/TestCases/Linux/cleanup_in_tsd_destructor.c
@@ -8,9 +8,6 @@
// RUN: %env_lsan_opts=$LSAN_BASE:use_tls=1 %run %t
// RUN: %env_lsan_opts=$LSAN_BASE:use_tls=0 not %run %t 2>&1 | FileCheck %s
-// Investigate why it does not fail with use_stack=0
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <assert.h>
#include <pthread.h>
#include <stdio.h>
diff --git a/test/lsan/TestCases/Linux/use_tls_pthread_specific_dynamic.cpp b/test/lsan/TestCases/Linux/use_tls_pthread_specific_dynamic.cpp
index ecb6dbe..650e6ad 100644
--- a/test/lsan/TestCases/Linux/use_tls_pthread_specific_dynamic.cpp
+++ b/test/lsan/TestCases/Linux/use_tls_pthread_specific_dynamic.cpp
@@ -5,9 +5,6 @@
// RUN: %env_lsan_opts=$LSAN_BASE:"use_tls=1" %run %t 2>&1
// RUN: %env_lsan_opts="" %run %t 2>&1
-// Investigate why it does not fail with use_tls=0
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <assert.h>
#include <pthread.h>
#include <stdio.h>
diff --git a/test/lsan/TestCases/disabler.c b/test/lsan/TestCases/disabler.c
index 6bfca7a..73f1b3e 100644
--- a/test/lsan/TestCases/disabler.c
+++ b/test/lsan/TestCases/disabler.c
@@ -3,9 +3,6 @@
// RUN: %clang_lsan %s -o %t
// RUN: %env_lsan_opts=$LSAN_BASE not %run %t 2>&1 | FileCheck %s
-// Investigate why it does not fail with use_stack=0
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <stdio.h>
#include <stdlib.h>
diff --git a/test/lsan/TestCases/do_leak_check_override.cpp b/test/lsan/TestCases/do_leak_check_override.cpp
index 3503eb0..40a9763 100644
--- a/test/lsan/TestCases/do_leak_check_override.cpp
+++ b/test/lsan/TestCases/do_leak_check_override.cpp
@@ -6,9 +6,6 @@
// RUN: %env_lsan_opts=$LSAN_BASE not %run %t 2>&1 | FileCheck --check-prefix=CHECK-strict %s
// RUN: %env_lsan_opts=$LSAN_BASE not %run %t foo 2>&1 | FileCheck --check-prefix=CHECK-normal %s
-// Investigate why LeakyGlobal leak does show
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <stdio.h>
#include <stdlib.h>
#include <sanitizer/lsan_interface.h>
diff --git a/test/lsan/TestCases/ignore_object.c b/test/lsan/TestCases/ignore_object.c
index e5fc012..92f03ee 100644
--- a/test/lsan/TestCases/ignore_object.c
+++ b/test/lsan/TestCases/ignore_object.c
@@ -3,9 +3,6 @@
// RUN: %clang_lsan %s -o %t
// RUN: %env_lsan_opts=$LSAN_BASE not %run %t 2>&1 | FileCheck %s
-// Investigate why it does not fail with use_stack=0
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <stdio.h>
#include <stdlib.h>
diff --git a/test/lsan/TestCases/use_after_return.cpp b/test/lsan/TestCases/use_after_return.cpp
index decab6c..5c60ec6 100644
--- a/test/lsan/TestCases/use_after_return.cpp
+++ b/test/lsan/TestCases/use_after_return.cpp
@@ -6,9 +6,6 @@
// RUN: ASAN_OPTIONS=$ASAN_OPTIONS:detect_stack_use_after_return=1 %env_lsan_opts=$LSAN_BASE:"use_stacks=1" %run %t 2>&1
// RUN: ASAN_OPTIONS=$ASAN_OPTIONS:detect_stack_use_after_return=1 %env_lsan_opts="" %run %t 2>&1
-// Investigate why it does not fail with use_stack=0
-// UNSUPPORTED: arm-linux || armhf-linux
-
#include <stdio.h>
#include <stdlib.h>
#include "sanitizer_common/print_address.h"
diff --git a/test/sanitizer_common/CMakeLists.txt b/test/sanitizer_common/CMakeLists.txt
index 7f1b0f2..3af62a0 100644
--- a/test/sanitizer_common/CMakeLists.txt
+++ b/test/sanitizer_common/CMakeLists.txt
@@ -76,6 +76,15 @@
set(SANITIZER_COMMON_TEST_TARGET_ARCH ${arch})
get_test_cc_for_arch(${arch} SANITIZER_COMMON_TEST_TARGET_CC SANITIZER_COMMON_TEST_TARGET_CFLAGS)
set(CONFIG_NAME ${tool}-${arch}-${OS_NAME})
+
+ # ARM on Linux might use the slow unwinder as default and the unwind table is
+ # required to get a complete stacktrace.
+ if ("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux" AND NOT ANDROID)
+ list(APPEND SANITIZER_COMMON_TEST_TARGET_CFLAGS -funwind-tables)
+ string(REPLACE ";" " " SANITIZER_COMMON_TEST_TARGET_CFLAGS
+ "${SANITIZER_COMMON_TEST_TARGET_CFLAGS}")
+ endif()
+
configure_lit_site_cfg(
${CMAKE_CURRENT_SOURCE_DIR}/lit.site.cfg.py.in
${CMAKE_CURRENT_BINARY_DIR}/${CONFIG_NAME}/lit.site.cfg.py)