Ошибка теневой памяти и fPie при запуске кода с помощью средства очистки потока?

Следующий пример кода скомпилирован с последующим вводом командной строки

#include <pthread.h>
#include <stdio.h>
#include <string>
#include <map>

typedef std::map<std::string, std::string> map_t;

void *threadfunc(void *p) {
  map_t& m = *(map_t*)p;
  m["foo"] = "bar";
  return 0;
}

int main() {
  map_t m;
  pthread_t t;
  pthread_create(&t, 0, threadfunc, &m);
  printf("foo=%s\n", m["foo"].c_str());
  pthread_join(t, 0);
}

Ввод командной строки:

g++ thread.cpp -fsanitize=thread -fPIE -pie -lpie -g

Он хорошо компилируется, но при запуске кода возникают ошибки времени выполнения.

FATAL: ThreadSanitizer can not mmap the shadow memory (something is mapped at 0x56167ae3b000 < 0x7cf000000000)
FATAL: Make sure to compile with -fPIE and to link with -pie.

Я запускаю это с версией g++, которая имеет fSanitize, поэтому я не уверен, где источник проблемы?

g++ (GCC) 4.8.5 20150623 (Red Hat 4.8.5-28)

1 ответ

GCC слишком стар для ядра Linux, используемого в вашем RedHat. Из-за сопоставленного адреса 0x56167ae3b000 я предполагаю, что версия ядра - 4.1+ (или перенесена из версии ядра 4.1+), которая отображает двоичные файлы в 0x550000000000. Этот сопоставленный адрес поддерживается GCC начиная с версии 7.1.1. Пожалуйста, попробуйте добавить флаг компилятора -static-libtsan, Если это не поможет, вам нужно обновить компилятор.

Другие вопросы по тегам