您的位置:首页 > 编程语言 > C语言/C++

C++ 手动替换malloc函数,并且手动获取调用者地址

2015-08-14 16:02 337 查看
在CPP文件中添加

#include<stdint.h>
/* 获取寄存器ebp的值 */
void get_ebp(unsigned long *ebp) {
__asm__ __volatile__ (
"mov %%ebp, %0"
:"=m"(*ebp)
::"memory");
}

void * __wrap_malloc( size_t size)
{
void* result;
result= __real_malloc( size); //result = memalign(32, size);

if(size>1024){
unsigned long ebp = 0;

/* 1.得到首层函数的栈基址 */
__asm__ __volatile__ (
"mov %%ebp, %0"
:"=m"(ebp)
::"memory");
printf("Malloc: allocate %d byte mem, start at %p, ebp:%u\n", size, result,*(uint32_t*)(ebp+4));
}

return result;
}在头文件添加:
extern "C" void get_ebp(unsigned long *ebp);
extern "C" void * __real_malloc( size_t size) ;
extern "C" void * __wrap_malloc( size_t size);

编译时添加编译选项
-Wl,-wrap,malloc


便可以打印调用wrap_malloc的上次函数的地址
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息