首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Power9架构上运行x86二进制文件

在Power9架构上运行x86二进制文件
EN

Stack Overflow用户
提问于 2018-12-14 17:28:04
回答 1查看 1.3K关注 0票数 2

尝试在IBMPower9处理器上运行x86编译的二进制文件的最佳选择是什么?不幸的是,我没有源代码,二进制文件也不是用调试信息编译的,所以我不能重新编译它。

EN

回答 1

Stack Overflow用户

发布于 2018-12-21 15:00:55

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

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

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

代码语言:javascript
复制
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):

代码语言:javascript
复制
: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中,所以我们必须为单个文件创建符号链接。换句话说,你想做这样的事情:

代码语言:javascript
复制
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标准页面大小

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53776825

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档