Android X86上运行基于ARM">ARM处理器的应用程序

Android X86上运行基于ARM">ARM处理器的应用程序

众所周知,移动端的ARM CPU和计算机上的X86 CPU使用不同的指令集。虽然在编译时可以选择不同的编译器编译对应的程序,但是Android作为一个天生为手机开发的系统,基于ARM的程序占据了几乎所有的Android生态环境。于是Android X86的一个至关重要的问题就是兼容ARM应用程序。

这里要提一下Inter。Inter为了打入移动市场,不仅做出了像Atom这样的的CPU,还顺带开发了一系列软件。其中对应Android X86的问题开发了Houdini。Houdini可以把ARM指令集转化为X86指令集从而在Android X86设备上运行。

准备条件:打开设置-应用兼容性-兼容模式

打开后如下图:
Android X86上运行基于ARMARM处理器的应用程序_第1张图片" width="640" height="360" style="border:1px solid black;">

IT之家学院:在Android X86上运行基于ARM处理器的应用程序0

不要以为就这么简单,接下来正式开始教程。

官方步骤(对国内用户无效):

打开终端模拟器,先输入su,回车,等出现#再输入enable_nativebridge
输入后系统会自动下载Houdini并运行。

实际运行情况如下:
Android X86上运行基于ARMARM处理器的应用程序_第2张图片" width="640" height="360" style="border:1px solid black;">

IT之家学院:在Android X86上运行基于ARM处理器的应用程序1

系统会一直连接goo.gl造成死循环。

打开/system/bin/enable_nativebridge,可以看到这其实是一个Shell脚本文件。
Android X86上运行基于ARMARM处理器的应用程序_第3张图片" width="640" height="360" style="border:1px solid black;">

IT之家学院:在Android X86上运行基于ARM处理器的应用程序2

其中问题出在goo.gl短链接识别不出来。

在[ “uname -m” = “x86_64” ] && url=https://goo.gl/Knnmyl || url=https://goo.gl/JsoX2C这一行就是Houdini的下载地址。我用的是Android 6.0,如果Android版本不一致Houdini是不通用的,请自行提取你的电脑上的/system/bin/enable_nativebridge文件。

如果你是64位的Android镜像,就打开左边的链接。

如果你是32位的Android镜像,就打开右边的链接。

通过Windows开VPN下载了一个houdini.sfs的文件,这就是ARM翻译器的镜像了。

复制下面的代码为.sh文件:

(32位版)

#!/system/bin/sh

PATH=/system/bin:/system/xbin

busybox mount /system/bin/houdini$1.sfs /system/lib$1/arm$1
if [ ! -e $binfmt_misc_dir/register ]; then

mount -t binfmt_misc none /proc/sys/fs/binfmt_misc

fi
cd /proc/sys/fs/binfmt_misc

register Houdini for arm binaries

echo ‘:arm_exe:M::\x7f\x45\x4c\x46\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x28::’"/system/lib/arm/houdini:P" > register

echo ‘:arm_dyn:M::\x7f\x45\x4c\x46\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x03\x00\x28::’"/system/lib/arm/houdini:P" > register

[ “$(getprop ro.zygote)” = “zygote64_32” -a -z “$1” ] && exec $0 64

exit 0

(64位版)

#!/system/bin/sh

PATH=/system/bin:/system/xbin

busybox mount /system/bin/houdini$1.sfs /system/lib$1/arm$1
if [ ! -e $binfmt_misc_dir/register ]; then

mount -t binfmt_misc none /proc/sys/fs/binfmt_misc

fi

cd /proc/sys/fs/binfmt_misc

register Houdini for arm binaries

echo ‘:arm64_exe:M::\x7f\x45\x4c\x46\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\xb7::’"$dest_dir/houdini64:P" > register

echo ‘:arm64_dyn:M::\x7f\x45\x4c\x46\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x03\x00\xb7::’"$dest_dir/houdini64:P" > register

[ “$(getprop ro.zygote)” = “zygote64_32” -a -z “$1” ] && exec $0 64

exit 0

并把houdini.sfs复制到Android的/system/bin

接着打开终端模拟器,先输入su,再运行这段脚本。

恭喜你,大功告成。

如果想要每次开机自动启用ARM翻译器,可以把脚本文件放到/system/etc/init.d/
启用前:
Android X86上运行基于ARMARM处理器的应用程序_第4张图片" width="640" height="360" style="border:1px solid black;">
  IT之家学院:在Android X86上运行基于ARM处理器的应用程序3

启用后:
Android X86上运行基于ARMARM处理器的应用程序_第5张图片" width="640" height="360" style="border:1px solid black;">
  IT之家学院:在Android X86上运行基于ARM处理器的应用程序4

可以看到CPU已经被识别为“ARMv7”,ARM翻译器已经正常工作了。

转载:https://www.stmcu.org.cn/article/id-329167

你可能感兴趣的:(android内核及源码)