版权声明:本文为博主原创文章,未经博主允许不得转载。
Android x86最近出了一个5.1的新版本,其中包括了Intel新的houdini版本,以及其和ART虚拟机的集成。
最近想对其做一个研究。但是,直接找一台机器装实在太浪费。因此,决定将其安装在VirtualBox的虚拟机中。
首先,下载安装光盘镜像文件。最新版的Android-x86安装盘.iso文件,可以从这里下载到。笔者下载的是最新版,文件名是“android-x86-5.1-rc1.iso”。
然后,在VirtualBox中创建一个虚拟机,用来安装Android-x86。具体步骤如下:
1)点击左上角的“New”按键,在新对话框中,名字随便取一个,类型选择“Linux”,版本选择“Linux 2.6 /3.x /4.x (32-bit)”:
2)选择“Next”,在新对话框中,设置虚拟机的内存大小。笔者设置为2GB:
3)点击“Next”,在接下来的对话框中,选择“Create a virtual hard disk now”:
4)点击“Create”,在新对话框中,选择磁盘镜像文件类型为VDI,即第一项:
5)点击“Next”,选择动态分配:
6)再点击“Next”,填入磁盘镜像文件的文件名和容量的上限,笔者选择10GB,应该够用了:
7)点击“Create”后,虚拟机就创建成功了。
8)在虚拟机中创建一个光盘驱动器,并讲下载下来的Android-x86的光盘镜像文件关联上去。
在VirtualBox中,选择你刚才创建的那个虚拟机,然后点击上方的“Settings”按钮。
接着选择“Storage”选项卡,在右边的控制器旁边,点击那个带加号的光盘图标,在弹出的对话框中选择“Choose disk”:
接下来找到你下载的那个.iso文件,并选择打开就可以了。
同时,请确保虚拟机允许光盘启动,还是在“Settings”对话框中,选择“System”,在右边的“Boot Order”中,“Optical”被选上了:
9)更改一下网络配置,芯片组请选择Intel的ICH系列的,最好不要选择PIIX3,如上图。
在“Network”选项卡中,启动一个网卡适配器,选择网络类型为“NAT”或“Bridged Adapter”,名字是“eth0”,在高级选项中将适配器类型也改成Intel系列的:
好了,虚拟机配置好了,下面直接启动虚拟机,进行安装。具体安装的步骤如下:
1)在光盘启动界面中,选择“Installation – Install Android-x86 to harddisk”:
2)在接下来的对话框中,你应该可以看到“sda”,它就是你前面创建虚拟机时挂载上来的那个磁盘镜像。不过,这个磁盘镜像还没有格式化,还不能用于安装,所以我们先要选择“Create/Modify partitions”:
3)下面让你选择是否用GPT,请确保千万选择No:
4)再选择“New”,创建磁盘分区:
5)选择“Primary”:
6)下面的“Size”直接回车,选择默认值。然后,千万记得要将这个分区标记为可启动的:
7)再选择“Write”,将改变写入磁盘,请耐心等待,这步可能要花一点时间。最后,选择“Quit”退出到前面的页面。这时,应该可以看到“sda1”了,证明分区成功:
8)选择这个分区,并在下面的页面中,选择将磁盘格式化成ext3格式:
9)请键入yes确认要格式化。在下面的页面中,请选择安装GRUB,但不用选择安装GRUB2:
10)再下面的配置,选什么都随便了,一路回车,安装就会正式进行了。
安装完成后,选择“Reboot”重启一下。别忘了,将虚拟机的光盘启动关掉,或者将启动的优先级调到硬盘之后,否则再次启动还是从光盘引导。
启动之后,画面如下:
大功告成!:-)
前面的文章中介绍了如何在VirtualBox虚拟机中安装Android X86。不过,安装结束后,试了几个只有ARM版.so文件的apk程序,发现都打不开。难道是新版Android X86动态将ARM指令集转成X86指令集的houdini兼容性有问题?
经过一番研究,发现默认情况下,其实Android X86是不带houdini的,也就是不能运行只有ARM版.so文件的程序。
不过,可以通过几个步骤,将houdini安装上去,打开对动态转码的支持。而这只需要执行两步操作就可以了:
1)在“Settings”中选择“Apps compatibility”:
打开“Enable native bridge”选项:
但是,光打开了这个选项还没有用。打开这个选项的效果只是将系统属性“persist.sys.nativebridge”的值从false(0)改成了true(1):
其它什么都没有做,其实仍然还不能运行ARM指令的程序,还需要下面的第二步。但是,即使运行了下一步,但是没有打开这个选项的话,也是不能运行ARM指令的程序的。
2)打开命令行,切换到root用户,敲入命令“enable_nativebridge”:
之后,程序会自动上网下载一些东西,等到结束后,houdini的支持就算正式打开了。
那么enable_nativebridge命令到底做了什么呢?其实它只是一个shell脚本文件,位于/system/bin/目录下。
该脚本中的代码如下:
- #!/system/bin/sh
- PATH=/system/bin:/system/xbin
- houdini_bin=0
- dest_dir=/system/lib$1/arm$1
- binfmt_misc_dir=/proc/sys/fs/binfmt_misc
- cd $dest_dir
- if [ ! -s libhoudini.so ]; then
- if touch .dl_houdini; then
- rm -f .dl_houdini
- else
- cd .. && cp -a arm$1 /data/local/tmp
- mount -t tmpfs tmpfs arm$1 && cd arm$1 &&
- cp -a /data/local/tmp/arm$1/* . && rm -rf /data/local/tmp/arm$1
- fi
- fi
- cd /data/local/tmp
- while [ ! -s $dest_dir/libhoudini.so ]; do
- while [ “$(getprop net.dns1)” = “” ]; do
- sleep 10
- done
- if [ -z “$1” ]; then
- [ “`uname -m`” = “x86_64” ] && url=http://goo.gl/Xl1str || url=http://goo.gl/PA2qZ7
- else
- url=http://goo.gl/L00S7l
- fi
- wget $url -cO houdini.tgz &&
- bzcat houdini.tgz | tar xvf – -C $dest_dir && rm -f houdini.tgz && break
- rm -f houdini.tgz
- sleep 30
- done
- if [ ! -e $binfmt_misc_dir/register ]; then
- mount -t binfmt_misc none $binfmt_misc_dir
- fi
- cd $binfmt_misc_dir
- if [ -e register ]; then
- # register Houdini for arm binaries
- if [ -z “$1” ]; then
- echo ‘:arm_exe:M::\\x7f\\x45\\x4c\\x46\\x01\\x01\\x01\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x02\\x00\\x28::'”$dest_dir/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::'”$dest_dir/houdini:P” > register
- else
- 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
- fi
- if [ -e arm${1}_exe ]; then
- houdini_bin=1
- fi
- else
- log -pe -thoudini “No binfmt_misc support”
- fi
- if [ $houdini_bin -eq 0 ]; then
- log -pe -thoudini “houdini$1 enabling failed!”
- else
- log -pi -thoudini “houdini$1 enabled”
- fi
- [ “$(getprop ro.zygote)” = “zygote64_32” -a -z “$1” ] && exec $0 64
- exit 0
其实主要就做了两件事情:
一是,根据命令是否带参数,以及支持的平台是32位的还是64位的等条件,从网上下载了一个压缩包,并解压缩到“/system/lib/arm”或者“/system/lib64/arm64”目录下。如果没有任何参数的直接运行“enable_nativebridge”命令的话,且在32位系统上的话,则下载链接为:http://goo.gl/PA2qZ7;如果没有任何参数的运行命令,且在64位系统上的花,则下载链接为:http://goo.gl/Xl1str;如果带参数运行“enable_nativebridge”命令的话(参数一般是“64”),则下载链接为:http://goo.gl/L00S7l。
二是,往目录“/proc/sys/fs/binfmt_misc”下的名为“register”的文件中写入了两串字符串,从而告诉Linux内核,所有使用ARM指令集的可执行和动态库ELF文件都用houdini程序打开,而所有ARM64指令集的可执行和动态库ELF文件都用houdini64程序打开(关于binfmt_misc的详细解释,可以参考《Linux下如何指定某一类型程序用特定程序打开(通过binfmt_misc)》)。