diff --git a/clang/include/clang/Driver/Action.h b/clang/include/clang/Driver/Action.h index f6d4ad579c5d..077f1a9efb26 100644 --- a/clang/include/clang/Driver/Action.h +++ b/clang/include/clang/Driver/Action.h @@ -160,14 +160,16 @@ public: class CudaHostAction : public Action { virtual void anchor(); ActionList DeviceActions; + const char *DeviceTriple; public: - CudaHostAction(std::unique_ptr Input, - const ActionList &DeviceActions); + CudaHostAction(std::unique_ptr Input, const ActionList &DeviceActions, + const char *DeviceTriple); ~CudaHostAction() override; ActionList &getDeviceActions() { return DeviceActions; } const ActionList &getDeviceActions() const { return DeviceActions; } + const char *getDeviceTriple() const { return DeviceTriple; } static bool classof(const Action *A) { return A->getKind() == CudaHostClass; } }; diff --git a/clang/lib/Driver/Action.cpp b/clang/lib/Driver/Action.cpp index 6fe2a5034640..fdbae113ff80 100644 --- a/clang/lib/Driver/Action.cpp +++ b/clang/lib/Driver/Action.cpp @@ -66,8 +66,10 @@ CudaDeviceAction::CudaDeviceAction(std::unique_ptr Input, void CudaHostAction::anchor() {} CudaHostAction::CudaHostAction(std::unique_ptr Input, - const ActionList &DeviceActions) - : Action(CudaHostClass, std::move(Input)), DeviceActions(DeviceActions) {} + const ActionList &DeviceActions, + const char *DeviceTriple) + : Action(CudaHostClass, std::move(Input)), DeviceActions(DeviceActions), + DeviceTriple(DeviceTriple) {} CudaHostAction::~CudaHostAction() { for (auto &DA : DeviceActions) diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp index ebf8b7d953dc..c29059bdeb4e 100644 --- a/clang/lib/Driver/Driver.cpp +++ b/clang/lib/Driver/Driver.cpp @@ -1246,13 +1246,18 @@ static std::unique_ptr buildCudaActions(const Driver &D, const ToolChain &TC, DerivedArgList &Args, const Arg *InputArg, std::unique_ptr HostAction, ActionList &Actions) { + // Figure out which NVPTX triple to use for device-side compilation based on + // whether host is 64-bit. + const char *DeviceTriple = TC.getTriple().isArch64Bit() + ? "nvptx64-nvidia-cuda" + : "nvptx-nvidia-cuda"; Arg *PartialCompilationArg = Args.getLastArg(options::OPT_cuda_host_only, options::OPT_cuda_device_only); // Host-only compilation case. if (PartialCompilationArg && PartialCompilationArg->getOption().matches(options::OPT_cuda_host_only)) return std::unique_ptr( - new CudaHostAction(std::move(HostAction), {})); + new CudaHostAction(std::move(HostAction), {}, DeviceTriple)); // Collect all cuda_gpu_arch parameters, removing duplicates. SmallVector GpuArchList; @@ -1290,12 +1295,6 @@ buildCudaActions(const Driver &D, const ToolChain &TC, DerivedArgList &Args, } } - // Figure out which NVPTX triple to use for device-side compilation based on - // whether host is 64-bit. - const char *DeviceTriple = TC.getTriple().isArch64Bit() - ? "nvptx64-nvidia-cuda" - : "nvptx-nvidia-cuda"; - // Figure out what to do with device actions -- pass them as inputs to the // host action or run each of them independently. bool DeviceOnlyCompilation = PartialCompilationArg != nullptr; @@ -1331,7 +1330,7 @@ buildCudaActions(const Driver &D, const ToolChain &TC, DerivedArgList &Args, // Return a new host action that incorporates original host action and all // device actions. return std::unique_ptr( - new CudaHostAction(std::move(HostAction), DeviceActions)); + new CudaHostAction(std::move(HostAction), DeviceActions, DeviceTriple)); } void Driver::BuildActions(const ToolChain &TC, DerivedArgList &Args,