From: LLVM Packaging Team Date: Sat, 29 Jan 2022 09:17:38 +0000 (+0000) Subject: fix-clang-path-and-build X-Git-Tag: archive/raspbian/1%12.0.1-19+rpi1^2~75 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=0337d363ecb56a187b8fc3aa7d8d009dc38d2103;p=llvm-toolchain-12.git fix-clang-path-and-build =================================================================== Gbp-Pq: Name fix-clang-path-and-build.diff --- diff --git a/clang/lib/Driver/ToolChains/Linux.cpp b/clang/lib/Driver/ToolChains/Linux.cpp index 9663a7390a..c4f385d0f0 100644 --- a/clang/lib/Driver/ToolChains/Linux.cpp +++ b/clang/lib/Driver/ToolChains/Linux.cpp @@ -12,6 +12,7 @@ #include "Arch/PPC.h" #include "Arch/RISCV.h" #include "CommonArgs.h" +#include "clang/Basic/Version.h" #include "clang/Config/config.h" #include "clang/Driver/Distro.h" #include "clang/Driver/Driver.h" @@ -574,8 +575,18 @@ void Linux::AddClangSystemIncludeArgs(const ArgList &DriverArgs, SmallString<128> ResourceDirInclude(D.ResourceDir); llvm::sys::path::append(ResourceDirInclude, "include"); if (!DriverArgs.hasArg(options::OPT_nobuiltininc) && - (!getTriple().isMusl() || DriverArgs.hasArg(options::OPT_nostdlibinc))) - addSystemInclude(DriverArgs, CC1Args, ResourceDirInclude); + (!getTriple().isMusl() || DriverArgs.hasArg(options::OPT_nostdlibinc))) { + if (llvm::sys::fs::exists(ResourceDirInclude)) { + /* Include the build include directory only + * Otherwise, it fails with stage2 when clang headers are available on the system + * they usually fail because of the include_next. Two llvm/clang headers are found + * while we are waiting for the lib C++ (std or not) + */ + addSystemInclude(DriverArgs, CC1Args, ResourceDirInclude); + } else { + addSystemInclude(DriverArgs, CC1Args, "/usr/include/clang/" + std::string(CLANG_VERSION_STRING) + "/include/"); + } + } if (DriverArgs.hasArg(options::OPT_nostdlibinc)) return;