Я столкнулся с проблемой при использовании libasan для улучшения кода, который я написал.
ситуация:
— код компиляции с -fsanitize = address -lasan
— запустить код.
Образец ниже:
#include <iostream>
#include <sys/time.h>
using namespace std;
int main () {
time_t currentTime ;
time(¤tTime);
std::cout << "current time ---> " << currentTime << endl;
}
проблема: этот код прекрасно работает в примере программы, но не работает в моем приложении. приложение падает с трассировкой стека ошибок:
==23316==ERROR: AddressSanitizer: stack-buffer-overflow on address ... at pc ... bp ... sp ...
Address ... is located in stack of thread T3==23316==AddressSanitizer CHECK failed: ../../../../../src/libsanitizer/asan/asan_thread.cc:243 "((ptr[0] == kCurrentStackFrameMagic)) != (0)" (0x0, 0x0)
#0 0xf7261fe6 (/usr/lib32/libasan.so.3+0xc7fe6)
#1 0xf72682f9 in __sanitizer::CheckFailed(char const*, int, char const*, unsigned long long, unsigned long long) (/usr/lib32/libasan.so.3+0xce2f9)
#2 0xf7266015 (/usr/lib32/libasan.so.3+0xcc015)
#3 0xf725d473 (/usr/lib32/libasan.so.3+0xc3473)
#4 0xf725dcc1 (/usr/lib32/libasan.so.3+0xc3cc1)
#5 0xf72612f6 (/usr/lib32/libasan.so.3+0xc72f6)
#6 0xf71d20a0 in __interceptor_time (/usr/lib32/libasan.so.3+0x380a0)
Теперь я понимаю, что это не из-за кода, который я выложил выше, но сейчас я не понимаю, как найти место, где я испортил мой указатель стека.
Любая помощь оценивается.
Задача ещё не решена.
Других решений пока нет …