diff --git a/debian/patches/llvm-toolchain-17-sve-types-aux-target.diff b/debian/patches/llvm-toolchain-17-sve-types-aux-target.diff new file mode 100644 index 00000000..23d14ffe --- /dev/null +++ b/debian/patches/llvm-toolchain-17-sve-types-aux-target.diff @@ -0,0 +1,56 @@ +From: Emanuele Rocca +Date: Fri, 19 Jul 2024 09:25:38 +0200 +Subject: [PATCH] [Clang] make SVE types known to device targets too (#99446) + +For the purpose of preprocessing and declarations in header files, +ensure clang accepts SVE types for both device and host targets. + +Co-authored-by: Sander De Smalen +--- + clang/lib/AST/ASTContext.cpp | 3 ++- + clang/lib/Sema/Sema.cpp | 4 +++- + clang/test/PCH/aarch64-sve-types.c | 2 ++ + 3 files changed, 7 insertions(+), 2 deletions(-) + +Index: llvm-toolchain-17-17.0.6/clang/lib/AST/ASTContext.cpp +=================================================================== +--- llvm-toolchain-17-17.0.6.orig/clang/lib/AST/ASTContext.cpp ++++ llvm-toolchain-17-17.0.6/clang/lib/AST/ASTContext.cpp +@@ -1353,7 +1353,8 @@ void ASTContext::InitBuiltinTypes(const + #include "clang/Basic/OpenCLExtensionTypes.def" + } + +- if (Target.hasAArch64SVETypes()) { ++ if (Target.hasAArch64SVETypes() || ++ (AuxTarget && AuxTarget->hasAArch64SVETypes())) { + #define SVE_TYPE(Name, Id, SingletonId) \ + InitBuiltinType(SingletonId, BuiltinType::Id); + #include "clang/Basic/AArch64SVEACLETypes.def" +Index: llvm-toolchain-17-17.0.6/clang/lib/Sema/Sema.cpp +=================================================================== +--- llvm-toolchain-17-17.0.6.orig/clang/lib/Sema/Sema.cpp ++++ llvm-toolchain-17-17.0.6/clang/lib/Sema/Sema.cpp +@@ -424,7 +424,9 @@ void Sema::Initialize() { + #include "clang/Basic/OpenCLExtensionTypes.def" + } + +- if (Context.getTargetInfo().hasAArch64SVETypes()) { ++ if (Context.getTargetInfo().hasAArch64SVETypes() || ++ (Context.getAuxTargetInfo() && ++ Context.getAuxTargetInfo()->hasAArch64SVETypes())) { + #define SVE_TYPE(Name, Id, SingletonId) \ + addImplicitTypedef(Name, Context.SingletonId); + #include "clang/Basic/AArch64SVEACLETypes.def" +Index: llvm-toolchain-17-17.0.6/clang/test/PCH/aarch64-sve-types.c +=================================================================== +--- llvm-toolchain-17-17.0.6.orig/clang/test/PCH/aarch64-sve-types.c ++++ llvm-toolchain-17-17.0.6/clang/test/PCH/aarch64-sve-types.c +@@ -1,6 +1,8 @@ + // RUN: %clang_cc1 -triple aarch64-linux-gnu -emit-pch -o %t %s + // RUN: %clang_cc1 -triple aarch64-linux-gnu -include-pch %t \ + // RUN: -fsyntax-only -verify %s ++// RUN: %clang_cc1 -triple amdgcn-amd-amdhsa -aux-triple aarch64-linux-gnu \ ++// RUN: -x hip-cpp-output -emit-pch -o %t %s + + // expected-no-diagnostics + diff --git a/debian/patches/series b/debian/patches/series index 83715bf3..c18106e0 100644 --- a/debian/patches/series +++ b/debian/patches/series @@ -154,3 +154,4 @@ ubuntu-releases.patch clang-record-gcc-switches-by-default.patch rename-libllvm.diff link-with-package-metadata.diff +llvm-toolchain-17-sve-types-aux-target.diff