summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzhanyong.wan <zhanyong.wan@861a406c-534a-0410-8894-cb66d6ee9925>2011-04-14 19:36:05 (GMT)
committerzhanyong.wan <zhanyong.wan@861a406c-534a-0410-8894-cb66d6ee9925>2011-04-14 19:36:05 (GMT)
commitc006f8c12bc74131692a2df8fd64dcedeafe6c77 (patch)
tree245c3119b6d5b8f63903e93d22d5deecb634f06e
parent6a5a25b1e10e9c3c3f4edef0ce322cdf8ce97866 (diff)
downloadgoogletest-c006f8c12bc74131692a2df8fd64dcedeafe6c77.zip
googletest-c006f8c12bc74131692a2df8fd64dcedeafe6c77.tar.gz
googletest-c006f8c12bc74131692a2df8fd64dcedeafe6c77.tar.bz2
fixes a problem caused by gcc 4.6 optimization (by Paul Pluzhnikov)
-rw-r--r--include/gtest/internal/gtest-port.h7
-rw-r--r--src/gtest-death-test.cc5
2 files changed, 12 insertions, 0 deletions
diff --git a/include/gtest/internal/gtest-port.h b/include/gtest/internal/gtest-port.h
index d2bc6cb..c6d102a 100644
--- a/include/gtest/internal/gtest-port.h
+++ b/include/gtest/internal/gtest-port.h
@@ -662,6 +662,13 @@
# define GTEST_API_
#endif
+#if defined(__GNUC__)
+// Ask the compiler to never inline a given function.
+#define GTEST_NO_INLINE_ __attribute__((noinline))
+#else
+#define GTEST_NO_INLINE_
+#endif // __GNUC__
+
namespace testing {
class Message;
diff --git a/src/gtest-death-test.cc b/src/gtest-death-test.cc
index 603fccc..8b2e413 100644
--- a/src/gtest-death-test.cc
+++ b/src/gtest-death-test.cc
@@ -932,6 +932,11 @@ static int ExecDeathTestChildMain(void* child_arg) {
// This could be accomplished more elegantly by a single recursive
// function, but we want to guard against the unlikely possibility of
// a smart compiler optimizing the recursion away.
+//
+// GTEST_NO_INLINE_ is required to prevent GCC 4.6 from inlining
+// StackLowerThanAddress into StackGrowsDown, which then doesn't give
+// correct answer.
+bool StackLowerThanAddress(const void* ptr) GTEST_NO_INLINE_;
bool StackLowerThanAddress(const void* ptr) {
int dummy;
return &dummy < ptr;