TLS模型上的GCC公共变量属性

问题描述

引用GCC website。据说

tls_model属性设置特定__thread变量的线程本地存储模型(请参见Thread-Local),并在每个变量的基础上覆盖-ftls-model =命令行开关。 tls_model参数应为全局动态,局部动态,initial-exec或local-exec中的一个。并非所有目标都支持此属性。

为了研究为不同的TLS模型生成的程序集的差异,创建了一个具有三个__thread变量的类。

#include <cstdint>

class Holder
{
public:
    static int32_t calc();
    static int32_t calc2();
    static int32_t calc3();
    static __thread int32_t value  __attribute__ ((tls_model("initial-exec")));
    static __thread int32_t value2  __attribute__ ((tls_model("local-dynamic")));
    static __thread int32_t value3;
};

__thread int32_t Holder::value;
__thread int32_t Holder::value2;
__thread int32_t Holder::value3;

int32_t Holder::calc()
{
    return value * 2;
}

int32_t Holder::calc2()
{
    return value2 * 2;
}

int32_t Holder::calc3()
{
    return value3 * 2;
}

这是用-c -shared -fPIC -O3标志编译的。但是,请注意,该属性在相应的calc函数中不会产生任何差异。 (所有都在相应的calc函数中使用__tls_get_addr。)但是,如果添加了-ftls-model=initial-exec标志,它的确会更改TLS模型,但全部被覆盖以使用inital-exec(所有calc函数都使用{ {1}})

使用在线编译器浏览器,发现clang(LLVM)和icc似乎都支持该属性,但不支持gcc。它也似乎与GCC网站中的描述相矛盾(以每个变量为基础)。可以在this上尝试一下,然后切换到其他编译器。

GCC是否有理由取消覆盖每个变量设置的功能?还是我做错了事或有错误的期望?

感谢您事先提供的帮助和说明。

解决方法

这是一个错误,可能是C ++前端和/或属性合并代码中的错误。如果从定义的声明中移动或复制该属性,则该属性将按预期工作。如果消除定义,仅保留声明,则它也可以根据文档使用。基本上,每个定义似乎都不能正确地继承前面的声明中的属性。这值得在https://gnu.gnu.org/bugzilla

进行错误报告

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...