Anthony Towns
8 years ago
2 changed files with 43 additions and 0 deletions
@ -0,0 +1,40 @@
@@ -0,0 +1,40 @@
|
||||
# Some versions of gcc/libstdc++ require linking with -latomic if |
||||
# using the C++ atomic library. |
||||
# |
||||
# Sourced from http://bugs.debian.org/797228 |
||||
|
||||
m4_define([_CHECK_ATOMIC_testbody], [[ |
||||
#include <atomic> |
||||
#include <cstdint> |
||||
|
||||
int main() { |
||||
std::atomic<int64_t> a{}; |
||||
|
||||
int64_t v = 5; |
||||
int64_t r = a.fetch_add(v); |
||||
return static_cast<int>(r); |
||||
} |
||||
]]) |
||||
|
||||
AC_DEFUN([CHECK_ATOMIC], [ |
||||
|
||||
AC_LANG_PUSH(C++) |
||||
|
||||
AC_MSG_CHECKING([whether std::atomic can be used without link library]) |
||||
|
||||
AC_LINK_IFELSE([AC_LANG_SOURCE([_CHECK_ATOMIC_testbody])],[ |
||||
AC_MSG_RESULT([yes]) |
||||
],[ |
||||
AC_MSG_RESULT([no]) |
||||
LIBS="$LIBS -latomic" |
||||
AC_MSG_CHECKING([whether std::atomic needs -latomic]) |
||||
AC_LINK_IFELSE([AC_LANG_SOURCE([_CHECK_ATOMIC_testbody])],[ |
||||
AC_MSG_RESULT([yes]) |
||||
],[ |
||||
AC_MSG_RESULT([no]) |
||||
AC_MSG_FAILURE([cannot figure our how to use std::atomic]) |
||||
]) |
||||
]) |
||||
|
||||
AC_LANG_POP |
||||
]) |
Loading…
Reference in new issue