将动态链接器与 qemu-arm 一起使用

ttk*_*203 5 linux arm qemu

我有一个使用工具链编译的非常简单的arm可执行文件arm-linux-gnueabiqemu-arm我可以毫无问题地执行它:

$ qemu-arm -L /usr/arm-linux-gnueabi/ ./a.out
Hello world !
Run Code Online (Sandbox Code Playgroud)

不带任何参数运行链接器似乎也有效:

qemu-arm /usr/arm-linux-gnueabi/lib/ld-linux.so.3
Usage: ld.so [OPTION]... EXECUTABLE-FILE [ARGS-FOR-PROGRAM...]
You have invoked `ld.so', the helper program for shared library executables.
...
Run Code Online (Sandbox Code Playgroud)

但是,如果我希望链接器运行我的可执行文件,则会发生以下情况:

$ qemu-arm -L /usr/arm-linux-gnueabi/ /usr/arm-linux-gnueabi/lib/ld-linux.so.3 a.out
a.out: error while loading shared libraries: a.out: cannot open shared object file
Run Code Online (Sandbox Code Playgroud)

这是 strace 的输出:https://pastebin.com/uJ7AhBdh

知道为什么会发生这种情况吗?

Cir*_*lli 5

我无法在 Ubuntu 20.04 上重现该问题:

sudo apt install gcc-arm-linux-gnueabihf qemu-user
printf '
#include <stdio.h>
#include <stdlib.h>

int main() {
    puts("hello world");
    return EXIT_SUCCESS;
}
' >  hello_world.c
qemu-arm -L /usr/arm-linux-gnueabihf ./hello_world
Run Code Online (Sandbox Code Playgroud)

和aarch64:

sudo apt install gcc-aarch64-linux-gnu qemu-user
aarch64-linux-gnu-gcc -ggdb3 -static -o hello_world hello_world.c
qemu-aarch64 -L /usr/aarch64-linux-gnu ./hello_world
Run Code Online (Sandbox Code Playgroud)

两者都运行良好。

您还可以提供您的确切发行版本吗?

与 GDB 单步调试相关:如何在 QEMU 用户模式下 GDB 单步调试动态链接的可执行文件?