diff options
author | Louis Dionne <ldionne@apple.com> | 2019-08-13 15:02:53 +0000 |
---|---|---|
committer | Louis Dionne <ldionne@apple.com> | 2019-08-13 15:02:53 +0000 |
commit | 8a033a9e3fb96b9a1099325c4cd218c1c979d9d9 (patch) | |
tree | 16928742174286dedc0d67f29541fefcc7a0dbbe /libcxx/src | |
parent | 676594305a16bb085b8dfa24a5adbb5e97be6d69 (diff) | |
download | bcm5719-llvm-8a033a9e3fb96b9a1099325c4cd218c1c979d9d9.tar.gz bcm5719-llvm-8a033a9e3fb96b9a1099325c4cd218c1c979d9d9.zip |
[libc++] Always build with -fvisibility=hidden
Summary:
This avoids symbols being accidentally exported from the dylib when they
shouldn't. The next step is to use a pragma to apply hidden visibility
to all declarations (unless otherwise specified), which will allow us
to drop the per-declaration hidden visibility attributes we currently
have.
This also has the nice side effect of making sure the dylib exports the
same symbols regardless of the optimization level.
PR38138
Reviewers: EricWF, mclow.lists
Subscribers: mgorny, christof, jkorous, dexonsmith, libcxx-commits
Tags: #libc
Differential Revision: https://reviews.llvm.org/D62868
llvm-svn: 368703
Diffstat (limited to 'libcxx/src')
-rw-r--r-- | libcxx/src/CMakeLists.txt | 2 | ||||
-rw-r--r-- | libcxx/src/valarray.cpp | 4 |
2 files changed, 3 insertions, 3 deletions
diff --git a/libcxx/src/CMakeLists.txt b/libcxx/src/CMakeLists.txt index 352791e8b28..11c911ac2dc 100644 --- a/libcxx/src/CMakeLists.txt +++ b/libcxx/src/CMakeLists.txt @@ -204,6 +204,7 @@ function(cxx_set_common_defines name) if(LIBCXX_CXX_ABI_HEADER_TARGET) add_dependencies(${name} ${LIBCXX_CXX_ABI_HEADER_TARGET}) endif() + target_compile_options(${name} PRIVATE -fvisibility=hidden) if(WIN32 AND NOT MINGW) target_compile_definitions(${name} PRIVATE @@ -355,7 +356,6 @@ if (LIBCXX_ENABLE_STATIC) cxx_set_common_defines(cxx_static) if (LIBCXX_HERMETIC_STATIC_LIBRARY) - append_flags_if_supported(CXX_STATIC_LIBRARY_FLAGS -fvisibility=hidden) # If the hermetic library doesn't define the operator new/delete functions # then its code shouldn't declare them with hidden visibility. They might # actually be provided by a shared library at link time. diff --git a/libcxx/src/valarray.cpp b/libcxx/src/valarray.cpp index 7bf0b417588..64d26583c74 100644 --- a/libcxx/src/valarray.cpp +++ b/libcxx/src/valarray.cpp @@ -12,8 +12,8 @@ _LIBCPP_BEGIN_NAMESPACE_STD // These two symbols are part of the v1 ABI but not part of the >=v2 ABI. #if _LIBCPP_ABI_VERSION == 1 -template valarray<size_t>::valarray(size_t); -template valarray<size_t>::~valarray(); +template _LIBCPP_FUNC_VIS valarray<size_t>::valarray(size_t); +template _LIBCPP_FUNC_VIS valarray<size_t>::~valarray(); #endif template void valarray<size_t>::resize(size_t, size_t); |