mirror of
https://git.proxmox.com/git/llvm-toolchain
synced 2025-06-12 11:06:17 +00:00

0044-soname.diff,23-strlcpy_strlcat_warning_removed.diff, 26-set-correct-float-abi.diff,atomic_library_[12].diff, fix-clang-path-and-build.diff,fix-lldb-server-build,lldb-libname.diff, lldb-soname.diff,mips-fpxx-enable.diff,removeduplicatedeclaration.diff}: Refreshed. * debian/patches/{silent-gold-utils,kfreebsd-support}.diff: Updated.
41 lines
1.4 KiB
Diff
41 lines
1.4 KiB
Diff
---
|
|
clang/lib/Basic/Targets.cpp | 27 ---------------------------
|
|
1 file changed, 27 deletions(-)
|
|
|
|
--- a/clang/lib/Basic/Targets.cpp
|
|
+++ b/clang/lib/Basic/Targets.cpp
|
|
@@ -4414,33 +4414,6 @@ protected:
|
|
Builder.defineMacro("__ELF__");
|
|
}
|
|
|
|
- static bool shouldUseInlineAtomic(const llvm::Triple &T) {
|
|
- // On linux, binaries targeting old cpus call functions in libgcc to
|
|
- // perform atomic operations. The implementation in libgcc then calls into
|
|
- // the kernel which on armv6 and newer uses ldrex and strex. The net result
|
|
- // is that if we assume the kernel is at least as recent as the hardware,
|
|
- // it is safe to use atomic instructions on armv6 and newer.
|
|
- if (T.getOS() != llvm::Triple::Linux)
|
|
- return false;
|
|
- StringRef ArchName = T.getArchName();
|
|
- if (T.getArch() == llvm::Triple::arm) {
|
|
- if (!ArchName.startswith("armv"))
|
|
- return false;
|
|
- StringRef VersionStr = ArchName.substr(4);
|
|
- unsigned Version;
|
|
- if (VersionStr.getAsInteger(10, Version))
|
|
- return false;
|
|
- return Version >= 6;
|
|
- }
|
|
- assert(T.getArch() == llvm::Triple::thumb);
|
|
- if (!ArchName.startswith("thumbv"))
|
|
- return false;
|
|
- StringRef VersionStr = ArchName.substr(6);
|
|
- unsigned Version;
|
|
- if (VersionStr.getAsInteger(10, Version))
|
|
- return false;
|
|
- return Version >= 7;
|
|
- }
|
|
|
|
public:
|
|
RTEMSTargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts)
|