From: Eric Niebler Date: Thu, 16 Jun 2016 17:08:54 +0000 (-0700) Subject: folly: fix clang's -Wundefined-var-template X-Git-Tag: 2016.07.26~138 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=7570fc58eb757feb6c852275f9573ba0fcbdfdc5;p=folly.git folly: fix clang's -Wundefined-var-template Summary: [temp] (14)/6: > A function template, member function of a class template, variable template, or static data member of a class template shall be defined in every translation unit in which it is implicitly instantiated (14.7.1) unless the corresponding specialization is explicitly instantiated (14.7.2) in some translation unit; no diagnostic is required. `-Wundefined-var-template` warns on any implicit instantiations that are needed but could not be performed because the definition is not available. In particular, for valid code, this warns on templates/temploids which have their definition and all relevant explicit instantiations tucked away in some source file (but for which no explicit instantiation declarations are provided in the relevant header file) - used a few times in folly. This seems a bad style, the static data member template should either be defined in the header file or should be explicitly instantiated in each .cpp file. Reviewed By: igorsugak Differential Revision: D3270439 fbshipit-source-id: bf305fde3af575a265d65a0ae0bf95db5597587f --- diff --git a/folly/Fingerprint.h b/folly/Fingerprint.h index f1980ae2..c7a20fb7 100644 --- a/folly/Fingerprint.h +++ b/folly/Fingerprint.h @@ -51,12 +51,20 @@ namespace folly { namespace detail { + template struct FingerprintTable { - static const uint64_t poly[1 + (BITS-1)/64]; - static const uint64_t table[8][256][1 + (BITS-1)/64]; + static const uint64_t poly[1 + (BITS - 1) / 64]; + static const uint64_t table[8][256][1 + (BITS - 1) / 64]; }; -} // namespace detail + +template +const uint64_t FingerprintTable::poly[1 + (BITS - 1) / 64] = {}; + +template +const uint64_t FingerprintTable::table[8][256][1 + (BITS - 1) / 64] = {}; + +} // namespace detail /** * Compute the Rabin fingerprint. diff --git a/folly/SharedMutex.cpp b/folly/SharedMutex.cpp index e7c5267e..23266b7c 100644 --- a/folly/SharedMutex.cpp +++ b/folly/SharedMutex.cpp @@ -16,7 +16,8 @@ #include "SharedMutex.h" -COMMON_CONCURRENCY_SHARED_MUTEX_DECLARE_STATIC_STORAGE( - folly::SharedMutexReadPriority); -COMMON_CONCURRENCY_SHARED_MUTEX_DECLARE_STATIC_STORAGE( - folly::SharedMutexWritePriority); +namespace folly { +// Explicitly instantiate SharedMutex here: +template class SharedMutexImpl; +template class SharedMutexImpl; +} diff --git a/folly/SharedMutex.h b/folly/SharedMutex.h index 15dc91e6..2d71a884 100644 --- a/folly/SharedMutex.h +++ b/folly/SharedMutex.h @@ -1429,16 +1429,33 @@ class SharedMutexImpl { } }; -#define COMMON_CONCURRENCY_SHARED_MUTEX_DECLARE_STATIC_STORAGE(type) \ - template <> \ - type::DeferredReaderSlot \ - type::deferredReaders[type::kMaxDeferredReaders * \ - type::kDeferredSeparationFactor] = {}; \ - template <> \ - FOLLY_TLS uint32_t type::tls_lastTokenlessSlot = 0; +template < + bool ReaderPriority, + typename Tag_, + template class Atom, + bool BlockImmediately> +typename SharedMutexImpl:: + DeferredReaderSlot + SharedMutexImpl:: + deferredReaders[kMaxDeferredReaders * kDeferredSeparationFactor] = + {}; + +template < + bool ReaderPriority, + typename Tag_, + template class Atom, + bool BlockImmediately> +FOLLY_TLS uint32_t + SharedMutexImpl:: + tls_lastTokenlessSlot = 0; typedef SharedMutexImpl SharedMutexReadPriority; typedef SharedMutexImpl SharedMutexWritePriority; typedef SharedMutexWritePriority SharedMutex; +// Prevent the compiler from instantiating these in other translation units. +// They are instantiated once in SharedMutex.cpp +extern template class SharedMutexImpl; +extern template class SharedMutexImpl; + } // namespace folly diff --git a/folly/detail/CacheLocality.cpp b/folly/detail/CacheLocality.cpp index e75120d6..c62e0ac8 100644 --- a/folly/detail/CacheLocality.cpp +++ b/folly/detail/CacheLocality.cpp @@ -28,8 +28,6 @@ #include #include -DECLARE_ACCESS_SPREADER_TYPE(std::atomic) - namespace folly { namespace detail { @@ -233,21 +231,11 @@ Getcpu::Func Getcpu::resolveVdsoFunc() { #ifdef FOLLY_TLS /////////////// SequentialThreadId - -template <> -std::atomic SequentialThreadId::prevId(0); - -template <> -FOLLY_TLS size_t SequentialThreadId::currentId(0); +template struct SequentialThreadId; #endif /////////////// AccessSpreader - -template <> -Getcpu::Func AccessSpreader::pickGetcpuFunc() { - auto best = Getcpu::resolveVdsoFunc(); - return best ? best : &FallbackGetcpuType::getcpu; -} +template struct AccessSpreader; } // namespace detail } // namespace folly diff --git a/folly/detail/CacheLocality.h b/folly/detail/CacheLocality.h index 1ede43cb..c9baf528 100644 --- a/folly/detail/CacheLocality.h +++ b/folly/detail/CacheLocality.h @@ -161,6 +161,16 @@ struct SequentialThreadId { static FOLLY_TLS size_t currentId; }; + +template