From daa332df14291ad12d5978283ea9071a07a45529 Mon Sep 17 00:00:00 2001 From: Nikita Popov Date: Mon, 12 Dec 2022 10:50:36 +0100 Subject: [PATCH] Backport patches for ucrt64 toolchain detection --- ...ove-extend-the-gcc-sysroot-detection.patch | 280 ++++++++++++++++++ ...ove-detection-of-libstdc-headers-on-.patch | 139 +++++++++ clang.spec | 9 +- 3 files changed, 427 insertions(+), 1 deletion(-) create mode 100644 0001-clang-MinGW-Improve-extend-the-gcc-sysroot-detection.patch create mode 100644 0002-clang-MinGW-Improve-detection-of-libstdc-headers-on-.patch diff --git a/0001-clang-MinGW-Improve-extend-the-gcc-sysroot-detection.patch b/0001-clang-MinGW-Improve-extend-the-gcc-sysroot-detection.patch new file mode 100644 index 0000000..7f54d32 --- /dev/null +++ b/0001-clang-MinGW-Improve-extend-the-gcc-sysroot-detection.patch @@ -0,0 +1,280 @@ +From efe3686d4a519b357cecb5aaf715f1e1b6f2d025 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Martin=20Storsj=C3=B6?= +Date: Tue, 22 Nov 2022 14:38:54 +0200 +Subject: [PATCH 1/2] [clang] [MinGW] Improve/extend the gcc/sysroot detection + logic + +There are three functions that try to detect the right implicit +sysroot and libgcc directory setup to use +- One which looks for mingw sysroots located in + /../ +- One which looks for a mingw-targeting gcc executables in the PATH +- One which looks in the /lib/gcc directory to find the + right one to use, and the right specific triple used for arch + specific directories in the gcc/libstdc++ install + +These have mostly tried to look for executables named +"-w64-mingw32-gcc" or "mingw32-gcc" or subdirectories +named "-w64-mingw32" or "mingw32". + +In the case of findClangRelativeSysroot, it also has looked +for directories with the name of the actual triple. This +was added in deff7536278d355977171726124f83aa4bb95419, +with the intent of looking for a directory matching exactly +the user provided literal triple - however the triple here +is the normalized one, not the one provided by the user on +the command line. + +Improve and unify this logic somewhat: +- Always first look for things based on the literal triple + provided by the user. +- Secondly look for things based on the normalized triple + (which usually ends up as e.g. x86_64-w64-windows-gnu), + accessed via the Triple which is passed to the constructor +- Then look for the common triple form -w64-mingw32 + +The literal triple provided by the user is available via +Driver::getTargetTriple(), but computeTargetTriple() may +change e.g. the architecture of it, so we need to +reapply the effective architecture on the literal triple +spelling from Driver::getTargetTriple(). + +Do this consistently for all of findGcc, findClangRelativeSysroot +and findGccLibDir (while keeping the existing plain "mingw32" +cases in findGcc and findGccLibDir too). + +Fedora 37 started shipping mingw sysroots targeting UCRT, +in addition to the traditional msvcrt.dll, and these use +triples in the form -w64-mingw32ucrt - see +https://fedoraproject.org/wiki/Changes/F37MingwUCRT. + +Thus, in addition to the existing default tested triples, +try looking for triples in the form -w64-mingw32ucrt, +to automatically find the UCRT sysroots on Fedora 37. +By explicitly setting a specific target on the Clang command +line, the user can be more explicit with which flavour is +to be preferred. + +This should fix the main issue in +https://github.com/llvm/llvm-project/issues/59001. + +Differential Revision: https://reviews.llvm.org/D138692 +--- + clang/lib/Driver/ToolChains/MinGW.cpp | 68 ++++++++++++++----- + clang/lib/Driver/ToolChains/MinGW.h | 2 +- + .../12.2.1/include-fixed/.keep | 0 + .../sys-root/mingw/include/.keep | 0 + .../sys-root/mingw/include/c++/backward/.keep | 0 + .../include/c++/x86_64-w64-mingw32ucrt/.keep | 0 + clang/test/Driver/mingw-sysroot.cpp | 13 ++++ + clang/test/Driver/mingw.cpp | 4 ++ + 8 files changed, 68 insertions(+), 19 deletions(-) + create mode 100644 clang/test/Driver/Inputs/mingw_fedora_tree/usr/lib/gcc/x86_64-w64-mingw32ucrt/12.2.1/include-fixed/.keep + create mode 100644 clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/.keep + create mode 100644 clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/backward/.keep + create mode 100644 clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/x86_64-w64-mingw32ucrt/.keep + +diff --git a/clang/lib/Driver/ToolChains/MinGW.cpp b/clang/lib/Driver/ToolChains/MinGW.cpp +index ae7c4c56bf9e..0ebacea6e87f 100644 +--- a/clang/lib/Driver/ToolChains/MinGW.cpp ++++ b/clang/lib/Driver/ToolChains/MinGW.cpp +@@ -359,13 +359,26 @@ static bool findGccVersion(StringRef LibDir, std::string &GccLibDir, + return Ver.size(); + } + +-void toolchains::MinGW::findGccLibDir() { +- llvm::SmallVector, 2> SubdirNames; ++static llvm::Triple getLiteralTriple(const Driver &D, const llvm::Triple &T) { ++ llvm::Triple LiteralTriple(D.getTargetTriple()); ++ // The arch portion of the triple may be overridden by -m32/-m64. ++ LiteralTriple.setArchName(T.getArchName()); ++ return LiteralTriple; ++} ++ ++void toolchains::MinGW::findGccLibDir(const llvm::Triple &LiteralTriple) { ++ llvm::SmallVector, 5> SubdirNames; ++ SubdirNames.emplace_back(LiteralTriple.str()); ++ SubdirNames.emplace_back(getTriple().str()); + SubdirNames.emplace_back(getTriple().getArchName()); +- SubdirNames[0] += "-w64-mingw32"; ++ SubdirNames.back() += "-w64-mingw32"; ++ SubdirNames.emplace_back(getTriple().getArchName()); ++ SubdirNames.back() += "-w64-mingw32ucrt"; + SubdirNames.emplace_back("mingw32"); +- if (SubdirName.empty()) +- SubdirName = std::string(SubdirNames[0].str()); ++ if (SubdirName.empty()) { ++ SubdirName = getTriple().getArchName(); ++ SubdirName += "-w64-mingw32"; ++ } + // lib: Arch Linux, Ubuntu, Windows + // lib64: openSUSE Linux + for (StringRef CandidateLib : {"lib", "lib64"}) { +@@ -380,10 +393,17 @@ void toolchains::MinGW::findGccLibDir() { + } + } + +-static llvm::ErrorOr findGcc(const llvm::Triple &T) { +- llvm::SmallVector, 2> Gccs; ++static llvm::ErrorOr findGcc(const llvm::Triple &LiteralTriple, ++ const llvm::Triple &T) { ++ llvm::SmallVector, 5> Gccs; ++ Gccs.emplace_back(LiteralTriple.str()); ++ Gccs.back() += "-gcc"; ++ Gccs.emplace_back(T.str()); ++ Gccs.back() += "-gcc"; + Gccs.emplace_back(T.getArchName()); +- Gccs[0] += "-w64-mingw32-gcc"; ++ Gccs.back() += "-w64-mingw32-gcc"; ++ Gccs.emplace_back(T.getArchName()); ++ Gccs.back() += "-w64-mingw32ucrt-gcc"; + Gccs.emplace_back("mingw32-gcc"); + // Please do not add "gcc" here + for (StringRef CandidateGcc : Gccs) +@@ -393,12 +413,15 @@ static llvm::ErrorOr findGcc(const llvm::Triple &T) { + } + + static llvm::ErrorOr +-findClangRelativeSysroot(const Driver &D, const llvm::Triple &T, +- std::string &SubdirName) { +- llvm::SmallVector, 2> Subdirs; ++findClangRelativeSysroot(const Driver &D, const llvm::Triple &LiteralTriple, ++ const llvm::Triple &T, std::string &SubdirName) { ++ llvm::SmallVector, 4> Subdirs; ++ Subdirs.emplace_back(LiteralTriple.str()); + Subdirs.emplace_back(T.str()); + Subdirs.emplace_back(T.getArchName()); +- Subdirs[1] += "-w64-mingw32"; ++ Subdirs.back() += "-w64-mingw32"; ++ Subdirs.emplace_back(T.getArchName()); ++ Subdirs.back() += "-w64-mingw32ucrt"; + StringRef ClangRoot = llvm::sys::path::parent_path(D.getInstalledDir()); + StringRef Sep = llvm::sys::path::get_separator(); + for (StringRef CandidateSubdir : Subdirs) { +@@ -418,14 +441,16 @@ toolchains::MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, + + // The sequence for detecting a sysroot here should be kept in sync with + // the testTriple function below. ++ llvm::Triple LiteralTriple = getLiteralTriple(D, getTriple()); + if (getDriver().SysRoot.size()) + Base = getDriver().SysRoot; + // Look for /../; if found, use /.. as the + // base as it could still be a base for a gcc setup with libgcc. +- else if (llvm::ErrorOr TargetSubdir = +- findClangRelativeSysroot(getDriver(), getTriple(), SubdirName)) ++ else if (llvm::ErrorOr TargetSubdir = findClangRelativeSysroot( ++ getDriver(), LiteralTriple, getTriple(), SubdirName)) + Base = std::string(llvm::sys::path::parent_path(TargetSubdir.get())); +- else if (llvm::ErrorOr GPPName = findGcc(getTriple())) ++ else if (llvm::ErrorOr GPPName = ++ findGcc(LiteralTriple, getTriple())) + Base = std::string(llvm::sys::path::parent_path( + llvm::sys::path::parent_path(GPPName.get()))); + else +@@ -433,7 +458,7 @@ toolchains::MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, + llvm::sys::path::parent_path(getDriver().getInstalledDir())); + + Base += llvm::sys::path::get_separator(); +- findGccLibDir(); ++ findGccLibDir(LiteralTriple); + // GccLibDir must precede Base/lib so that the + // correct crtbegin.o ,cetend.o would be found. + getFilePaths().push_back(GccLibDir); +@@ -576,6 +601,12 @@ void toolchains::MinGW::printVerboseInfo(raw_ostream &OS) const { + // /usr/include/c++/4.8/backward + // /usr/x86_64-w64-mingw32/include + ++// Fedora ++// /usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/x86_64-w64-mingw32ucrt ++// /usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/backward ++// /usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include ++// /usr/lib/gcc/x86_64-w64-mingw32ucrt/12.2.1/include-fixed ++ + void toolchains::MinGW::AddClangSystemIncludeArgs(const ArgList &DriverArgs, + ArgStringList &CC1Args) const { + if (DriverArgs.hasArg(options::OPT_nostdinc)) +@@ -667,10 +698,11 @@ static bool testTriple(const Driver &D, const llvm::Triple &Triple, + std::string SubdirName; + if (D.SysRoot.size()) + return true; ++ llvm::Triple LiteralTriple = getLiteralTriple(D, Triple); + if (llvm::ErrorOr TargetSubdir = +- findClangRelativeSysroot(D, Triple, SubdirName)) ++ findClangRelativeSysroot(D, LiteralTriple, Triple, SubdirName)) + return true; +- if (llvm::ErrorOr GPPName = findGcc(Triple)) ++ if (llvm::ErrorOr GPPName = findGcc(LiteralTriple, Triple)) + return true; + // If we neither found a colocated sysroot or a matching gcc executable, + // conclude that we can't know if this is the correct spelling of the triple. +diff --git a/clang/lib/Driver/ToolChains/MinGW.h b/clang/lib/Driver/ToolChains/MinGW.h +index f15f99dc8a8c..bc17d273e776 100644 +--- a/clang/lib/Driver/ToolChains/MinGW.h ++++ b/clang/lib/Driver/ToolChains/MinGW.h +@@ -108,7 +108,7 @@ private: + std::string SubdirName; + mutable std::unique_ptr Preprocessor; + mutable std::unique_ptr Compiler; +- void findGccLibDir(); ++ void findGccLibDir(const llvm::Triple &LiteralTriple); + + bool NativeLLVMSupport; + }; +diff --git a/clang/test/Driver/Inputs/mingw_fedora_tree/usr/lib/gcc/x86_64-w64-mingw32ucrt/12.2.1/include-fixed/.keep b/clang/test/Driver/Inputs/mingw_fedora_tree/usr/lib/gcc/x86_64-w64-mingw32ucrt/12.2.1/include-fixed/.keep +new file mode 100644 +index 000000000000..e69de29bb2d1 +diff --git a/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/.keep b/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/.keep +new file mode 100644 +index 000000000000..e69de29bb2d1 +diff --git a/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/backward/.keep b/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/backward/.keep +new file mode 100644 +index 000000000000..e69de29bb2d1 +diff --git a/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/x86_64-w64-mingw32ucrt/.keep b/clang/test/Driver/Inputs/mingw_fedora_tree/usr/x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/x86_64-w64-mingw32ucrt/.keep +new file mode 100644 +index 000000000000..e69de29bb2d1 +diff --git a/clang/test/Driver/mingw-sysroot.cpp b/clang/test/Driver/mingw-sysroot.cpp +index 1cb51b3aea2d..985be9e5f2ac 100644 +--- a/clang/test/Driver/mingw-sysroot.cpp ++++ b/clang/test/Driver/mingw-sysroot.cpp +@@ -14,6 +14,11 @@ + // RUN: ln -s %S/Inputs/mingw_ubuntu_posix_tree/usr/x86_64-w64-mingw32 %T/testroot-clang/x86_64-w64-mingw32 + // RUN: ln -s %S/Inputs/mingw_arch_tree/usr/i686-w64-mingw32 %T/testroot-clang/i686-w64-mingw32 + ++// RUN: rm -rf %T/testroot-custom-triple ++// RUN: mkdir -p %T/testroot-custom-triple/bin ++// RUN: ln -s %clang %T/testroot-custom-triple/bin/x86_64-w64-mingw32foo-clang ++// RUN: ln -s %clang %T/testroot-custom-triple/bin/clang ++// RUN: ln -s %S/Inputs/mingw_ubuntu_posix_tree/usr/x86_64-w64-mingw32 %T/testroot-custom-triple/x86_64-w64-mingw32foo + + // If we find a gcc in the path with the right triplet prefix, pick that as + // sysroot: +@@ -51,3 +56,11 @@ + + // RUN: env "PATH=%T/testroot-gcc/bin:%PATH%" %T/testroot-clang/bin/x86_64-w64-mingw32-clang --target=x86_64-w64-mingw32 -m32 -rtlib=compiler-rt -stdlib=libstdc++ --sysroot="" -c -### %s 2>&1 | FileCheck -check-prefix=CHECK_TESTROOT_CLANG_I686 %s + // CHECK_TESTROOT_CLANG_I686: "{{[^"]+}}/testroot-clang{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include" ++ ++ ++// If the user calls clang with a custom literal triple, make sure this maps ++// to sysroots with the matching spelling. ++ ++// RUN: %T/testroot-custom-triple/bin/x86_64-w64-mingw32foo-clang -rtlib=compiler-rt -stdlib=libstdc++ --sysroot="" -c -### %s 2>&1 | FileCheck -check-prefix=CHECK_TESTROOT_CUSTOM_TRIPLE %s ++// RUN: %T/testroot-custom-triple/bin/clang --target=x86_64-w64-mingw32foo -rtlib=compiler-rt -stdlib=libstdc++ --sysroot="" -c -### %s 2>&1 | FileCheck -check-prefix=CHECK_TESTROOT_CUSTOM_TRIPLE %s ++// CHECK_TESTROOT_CUSTOM_TRIPLE: "{{[^"]+}}/testroot-custom-triple{{/|\\\\}}x86_64-w64-mingw32foo{{/|\\\\}}include" +diff --git a/clang/test/Driver/mingw.cpp b/clang/test/Driver/mingw.cpp +index b37503e475d8..bde952fb3565 100644 +--- a/clang/test/Driver/mingw.cpp ++++ b/clang/test/Driver/mingw.cpp +@@ -39,6 +39,10 @@ + // CHECK_MINGW_OPENSUSE_TREE: "[[BASE]]/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}x86_64-w64-mingw32/sys-root/mingw/include" + + ++// RUN: %clang -target x86_64-pc-windows-gnu -rtlib=platform -stdlib=libstdc++ -c -### --sysroot=%S/Inputs/mingw_fedora_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_FEDORA_TREE %s ++// CHECK_MINGW_FEDORA_TREE: "[[BASE:[^"]+]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include" ++ ++ + // RUN: %clang -target i686-pc-windows-gnu -rtlib=platform -stdlib=libstdc++ -c -### --sysroot=%S/Inputs/mingw_arch_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_ARCH_TREE %s + // CHECK_MINGW_ARCH_TREE: "[[BASE:[^"]+]]/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}5.1.0" + // CHECK_MINGW_ARCH_TREE: "[[BASE]]/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}5.1.0{{/|\\\\}}i686-w64-mingw32" +-- +2.38.1 + diff --git a/0002-clang-MinGW-Improve-detection-of-libstdc-headers-on-.patch b/0002-clang-MinGW-Improve-detection-of-libstdc-headers-on-.patch new file mode 100644 index 0000000..7376d7f --- /dev/null +++ b/0002-clang-MinGW-Improve-detection-of-libstdc-headers-on-.patch @@ -0,0 +1,139 @@ +From d3b79c2950d590cb272648f1c6a9dd7646f57beb Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Martin=20Storsj=C3=B6?= +Date: Tue, 22 Nov 2022 14:39:39 +0200 +Subject: [PATCH 2/2] [clang] [MinGW] Improve detection of libstdc++ headers on + Fedora + +There's some variation in where different toolchain distributions +(and linux distributions) package the mingw sysroots - this is +so far handled by adding specific known subdirectory paths +to the include and lib directory lists. + +There are multiple degrees of combinatorics involved here though; +the distros may use different locations such as +/usr/x86_64-w64-mingw32/include or +/usr/x86_64-w64-mingw32/sys-root/mingw/include. + +So far, this setup has been treated as base=/usr, subdir=x86_64-w64-mingw32, +and the driver tries to add further subdirectories such as +//include, //sys-root/mingw/include. + +When it comes to libstdc++ (and libc++), each of these come with +a large number of potential subdirectories. Instead of further +exploding the combinatorics another step by adding all combinations +of all paths, check whether //sys-root/mingw/include +exists, and if it does, append that subpath into the subdir variable. + +This allows finding libstdc++ headers in e.g. +/usr/x86_64-w64-mingw32/sys-root/mingw/include/c++/x86_64-w64-mingw32 +on Fedora. + +The same logic (where everything belonging to this target fits +under one expanded path, with just /include and /lib +under it) doesn't seem to apply on Gentoo, where the includes +are found in //usr/include while the libraries +are in //mingw/lib (see +8e218026f8d5eabfdef9141ae5e26aa91d1933e6). But apparently +the libstdc++ headers aren't installed under +//usr/include, so that path hierarchy quirk doesn't +need to be taken into account in AddClangCXXStdlibIncludeArgs. + +Differential Revision: https://reviews.llvm.org/D138693 +--- + clang/lib/Driver/ToolChains/MinGW.cpp | 19 +++++++++---------- + clang/lib/Driver/ToolChains/MinGW.h | 1 + + clang/test/Driver/mingw.cpp | 5 ++++- + 3 files changed, 14 insertions(+), 11 deletions(-) + +diff --git a/clang/lib/Driver/ToolChains/MinGW.cpp b/clang/lib/Driver/ToolChains/MinGW.cpp +index 0ebacea6e87f..2a9bf4b18f19 100644 +--- a/clang/lib/Driver/ToolChains/MinGW.cpp ++++ b/clang/lib/Driver/ToolChains/MinGW.cpp +@@ -376,7 +376,7 @@ void toolchains::MinGW::findGccLibDir(const llvm::Triple &LiteralTriple) { + SubdirNames.back() += "-w64-mingw32ucrt"; + SubdirNames.emplace_back("mingw32"); + if (SubdirName.empty()) { +- SubdirName = getTriple().getArchName(); ++ SubdirName = getTriple().getArchName().str(); + SubdirName += "-w64-mingw32"; + } + // lib: Arch Linux, Ubuntu, Windows +@@ -459,9 +459,16 @@ toolchains::MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, + + Base += llvm::sys::path::get_separator(); + findGccLibDir(LiteralTriple); ++ TripleDirName = SubdirName; + // GccLibDir must precede Base/lib so that the + // correct crtbegin.o ,cetend.o would be found. + getFilePaths().push_back(GccLibDir); ++ ++ // openSUSE/Fedora ++ std::string CandidateSubdir = SubdirName + "/sys-root/mingw"; ++ if (getDriver().getVFS().exists(Base + CandidateSubdir)) ++ SubdirName = CandidateSubdir; ++ + getFilePaths().push_back( + (Base + SubdirName + llvm::sys::path::get_separator() + "lib").str()); + +@@ -470,8 +477,6 @@ toolchains::MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, + (Base + SubdirName + llvm::sys::path::get_separator() + "mingw/lib").str()); + + getFilePaths().push_back(Base + "lib"); +- // openSUSE +- getFilePaths().push_back(Base + SubdirName + "/sys-root/mingw/lib"); + + NativeLLVMSupport = + Args.getLastArgValue(options::OPT_fuse_ld_EQ, CLANG_DEFAULT_LINKER) +@@ -621,12 +626,6 @@ void toolchains::MinGW::AddClangSystemIncludeArgs(const ArgList &DriverArgs, + if (DriverArgs.hasArg(options::OPT_nostdlibinc)) + return; + +- if (GetRuntimeLibType(DriverArgs) == ToolChain::RLT_Libgcc) { +- // openSUSE +- addSystemInclude(DriverArgs, CC1Args, +- Base + SubdirName + "/sys-root/mingw/include"); +- } +- + addSystemInclude(DriverArgs, CC1Args, + Base + SubdirName + llvm::sys::path::get_separator() + + "include"); +@@ -684,7 +683,7 @@ void toolchains::MinGW::AddClangCXXStdlibIncludeArgs( + for (auto &CppIncludeBase : CppIncludeBases) { + addSystemInclude(DriverArgs, CC1Args, CppIncludeBase); + CppIncludeBase += Slash; +- addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + SubdirName); ++ addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + TripleDirName); + addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + "backward"); + } + break; +diff --git a/clang/lib/Driver/ToolChains/MinGW.h b/clang/lib/Driver/ToolChains/MinGW.h +index bc17d273e776..ef9bfb29e175 100644 +--- a/clang/lib/Driver/ToolChains/MinGW.h ++++ b/clang/lib/Driver/ToolChains/MinGW.h +@@ -106,6 +106,7 @@ private: + clang::driver::toolchains::Generic_GCC::GCCVersion GccVer; + std::string Ver; + std::string SubdirName; ++ std::string TripleDirName; + mutable std::unique_ptr Preprocessor; + mutable std::unique_ptr Compiler; + void findGccLibDir(const llvm::Triple &LiteralTriple); +diff --git a/clang/test/Driver/mingw.cpp b/clang/test/Driver/mingw.cpp +index bde952fb3565..46ea55b9500d 100644 +--- a/clang/test/Driver/mingw.cpp ++++ b/clang/test/Driver/mingw.cpp +@@ -40,7 +40,10 @@ + + + // RUN: %clang -target x86_64-pc-windows-gnu -rtlib=platform -stdlib=libstdc++ -c -### --sysroot=%S/Inputs/mingw_fedora_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_FEDORA_TREE %s +-// CHECK_MINGW_FEDORA_TREE: "[[BASE:[^"]+]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include" ++// CHECK_MINGW_FEDORA_TREE: "[[BASE:[^"]+]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++" ++// CHECK_MINGW_FEDORA_TREE: "[[BASE]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/x86_64-w64-mingw32ucrt" ++// CHECK_MINGW_FEDORA_TREE: "[[BASE]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include/c++/backward" ++// CHECK_MINGW_FEDORA_TREE: "[[BASE]]/Inputs/mingw_fedora_tree/usr{{/|\\\\}}x86_64-w64-mingw32ucrt/sys-root/mingw/include" + + + // RUN: %clang -target i686-pc-windows-gnu -rtlib=platform -stdlib=libstdc++ -c -### --sysroot=%S/Inputs/mingw_arch_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_ARCH_TREE %s +-- +2.38.1 + diff --git a/clang.spec b/clang.spec index e9d883c..9b80ad6 100644 --- a/clang.spec +++ b/clang.spec @@ -41,7 +41,7 @@ Name: %pkg_name Version: %{clang_version}%{?rc_ver:~rc%{rc_ver}} -Release: 1%{?dist} +Release: 2%{?dist} Summary: A C language family front-end for LLVM License: NCSA @@ -72,6 +72,10 @@ Patch7: 0001-Mark-fopenmp-implicit-rpath-as-NoArgumentUnused.patch # TODO: Can be dropped in LLVM 16: https://reviews.llvm.org/D134362 Patch8: 0001-clang-Fix-interaction-between-asm-labels-and-inline-.patch +# TODO: Can be dropped in LLVM 16. +Patch9: 0001-clang-MinGW-Improve-extend-the-gcc-sysroot-detection.patch +Patch10: 0002-clang-MinGW-Improve-detection-of-libstdc-headers-on-.patch + %if %{without compat_build} # Patches for clang-tools-extra # See https://reviews.llvm.org/D120301 @@ -608,6 +612,9 @@ false %endif %changelog +* Mon Dec 12 2022 Nikita Popov - 15.0.6-2 +- Backport patches for ucrt64 toolchain detection + * Mon Dec 05 2022 Nikita Popov - 15.0.6-1 - Update to LLVM 15.0.6