forked from OSchip/llvm-project
[OPENMP-SIMD] Fix PR37536: Fix definition of _OPENMP macro.
if `-fopenmp-simd` is specified alone, `_OPENMP` macro should not be defined. If `-fopenmp-simd` is specified along with the `-fopenmp`, `_OPENMP` macro should be defined with the value `201511`. llvm-svn: 332852
This commit is contained in:
parent
b5757abefb
commit
66f9577f09
|
@ -3989,6 +3989,8 @@ 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.AddLastArg(CmdArgs, options::OPT_fopenmp_simd,
|
||||
options::OPT_fno_openmp_simd);
|
||||
Args.AddAllArgs(CmdArgs, options::OPT_fopenmp_version_EQ);
|
||||
|
||||
// When in OpenMP offloading mode with NVPTX target, forward
|
||||
|
|
|
@ -2562,9 +2562,10 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
|
|||
// Check if -fopenmp is specified.
|
||||
Opts.OpenMP = Args.hasArg(options::OPT_fopenmp) ? 1 : 0;
|
||||
// Check if -fopenmp-simd is specified.
|
||||
Opts.OpenMPSimd = !Opts.OpenMP && Args.hasFlag(options::OPT_fopenmp_simd,
|
||||
options::OPT_fno_openmp_simd,
|
||||
/*Default=*/false);
|
||||
bool IsSimdSpecified =
|
||||
Args.hasFlag(options::OPT_fopenmp_simd, options::OPT_fno_openmp_simd,
|
||||
/*Default=*/false);
|
||||
Opts.OpenMPSimd = !Opts.OpenMP && IsSimdSpecified;
|
||||
Opts.OpenMPUseTLS =
|
||||
Opts.OpenMP && !Args.hasArg(options::OPT_fnoopenmp_use_tls);
|
||||
Opts.OpenMPIsDevice =
|
||||
|
@ -2573,9 +2574,9 @@ static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
|
|||
if (Opts.OpenMP || Opts.OpenMPSimd) {
|
||||
if (int Version =
|
||||
getLastArgIntValue(Args, OPT_fopenmp_version_EQ,
|
||||
Opts.OpenMPSimd ? 45 : Opts.OpenMP, Diags))
|
||||
IsSimdSpecified ? 45 : Opts.OpenMP, Diags))
|
||||
Opts.OpenMP = Version;
|
||||
else if (Opts.OpenMPSimd)
|
||||
else if (IsSimdSpecified)
|
||||
Opts.OpenMP = 45;
|
||||
// Provide diagnostic when a given target is not expected to be an OpenMP
|
||||
// device or host.
|
||||
|
|
|
@ -1027,19 +1027,21 @@ static void InitializePredefinedMacros(const TargetInfo &TI,
|
|||
// 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, in Simd only mode - 4.5
|
||||
Builder.defineMacro("_OPENMP", LangOpts.OpenMPSimd ? "201511" : "201107");
|
||||
break;
|
||||
if (!LangOpts.OpenMPSimd) {
|
||||
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
|
||||
|
|
|
@ -18,19 +18,11 @@
|
|||
|
||||
// CHECK-DEFAULT-VERSION: #define _OPENMP 201107
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd | FileCheck --check-prefix=CHECK-SIMD-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=1 | FileCheck --check-prefix=CHECK-SIMD-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=0 | FileCheck --check-prefix=CHECK-SIMD-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=100 | FileCheck --check-prefix=CHECK-SIMD-DEFAULT-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=31 | FileCheck --check-prefix=CHECK-SIMD-DEFAULT-VERSION %s
|
||||
// CHECK-SIMD-DEFAULT-VERSION: #define _OPENMP 201511
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=40 | FileCheck --check-prefix=CHECK-40-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=40 | FileCheck --check-prefix=CHECK-40-VERSION %s
|
||||
// CHECK-40-VERSION: #define _OPENMP 201307
|
||||
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-version=45 | FileCheck --check-prefix=CHECK-45-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=45 | FileCheck --check-prefix=CHECK-45-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp=libomp -fopenmp-simd | 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
|
||||
|
@ -39,5 +31,13 @@
|
|||
// RUN: %clang %s -c -E -dM -fopenmp-version=45 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-version=45 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fno-openmp-simd -fopenmp-version=45 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=1 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=0 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=100 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=31 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=40 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
// RUN: %clang %s -c -E -dM -fopenmp-simd -fopenmp-version=45 | FileCheck --check-prefix=CHECK-VERSION %s
|
||||
|
||||
// CHECK-VERSION-NOT: #define _OPENMP
|
||||
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
// RUN: %clang_cc1 -fopenmp -verify -DFOPENMP -o - %s
|
||||
// RUN: %clang_cc1 -verify -o - %s
|
||||
|
||||
// RUN: %clang_cc1 -fopenmp-simd -verify -DFOPENMP -o - %s
|
||||
// RUN: %clang_cc1 -verify -o - %s
|
||||
// RUN: %clang_cc1 -fopenmp-simd -verify -o - %s
|
||||
// RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=45 -verify -o - %s
|
||||
// expected-no-diagnostics
|
||||
#ifdef FOPENMP
|
||||
// -fopenmp option is specified
|
||||
|
|
Loading…
Reference in New Issue