https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96853

            Bug ID: 96853
           Summary: Explicit template instantiation & thread_local
                    interaction
           Product: gcc
           Version: 10.1.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: tobias.bruell at gmail dot com
  Target Milestone: ---

Compiling the below with

> g++-10 main.cpp library.cpp -o main

in gcc 10.1 leads to an executable "main" that segfaults. The problem seems to
be that the out-commented "extern" declarations in library.hpp are missing.

So, the program might be UB, but it would be nice to get an error message from
the compiler (as Clang does).

Otherwise, the linker could give an error: the final executable "main" contains
a "callq 0x0" instruction (on x86_64) if you also add "-static" to the above
command-line. I think the problem is that "_ZTHN7library3FooIiE1fE" (TLS init
function for library::Foo<int>::f) is missing from any of the intermediate
object files.

--------------------------------
--------- library.hpp ----------

#ifndef INCLUDE_GUARD_LIBRARY_H_
#define INCLUDE_GUARD_LIBRARY_H_

namespace library
{
  template<typename T>
  struct Foo
  {
    using Func = T (*) (T);
    static thread_local Func f;
  };

  //extern template struct Foo<char>;
  //extern template struct Foo<int>;
  //extern template struct Foo<long>;
}

#endif

-------------------------------
--------- library.cpp ---------

#include "library.hpp"

namespace library
{
  template<typename T>
  T core_function (T val)
  {
    return val * 2;
  }

  template<typename T>
  thread_local
  typename Foo<T>::Func
  Foo<T>::f = &core_function<T>;

  template struct Foo<char>;
  template struct Foo<int>;
  template struct Foo<long>;
}

--------------------------------
----------- main.cpp -----------

#include "library.hpp"

int main () {
  return library::Foo<int>::f(2);
}

Reply via email to