为了尝试在IBM“ Power 9”处理器上运行x86编译的二进制文件,最佳选择是什么?不幸的是,我没有源代码,并且二进制文件没有使用调试信息进行编译,因此我无法重新编译它。
答案 0 :(得分:4)
正如@Peter Cordes在评论中提到的,第一个选项是完全仿真(模拟x86_64内核和应用程序),另一个是QEMU的用户模式转换(仅模拟用户模式,将系统调用转换为正在运行的ppc64内核)。在这里,我们将使用QEMU用户模式转换。
您应该可以在x86上使用Catalyst来安装可以正常使用的Gentoo ppc64,下一步是如果尚未从Catalyst准备中获得x86_64跨开发环境,请执行下一步。它将创建目录/ usr / x86_64-multilib-linux-gnu /,它是由cross-x86_64-multilib-linux-gnu / glibc和类似的ebuilds组成的。
然后,您需要具有适当目标的QEMU(将其添加到make.conf中并出现qemu):
QEMU_USER_TARGETS="x86_64"
要允许像运行其他任何应用程序一样运行x86_64应用程序,需要在内核中启用binfmt_misc(CONFIG_BINFMT_MISC)并加载x86_64 ELF定义。查看/etc/init.d/qemu-binfmt(Open-RC)或添加此文件/etc/binfmt.d/qemu-x86_64.conf并启用systemd-binfmt服务(对于systemd):
:x86_64:M::\x7fELF\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x3e
这将允许直接使用qemu-x86_64直接运行x86_64二进制文件。
但是除非您使用chroot,否则由于缺少ld链接器和库,它仍然无法工作。使用strace可以看到它尝试在各种路径下加载库。它在/lib64/ld-linux-x86-64.so.2中搜索链接器,因此我们必须在此处进行符号链接。对于其他库,它尝试使用/ lib64 / x86_64和/ usr / lib64 / x86_64,它们是进行符号链接的理想选择。剩下的唯一路径是gcc库,我们无法将它们添加到您的ppc64 GCC LDPATH所在的/etc/ld.so.conf.d中,因此我们必须为单个文件建立符号链接。换句话说,您想要执行以下操作:
sudo ln -s /usr/x86_64-multilib-linux-gnu/lib64 /lib64/x86_64
sudo ln -s /usr/x86_64-multilib-linux-gnu/usr/lib64 /usr/lib64/x86_64
sudo ln -s /lib64/x86_64/ld-linux-x86-64.so.2 /lib64/ld-linux-x86-64.so.2
sudo ln -s /usr/lib/gcc/x86_64-multilib-linux-gnu/7.3.0/libgcc_s.so.1 /lib/x86
然后,x86二进制文件应该像其他任何二进制文件一样自动神奇地工作,而无需使用显式的chroot。
您可能会遇到一个问题,即尽管看到x86_64库,但可执行文件无法加载库。您所看到的是mmap因errno EFAULT错误而失败,并出现诸如“加载共享库时出错”或“无法从共享库映射段”之类的错误。那是因为您的内核不是以4k页面大小编译的!在内核menuconfig中,它位于“内核配置”->“页面大小”下(CONFIG_PPC_4K_PAGES = y)。它必须是4k,因为它是x86_64标准页面大小