summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAmy Kwan <amy.kwan1@ibm.com>2019-04-30 20:09:00 +0000
committerAmy Kwan <amy.kwan1@ibm.com>2019-04-30 20:09:00 +0000
commit31dbbf1df911b2850f9641e2626f5e65846153e1 (patch)
treea94a8adfa7d34d5d03ecb29971c698b142b79e71
parent397ca2f22eeb9dfb3837944212f59514908b3304 (diff)
downloadbcm5719-llvm-31dbbf1df911b2850f9641e2626f5e65846153e1.tar.gz
bcm5719-llvm-31dbbf1df911b2850f9641e2626f5e65846153e1.zip
[compiler-rt][builtins][sanitizers] Update compiler-rt test cases for
compatibility with system's toolchain This patch aims to: - Guard ompiler-rt/test/builtins/Unit/compiler_rt_logb_test.c with macros, so the test runs on GLIBC versions >= 2.23. This is because the test relies on comparing its computed values to libm. Oolder versions might not compute to the same value as the compiler-rt value. - Update compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc so that std::string is not used, since false positives may be detected. Differential Revision: https://reviews.llvm.org/D60644 llvm-svn: 359606
-rw-r--r--compiler-rt/test/builtins/Unit/compiler_rt_logb_test.c7
-rw-r--r--compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc14
2 files changed, 15 insertions, 6 deletions
diff --git a/compiler-rt/test/builtins/Unit/compiler_rt_logb_test.c b/compiler-rt/test/builtins/Unit/compiler_rt_logb_test.c
index cf2a04e4db7..47412532527 100644
--- a/compiler-rt/test/builtins/Unit/compiler_rt_logb_test.c
+++ b/compiler-rt/test/builtins/Unit/compiler_rt_logb_test.c
@@ -36,6 +36,10 @@ double cases[] = {
};
int main() {
+ // Do not the run the compiler-rt logb test case if using GLIBC version
+ // < 2.23. Older versions might not compute to the same value as the
+ // compiler-rt value.
+#if !defined(__GLIBC__) || (defined(__GLIBC_PREREQ) && __GLIBC_PREREQ(2, 23))
const unsigned N = sizeof(cases) / sizeof(cases[0]);
unsigned i;
for (i = 0; i < N; ++i) {
@@ -57,6 +61,9 @@ int main() {
if (test__compiler_rt_logb(fromRep(signBit ^ x))) return 1;
x >>= 1;
}
+#else
+ printf("skipped\n");
+#endif
return 0;
}
diff --git a/compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc b/compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc
index b4bc9b43d0d..c373132eb3e 100644
--- a/compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc
+++ b/compiler-rt/test/sanitizer_common/TestCases/Posix/getpw_getgr.cc
@@ -8,9 +8,8 @@
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
-#include <string>
-std::string any_group;
+std::unique_ptr<char []> any_group;
const int N = 123456;
void Check(const char *str) {
@@ -48,8 +47,11 @@ void Check(const group *result) {
assert(result->gr_gid != N);
for (char **mem = result->gr_mem; *mem; ++mem)
Check(*mem);
- if (any_group.empty())
- any_group = result->gr_name;
+ if (!any_group) {
+ auto length = strlen(result->gr_name);
+ any_group.reset(new char[length + 1]);
+ memcpy(any_group.get(), result->gr_name, length + 1);
+ }
}
template <class T, class Fn, class... Args>
@@ -72,7 +74,7 @@ int main(int argc, const char *argv[]) {
test<passwd>(&getpwuid, 0);
test<passwd>(&getpwnam, "root");
test<group>(&getgrgid, 0);
- test<group>(&getgrnam, any_group.c_str());
+ test<group>(&getgrnam, any_group.get());
#if !defined(__ANDROID__)
setpwent();
@@ -91,7 +93,7 @@ int main(int argc, const char *argv[]) {
test_r<passwd>(&getpwnam_r, "root");
test_r<group>(&getgrgid_r, 0);
- test_r<group>(&getgrnam_r, any_group.c_str());
+ test_r<group>(&getgrnam_r, any_group.get());
#if defined(__linux__)
auto pwd_file = [] {
OpenPOWER on IntegriCloud