summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexey Bataev <a.bataev@hotmail.com>2015-05-05 09:53:25 +0000
committerAlexey Bataev <a.bataev@hotmail.com>2015-05-05 09:53:25 +0000
commitc89567979ac6abc12391bc0bb5bf756b048b500e (patch)
tree72db3d6f6d493e15b3d19ab8b5bc87c03453cb76
parent5eb52b74cb51e4e24998550a235bb2d73c3b18e7 (diff)
downloadbcm5719-llvm-c89567979ac6abc12391bc0bb5bf756b048b500e.tar.gz
bcm5719-llvm-c89567979ac6abc12391bc0bb5bf756b048b500e.zip
[OPENMP] Allow use of macros in OpenMP directives/clauses.
llvm-svn: 236493
-rw-r--r--clang/lib/Parse/ParsePragma.cpp2
-rw-r--r--clang/test/OpenMP/parallel_num_threads_messages.cpp4
2 files changed, 5 insertions, 1 deletions
diff --git a/clang/lib/Parse/ParsePragma.cpp b/clang/lib/Parse/ParsePragma.cpp
index 96484b496d1..a8641efb705 100644
--- a/clang/lib/Parse/ParsePragma.cpp
+++ b/clang/lib/Parse/ParsePragma.cpp
@@ -1489,7 +1489,7 @@ PragmaOpenMPHandler::HandlePragma(Preprocessor &PP,
Token *Toks = new Token[Pragma.size()];
std::copy(Pragma.begin(), Pragma.end(), Toks);
PP.EnterTokenStream(Toks, Pragma.size(),
- /*DisableMacroExpansion=*/true, /*OwnsTokens=*/true);
+ /*DisableMacroExpansion=*/false, /*OwnsTokens=*/true);
}
/// \brief Handle '#pragma pointers_to_members'
diff --git a/clang/test/OpenMP/parallel_num_threads_messages.cpp b/clang/test/OpenMP/parallel_num_threads_messages.cpp
index facca5e3587..e82683893f1 100644
--- a/clang/test/OpenMP/parallel_num_threads_messages.cpp
+++ b/clang/test/OpenMP/parallel_num_threads_messages.cpp
@@ -9,6 +9,8 @@ bool foobool(int argc) {
struct S1; // expected-note {{declared here}}
+#define redef_num_threads(a, b) num_threads(a)
+
template <class T, typename S, int N> // expected-note {{declared here}}
T tmain(T argc, S **argv) {
#pragma omp parallel num_threads // expected-error {{expected '(' after 'num_threads'}}
@@ -22,6 +24,7 @@ T tmain(T argc, S **argv) {
#pragma omp parallel num_threads (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error 2 {{expression must have integral or unscoped enumeration type, not 'char *'}}
#pragma omp parallel num_threads (argc)
#pragma omp parallel num_threads (N) // expected-error {{argument to 'num_threads' clause must be a positive integer value}}
+ #pragma omp parallel redef_num_threads (argc, argc)
foo();
return argc;
@@ -38,6 +41,7 @@ int main(int argc, char **argv) {
#pragma omp parallel num_threads (S1) // expected-error {{'S1' does not refer to a value}}
#pragma omp parallel num_threads (argv[1]=2) // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{expression must have integral or unscoped enumeration type, not 'char *'}}
#pragma omp parallel num_threads (num_threads(tmain<int, char, -1>(argc, argv) // expected-error 2 {{expected ')'}} expected-note 2 {{to match this '('}} expected-note {{in instantiation of function template specialization 'tmain<int, char, -1>' requested here}}
+ #pragma omp parallel redef_num_threads (argc, argc)
foo();
return tmain<int, char, 3>(argc, argv); // expected-note {{in instantiation of function template specialization 'tmain<int, char, 3>' requested here}}
OpenPOWER on IntegriCloud