[llvm-branch-commits] [clang] clang/AMDGPU: Remove driver restriction on --gpu-max-threads-per-block (PR #204864)
Matt Arsenault via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Fri Jun 19 12:23:05 PDT 2026
https://github.com/arsenm updated https://github.com/llvm/llvm-project/pull/204864
>From cbf215cf085b7617579abb891f36fc95d4be151a Mon Sep 17 00:00:00 2001
From: Matt Arsenault <Matthew.Arsenault at amd.com>
Date: Fri, 19 Jun 2026 17:01:05 +0200
Subject: [PATCH] clang/AMDGPU: Remove driver restriction on
--gpu-max-threads-per-block
Previously this flag was only handled for HIP, and would produce an unused
argument warning. There is a custom warning produced by cc1 that the
argument isn't supported, but practically speaking that was unreachable
due to not forwarding the argument. Also add a test for the untested warning.
Also use a simpler method for forwarding the flag to cc1.
---
clang/lib/Driver/ToolChains/AMDGPU.cpp | 10 ++--------
clang/test/Driver/amdgpu-openmp-max-threads.c | 5 +++++
.../openmp-warn-gpu-max-threads-per-block.c | 14 ++++++++++++++
3 files changed, 21 insertions(+), 8 deletions(-)
create mode 100644 clang/test/Driver/amdgpu-openmp-max-threads.c
create mode 100644 clang/test/Frontend/openmp-warn-gpu-max-threads-per-block.c
diff --git a/clang/lib/Driver/ToolChains/AMDGPU.cpp b/clang/lib/Driver/ToolChains/AMDGPU.cpp
index 6611b133057f5..495f724338250 100644
--- a/clang/lib/Driver/ToolChains/AMDGPU.cpp
+++ b/clang/lib/Driver/ToolChains/AMDGPU.cpp
@@ -878,16 +878,10 @@ void AMDGPUToolChain::addClangTargetOptions(
if (DriverArgs.hasArgNoClaim(options::OPT_hipstdpar))
CC1Args.append({"-mllvm", "-amdgpu-enable-hipstdpar"});
}
-
- // FIXME: This should not depend on HIP
- StringRef MaxThreadsPerBlock =
- DriverArgs.getLastArgValue(options::OPT_gpu_max_threads_per_block_EQ);
- if (!MaxThreadsPerBlock.empty()) {
- CC1Args.push_back(DriverArgs.MakeArgString(
- Twine("--gpu-max-threads-per-block=") + MaxThreadsPerBlock));
- }
}
+ DriverArgs.AddLastArg(CC1Args, options::OPT_gpu_max_threads_per_block_EQ);
+
// Default to "hidden" visibility, as object level linking will not be
// supported for the foreseeable future.
// TODO: remove the SPIR-V bypass once it can encode (hidden) visibility.
diff --git a/clang/test/Driver/amdgpu-openmp-max-threads.c b/clang/test/Driver/amdgpu-openmp-max-threads.c
new file mode 100644
index 0000000000000..52f95e0182419
--- /dev/null
+++ b/clang/test/Driver/amdgpu-openmp-max-threads.c
@@ -0,0 +1,5 @@
+// Test that --gpu-max-threads-per-block is not ignored by openmp.
+// RUN: %clang -### -fopenmp --offload-arch=gfx906 --gpu-max-threads-per-block=256 %s 2>&1 | FileCheck %s
+
+// CHECK: "-cc1" "-triple" "amdgcn-amd-amdhsa"
+// CHECK-SAME: "--gpu-max-threads-per-block=256"
diff --git a/clang/test/Frontend/openmp-warn-gpu-max-threads-per-block.c b/clang/test/Frontend/openmp-warn-gpu-max-threads-per-block.c
new file mode 100644
index 0000000000000..3efdc9ac2b5a0
--- /dev/null
+++ b/clang/test/Frontend/openmp-warn-gpu-max-threads-per-block.c
@@ -0,0 +1,14 @@
+// REQUIRES: amdgpu-registered-target
+
+// Test that --gpu-max-threads-per-block warns when used outside of HIP.
+// RUN: %clang_cc1 -triple amdgcn-amd-amdhsa --gpu-max-threads-per-block=1024 \
+// RUN: -fsyntax-only -verify=warn %s
+
+// Test that no warning is emitted for HIP.
+// RUN: %clang_cc1 -triple amdgcn-amd-amdhsa -x hip -fcuda-is-device \
+// RUN: --gpu-max-threads-per-block=1024 -fsyntax-only -verify=hip %s
+
+// warn-warning@*{{'--gpu-max-threads-per-block=1024' is ignored since it is only supported for HIP}}
+// hip-no-diagnostics
+
+void f(void) {}
More information about the llvm-branch-commits
mailing list