diff options
author | Adrian McCarthy <amccarth@google.com> | 2016-02-29 21:13:29 +0000 |
---|---|---|
committer | Adrian McCarthy <amccarth@google.com> | 2016-02-29 21:13:29 +0000 |
commit | 536183275d67c1de31066386070a2fe9b403e241 (patch) | |
tree | 9c5d19fb559b9a2da11a3ddfc19bcad6199106cd /lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp | |
parent | 936499ae4cdb4f4601e7c0561be4fdd8a05fb04e (diff) | |
download | bcm5719-llvm-536183275d67c1de31066386070a2fe9b403e241.tar.gz bcm5719-llvm-536183275d67c1de31066386070a2fe9b403e241.zip |
Fix TestInlines.py on Windows
The inlining semantics for C and C++ are different, which affects the test's expectation of the number of times the function should appear in the binary. In the case of this test, C semantics means there should be three instances of inner_inline, while C++ semantics means there should be only two.
On Windows, clang uses C++ inline semantics even for C code, and there doesn't seem to be a combination of compiler flags to avoid this.
So, for consistency, I've recast the test to use C++ everywhere. Since the test resided under lang/c, it seemed appropriate to move it to lang/cpp.
This does not address the other XFAIL for this test on Linux/gcc. See https://llvm.org/bugs/show_bug.cgi?id=26710
Differential Revision: http://reviews.llvm.org/D17650
llvm-svn: 262255
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp')
-rw-r--r-- | lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp b/lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp new file mode 100644 index 00000000000..822d88e22f9 --- /dev/null +++ b/lldb/packages/Python/lldbsuite/test/lang/cpp/inlines/inlines.cpp @@ -0,0 +1,53 @@ +#include <stdio.h> +#include "inlines.h" + +#define INLINE_ME __inline__ __attribute__((always_inline)) + +int +not_inlined_2 (int input) +{ + printf ("Called in not_inlined_2 with : %d.\n", input); + return input; +} + +int +not_inlined_1 (int input) +{ + printf ("Called in not_inlined_1 with %d.\n", input); + return not_inlined_2(input); +} + +INLINE_ME int +inner_inline (int inner_input, int mod_value) +{ + int inner_result; + inner_result = inner_input % mod_value; + printf ("Returning: %d.\n", inner_result); + return not_inlined_1 (inner_result); // Set break point at this line. +} + +INLINE_ME int +outer_inline (int outer_input) +{ + int outer_result; + + outer_result = inner_inline (outer_input, outer_input % 3); + return outer_result; +} + +int +main (int argc, char **argv) +{ + printf ("Starting...\n"); + + int (*func_ptr) (int); + func_ptr = outer_inline; + + outer_inline (argc); + + func_ptr (argc); + + return 0; +} + + |