X-Git-Url: http://git.osdn.net/view?p=android-x86%2Fdevice-generic-common.git;a=blobdiff_plain;f=nativebridge%2Fbin%2Fenable_nativebridge;h=32b2e2f960f66775ed4f35f66f379a224beaece2;hp=ef00891371777e8114c61d69aebbd7cafa53849d;hb=cc13ae622dfde5f584b6db1b132cc590d01dfdb5;hpb=81475bc5b5714f0b5a3fc241de6f34acc6b79a68 diff --git a/nativebridge/bin/enable_nativebridge b/nativebridge/bin/enable_nativebridge index ef00891..32b2e2f 100644 --- a/nativebridge/bin/enable_nativebridge +++ b/nativebridge/bin/enable_nativebridge @@ -6,47 +6,61 @@ houdini_bin=0 dest_dir=/system/lib$1/arm$1 binfmt_misc_dir=/proc/sys/fs/binfmt_misc -cd $dest_dir +urls[0]=http://t.cn/EJrmzZv +urls[1]=http://t.cn/EJrmYMH +urls[2]=http://t.cn/EJrmrA7 +urls[3]=http://tinyurl.com/y3nagyza +urls[4]=http://tinyurl.com/y6azmjas +urls[5]=http://tinyurl.com/y6g6cx27 -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 +mount_sfs() +{ + mount -o 'context="u:object_r:system_file:s0"' $1 $2 +} + +if [ -z "$1" ]; then + v=9_y + u=1 +else + v=9_z + u=2 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 +if [ -s /system/lib$1/libhoudini.so ]; then + log -pi -thoudini "found /system/lib$1/libhoudini.so" +elif [ -e /system/etc/houdini$v.sfs ]; then + mount_sfs /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 - 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 [ ! -d /data/media/0/arm ]; then + mkdir -p /data/media/0/arm + chown 1023.1023 /data/media/0/arm + fi + cd /data/media/0/arm + [ -s /data/arm/houdini$v.sfs ] && mv /data/arm/houdini$v.sfs . + while ! mount_sfs houdini$v.sfs $dest_dir; do + while [ "$(getprop net.dns1)" = "" ]; do + sleep 10 + done + [ -s houdini$v.sfs ] && sleep 10 || sleep 30 + 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 cd $binfmt_misc_dir if [ -e register ]; then + [ -e /system/bin/houdini$1 ] && dest_dir=/system/bin # 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 @@ -68,6 +82,4 @@ else log -pi -thoudini "houdini$1 enabled" fi -[ "$(getprop ro.zygote)" = "zygote64_32" -a -z "$1" ] && exec $0 64 - exit 0