scripts: recovery addon.d-v2 and env fixes
- recovery addon.d-v2 requires /system and /system_root stay mounted - find OUTFD from recovery update_engine for addon.d-v2 output - fix finding OUTFD on addon.d failure with toybox ps - simplify heredoc creation - update to longer apex BOOTCLASSPATH - save and restore any mountpoint symlinks encountered Closes #2284
This commit is contained in:
parent
ed58cf953a
commit
45d5b4bea6
@ -80,17 +80,20 @@ if [ -d /system/addon.d ]; then
|
|||||||
ui_print "- Adding addon.d survival script"
|
ui_print "- Adding addon.d survival script"
|
||||||
mount -o rw,remount /system
|
mount -o rw,remount /system
|
||||||
ADDOND=/system/addon.d/99-magisk.sh
|
ADDOND=/system/addon.d/99-magisk.sh
|
||||||
cat <<EOF > $ADDOND
|
cat <<'EOF' > $ADDOND
|
||||||
#!/sbin/sh
|
#!/sbin/sh
|
||||||
# ADDOND_VERSION=2
|
# ADDOND_VERSION=2
|
||||||
|
|
||||||
mount /data 2>/dev/null
|
mount /data 2>/dev/null
|
||||||
|
|
||||||
if [ -f /data/adb/magisk/addon.d.sh ]; then
|
if [ -f /data/adb/magisk/addon.d.sh ]; then
|
||||||
exec sh /data/adb/magisk/addon.d.sh "\$@"
|
exec sh /data/adb/magisk/addon.d.sh "$@"
|
||||||
else
|
else
|
||||||
OUTFD=\$(ps | grep -v 'grep' | grep -oE 'update(.*)' | cut -d" " -f3)
|
OUTFD=$(ps | grep -v 'grep' | grep -oE 'update(.*)' | cut -d" " -f3)
|
||||||
ui_print() { echo -e "ui_print \$1\nui_print" >> /proc/self/fd/\$OUTFD; }
|
[ ! -z $OUTFD -a "$OUTFD" -eq "$OUTFD" ] 2>/dev/null || OUTFD=$(ps -Af | grep -v 'grep' | grep -oE 'update(.*)' | cut -d" " -f3)
|
||||||
|
[ ! -z $OUTFD -a "$OUTFD" -eq "$OUTFD" ] 2>/dev/null || OUTFD=$(ps | grep -v 'grep' | grep -oE 'status_fd=(.*)' | cut -d= -f2)
|
||||||
|
[ ! -z $OUTFD -a "$OUTFD" -eq "$OUTFD" ] 2>/dev/null || OUTFD=$(ps -Af | grep -v 'grep' | grep -oE 'status_fd=(.*)' | cut -d= -f2)
|
||||||
|
ui_print() { echo -e "ui_print $1\nui_print" >> /proc/self/fd/$OUTFD; }
|
||||||
|
|
||||||
ui_print "************************"
|
ui_print "************************"
|
||||||
ui_print "* Magisk addon.d failed"
|
ui_print "* Magisk addon.d failed"
|
||||||
|
@ -69,7 +69,7 @@ setup_flashable() {
|
|||||||
# We will have to manually find out OUTFD
|
# We will have to manually find out OUTFD
|
||||||
for FD in `ls /proc/$$/fd`; do
|
for FD in `ls /proc/$$/fd`; do
|
||||||
if readlink /proc/$$/fd/$FD | grep -q pipe; then
|
if readlink /proc/$$/fd/$FD | grep -q pipe; then
|
||||||
if ps | grep -v grep | grep -q " 3 $FD "; then
|
if ps | grep -v grep | grep -qE " 3 $FD |status_fd=$FD"; then
|
||||||
OUTFD=$FD
|
OUTFD=$FD
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
@ -109,12 +109,21 @@ recovery_actions() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
recovery_cleanup() {
|
recovery_cleanup() {
|
||||||
|
local DIR
|
||||||
ui_print "- Unmounting partitions"
|
ui_print "- Unmounting partitions"
|
||||||
(umount_apex
|
(umount_apex
|
||||||
|
if [ ! -d /postinstall/tmp ]; then
|
||||||
umount -l /system
|
umount -l /system
|
||||||
umount -l /system_root
|
umount -l /system_root
|
||||||
|
fi
|
||||||
umount -l /vendor
|
umount -l /vendor
|
||||||
umount -l /persist
|
umount -l /persist
|
||||||
|
for DIR in /apex /system /system_root; do
|
||||||
|
if [ -L "${DIR}_link" ]; then
|
||||||
|
rmdir $DIR
|
||||||
|
mv -f ${DIR}_link $DIR
|
||||||
|
fi
|
||||||
|
done
|
||||||
umount -l /dev/random) 2>/dev/null
|
umount -l /dev/random) 2>/dev/null
|
||||||
export PATH=$OLD_PATH
|
export PATH=$OLD_PATH
|
||||||
[ -z $OLD_LD_LIB ] || export LD_LIBRARY_PATH=$OLD_LD_LIB
|
[ -z $OLD_LD_LIB ] || export LD_LIBRARY_PATH=$OLD_LD_LIB
|
||||||
@ -148,13 +157,21 @@ find_block() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setup_mountpoint() {
|
||||||
|
local POINT=$1
|
||||||
|
[ -L $POINT ] && mv -f $POINT ${POINT}_link
|
||||||
|
if [ ! -d $POINT ]; then
|
||||||
|
rm -f $POINT
|
||||||
|
mkdir -p $POINT
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# mount_name <partname> <mountpoint> <flag>
|
# mount_name <partname> <mountpoint> <flag>
|
||||||
mount_name() {
|
mount_name() {
|
||||||
local PART=$1
|
local PART=$1
|
||||||
local POINT=$2
|
local POINT=$2
|
||||||
local FLAG=$3
|
local FLAG=$3
|
||||||
[ -L $POINT ] && rm -f $POINT
|
setup_mountpoint $POINT
|
||||||
mkdir -p $POINT 2>/dev/null
|
|
||||||
is_mounted $POINT && return
|
is_mounted $POINT && return
|
||||||
ui_print "- Mounting $POINT"
|
ui_print "- Mounting $POINT"
|
||||||
# First try mounting with fstab
|
# First try mounting with fstab
|
||||||
@ -187,8 +204,7 @@ mount_partitions() {
|
|||||||
mount_ro_ensure "system$SLOT app$SLOT" /system
|
mount_ro_ensure "system$SLOT app$SLOT" /system
|
||||||
if [ -f /system/init.rc ]; then
|
if [ -f /system/init.rc ]; then
|
||||||
SYSTEM_ROOT=true
|
SYSTEM_ROOT=true
|
||||||
[ -L /system_root ] && rm -f /system_root
|
setup_mountpoint /system_root
|
||||||
mkdir /system_root 2>/dev/null
|
|
||||||
mount --move /system /system_root
|
mount --move /system /system_root
|
||||||
mount -o bind /system_root/system /system
|
mount -o bind /system_root/system /system
|
||||||
else
|
else
|
||||||
@ -218,7 +234,7 @@ mount_apex() {
|
|||||||
[ -d /system/apex ] || return
|
[ -d /system/apex ] || return
|
||||||
# APEX files present; need to extract and mount the payload imgs or if already extracted, mount folders
|
# APEX files present; need to extract and mount the payload imgs or if already extracted, mount folders
|
||||||
local APEX DEST LOOP MINORX NUM
|
local APEX DEST LOOP MINORX NUM
|
||||||
[ -L /apex ] && rm -f /apex
|
setup_mountpoint /apex
|
||||||
[ -e /dev/block/loop1 ] && MINORX=$(ls -l /dev/block/loop1 | awk '{ print $6 }') || MINORX=1
|
[ -e /dev/block/loop1 ] && MINORX=$(ls -l /dev/block/loop1 | awk '{ print $6 }') || MINORX=1
|
||||||
NUM=0
|
NUM=0
|
||||||
for APEX in /system/apex/*; do
|
for APEX in /system/apex/*; do
|
||||||
@ -249,7 +265,7 @@ mount_apex() {
|
|||||||
done
|
done
|
||||||
export ANDROID_RUNTIME_ROOT=/apex/com.android.runtime
|
export ANDROID_RUNTIME_ROOT=/apex/com.android.runtime
|
||||||
export ANDROID_TZDATA_ROOT=/apex/com.android.tzdata
|
export ANDROID_TZDATA_ROOT=/apex/com.android.tzdata
|
||||||
export BOOTCLASSPATH=/apex/com.android.runtime/javalib/core-oj.jar:/apex/com.android.runtime/javalib/core-libart.jar:/apex/com.android.runtime/javalib/okhttp.jar:/apex/com.android.runtime/javalib/bouncycastle.jar:/apex/com.android.runtime/javalib/apache-xml.jar:/system/framework/framework.jar:/system/framework/ext.jar:/system/framework/telephony-common.jar:/system/framework/voip-common.jar:/system/framework/ims-common.jar:/system/framework/android.test.base.jar:/apex/com.android.conscrypt/javalib/conscrypt.jar:/apex/com.android.media/javalib/updatable-media.jar
|
export BOOTCLASSPATH=/apex/com.android.runtime/javalib/core-oj.jar:/apex/com.android.runtime/javalib/core-libart.jar:/apex/com.android.runtime/javalib/okhttp.jar:/apex/com.android.runtime/javalib/bouncycastle.jar:/apex/com.android.runtime/javalib/apache-xml.jar:/system/framework/framework.jar:/system/framework/ext.jar:/system/framework/telephony-common.jar:/system/framework/voip-common.jar:/system/framework/ims-common.jar:/system/framework/android.test.base.jar:/system/framework/telephony-ext.jar:/apex/com.android.conscrypt/javalib/conscrypt.jar:/apex/com.android.media/javalib/updatable-media.jar;
|
||||||
}
|
}
|
||||||
|
|
||||||
umount_apex() {
|
umount_apex() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user