forked from OSchip/llvm-project
Revert "[OPENMP]Initial support for the delayed diagnostics."
This reverts commit r353540. Erroneously committed, need to fix the message and description. llvm-svn: 353541
This commit is contained in:
parent
5e62adad0d
commit
346fb4bbcd
|
@ -203,6 +203,7 @@ LANGOPT(OpenMPUseTLS , 1, 0, "Use TLS for threadprivates or runtime calls")
|
||||||
LANGOPT(OpenMPIsDevice , 1, 0, "Generate code only for OpenMP target device")
|
LANGOPT(OpenMPIsDevice , 1, 0, "Generate code only for OpenMP target device")
|
||||||
LANGOPT(OpenMPCUDAMode , 1, 0, "Generate code for OpenMP pragmas in SIMT/SPMD mode")
|
LANGOPT(OpenMPCUDAMode , 1, 0, "Generate code for OpenMP pragmas in SIMT/SPMD mode")
|
||||||
LANGOPT(OpenMPCUDAForceFullRuntime , 1, 0, "Force to use full runtime in all constructs when offloading to CUDA devices")
|
LANGOPT(OpenMPCUDAForceFullRuntime , 1, 0, "Force to use full runtime in all constructs when offloading to CUDA devices")
|
||||||
|
LANGOPT(OpenMPHostCXXExceptions , 1, 0, "C++ exceptions handling in the host code.")
|
||||||
LANGOPT(OpenMPCUDANumSMs , 32, 0, "Number of SMs for CUDA devices.")
|
LANGOPT(OpenMPCUDANumSMs , 32, 0, "Number of SMs for CUDA devices.")
|
||||||
LANGOPT(OpenMPCUDABlocksPerSM , 32, 0, "Number of blocks per SM for CUDA devices.")
|
LANGOPT(OpenMPCUDABlocksPerSM , 32, 0, "Number of blocks per SM for CUDA devices.")
|
||||||
LANGOPT(OpenMPOptimisticCollapse , 1, 0, "Use at most 32 bits to represent the collapsed loop nest counter.")
|
LANGOPT(OpenMPOptimisticCollapse , 1, 0, "Use at most 32 bits to represent the collapsed loop nest counter.")
|
||||||
|
|
|
@ -8763,9 +8763,6 @@ private:
|
||||||
/// Pop OpenMP function region for non-capturing function.
|
/// Pop OpenMP function region for non-capturing function.
|
||||||
void popOpenMPFunctionRegion(const sema::FunctionScopeInfo *OldFSI);
|
void popOpenMPFunctionRegion(const sema::FunctionScopeInfo *OldFSI);
|
||||||
|
|
||||||
/// Check whether we're allowed to call Callee from the current function.
|
|
||||||
void checkOpenMPDeviceFunction(SourceLocation Loc, FunctionDecl *Callee);
|
|
||||||
|
|
||||||
/// Checks if a type or a declaration is disabled due to the owning extension
|
/// Checks if a type or a declaration is disabled due to the owning extension
|
||||||
/// being disabled, and emits diagnostic messages if it is disabled.
|
/// being disabled, and emits diagnostic messages if it is disabled.
|
||||||
/// \param D type or declaration to be checked.
|
/// \param D type or declaration to be checked.
|
||||||
|
@ -10252,23 +10249,6 @@ public:
|
||||||
/// Same as CUDADiagIfDeviceCode, with "host" and "device" switched.
|
/// Same as CUDADiagIfDeviceCode, with "host" and "device" switched.
|
||||||
DeviceDiagBuilder CUDADiagIfHostCode(SourceLocation Loc, unsigned DiagID);
|
DeviceDiagBuilder CUDADiagIfHostCode(SourceLocation Loc, unsigned DiagID);
|
||||||
|
|
||||||
/// Creates a DeviceDiagBuilder that emits the diagnostic if the current
|
|
||||||
/// context is "used as device code".
|
|
||||||
///
|
|
||||||
/// - If CurContext is a `declare target` function or it is known that the
|
|
||||||
/// function is emitted for the device, emits the diagnostics immediately.
|
|
||||||
/// - If CurContext is a non-`declare target` function and we are compiling
|
|
||||||
/// for the device, creates a diagnostic which is emitted if and when we
|
|
||||||
/// realize that the function will be codegen'ed.
|
|
||||||
///
|
|
||||||
/// Example usage:
|
|
||||||
///
|
|
||||||
/// // Variable-length arrays are not allowed in NVPTX device code.
|
|
||||||
/// if (diagIfOpenMPDeviceCode(Loc, diag::err_vla_unsupported))
|
|
||||||
/// return ExprError();
|
|
||||||
/// // Otherwise, continue parsing as normal.
|
|
||||||
DeviceDiagBuilder diagIfOpenMPDeviceCode(SourceLocation Loc, unsigned DiagID);
|
|
||||||
|
|
||||||
enum CUDAFunctionTarget {
|
enum CUDAFunctionTarget {
|
||||||
CFT_Device,
|
CFT_Device,
|
||||||
CFT_Global,
|
CFT_Global,
|
||||||
|
|
|
@ -2827,6 +2827,7 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
|
||||||
|
|
||||||
// Set the flag to prevent the implementation from emitting device exception
|
// Set the flag to prevent the implementation from emitting device exception
|
||||||
// handling code for those requiring so.
|
// handling code for those requiring so.
|
||||||
|
Opts.OpenMPHostCXXExceptions = Opts.Exceptions && Opts.CXXExceptions;
|
||||||
if ((Opts.OpenMPIsDevice && T.isNVPTX()) || Opts.OpenCLCPlusPlus) {
|
if ((Opts.OpenMPIsDevice && T.isNVPTX()) || Opts.OpenCLCPlusPlus) {
|
||||||
Opts.Exceptions = 0;
|
Opts.Exceptions = 0;
|
||||||
Opts.CXXExceptions = 0;
|
Opts.CXXExceptions = 0;
|
||||||
|
|
|
@ -14896,9 +14896,6 @@ void Sema::MarkFunctionReferenced(SourceLocation Loc, FunctionDecl *Func,
|
||||||
}
|
}
|
||||||
|
|
||||||
Func->markUsed(Context);
|
Func->markUsed(Context);
|
||||||
|
|
||||||
if (LangOpts.OpenMP && LangOpts.OpenMPIsDevice)
|
|
||||||
checkOpenMPDeviceFunction(Loc, Func);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -750,13 +750,12 @@ ExprResult Sema::BuildCXXThrow(SourceLocation OpLoc, Expr *Ex,
|
||||||
bool IsThrownVarInScope) {
|
bool IsThrownVarInScope) {
|
||||||
// Don't report an error if 'throw' is used in system headers.
|
// Don't report an error if 'throw' is used in system headers.
|
||||||
if (!getLangOpts().CXXExceptions &&
|
if (!getLangOpts().CXXExceptions &&
|
||||||
!getSourceManager().isInSystemHeader(OpLoc)) {
|
!getSourceManager().isInSystemHeader(OpLoc) &&
|
||||||
// Delay error emission for the OpenMP device code.
|
(!getLangOpts().OpenMPIsDevice ||
|
||||||
if (LangOpts.OpenMP && LangOpts.OpenMPIsDevice)
|
!getLangOpts().OpenMPHostCXXExceptions ||
|
||||||
diagIfOpenMPDeviceCode(OpLoc, diag::err_exceptions_disabled) << "throw";
|
isInOpenMPTargetExecutionDirective() ||
|
||||||
else
|
isInOpenMPDeclareTargetContext()))
|
||||||
Diag(OpLoc, diag::err_exceptions_disabled) << "throw";
|
Diag(OpLoc, diag::err_exceptions_disabled) << "throw";
|
||||||
}
|
|
||||||
|
|
||||||
// Exceptions aren't allowed in CUDA device code.
|
// Exceptions aren't allowed in CUDA device code.
|
||||||
if (getLangOpts().CUDA)
|
if (getLangOpts().CUDA)
|
||||||
|
|
|
@ -1393,56 +1393,6 @@ void Sema::popOpenMPFunctionRegion(const FunctionScopeInfo *OldFSI) {
|
||||||
DSAStack->popFunction(OldFSI);
|
DSAStack->popFunction(OldFSI);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool isOpenMPDeviceDelayedContext(Sema &S) {
|
|
||||||
assert(S.LangOpts.OpenMP && S.LangOpts.OpenMPIsDevice &&
|
|
||||||
"Expected OpenMP device compilation.");
|
|
||||||
return !S.isInOpenMPTargetExecutionDirective() &&
|
|
||||||
!S.isInOpenMPDeclareTargetContext();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Do we know that we will eventually codegen the given function?
|
|
||||||
static bool isKnownEmitted(Sema &S, FunctionDecl *FD) {
|
|
||||||
assert(S.LangOpts.OpenMP && S.LangOpts.OpenMPIsDevice &&
|
|
||||||
"Expected OpenMP device compilation.");
|
|
||||||
// Templates are emitted when they're instantiated.
|
|
||||||
if (FD->isDependentContext())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (OMPDeclareTargetDeclAttr::isDeclareTargetDeclaration(
|
|
||||||
FD->getCanonicalDecl()))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// Otherwise, the function is known-emitted if it's in our set of
|
|
||||||
// known-emitted functions.
|
|
||||||
return S.DeviceKnownEmittedFns.count(FD) > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Sema::DeviceDiagBuilder Sema::diagIfOpenMPDeviceCode(SourceLocation Loc,
|
|
||||||
unsigned DiagID) {
|
|
||||||
assert(LangOpts.OpenMP && LangOpts.OpenMPIsDevice &&
|
|
||||||
"Expected OpenMP device compilation.");
|
|
||||||
return DeviceDiagBuilder((isOpenMPDeviceDelayedContext(*this) &&
|
|
||||||
!isKnownEmitted(*this, getCurFunctionDecl()))
|
|
||||||
? DeviceDiagBuilder::K_Deferred
|
|
||||||
: DeviceDiagBuilder::K_Immediate,
|
|
||||||
Loc, DiagID, getCurFunctionDecl(), *this);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Sema::checkOpenMPDeviceFunction(SourceLocation Loc, FunctionDecl *Callee) {
|
|
||||||
assert(LangOpts.OpenMP && LangOpts.OpenMPIsDevice &&
|
|
||||||
"Expected OpenMP device compilation.");
|
|
||||||
assert(Callee && "Callee may not be null.");
|
|
||||||
FunctionDecl *Caller = getCurFunctionDecl();
|
|
||||||
|
|
||||||
// If the caller is known-emitted, mark the callee as known-emitted.
|
|
||||||
// Otherwise, mark the call in our call graph so we can traverse it later.
|
|
||||||
if (!isOpenMPDeviceDelayedContext(*this) ||
|
|
||||||
(Caller && isKnownEmitted(*this, Caller)))
|
|
||||||
markKnownEmitted(*this, Caller, Callee, Loc, isKnownEmitted);
|
|
||||||
else if (Caller)
|
|
||||||
DeviceCallGraph[Caller].insert({Callee, Loc});
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Sema::isOpenMPCapturedByRef(const ValueDecl *D, unsigned Level) const {
|
bool Sema::isOpenMPCapturedByRef(const ValueDecl *D, unsigned Level) const {
|
||||||
assert(LangOpts.OpenMP && "OpenMP is not allowed");
|
assert(LangOpts.OpenMP && "OpenMP is not allowed");
|
||||||
|
|
||||||
|
|
|
@ -3997,13 +3997,12 @@ StmtResult Sema::ActOnCXXTryBlock(SourceLocation TryLoc, Stmt *TryBlock,
|
||||||
ArrayRef<Stmt *> Handlers) {
|
ArrayRef<Stmt *> Handlers) {
|
||||||
// Don't report an error if 'try' is used in system headers.
|
// Don't report an error if 'try' is used in system headers.
|
||||||
if (!getLangOpts().CXXExceptions &&
|
if (!getLangOpts().CXXExceptions &&
|
||||||
!getSourceManager().isInSystemHeader(TryLoc)) {
|
!getSourceManager().isInSystemHeader(TryLoc) &&
|
||||||
// Delay error emission for the OpenMP device code.
|
(!getLangOpts().OpenMPIsDevice ||
|
||||||
if (LangOpts.OpenMP && LangOpts.OpenMPIsDevice)
|
!getLangOpts().OpenMPHostCXXExceptions ||
|
||||||
diagIfOpenMPDeviceCode(TryLoc, diag::err_exceptions_disabled) << "try";
|
isInOpenMPTargetExecutionDirective() ||
|
||||||
else
|
isInOpenMPDeclareTargetContext()))
|
||||||
Diag(TryLoc, diag::err_exceptions_disabled) << "try";
|
Diag(TryLoc, diag::err_exceptions_disabled) << "try";
|
||||||
}
|
|
||||||
|
|
||||||
// Exceptions aren't allowed in CUDA device code.
|
// Exceptions aren't allowed in CUDA device code.
|
||||||
if (getLangOpts().CUDA)
|
if (getLangOpts().CUDA)
|
||||||
|
|
|
@ -68,17 +68,4 @@ int baz2() {
|
||||||
return 2 + baz3();
|
return 2 + baz3();
|
||||||
}
|
}
|
||||||
|
|
||||||
int baz1() { throw 1; } // expected-error {{cannot use 'throw' with exceptions disabled}}
|
|
||||||
|
|
||||||
int foobar1();
|
|
||||||
int foobar2();
|
|
||||||
|
|
||||||
int (*A)() = &foobar1;
|
|
||||||
#pragma omp declare target
|
|
||||||
int (*B)() = &foobar2;
|
|
||||||
#pragma omp end declare target
|
|
||||||
|
|
||||||
int foobar1() { throw 1; }
|
|
||||||
int foobar2() { throw 1; } // expected-error {{cannot use 'throw' with exceptions disabled}}
|
|
||||||
|
|
||||||
#endif // HEADER
|
#endif // HEADER
|
||||||
|
|
Loading…
Reference in New Issue