I have the following pieces of code: (Note: the codes are simplified and changed a lot as I can't share the data)
exercise.cpp
#include "some_api.h"
int main(int argc, char** argv)
{
VExtension ve;
extension_init(&func, &ve);
return 0;
}
some_api.h
bool func(int const& a, void* const& b, VExtension* const& v)
{
std::cout << a << b << std::endl;
}
api.h
typedef int (func_t)(int c, void* p, VExtension* v)
file.cpp
#include "api.h" // this is included implicitly
extern "C" int extension_init(func_t* F, VExtension* v)
{
intptr_t ver = 7;
F(1, (void*)ver, v);
}
So, when F
is called func
is called from some_api.h
, but Seg Fault
appears when trying to output the values a
and b
. Static analyzer gives the following error message:
ASAN:DEADLYSIGNAL
=================================================================
==15==ERROR: AddressSanitizer: SEGV on unknown address 0x000000000001 (pc 0x55d6dbe48ca2 bp 0x7fff79dbf320 sp 0x7fff79dbf300 T0)
==15==The signal is caused by a READ memory access.
==15==Hint: address points to the zero page.
#0 0x55d6dbe48ca1 in func(int const&, void* const&, VExtension* const&) some_api.h:279
#1 0x55d6dbefe697 in file.cpp:809
#2 0x55d6dbe5373a in main exercise.cpp:123
#3 0x7f9c65393b96 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x21b96)
#4 0x55d6dbd49839 in _start (//...)
AddressSanitizer can not provide additional info.
SUMMARY: AddressSanitizer: some_api.h:279 in func(int const&, void* const&, VExtension* const&)
==15==ABORTING
Aucun commentaire:
Enregistrer un commentaire