[PATCH] D33026: [XRay] Fix the test func-id-utils.cc on PPC.
Tim Shen via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed May 10 09:20:21 PDT 2017
This revision was automatically updated to reflect the committed changes.
Closed by commit rL302686: [XRay] Fix the test func-id-utils.cc on PPC. (authored by timshen).
Changed prior to commit:
https://reviews.llvm.org/D33026?vs=98398&id=98476#toc
Repository:
rL LLVM
https://reviews.llvm.org/D33026
Files:
compiler-rt/trunk/test/xray/TestCases/Linux/func-id-utils.cc
Index: compiler-rt/trunk/test/xray/TestCases/Linux/func-id-utils.cc
===================================================================
--- compiler-rt/trunk/test/xray/TestCases/Linux/func-id-utils.cc
+++ compiler-rt/trunk/test/xray/TestCases/Linux/func-id-utils.cc
@@ -3,8 +3,6 @@
//
// RUN: %clangxx_xray -std=c++11 %s -o %t
// RUN: XRAY_OPTIONS="patch_premain=false xray_naive_log=false" %run %t
-// FIXME: When we know why this fails in ppc, un-xfail it.
-// XFAIL: powerpc64le
#include "xray/xray_interface.h"
#include <algorithm>
@@ -32,13 +30,21 @@
assert(all_instrumented.size() == __xray_max_function_id() &&
"each function id must be assigned to a unique function");
- std::set<void *> common;
- std::set_intersection(all_instrumented.begin(), all_instrumented.end(),
- must_be_instrumented.begin(),
- must_be_instrumented.end(),
- std::inserter(common, common.begin()));
+ std::set<void *> not_instrumented;
+ const auto comp = [](void *lhs, void *rhs) {
+#ifdef __PPC__
+ return reinterpret_cast<uintptr_t>(lhs) + 8 <
+ reinterpret_cast<uintptr_t>(rhs);
+#else
+ return lhs < rhs;
+#endif
+ };
+ std::set_difference(must_be_instrumented.begin(), must_be_instrumented.end(),
+ all_instrumented.begin(), all_instrumented.end(),
+ std::inserter(not_instrumented, not_instrumented.begin()),
+ comp);
assert(
- common == must_be_instrumented &&
+ not_instrumented.empty() &&
"we should see all explicitly instrumented functions with function ids");
- return common == must_be_instrumented ? 0 : 1;
+ return not_instrumented.empty() ? 0 : 1;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D33026.98476.patch
Type: text/x-patch
Size: 1749 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170510/3e4f8d2b/attachment.bin>
More information about the llvm-commits
mailing list