use*_*967 10 linux arm stack-trace backtrace uclibc
我们在ARM 9上运行uclibc linux.问题是uclibc不支持回溯.当核心转储发生时,我无法获取调用堆栈.
有人有一个很好的解决方案吗?
例如,现有的uclibc回溯移植,或者在发生核心转储时获取调用堆栈的任何好方法(uclibc + ARM + Linux)?
更新:
似乎创建了一个补丁来支持backtrace()
uclibc for x86和ARM(XScale),它使用了这个__libc_stack_end
符号.
原答案:
我参与了一个项目,我们使用的glibc版本没有backtrace()
为我们的ARM处理器提供功能,因此我们使用__libc_stack_end
符号开发了我们自己的glibc外部.以下是生成的代码.也许你可以用它来编写一个uclibc backtrace()
函数.
extern void * __libc_stack_end;
struct backtrace_frame_t
{
void * fp;
void * sp;
void * lr;
void * pc;
};
int backtrace(void ** array, int size)
{
void * top_frame_p;
void * current_frame_p;
struct backtrace_frame_t * frame_p;
int frame_count;
top_frame_p = __builtin_frame_address(0);
current_frame_p = top_frame_p;
frame_p = (struct backtrace_frame_t*)((void**)(current_frame_p)-3);
frame_count = 0;
if (__builtin_return_address(0) != frame_p->lr)
{
fprintf(stderr, "backtrace error: __builtin_return_address(0) != frame_p->lr\n");
return frame_count;
}
if (current_frame_p != NULL
&& current_frame_p > (void*)&frame_count
&& current_frame_p < __libc_stack_end)
{
while (frame_count < size
&& current_frame_p != NULL
&& current_frame_p > (void*)&frame_count
&& current_frame_p < __libc_stack_end)
{
frame_p = (struct backtrace_frame_t*)((void**)(current_frame_p)-3);
array[frame_count] = frame_p->lr;
frame_count++;
current_frame_p = frame_p->fp;
}
}
return frame_count;
}
Run Code Online (Sandbox Code Playgroud)
注意:__libc_stack_end
符号不再在更新版本的glibc中导出,我不确定它是否存在或uclibc中的类似符号.