LD_PRELOAD和线程局部变量

时间:2014-01-23 23:40:01

标签: c++ linux multithreading pthreads

我有一个共享库(libtest.cpp)和一个简单的程序(test.cpp)。我希望他们共享线程局部变量 gVar 。共享库通过LD_PRELOAD链接。

这是我的共享库libtest.cpp的代码:

#include<stdio.h>

__thread int gVar;

void print_gVar(){
  printf("%d\n", gVar);
}

以下是test.cpp的代码。

#include<stdio.h>

__thread int gVar;

void __attribute__((weak)) print_gVar();

int main(){
  gVar = 10;
  print_gVar(); 
  return 0;
}

我使用以下脚本编译并运行它们。

g++ -g -shared -fPIC -olibtest.so libtest.cpp
g++ -g -fPIC -o test test.cpp
LD_PRELOAD=./libtest.so ./test

预期结果为10,因为test.cpp中的赋值将影响libtest.cpp中的gVar。但是,我只得到0.似乎libtest.cpp中的gVar和test.cpp中的gVar没有链接。

我做了一些额外的测试:

如果我在任何文件中将__attribute__((weak))添加到gVar的声明中,则输出仍为0.

如果我从两个文件中删除__thread,则结果为10(成功)。

如果我将extern__attribute__((weak))添加到libtest.cpp中gVar的声明中,则会出现分段错误。

我想LD_PRELOAD__thread一定有问题。但我无法弄明白。

有谁能告诉我如何让它发挥作用?非常感谢你!

1 个答案:

答案 0 :(得分:5)

这是不可能的,因为线程本地存储需要每线程初始化。

LD_PRELOAD甚至会在加载标准库之前加载库,这会影响TLS初始化。

<强>更新

请阅读ELF Handling For Thread-Local Storage

的第2和第3部分