Magisk/scripts/flash_script.sh

140 lines
3.5 KiB
Bash
Raw Normal View History

#MAGISK
2016-09-14 04:31:13 +02:00
##########################################################################################
#
2017-06-03 14:19:01 +02:00
# Magisk Flash Script
2016-09-14 04:31:13 +02:00
# by topjohnwu
2017-07-24 20:02:19 +02:00
#
2017-06-03 14:19:01 +02:00
# This script will detect, construct the environment for Magisk
# It will then call boot_patch.sh to patch the boot image
2016-09-14 04:31:13 +02:00
#
##########################################################################################
2017-07-09 18:17:34 +02:00
##########################################################################################
# Preparation
##########################################################################################
2017-03-15 12:32:25 +01:00
COMMONDIR=$INSTALLER/common
2017-10-31 10:05:24 +01:00
APK=$COMMONDIR/magisk.apk
2016-11-28 21:16:01 +01:00
CHROMEDIR=$INSTALLER/chromeos
2016-11-13 09:58:43 +01:00
# Default permissions
umask 022
2016-09-14 04:31:13 +02:00
OUTFD=$2
ZIP=$3
2017-09-15 21:48:58 +02:00
if [ ! -f $COMMONDIR/util_functions.sh ]; then
2017-06-24 16:38:20 +02:00
echo "! Unable to extract zip file!"
exit 1
fi
2017-07-09 18:17:34 +02:00
# Load utility fuctions
2017-06-18 18:15:44 +02:00
. $COMMONDIR/util_functions.sh
2017-07-09 18:17:34 +02:00
get_outfd
##########################################################################################
# Detection
##########################################################################################
2017-04-22 01:05:10 +02:00
ui_print "************************"
2017-07-30 21:03:52 +02:00
ui_print "* Magisk v$MAGISK_VER Installer"
2017-04-22 01:05:10 +02:00
ui_print "************************"
2016-09-14 04:31:13 +02:00
2017-09-26 14:21:43 +02:00
is_mounted /data || mount /data || is_mounted /cache || mount /cache || abort "! Unable to mount partitions"
2017-09-12 22:07:25 +02:00
mount_partitions
2017-06-10 19:40:08 +02:00
2018-06-17 11:59:24 +02:00
find_boot_image
find_dtbo_image
get_flags
2016-09-14 04:31:13 +02:00
2018-07-04 17:46:16 +02:00
[ -z $BOOTIMAGE ] && abort "! Unable to detect target image"
ui_print "- Target image: $BOOTIMAGE"
[ -z $DTBOIMAGE ] || ui_print "- DTBO image: $DTBOIMAGE"
2017-07-02 15:36:09 +02:00
# Detect version and architecture
api_level_arch_detect
2016-10-02 22:34:50 +02:00
2018-07-04 17:46:16 +02:00
[ $API -lt 21 ] && abort "! Magisk is only for Lollipop and above (5.0+) (SDK 21+)"
2016-10-30 00:13:59 +02:00
ui_print "- Device platform: $ARCH"
2018-04-22 08:13:27 +02:00
BINDIR=$INSTALLER/$ARCH32
2017-03-12 12:22:15 +01:00
chmod -R 755 $CHROMEDIR $BINDIR
2016-10-30 00:13:59 +02:00
# Check if system root is installed and remove
remove_system_su
2016-11-13 09:58:43 +01:00
##########################################################################################
# Environment
##########################################################################################
2017-04-22 01:05:10 +02:00
ui_print "- Constructing environment"
2017-07-24 20:02:19 +02:00
2018-06-26 16:41:03 +02:00
check_data
2017-12-15 19:02:17 +01:00
if $DATA; then
2018-08-02 21:43:02 +02:00
MAGISKBIN=/data/magisk
$DATA_DE && MAGISKBIN=/data/adb/magisk
2018-01-01 09:46:28 +01:00
run_migrations
2017-12-15 19:02:17 +01:00
else
MAGISKBIN=/cache/data_bin
fi
2017-04-22 01:05:10 +02:00
# Copy required files
rm -rf $MAGISKBIN/* 2>/dev/null
mkdir -p $MAGISKBIN 2>/dev/null
2017-09-05 15:44:22 +02:00
cp -af $BINDIR/. $COMMONDIR/. $CHROMEDIR $TMPDIR/bin/busybox $MAGISKBIN
2017-04-22 01:05:10 +02:00
chmod -R 755 $MAGISKBIN
2017-02-04 11:44:07 +01:00
2017-06-18 18:15:44 +02:00
# addon.d
if [ -d /system/addon.d ]; then
ui_print "- Adding addon.d survival script"
mount -o rw,remount /system
2018-08-03 16:40:49 +02:00
ADDOND=/system/addon.d/99-magisk.sh
echo '#!/sbin/sh' > $ADDOND
echo '# ADDOND_VERSION=2' >> $ADDOND
echo 'exec sh /data/adb/magisk/addon.d.sh "$@"' >> $ADDOND
chmod 755 $ADDOND
2017-06-18 18:15:44 +02:00
fi
$BOOTMODE || recovery_actions
2017-04-17 10:36:49 +02:00
2017-03-12 11:13:58 +01:00
##########################################################################################
2017-09-05 15:44:22 +02:00
# Boot patching
2017-03-12 11:13:58 +01:00
##########################################################################################
2017-10-31 10:05:24 +01:00
eval $BOOTSIGNER -verify < $BOOTIMAGE && BOOTSIGNED=true
$BOOTSIGNED && ui_print "- Boot image is signed with AVB 1.0"
2017-03-12 11:13:58 +01:00
2017-06-03 14:19:01 +02:00
SOURCEDMODE=true
cd $MAGISKBIN
2017-02-04 11:44:07 +01:00
2017-06-03 14:19:01 +02:00
# Source the boot patcher
. ./boot_patch.sh "$BOOTIMAGE"
2017-03-12 11:13:58 +01:00
2018-08-10 12:59:14 +02:00
ui_print "- Flashing new boot image"
flash_image new-boot.img "$BOOTIMAGE" || abort "! Insufficient partition size"
2017-11-10 18:33:50 +01:00
rm -f new-boot.img
if [ -f stock_boot* ]; then
rm -f /data/stock_boot* 2>/dev/null
$DATA && mv stock_boot* /data
fi
2017-03-12 11:13:58 +01:00
$KEEPVERITY || patch_dtbo_image
2017-11-10 18:33:50 +01:00
if [ -f stock_dtbo* ]; then
rm -f /data/stock_dtbo* 2>/dev/null
$DATA && mv stock_dtbo* /data
2017-11-10 18:33:50 +01:00
fi
2016-09-14 04:31:13 +02:00
2017-01-01 19:00:53 +01:00
cd /
2017-09-05 15:44:22 +02:00
# Cleanups
$BOOTMODE || recovery_cleanup
rm -rf $TMPDIR
2017-07-30 21:03:52 +02:00
2016-09-14 04:31:13 +02:00
ui_print "- Done"
exit 0