diff options
| author | Michael J. Spencer <bigcheesegs@gmail.com> | 2013-04-04 23:53:43 +0000 |
|---|---|---|
| committer | Michael J. Spencer <bigcheesegs@gmail.com> | 2013-04-04 23:53:43 +0000 |
| commit | a0d5eb3a277a2e09bf1c51282a6b5d1bbcc3525c (patch) | |
| tree | bef40aecfd20939b1566564414d951c444b148c9 /clang/lib/Basic | |
| parent | d953d66ee97f89d5d72de15f6e45cb104324b301 (diff) | |
| download | bcm5719-llvm-a0d5eb3a277a2e09bf1c51282a6b5d1bbcc3525c.tar.gz bcm5719-llvm-a0d5eb3a277a2e09bf1c51282a6b5d1bbcc3525c.zip | |
Add support for __GCC_HAVE_SYNC_COMPARE_AND_SWAP_{1,2,4,8} on x86.
This fixes std::thread with libstdc++.
llvm-svn: 178816
Diffstat (limited to 'clang/lib/Basic')
| -rw-r--r-- | clang/lib/Basic/Targets.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index c7da36e8f7b..3eda9d8c184 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -2730,6 +2730,14 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts, case NoMMX3DNow: break; } + + if (CPU >= CK_i486) { + Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_1"); + Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_2"); + Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_4"); + } + if (CPU >= CK_i586) + Builder.defineMacro("__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8"); } bool X86TargetInfo::hasFeature(StringRef Feature) const { |

