[runtimes] Support ELF dependent libraries feature

As of r360984, LLD supports dependent libraries feature for ELF.
libunwind, libc++abi and libc++ have library dependencies: libdl librt
and libpthread, which means that when libunwind and libc++ are being
statically linked (using -static-libstdc++ flag), user has to manually
specify -ldl -lpthread which is onerous.

This change includes the lib pragma to specify the library dependencies
directly in the source that uses those libraries. This doesn't make any
difference when using linkers that don't support dependent libraries.
However, when using LLD that has dependent libraries feature, users no
longer have to manually specifying library dependencies when using
static linking, linker will pick the library automatically.

Differential Revision: https://reviews.llvm.org/D62090

git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@362048 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Petr Hosek
2019-05-30 01:34:41 +00:00
parent c30e2d9f77
commit 74d2da4ba5
10 changed files with 41 additions and 0 deletions

View File

@@ -8,7 +8,12 @@
#include "algorithm" #include "algorithm"
#include "random" #include "random"
#ifndef _LIBCPP_HAS_NO_THREADS
#include "mutex" #include "mutex"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD

View File

@@ -37,6 +37,10 @@
#endif #endif
#endif #endif
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "rt")
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD
namespace chrono namespace chrono

View File

@@ -15,6 +15,10 @@
#include "system_error" #include "system_error"
#include "__undef_macros" #include "__undef_macros"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD
condition_variable::~condition_variable() condition_variable::~condition_variable()

View File

@@ -13,7 +13,12 @@
#include "string" #include "string"
#include "cstdio" #include "cstdio"
#include "__hash_table" #include "__hash_table"
#ifndef _LIBCPP_HAS_NO_THREADS
#include "mutex" #include "mutex"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD

View File

@@ -12,6 +12,9 @@
#include "atomic" #include "atomic"
#elif !defined(_LIBCPP_HAS_NO_THREADS) #elif !defined(_LIBCPP_HAS_NO_THREADS)
#include "mutex" #include "mutex"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
#endif #endif
_LIBCPP_BEGIN_NAMESPACE_LFTS_PMR _LIBCPP_BEGIN_NAMESPACE_LFTS_PMR

View File

@@ -44,6 +44,10 @@
#include <sys/time.h> // for gettimeofday and timeval #include <sys/time.h> // for gettimeofday and timeval
#endif // !defined(CLOCK_REALTIME) #endif // !defined(CLOCK_REALTIME)
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "rt")
#endif
#if defined(_LIBCPP_COMPILER_GCC) #if defined(_LIBCPP_COMPILER_GCC)
#if _GNUC_VER < 500 #if _GNUC_VER < 500
#pragma GCC diagnostic ignored "-Wmissing-field-initializers" #pragma GCC diagnostic ignored "-Wmissing-field-initializers"

View File

@@ -10,6 +10,9 @@
#ifndef _LIBCPP_HAS_NO_THREADS #ifndef _LIBCPP_HAS_NO_THREADS
#include "mutex" #include "mutex"
#include "thread" #include "thread"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
#endif #endif
#include "include/atomic_support.h" #include "include/atomic_support.h"

View File

@@ -12,6 +12,12 @@
#include "include/atomic_support.h" #include "include/atomic_support.h"
#include "__undef_macros" #include "__undef_macros"
#ifndef _LIBCPP_HAS_NO_THREADS
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD
#ifndef _LIBCPP_HAS_NO_THREADS #ifndef _LIBCPP_HAS_NO_THREADS

View File

@@ -10,6 +10,9 @@
#ifndef _LIBCPP_HAS_NO_THREADS #ifndef _LIBCPP_HAS_NO_THREADS
#include "shared_mutex" #include "shared_mutex"
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD

View File

@@ -35,6 +35,10 @@
#include <windows.h> #include <windows.h>
#endif #endif
#if defined(__unix__) && defined(__ELF__) && defined(__clang__)
#pragma comment(lib, "pthread")
#endif
_LIBCPP_BEGIN_NAMESPACE_STD _LIBCPP_BEGIN_NAMESPACE_STD
thread::~thread() thread::~thread()