mirror of
https://github.com/intel/llvm.git
synced 2026-01-30 22:53:05 +08:00
[OPENMP] Fixed processing of '-fopenmp-version=' option and test.
llvm-svn: 270962
This commit is contained in:
@@ -4864,7 +4864,6 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
||||
// Forward flags for OpenMP
|
||||
if (Args.hasFlag(options::OPT_fopenmp, options::OPT_fopenmp_EQ,
|
||||
options::OPT_fno_openmp, false)) {
|
||||
Args.AddAllArgs(CmdArgs, options::OPT_fopenmp_version_EQ);
|
||||
switch (getOpenMPRuntime(getToolChain(), Args)) {
|
||||
case OMPRT_OMP:
|
||||
case OMPRT_IOMP5:
|
||||
@@ -4877,6 +4876,7 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
||||
if (!Args.hasFlag(options::OPT_fopenmp_use_tls,
|
||||
options::OPT_fnoopenmp_use_tls, /*Default=*/true))
|
||||
CmdArgs.push_back("-fnoopenmp-use-tls");
|
||||
Args.AddAllArgs(CmdArgs, options::OPT_fopenmp_version_EQ);
|
||||
break;
|
||||
default:
|
||||
// By default, if Clang doesn't know how to generate useful OpenMP code
|
||||
|
||||
@@ -1954,15 +1954,16 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
|
||||
}
|
||||
|
||||
// Check if -fopenmp is specified.
|
||||
Opts.OpenMP = Args.hasArg(options::OPT_fopenmp);
|
||||
Opts.OpenMP = Args.hasArg(options::OPT_fopenmp) ? 1 : 0;
|
||||
Opts.OpenMPUseTLS =
|
||||
Opts.OpenMP && !Args.hasArg(options::OPT_fnoopenmp_use_tls);
|
||||
Opts.OpenMPIsDevice =
|
||||
Opts.OpenMP && Args.hasArg(options::OPT_fopenmp_is_device);
|
||||
|
||||
if (Opts.OpenMP) {
|
||||
if (int Version = getLastArgIntValue(Args, OPT_fopenmp_version_EQ,
|
||||
Opts.OpenMP, Diags))
|
||||
int Version =
|
||||
getLastArgIntValue(Args, OPT_fopenmp_version_EQ, Opts.OpenMP, Diags);
|
||||
if (Version != 0)
|
||||
Opts.OpenMP = Version;
|
||||
// Provide diagnostic when a given target is not expected to be an OpenMP
|
||||
// device or host.
|
||||
|
||||
@@ -922,24 +922,24 @@ static void InitializePredefinedMacros(const TargetInfo &TI,
|
||||
}
|
||||
|
||||
// OpenMP definition
|
||||
if (LangOpts.OpenMP) {
|
||||
// OpenMP 2.2:
|
||||
// In implementations that support a preprocessor, the _OPENMP
|
||||
// macro name is defined to have the decimal value yyyymm where
|
||||
// yyyy and mm are the year and the month designations of the
|
||||
// version of the OpenMP API that the implementation support.
|
||||
switch (LangOpts.OpenMP) {
|
||||
case 40:
|
||||
Builder.defineMacro("_OPENMP", "201307");
|
||||
break;
|
||||
case 45:
|
||||
Builder.defineMacro("_OPENMP", "201511");
|
||||
break;
|
||||
default:
|
||||
// Default version is OpenMP 3.1
|
||||
Builder.defineMacro("_OPENMP", "201107");
|
||||
break;
|
||||
}
|
||||
// OpenMP 2.2:
|
||||
// In implementations that support a preprocessor, the _OPENMP
|
||||
// macro name is defined to have the decimal value yyyymm where
|
||||
// yyyy and mm are the year and the month designations of the
|
||||
// version of the OpenMP API that the implementation support.
|
||||
switch (LangOpts.OpenMP) {
|
||||
case 0:
|
||||
break;
|
||||
case 40:
|
||||
Builder.defineMacro("_OPENMP", "201307");
|
||||
break;
|
||||
case 45:
|
||||
Builder.defineMacro("_OPENMP", "201511");
|
||||
break;
|
||||
default:
|
||||
// Default version is OpenMP 3.1
|
||||
Builder.defineMacro("_OPENMP", "201107");
|
||||
break;
|
||||
}
|
||||
|
||||
// CUDA device path compilaton
|
||||
|
||||
@@ -8,17 +8,17 @@
|
||||
// CHECK-NO-TLS: -cc1
|
||||
// CHECK-NO-TLS-SAME: -fnoopenmp-use-tls
|
||||
//
|
||||
// RUN: %clang %s -c -E -dM -fopenmp | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=1 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=0 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=100 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=31 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=1 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=0 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=100 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=31 | FileCheck --check-prefix=CHECK-DEFAULT-VERSION %s
|
||||
// CHECK-DEFAULT-VERSION: #define _OPENMP 201107
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=40 | FileCheck --check-prefix=CHECK-40-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=40 | FileCheck --check-prefix=CHECK-40-VERSION %s
|
||||
// CHECK-40-VERSION: #define _OPENMP 201307
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp -fopenmp-version=45 | FileCheck --check-prefix=CHECK-45-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=45 | FileCheck --check-prefix=CHECK-45-VERSION %s
|
||||
// CHECK-45-VERSION: #define _OPENMP 201511
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-version=1 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
|
||||
Reference in New Issue
Block a user