[OPENMP] Codegen for teams directive for NVPTX
authorCarlo Bertolli <cbertol@us.ibm.com>
Mon, 4 Apr 2016 15:55:02 +0000 (15:55 +0000)
committerCarlo Bertolli <cbertol@us.ibm.com>
Mon, 4 Apr 2016 15:55:02 +0000 (15:55 +0000)
commitc687225b436cd0ff0a6061a6f79f13c35e6b6228
tree71f1428bdf6f4138fd2c53ebe76960b814fc4ec2
parent1eec3f01f07c88325f9958b85dee8d33f548af52
[OPENMP] Codegen for teams directive for NVPTX

This patch implements the teams directive for the NVPTX backend. It is different from the host code generation path as it:

Does not call kmpc_fork_teams. All necessary teams and threads are started upon touching the target region, when launching a CUDA kernel, and their execution is coordinated through sequential and parallel regions within the target region.
Does not call kmpc_push_num_teams even if a num_teams of thread_limit clause is present. Setting the number of teams and the thread limit is implemented by the nvptx-related runtime.
Please note that I am now passing a Clang Expr * to emitPushNumTeams instead of the originally chosen llvm::Value * type. The reason for that is that I want to avoid emitting expressions for num_teams and thread_limit if they are not needed in the target region.

http://reviews.llvm.org/D17963

llvm-svn: 265304
clang/lib/CodeGen/CGOpenMPRuntime.cpp
clang/lib/CodeGen/CGOpenMPRuntime.h
clang/lib/CodeGen/CGOpenMPRuntimeNVPTX.cpp
clang/lib/CodeGen/CGOpenMPRuntimeNVPTX.h
clang/lib/CodeGen/CGStmtOpenMP.cpp
clang/test/OpenMP/nvptx_teams_codegen.cpp [new file with mode: 0644]