Blame view

buildroot/buildroot-2016.08.1/package/mpd/0001-configure.ac-check-if-libatomic-is-needed.patch 1.45 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
  From 8eaf14a17244aaf000b4d19e4fde4a637576939f Mon Sep 17 00:00:00 2001
  From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
  Date: Sun, 7 Feb 2016 21:40:47 +0100
  Subject: [PATCH] configure.ac: check if libatomic is needed
  
  The mpd source code uses the C++11 <atomic> functionality, which
  internally is implemented using the __atomic_*() gcc built-ins. On
  certain architectures, the __atomic_*() built-ins are implemented in
  the libatomic library that comes with the rest of the gcc runtime. Due
  to this, code using <atomic> might need to link against libatomic,
  otherwise one hits build issues such as:
  
  GlobalEvents.cxx:(.text._ZN12GlobalEvents4EmitENS_5EventE+0x14): undefined reference to `__atomic_fetch_or_4'
  
  on an architecture like SPARC.
  
  To solve this, a configure.ac check is added to know if we need to
  link against libatomic or not.
  
  Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
  ---
   configure.ac | 2 ++
   1 file changed, 2 insertions(+)
  
  diff --git a/configure.ac b/configure.ac
  index 107b45a..8e6fab7 100644
  --- a/configure.ac
  +++ b/configure.ac
  @@ -233,6 +233,8 @@ if test x$have_pthread_setname_np = xyes; then
   	AC_DEFINE(HAVE_PTHREAD_SETNAME_NP, 1, [Is pthread_setname_np() available?])
   fi
   
  +AC_SEARCH_LIBS([__atomic_load_4], [atomic])
  +
   dnl ---------------------------------------------------------------------------
   dnl Event loop selection
   dnl ---------------------------------------------------------------------------
  -- 
  2.6.4