X-Git-Url: http://git.osdn.net/view?p=android-x86%2Fdevice-generic-common.git;a=blobdiff_plain;f=nativebridge%2Fbin%2Fenable_nativebridge;h=609ecdbb6df4697a9c883705e95d2e218e5100c4;hp=18a06db7700119812c76dfed8bafe02c610e2d7b;hb=751661d462e9c0fce3a502991022d214ea067fca;hpb=baf6eb9c52cbb30b8e2ab2bd483f1728f64cd696 diff --git a/nativebridge/bin/enable_nativebridge b/nativebridge/bin/enable_nativebridge index 18a06db..609ecdb 100644 --- a/nativebridge/bin/enable_nativebridge +++ b/nativebridge/bin/enable_nativebridge @@ -6,39 +6,49 @@ houdini_bin=0 dest_dir=/system/lib$1/arm$1 binfmt_misc_dir=/proc/sys/fs/binfmt_misc -cd /data/arm -if [ -e /system/lib$1/libhoudini.so ]; then +urls[0]=http://t.cn/RBJ7mfG +urls[1]=http://t.cn/RBJ7eml +urls[2]=http://t.cn/RBJzLwu +urls[3]=http://goo.gl/96BPKe +urls[4]=http://goo.gl/v6c4Co +urls[5]=http://goo.gl/CtKjxx + +if [ -z "$1" ]; then + v=8_y + u=1 +else + v=8_z + u=2 +fi + +if [ -s /system/lib$1/libhoudini.so ]; then log -pi -thoudini "found /system/lib$1/libhoudini.so" -elif [ -e /system/etc/houdini$1.sfs ]; then - busybox mount /system/etc/houdini$1.sfs $dest_dir +elif [ -e /system/etc/houdini$v.sfs ]; then + mount /system/etc/houdini$v.sfs $dest_dir else if mountpoint -q $dest_dir; then kill -9 `fuser -m $dest_dir` umount -f $dest_dir fi - while ! busybox mount houdini$1.sfs $dest_dir; do + mkdir -p /data/arm + cd /data/arm + while ! mount houdini$v.sfs $dest_dir; do while [ "$(getprop net.dns1)" = "" ]; do sleep 10 done - if [ -z "$1" ]; then - [ "`uname -m`" = "x86_64" ] && url=http://goo.gl/Knnmyl || url=http://goo.gl/JsoX2C - else - url=http://goo.gl/n6KtQa - fi - wget $url -cO houdini$1.sfs && continue - rm -f houdini$1.sfs + wget ${urls[$u%6]} -cO houdini$v.sfs && continue + rm -f houdini$v.sfs sleep 30 + let u+=3 done fi - -# if you don't see the files 'register' and 'status' in /proc/sys/fs/binfmt_misc -# then run the following command: -# mount -t binfmt_misc none /proc/sys/fs/binfmt_misc +[ -s /system/lib$1/libhoudini.so ] || mount --bind $dest_dir/libhoudini.so /system/lib$1/libhoudini.so # this is to add the supported binary formats via binfmt_misc if [ ! -e $binfmt_misc_dir/register ]; then + modprobe binfmt_misc mount -t binfmt_misc none $binfmt_misc_dir fi @@ -66,6 +76,4 @@ else log -pi -thoudini "houdini$1 enabled" fi -[ "$(getprop ro.zygote)" = "zygote64_32" -a -z "$1" ] && exec $0 64 - exit 0