在POWER9体系结构上运行x86二进制文件

在POWER9体系结构上运行x86二进制文件,x86,binary,cross-platform,X86,Binary,Cross Platform,要在IBM“Power 9”处理器上运行x86编译的二进制文件,最好的选择是什么?不幸的是,我没有源代码,并且二进制文件没有使用调试信息编译,因此我无法重新编译它 正如@Peter Cordes在评论中提到的,第一个选项是完全模拟(模拟x86_64内核和应用程序),另一个选项是QEMU的用户模式转换(只模拟用户模式,将系统调用转换为运行中的ppc64内核)。这里,我们将使用QEMU用户模式转换 您应该有一个可以在x86上实现的Gentoo ppc64安装,下一步是获得一个x86_64跨开发环境,

要在IBM“Power 9”处理器上运行x86编译的二进制文件,最好的选择是什么?不幸的是,我没有源代码,并且二进制文件没有使用调试信息编译,因此我无法重新编译它

正如@Peter Cordes在评论中提到的,第一个选项是完全模拟(模拟x86_64内核和应用程序),另一个选项是QEMU的用户模式转换(只模拟用户模式,将系统调用转换为运行中的ppc64内核)。这里,我们将使用QEMU用户模式转换

您应该有一个可以在x86上实现的Gentoo ppc64安装,下一步是获得一个x86_64跨开发环境,如果您还没有从Catalyst准备中获得它的话。它将创建一个目录/usr/x86_64-multilib-linux-gnu/,由cross-x86_64-multilib-linux-gnu/glibc和类似的ebuild创建

然后您需要具有适当目标的QEMU(将其添加到make.conf和emerge QEMU中):

要允许像任何其他应用程序一样运行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):

这将允许直接使用qemu-x86_64自动运行x86_64二进制文件

但是,除非您使用chroot,否则它仍然无法工作,因为缺少ld链接器和库。使用strace,您可以看到它尝试在各种路径下加载库。它在/lib64/ld-linux-x86-64.so.2上搜索链接器,因此我们必须在那里创建一个符号链接。对于其他库,它会尝试使用/lib64/x86_64和/usr/lib64/x86_64,它们是符号链接的完美候选。剩下的唯一路径是gcc libs,我们无法将它们添加到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页面大小编译的!在内核菜单配置中,它位于“内核配置”->“页面大小”(config\u PPC\u 4K\u PAGES=y)下。它必须是4k,因为它是x86_64标准页面大小

qemu
这样的仿真器是显而易见的。如果它是Power Linux上的Linux二进制文件,那么您可以使用
qemu user
只模拟一个进程的系统调用,而不是模拟运行内核的整个系统。
:x86_64:M::\x7fELF\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x3e
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