Author: abataev Date: Mon Sep 16 10:06:31 2019 New Revision: 372011 URL: http://llvm.org/viewvc/llvm-project?rev=372011&view=rev Log: [OPENMP]Fix parsing/sema for function templates with declare simd.
Need to return original declaration group with FunctionTemplateDecl, not the inner FunctionDecl, to correctly handle parsing of directives with the templates parameters. Modified: cfe/trunk/lib/Sema/SemaOpenMP.cpp cfe/trunk/test/OpenMP/declare_simd_ast_print.cpp Modified: cfe/trunk/lib/Sema/SemaOpenMP.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaOpenMP.cpp?rev=372011&r1=372010&r2=372011&view=diff ============================================================================== --- cfe/trunk/lib/Sema/SemaOpenMP.cpp (original) +++ cfe/trunk/lib/Sema/SemaOpenMP.cpp Mon Sep 16 10:06:31 2019 @@ -4889,7 +4889,7 @@ Sema::DeclGroupPtrTy Sema::ActOnOpenMPDe const_cast<unsigned *>(LinModifiers.data()), LinModifiers.size(), NewSteps.data(), NewSteps.size(), SR); ADecl->addAttr(NewAttr); - return ConvertDeclToDeclGroup(ADecl); + return DG; } Sema::DeclGroupPtrTy Modified: cfe/trunk/test/OpenMP/declare_simd_ast_print.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/OpenMP/declare_simd_ast_print.cpp?rev=372011&r1=372010&r2=372011&view=diff ============================================================================== --- cfe/trunk/test/OpenMP/declare_simd_ast_print.cpp (original) +++ cfe/trunk/test/OpenMP/declare_simd_ast_print.cpp Mon Sep 16 10:06:31 2019 @@ -21,6 +21,15 @@ void add_1(float *d) __attribute__((cold // CHECK-NEXT: void add_1(float *d) __attribute__((cold)); // +#pragma omp declare simd aligned(hp, hp2:V) +#pragma omp declare simd aligned(hp, hp2:V) +template <class C, int V> void h(C *hp, C *hp2, C *hq, C *lin) { +} +// CHECK-NEXT: #pragma omp declare simd aligned(hp: V) aligned(hp2: V) +// CHECK-NEXT: #pragma omp declare simd aligned(hp: V) aligned(hp2: V) +// CHECK-NEXT: template <class C, int V> void h(C *hp, C *hp2, C *hq, C *lin) { +// CHECK-NEXT: } + #pragma omp declare simd aligned(hp, hp2) template <class C> void h(C *hp, C *hp2, C *hq, C *lin) { } _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits