forked from OSchip/llvm-project
[SYCL] Rework the SYCL driver options
SYCL compilations initiated by the driver will spawn off one or more frontend compilation jobs (one for device and one for host). This patch reworks the driver options to make upstreaming this from the downstream SYCL fork easier. This patch introduces a language option to identify host executions (SYCLIsHost) and a -cc1 frontend option to enable this mode. -fsycl and -fno-sycl become driver-only options that are rejected when passed to -cc1. This is because the frontend and beyond should be looking at whether the user is doing a device or host compilation specifically. Because the frontend should only ever be in one mode or the other, -fsycl-is-device and -fsycl-is-host are mutually exclusive options.
This commit is contained in:
parent
cca3167de0
commit
c165a99a1b
|
@ -249,8 +249,8 @@ LANGOPT(GPUMaxThreadsPerBlock, 32, 1024, "default max threads per block for kern
|
|||
LANGOPT(GPUDeferDiag, 1, 0, "defer host/device related diagnostic messages for CUDA/HIP")
|
||||
LANGOPT(GPUExcludeWrongSideOverloads, 1, 0, "always exclude wrong side overloads in overloading resolution for CUDA/HIP")
|
||||
|
||||
LANGOPT(SYCL , 1, 0, "SYCL")
|
||||
LANGOPT(SYCLIsDevice , 1, 0, "Generate code for SYCL device")
|
||||
LANGOPT(SYCLIsHost , 1, 0, "SYCL host compilation")
|
||||
ENUM_LANGOPT(SYCLVersion , SYCLMajorVersion, 1, SYCL_None, "Version of the SYCL standard used")
|
||||
|
||||
LANGOPT(HIPUseNewLaunchAPI, 1, 0, "Use new kernel launching API for HIP")
|
||||
|
|
|
@ -4283,15 +4283,10 @@ defm underscoring : BooleanFFlag<"underscoring">, Group<gfortran_Group>;
|
|||
defm whole_file : BooleanFFlag<"whole-file">, Group<gfortran_Group>;
|
||||
|
||||
// C++ SYCL options
|
||||
defm sycl : BoolOption<"f", "sycl",
|
||||
LangOpts<"SYCL">, DefaultFalse,
|
||||
PosFlag<SetTrue, [CC1Option], "Enable">, NegFlag<SetFalse, [], "Disable">,
|
||||
BothFlags<[CoreOption], " SYCL kernels compilation for device">>,
|
||||
Group<sycl_Group>;
|
||||
def sycl_std_EQ : Joined<["-"], "sycl-std=">, Group<sycl_Group>, Flags<[CC1Option, NoArgumentUnused, CoreOption]>,
|
||||
HelpText<"SYCL language standard to compile for.">, Values<"2017,121,1.2.1,sycl-1.2.1">,
|
||||
NormalizedValues<["SYCL_2017", "SYCL_2017", "SYCL_2017", "SYCL_2017"]>, NormalizedValuesScope<"LangOptions">,
|
||||
MarshallingInfoEnum<LangOpts<"SYCLVersion">, "SYCL_None">, ShouldParseIf<fsycl.KeyPath>;
|
||||
def fsycl : Flag<["-"], "fsycl">, Flags<[NoXarchOption, CoreOption]>,
|
||||
Group<sycl_Group>, HelpText<"Enables SYCL kernels compilation for device">;
|
||||
def fno_sycl : Flag<["-"], "fno-sycl">, Flags<[NoXarchOption, CoreOption]>,
|
||||
Group<sycl_Group>, HelpText<"Disables SYCL kernels compilation for device">;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// FLangOption + CoreOption + NoXarchOption
|
||||
|
@ -5546,11 +5541,22 @@ def fopenmp_host_ir_file_path : Separate<["-"], "fopenmp-host-ir-file-path">,
|
|||
|
||||
def fsycl_is_device : Flag<["-"], "fsycl-is-device">,
|
||||
HelpText<"Generate code for SYCL device.">,
|
||||
MarshallingInfoFlag<LangOpts<"SYCLIsDevice">>,
|
||||
ShouldParseIf<fsycl.KeyPath>;
|
||||
MarshallingInfoFlag<LangOpts<"SYCLIsDevice">>;
|
||||
def fsycl_is_host : Flag<["-"], "fsycl-is-host">,
|
||||
HelpText<"SYCL host compilation">,
|
||||
MarshallingInfoFlag<LangOpts<"SYCLIsHost">>;
|
||||
|
||||
} // let Flags = [CC1Option, NoDriverOption]
|
||||
|
||||
def sycl_std_EQ : Joined<["-"], "sycl-std=">, Group<sycl_Group>,
|
||||
Flags<[CC1Option, NoArgumentUnused, CoreOption]>,
|
||||
HelpText<"SYCL language standard to compile for.">,
|
||||
Values<"2017,121,1.2.1,sycl-1.2.1">,
|
||||
NormalizedValues<["SYCL_2017", "SYCL_2017", "SYCL_2017", "SYCL_2017"]>,
|
||||
NormalizedValuesScope<"LangOptions">,
|
||||
MarshallingInfoEnum<LangOpts<"SYCLVersion">, "SYCL_None">,
|
||||
ShouldParseIf<!strconcat(fsycl_is_device.KeyPath, "||", fsycl_is_host.KeyPath)>;
|
||||
|
||||
defm cuda_approx_transcendentals : BoolFOption<"cuda-approx-transcendentals",
|
||||
LangOpts<"CUDADeviceApproxTranscendentals">, DefaultFalse,
|
||||
PosFlag<SetTrue, [CC1Option], "Use">, NegFlag<SetFalse, [], "Don't use">,
|
||||
|
|
|
@ -4251,7 +4251,6 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
|||
}
|
||||
|
||||
if (Args.hasFlag(options::OPT_fsycl, options::OPT_fno_sycl, false)) {
|
||||
CmdArgs.push_back("-fsycl");
|
||||
CmdArgs.push_back("-fsycl-is-device");
|
||||
|
||||
if (Arg *A = Args.getLastArg(options::OPT_sycl_std_EQ)) {
|
||||
|
|
|
@ -466,6 +466,11 @@ static bool FixupInvocation(CompilerInvocation &Invocation,
|
|||
LangOpts.NewAlignOverride = 0;
|
||||
}
|
||||
|
||||
// Prevent the user from specifying both -fsycl-is-device and -fsycl-is-host.
|
||||
if (LangOpts.SYCLIsDevice && LangOpts.SYCLIsHost)
|
||||
Diags.Report(diag::err_drv_argument_not_allowed_with) << "-fsycl-is-device"
|
||||
<< "-fsycl-is-host";
|
||||
|
||||
if (Args.hasArg(OPT_fgnu89_inline) && LangOpts.CPlusPlus)
|
||||
Diags.Report(diag::err_drv_argument_not_allowed_with)
|
||||
<< "-fgnu89-inline" << GetInputKindName(IK);
|
||||
|
|
|
@ -474,7 +474,7 @@ static void InitializeStandardPredefinedMacros(const TargetInfo &TI,
|
|||
Builder.defineMacro("__FAST_RELAXED_MATH__");
|
||||
}
|
||||
|
||||
if (LangOpts.SYCL) {
|
||||
if (LangOpts.SYCLIsDevice || LangOpts.SYCLIsHost) {
|
||||
// SYCL Version is set to a value when building SYCL applications
|
||||
if (LangOpts.getSYCLVersion() == LangOptions::SYCL_2017)
|
||||
Builder.defineMacro("CL_SYCL_LANGUAGE_VERSION", "121");
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// RUN: %clang_cc1 -fsycl -fsycl-is-device -emit-llvm -disable-llvm-passes \
|
||||
// RUN: %clang_cc1 -fsycl-is-device -emit-llvm -disable-llvm-passes \
|
||||
// RUN: -triple spir64-unknown-unknown-sycldevice -emit-llvm %s -o - | \
|
||||
// RUN: FileCheck %s
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// RUN: %clang_cc1 -fsycl -fsycl-is-device -triple spir64-unknown-unknown-sycldevice -emit-llvm %s -o - | FileCheck %s
|
||||
// RUN: %clang_cc1 -fsycl-is-device -triple spir64-unknown-unknown-sycldevice -emit-llvm %s -o - | FileCheck %s
|
||||
//
|
||||
// Check that file-scope asm is ignored during device-side SYCL compilation.
|
||||
//
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
// RUN: %clang_cc1 %s -triple spir -aux-triple x86_64-unknown-linux-gnu -E -dM | FileCheck %s
|
||||
// RUN: %clang_cc1 %s -fsycl -fsycl-is-device -triple spir -aux-triple x86_64-unknown-linux-gnu -E -dM | FileCheck --check-prefix=CHECK-SYCL %s
|
||||
// RUN: %clang_cc1 %s -fsycl-is-device -triple spir -aux-triple x86_64-unknown-linux-gnu -E -dM | FileCheck --check-prefix=CHECK-SYCL %s
|
||||
|
||||
// CHECK-NOT:#define __x86_64__ 1
|
||||
// CHECK-SYCL:#define __x86_64__ 1
|
||||
|
|
|
@ -0,0 +1,13 @@
|
|||
// Test that we disallow -cc1 -fsycl, even when specifying device or host mode.
|
||||
|
||||
// RUN: not %clang_cc1 -fsycl %s 2>&1 | FileCheck --check-prefix=ERROR %s
|
||||
// RUN: not %clang_cc1 -fsycl -fsycl-is-device %s 2>&1 | FileCheck --check-prefix=ERROR %s
|
||||
// RUN: not %clang_cc1 -fsycl -fsycl-is-host %s 2>&1 | FileCheck --check-prefix=ERROR %s
|
||||
|
||||
// ERROR: error: unknown argument: '-fsycl'
|
||||
|
||||
// Test that you cannot specify -fsycl-is-device and -fsycl-is-host at the same time.
|
||||
// RUN: not %clang_cc1 -fsycl-is-device -fsycl-is-host %s 2>&1 | FileCheck --check-prefix=ERROR-BOTH %s
|
||||
// RUN: not %clang_cc1 -fsycl-is-host -fsycl-is-device %s 2>&1 | FileCheck --check-prefix=ERROR-BOTH %s
|
||||
|
||||
// ERROR-BOTH: error: invalid argument '-fsycl-is-device' not allowed with '-fsycl-is-host'
|
|
@ -1,7 +1,8 @@
|
|||
// RUN: %clang_cc1 %s -E -dM | FileCheck %s
|
||||
// RUN: %clang_cc1 %s -fsycl -sycl-std=2017 -E -dM | FileCheck --check-prefix=CHECK-SYCL-STD %s
|
||||
// RUN: %clang_cc1 %s -fsycl -fsycl-is-device -sycl-std=1.2.1 -E -dM | FileCheck --check-prefix=CHECK-SYCL-STD %s
|
||||
// RUN: %clang_cc1 %s -fsycl -fsycl-is-device -E -dM | FileCheck --check-prefixes=CHECK-SYCL %s
|
||||
// RUN: %clang_cc1 %s -fsycl-is-device -sycl-std=2017 -E -dM | FileCheck --check-prefix=CHECK-SYCL-STD %s
|
||||
// RUN: %clang_cc1 %s -fsycl-is-host -sycl-std=2017 -E -dM | FileCheck --check-prefix=CHECK-SYCL-STD %s
|
||||
// RUN: %clang_cc1 %s -fsycl-is-device -sycl-std=1.2.1 -E -dM | FileCheck --check-prefix=CHECK-SYCL-STD %s
|
||||
// RUN: %clang_cc1 %s -fsycl-is-device -E -dM | FileCheck --check-prefixes=CHECK-SYCL %s
|
||||
|
||||
// CHECK-NOT:#define __SYCL_DEVICE_ONLY__ 1
|
||||
// CHECK-NOT:#define CL_SYCL_LANGUAGE_VERSION 121
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
// RUN: %clang_cc1 -triple spir64 -fsycl -fsycl-is-device -verify -fsyntax-only %s
|
||||
// RUN: %clang_cc1 -triple x86_64-linux-gnu -fsycl -fsycl-is-device -fsyntax-only %s
|
||||
// RUN: %clang_cc1 -triple spir64 -fsycl-is-device -verify -fsyntax-only %s
|
||||
// RUN: %clang_cc1 -triple x86_64-linux-gnu -fsycl-is-device -fsyntax-only %s
|
||||
|
||||
typedef __float128 BIGTY;
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
// RUN: %clang_cc1 -triple spir64 -aux-triple x86_64-unknown-linux-gnu \
|
||||
// RUN: -fsycl -fsycl-is-device -verify -fsyntax-only %s
|
||||
// RUN: -fsycl-is-device -verify -fsyntax-only %s
|
||||
|
||||
typedef __uint128_t BIGTY;
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -fsycl -fsycl-is-device -verify %s
|
||||
// RUN: %clang_cc1 -std=c++11 -fsyntax-only -fsycl-is-device -verify %s
|
||||
|
||||
// Only function templates
|
||||
[[clang::sycl_kernel]] int gv2 = 0; // expected-warning {{'sycl_kernel' attribute only applies to function templates}}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// RUN: %clang_cc1 -fsycl -fsycl-is-device -triple spir64 -verify -fsyntax-only %s
|
||||
// RUN: %clang_cc1 -fsycl-is-device -triple spir64 -verify -fsyntax-only %s
|
||||
|
||||
thread_local const int prohobit_ns_scope = 0;
|
||||
thread_local int prohobit_ns_scope2 = 0;
|
||||
|
|
|
@ -516,7 +516,8 @@ TEST_F(CommandLineTest, ConditionalParsingIfFalseFlagNotPresent) {
|
|||
CompilerInvocation::CreateFromArgs(Invocation, Args, *Diags);
|
||||
|
||||
ASSERT_FALSE(Diags->hasErrorOccurred());
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCL);
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCLIsDevice);
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCLIsHost);
|
||||
ASSERT_EQ(Invocation.getLangOpts()->getSYCLVersion(), LangOptions::SYCL_None);
|
||||
|
||||
Invocation.generateCC1CommandLine(GeneratedArgs, *this);
|
||||
|
@ -531,42 +532,42 @@ TEST_F(CommandLineTest, ConditionalParsingIfFalseFlagPresent) {
|
|||
CompilerInvocation::CreateFromArgs(Invocation, Args, *Diags);
|
||||
|
||||
ASSERT_FALSE(Diags->hasErrorOccurred());
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCL);
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCLIsDevice);
|
||||
ASSERT_FALSE(Invocation.getLangOpts()->SYCLIsHost);
|
||||
ASSERT_EQ(Invocation.getLangOpts()->getSYCLVersion(), LangOptions::SYCL_None);
|
||||
|
||||
Invocation.generateCC1CommandLine(GeneratedArgs, *this);
|
||||
|
||||
ASSERT_THAT(GeneratedArgs, Not(Contains(StrEq("-fsycl"))));
|
||||
ASSERT_THAT(GeneratedArgs, Not(Contains(StrEq("-fsycl-is-device"))));
|
||||
ASSERT_THAT(GeneratedArgs, Not(Contains(StrEq("-fsycl-is-host"))));
|
||||
ASSERT_THAT(GeneratedArgs, Not(Contains(HasSubstr("-sycl-std="))));
|
||||
}
|
||||
|
||||
TEST_F(CommandLineTest, ConditionalParsingIfTrueFlagNotPresent) {
|
||||
const char *Args[] = {"-fsycl"};
|
||||
const char *Args[] = {"-fsycl-is-host"};
|
||||
|
||||
CompilerInvocation::CreateFromArgs(Invocation, Args, *Diags);
|
||||
|
||||
ASSERT_FALSE(Diags->hasErrorOccurred());
|
||||
ASSERT_TRUE(Invocation.getLangOpts()->SYCL);
|
||||
ASSERT_EQ(Invocation.getLangOpts()->getSYCLVersion(), LangOptions::SYCL_None);
|
||||
|
||||
Invocation.generateCC1CommandLine(GeneratedArgs, *this);
|
||||
|
||||
ASSERT_THAT(GeneratedArgs, Contains(StrEq("-fsycl")));
|
||||
ASSERT_THAT(GeneratedArgs, Contains(StrEq("-fsycl-is-host")));
|
||||
ASSERT_THAT(GeneratedArgs, Not(Contains(HasSubstr("-sycl-std="))));
|
||||
}
|
||||
|
||||
TEST_F(CommandLineTest, ConditionalParsingIfTrueFlagPresent) {
|
||||
const char *Args[] = {"-fsycl", "-sycl-std=2017"};
|
||||
const char *Args[] = {"-fsycl-is-device", "-sycl-std=2017"};
|
||||
|
||||
CompilerInvocation::CreateFromArgs(Invocation, Args, *Diags);
|
||||
|
||||
ASSERT_FALSE(Diags->hasErrorOccurred());
|
||||
ASSERT_TRUE(Invocation.getLangOpts()->SYCL);
|
||||
ASSERT_EQ(Invocation.getLangOpts()->getSYCLVersion(), LangOptions::SYCL_2017);
|
||||
|
||||
Invocation.generateCC1CommandLine(GeneratedArgs, *this);
|
||||
|
||||
ASSERT_THAT(GeneratedArgs, Contains(StrEq("-fsycl")));
|
||||
ASSERT_THAT(GeneratedArgs, Contains(StrEq("-fsycl-is-device")));
|
||||
ASSERT_THAT(GeneratedArgs, Contains(StrEq("-sycl-std=2017")));
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue