Author: Chris Bieneman Date: 2022-09-20T10:56:17-05:00 New Revision: 0c89b343371fca437a86093a01dc5eb6ed1a4a9b
URL: https://github.com/llvm/llvm-project/commit/0c89b343371fca437a86093a01dc5eb6ed1a4a9b DIFF: https://github.com/llvm/llvm-project/commit/0c89b343371fca437a86093a01dc5eb6ed1a4a9b.diff LOG: [HLSL] Pass flags to cc1 based on language Having the flags only pass through if you're using the dxc-driver means that the clang driver doesn't work for HLSL, which is undesirable. This change switches to instead passing flags based on the language mode similar to how OpenCL does it. This allows the clang driver to be used for HLSL source files as well. Reviewed By: python3kgae Differential Revision: https://reviews.llvm.org/D133958 Added: Modified: clang/include/clang/Driver/Types.h clang/lib/Driver/ToolChains/Clang.cpp clang/lib/Driver/Types.cpp clang/test/Driver/hlsl_no_stdinc.hlsl Removed: ################################################################################ diff --git a/clang/include/clang/Driver/Types.h b/clang/include/clang/Driver/Types.h index fc5dd7bbfd6f..4a21af3534de 100644 --- a/clang/include/clang/Driver/Types.h +++ b/clang/include/clang/Driver/Types.h @@ -95,6 +95,9 @@ namespace types { /// isOpenCL - Is this an "OpenCL" input. bool isOpenCL(ID Id); + /// isHLSL - Is this an HLSL input. + bool isHLSL(ID Id); + /// isSrcFile - Is this a source file, i.e. something that still has to be /// preprocessed. The logic behind this is the same that decides if the first /// compilation phase is a preprocessing one. diff --git a/clang/lib/Driver/ToolChains/Clang.cpp b/clang/lib/Driver/ToolChains/Clang.cpp index 34caeaf0f6af..7af0f9998455 100644 --- a/clang/lib/Driver/ToolChains/Clang.cpp +++ b/clang/lib/Driver/ToolChains/Clang.cpp @@ -3529,12 +3529,14 @@ static void RenderHLSLOptions(const ArgList &Args, ArgStringList &CmdArgs, options::OPT_disable_llvm_passes, options::OPT_fnative_half_type, options::OPT_hlsl_entrypoint}; - + if (!types::isHLSL(InputType)) + return; for (const auto &Arg : ForwardedArguments) if (const auto *A = Args.getLastArg(Arg)) A->renderAsInput(Args, CmdArgs); // Add the default headers if dxc_no_stdinc is not set. - if (!Args.hasArg(options::OPT_dxc_no_stdinc)) + if (!Args.hasArg(options::OPT_dxc_no_stdinc) && + !Args.hasArg(options::OPT_nostdinc)) CmdArgs.push_back("-finclude-default-header"); } @@ -6389,8 +6391,7 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, RenderOpenCLOptions(Args, CmdArgs, InputType); // Forward hlsl options to -cc1 - if (C.getDriver().IsDXCMode()) - RenderHLSLOptions(Args, CmdArgs, InputType); + RenderHLSLOptions(Args, CmdArgs, InputType); if (IsHIP) { if (Args.hasFlag(options::OPT_fhip_new_launch_api, diff --git a/clang/lib/Driver/Types.cpp b/clang/lib/Driver/Types.cpp index 6e30bb744b4f..ffbca82c98c3 100644 --- a/clang/lib/Driver/Types.cpp +++ b/clang/lib/Driver/Types.cpp @@ -286,6 +286,8 @@ bool types::isHIP(ID Id) { } } +bool types::isHLSL(ID Id) { return Id == TY_HLSL; } + bool types::isSrcFile(ID Id) { return Id != TY_Object && getPreprocessedType(Id) != TY_INVALID; } diff --git a/clang/test/Driver/hlsl_no_stdinc.hlsl b/clang/test/Driver/hlsl_no_stdinc.hlsl index ec6d0612a9ed..b5567aae5236 100644 --- a/clang/test/Driver/hlsl_no_stdinc.hlsl +++ b/clang/test/Driver/hlsl_no_stdinc.hlsl @@ -1,5 +1,7 @@ // RUN: %clang_dxc -Tlib_6_7 -fcgl -Fo - %s -### 2>&1 | FileCheck %s --check-prefix=STDINC +// RUN: %clang -target dxil-pc-shadermodel6.3-library -o - %s -### 2>&1 | FileCheck %s --check-prefix=STDINC // RUN: %clang_dxc -Tlib_6_7 -hlsl-no-stdinc -fcgl -Fo - %s -### 2>&1 | FileCheck %s --check-prefix=NOSTDINC +// RUN: %clang -target dxil-pc-shadermodel6.3-library -nostdinc -o - %s -### 2>&1 | FileCheck %s --check-prefix=NOSTDINC // RUN: %clang -cc1 -triple dxil-pc-shadermodel6.3-library -x hlsl -ast-dump -o - %s -verify _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits