[OPENMP] Bugfix for processing of global variables in OpenMP regions.
Currently, if global variable is marked as a private OpenMP variable, the compiler crashes in debug version or generates incorrect code in release version. It happens because in the OpenMP region the original global variable is used instead of the generated private copy. It happens because currently globals variables are not captured in the OpenMP region. This patch adds capturing of global variables iff private copy of the global variable must be used in the OpenMP region. Differential Revision: http://reviews.llvm.org/D6259 llvm-svn: 224323
This commit is contained in:
@@ -182,6 +182,8 @@ public:
|
||||
/// \brief API for captured statement code generation.
|
||||
class CGCapturedStmtInfo {
|
||||
public:
|
||||
explicit CGCapturedStmtInfo(CapturedRegionKind K = CR_Default)
|
||||
: Kind(K), ThisValue(nullptr), CXXThisFieldDecl(nullptr) {}
|
||||
explicit CGCapturedStmtInfo(const CapturedStmt &S,
|
||||
CapturedRegionKind K = CR_Default)
|
||||
: Kind(K), ThisValue(nullptr), CXXThisFieldDecl(nullptr) {
|
||||
@@ -614,7 +616,6 @@ public:
|
||||
addPrivate(const VarDecl *LocalVD,
|
||||
const std::function<llvm::Value *()> &PrivateGen) {
|
||||
assert(PerformCleanup && "adding private to dead scope");
|
||||
assert(LocalVD->isLocalVarDecl() && "privatizing non-local variable");
|
||||
if (SavedLocals.count(LocalVD) > 0) return false;
|
||||
SavedLocals[LocalVD] = CGF.LocalDeclMap.lookup(LocalVD);
|
||||
CGF.LocalDeclMap.erase(LocalVD);
|
||||
|
||||
Reference in New Issue
Block a user