我在文件backtrace.c创建了以下测试程序:
#include
#include
#include
int main(int argc,char**argv){
void *stack[128];
int frameCount = backtrace(stack, sizeof stack);
char **symbols = backtrace_symbols(stack, frameCount);
printf("Backtrace: %d frames\n", frameCount);
for (int i = 0; i < frameCount; i++) {
printf("\t%s\n", symbols[i]);
}
free(symbols);
return 0;
}
然后,我使用以下脚本在i386,amd64,arm32v5,arm64v8和s390x Debian Linux Docker容器中测试程序:
for arch in i386 amd64 arm32v5 arm32v7 arm64v8 s390x; do
echo "=== $arch ==="
docker run -w /work -v $(pwd -P):/work $arch/debian /bin/bash -c "apt-get update && apt-get install -y gcc && gcc -funwind-tables -o backtrace backtrace.c && ./backtrace"
done
(注意-funwind-tables是获得arm32v5上任何帧所必需的。在其他体系结构上,它不是必需的,但不会造成任何伤害。)
主机CPU体系结构是amd64(实际上是Mac 2.1.0.1的Docker Desktop),因此arm *和s390x容器由QEMU用户仿真通过binfmt_misc执行。
无论如何,我在ppc64le上做同样的事情,它是segfaults:
arch=ppc64le
docker run -w /work -v $(pwd -P):/work $arch/debian /bin/bash -c "apt-get update && apt-get install -y gcc && gcc -funwind-tables -o backtrace backtrace.c && ./backtrace"
为什么在ppc64le上不起作用? 关于gcc标志吗? (我尝试使用-funwind-tables和不使用-funwind-tables进行段-funwind-tables 。添加-fasynchronous-unwind-tables也没有什么区别。)