llvm-project/clang/test/OpenMP/assume_nesting_tmpl.cpp
David Pagan a5fc7c3ac1
[clang][OpenMP] New OpenMP 6.0 assumption clause, 'no_openmp_constructs' (#125933)
Add initial parsing/sema support for new assumption clause so clause can
be specified. For now, it's ignored, just like the others.

Added support for 'no_openmp_construct' to release notes.

Testing
- Updated appropriate LIT tests.
- Testing: check-all
2025-02-06 12:41:10 -08:00

68 lines
1.3 KiB
C++

// RUN: %clang_cc1 -fopenmp -fopenmp-version=60 -x c++ -std=c++11 -ast-print %s | FileCheck %s
// expected-no-diagnostics
extern void bar();
template<int N>
void foo()
{
#pragma omp assume no_openmp_routines
// CHECK: omp assume no_openmp_routines
{
#pragma omp assume no_parallelism
// CHECK: omp assume no_parallelism
{}
}
#pragma omp assume no_openmp_constructs
// CHECK: omp assume no_openmp_constructs
{
#pragma omp assume no_parallelism
// CHECK: omp assume no_parallelism
{}
}
#pragma omp target
// CHECK: omp target
{
#pragma omp assume holds(1==N)
// CHECK: omp assume holds(1 == N)
{}
}
#pragma omp assume no_parallelism
// CHECK: omp assume no_parallelism
{
#pragma omp target
// CHECK: omp target
{}
}
#pragma omp assume absent(parallel)
// CHECK: omp assume absent(parallel)
{
#pragma omp assume contains(target, loop)
// CHECK: omp assume contains(target, loop)
{
#pragma omp assume holds(1==N)
// CHECK: omp assume holds(1 == N)
{
#pragma omp assume absent(teams)
// CHECK: omp assume absent(teams)
{
#pragma omp assume no_openmp_routines
// CHECK: omp assume no_openmp_routines
{
bar();
}
}
}
}
}
}
int main() {
foo<5>();
return 0;
}