Compare commits
	
		
			2 Commits
		
	
	
		
			master
			...
			5a965d05ac
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5a965d05ac | |||
| d1079ba610 | 
							
								
								
									
										174
									
								
								boot_patch.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								boot_patch.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,174 @@ | ||||
| #!/system/bin/sh | ||||
| ####################################################################################### | ||||
| # Magisk Boot Image Patcher | ||||
| ####################################################################################### | ||||
| # | ||||
| # Usage: boot_patch.sh <bootimage> | ||||
| # | ||||
| # The following flags can be set in environment variables: | ||||
| # KEEPVERITY, KEEPFORCEENCRYPT, RECOVERYMODE | ||||
| # | ||||
| # This script should be placed in a directory with the following files: | ||||
| # | ||||
| # File name          Type      Description | ||||
| # | ||||
| # boot_patch.sh      script    A script to patch boot image for Magisk. | ||||
| #                  (this file) The script will use files in its same | ||||
| #                              directory to complete the patching process | ||||
| # util_functions.sh  script    A script which hosts all functions required | ||||
| #                              for this script to work properly | ||||
| # magiskinit         binary    The binary to replace /init | ||||
| # magisk(32/64)      binary    The magisk binaries | ||||
| # magiskboot         binary    A tool to manipulate boot images | ||||
| # chromeos           folder    This folder includes the utility and keys to sign | ||||
| #                  (optional)  chromeos boot images. Only used for Pixel C. | ||||
| # | ||||
| ####################################################################################### | ||||
|  | ||||
| ############ | ||||
| # Functions | ||||
| ############ | ||||
|  | ||||
| # Pure bash dirname implementation | ||||
| getdir() { | ||||
|   case "$1" in | ||||
|     */*) | ||||
|       dir=${1%/*} | ||||
|       if [ -z $dir ]; then | ||||
|         echo "/" | ||||
|       else | ||||
|         echo $dir | ||||
|       fi | ||||
|     ;; | ||||
|     *) echo "." ;; | ||||
|   esac | ||||
| } | ||||
|  | ||||
| ################# | ||||
| # Initialization | ||||
| ################# | ||||
|  | ||||
| [ -e "$BOOTIMAGE" ] || abort "$BOOTIMAGE does not exist!" | ||||
|  | ||||
| # Dump image for MTD/NAND character device boot partitions | ||||
| if [ -c "$BOOTIMAGE" ]; then | ||||
|   nanddump -f boot.img "$BOOTIMAGE" | ||||
|   BOOTNAND="$BOOTIMAGE" | ||||
|   BOOTIMAGE=boot.img | ||||
| fi | ||||
|  | ||||
| # Flags | ||||
| [ -z $KEEPVERITY ] && KEEPVERITY=false | ||||
| [ -z $KEEPFORCEENCRYPT ] && KEEPFORCEENCRYPT=false | ||||
| [ -z $RECOVERYMODE ] && RECOVERYMODE=false | ||||
| export KEEPVERITY | ||||
| export KEEPFORCEENCRYPT | ||||
|  | ||||
| chmod -R 755 . | ||||
|  | ||||
| ######### | ||||
| # Unpack | ||||
| ######### | ||||
|  | ||||
| CHROMEOS=false | ||||
|  | ||||
| ui_print "- Unpacking boot image" | ||||
| $MAGISKBIN/magiskboot unpack "$BOOTIMAGE" | ||||
|  | ||||
| case $? in | ||||
|   0 ) ;; | ||||
|   1 ) | ||||
|     abort "! Unsupported/Unknown image format" | ||||
|     ;; | ||||
|   2 ) | ||||
|     ui_print "- ChromeOS boot image detected" | ||||
|     CHROMEOS=true | ||||
|     ;; | ||||
|   * ) | ||||
|     abort "! Unable to unpack boot image" | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| [ -f recovery_dtbo ] && RECOVERYMODE=true | ||||
|  | ||||
| ################### | ||||
| # Ramdisk Restores | ||||
| ################### | ||||
|  | ||||
| # Test patch status and do restore | ||||
| ui_print "- Checking ramdisk status" | ||||
| if [ -e ramdisk.cpio ]; then | ||||
|   $MAGISKBIN/magiskboot cpio ramdisk.cpio test | ||||
|   STATUS=$? | ||||
| else | ||||
|   # Stock A only system-as-root | ||||
|   STATUS=0 | ||||
| fi | ||||
| case $((STATUS & 3)) in | ||||
|   0 )  # Stock boot | ||||
|     ui_print "- Stock boot image detected" | ||||
|     abort "! magisk must be installed" | ||||
|     ;; | ||||
|   1 )  # Magisk patched | ||||
|     ui_print "- Magisk patched boot image detected" | ||||
|     # Find SHA1 of stock boot image | ||||
|     [ -z $SHA1 ] && SHA1=$($MAGISKBIN/magiskboot cpio ramdisk.cpio sha1 2>/dev/null) | ||||
|     cp -af ramdisk.cpio ramdisk.cpio.stock.magisk | ||||
|     ;; | ||||
|   2 )  # Unsupported | ||||
|     ui_print "! Boot image patched by unsupported programs" | ||||
|     abort "! Please restore back to stock boot image" | ||||
|     ;; | ||||
| esac | ||||
|  | ||||
| ################## | ||||
| # Ramdisk Patches | ||||
| ################## | ||||
|  | ||||
| ui_print "- Patching ramdisk" | ||||
|  | ||||
| echo "KEEPVERITY=$KEEPVERITY" > config | ||||
| echo "KEEPFORCEENCRYPT=$KEEPFORCEENCRYPT" >> config | ||||
| echo "RECOVERYMODE=$RECOVERYMODE" >> config | ||||
| [ ! -z $SHA1 ] && echo "SHA1=$SHA1" >> config | ||||
|  | ||||
| $MAGISKBIN/magiskboot cpio ramdisk.cpio "extract overlay.d/ghid.rc ghid.rc" 2>/dev/null | ||||
| if ! diff $MODPATH/overlay.d/ghid.rc ghid.rc 2>/dev/null; then | ||||
|   ui_print "- Adding overlay.d/ghid.rc" | ||||
|  | ||||
|   $MAGISKBIN/magiskboot cpio ramdisk.cpio \ | ||||
|   "mkdir 755 overlay.d" \ | ||||
|   "add 755 overlay.d/ghid.rc $MODPATH/overlay.d/ghid.rc" | ||||
|  | ||||
|   rm -f ramdisk.cpio.orig config magisk*.xz | ||||
|  | ||||
| ################# | ||||
| # Binary Patches | ||||
| ################# | ||||
|  | ||||
|   if [ $((STATUS & 4)) -ne 0 ]; then | ||||
|     ui_print "- Compressing ramdisk" | ||||
|     $MAGISKBIN/magiskboot cpio ramdisk.cpio compress | ||||
|   fi | ||||
|  | ||||
|   rm -f ramdisk.cpio.stock.magisk config ghid.rc | ||||
| ################# | ||||
| # Repack & Flash | ||||
| ################# | ||||
|  | ||||
|   ui_print "- Repacking boot image" | ||||
|   $MAGISKBIN/magiskboot repack "$BOOTIMAGE" || abort "! Unable to repack boot image!" | ||||
| # Sign chromeos boot | ||||
| $CHROMEOS && sign_chromeos | ||||
|  | ||||
|   # Sign chromeos boot | ||||
|   $CHROMEOS && sign_chromeos | ||||
| else | ||||
|   ui_print "- ghid.rc already installed. Skipping boot patching." | ||||
|   rm -f ramdisk.cpio.stock.magisk config ghid.rc | ||||
| fi | ||||
| # Restore the original boot partition path | ||||
| [ -e "$BOOTNAND" ] && BOOTIMAGE="$BOOTNAND" | ||||
|  | ||||
| # Reset any error code | ||||
| true | ||||
							
								
								
									
										2
									
								
								build.sh
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								build.sh
									
									
									
									
									
								
							| @ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| rm *.zip 2>/dev/null | ||||
| eval $(grep -v ' ' module.prop) | ||||
| printf '%s\n' * | grep -Ev '(zip|build.sh)$' | xargs zip -r "magisk-$name-$version-$versionCode.zip" | ||||
| printf '%s\n' * | grep -v 'zip$' | xargs zip -r "magisk-$name-$version-$versionCode.zip" | ||||
| adb push "magisk-$name-$version-$versionCode.zip" /sdcard/ | ||||
|  | ||||
							
								
								
									
										21
									
								
								customize.sh
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								customize.sh
									
									
									
									
									
								
							| @ -1,23 +1,16 @@ | ||||
| #!/system/bin/sh | ||||
| #!/bin/sh | ||||
| $BOOTMODE || abort "! must be installed in the running system" | ||||
| if [[ -e /proc/config.gz ]]; then | ||||
|     zcat /proc/config.gz | grep -Eq 'CONFIG_USB_(CONFIGFS_)?F_HID=[my]' || abort "! kernel does not have the required modules" | ||||
| else | ||||
|     test -d /config/usb_gadget || abort "! kernel does not have the required modules" | ||||
|     [[ -d /config/usb_gadget ]]                    || abort "! kernel does not have the required modules" | ||||
|     mkdir /config/usb_gadget/g1                    || abort "! kernel does not have the required modules" | ||||
|     mkdir /config/usb_gadget/g1/functions/hid.usb0 || abort "! kernel does not have the required modules" | ||||
| fi | ||||
| chmod 755 "$MODPATH/system/bin/ghid.sh" | ||||
| chmod 755 "$MODPATH/service.sh" | ||||
| sed -i -e "s@\[MODDIR\]@${MODPATH%_update/ghid}/ghid@g" "$MODPATH/system/bin/ghid.sh" | ||||
| sed "s@\[MODDIR\]@$MODPATH@g" "$MODPATH/system/bin/ghid.sh" | sed 's/modules_update/modules/g' >"$TMPDIR/ghid.sh" | ||||
| cp "$TMPDIR/ghid.sh" "$MODPATH/system/bin/ghid.sh" | ||||
| FILE_CONTEXTS=$(find /system -name plat_file_contexts 2>/dev/null | head -n 1) | ||||
|  | ||||
| mkdir -p "$MODPATH/system/system_ext/etc/selinux/" "$MODPATH/system/etc" | ||||
| { | ||||
|     grep -v /dev/hidg /system_ext/etc/selinux/system_ext_file_contexts | ||||
|     echo "/dev/hidg[0-9]+               u:object_r:null_device:s0" | ||||
| } >"$MODPATH/system/system_ext/etc/selinux/system_ext_file_contexts" | ||||
|  | ||||
| { | ||||
|     grep -v /dev/hidg /system/etc/ueventd.rc | ||||
|     echo "/dev/hidg*                0666   root       root" | ||||
| } >"$MODPATH/system/etc/ueventd.rc" | ||||
| . "$MODPATH/utils.sh" | ||||
| . "$MODPATH/flash_script.sh" | ||||
|  | ||||
							
								
								
									
										60
									
								
								flash_script.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								flash_script.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| #MAGISK | ||||
| ############################################ | ||||
| # Magisk Flash Script (updater-script) | ||||
| ############################################ | ||||
|  | ||||
| ############## | ||||
| # Preparation | ||||
| ############## | ||||
|  | ||||
| find_magisk_apk | ||||
| # Default permissions | ||||
| umask 022 | ||||
|  | ||||
| OUTFD=$2 | ||||
| APK="$3" | ||||
| COMMONDIR=$INSTALLER/assets | ||||
| CHROMEDIR=$INSTALLER/assets/chromeos | ||||
|  | ||||
| setup_flashable | ||||
|  | ||||
| ############ | ||||
| # Detection | ||||
| ############ | ||||
|  | ||||
| if echo $MAGISK_VER | grep -q '\.'; then | ||||
|   PRETTY_VER=$MAGISK_VER | ||||
| else | ||||
|   PRETTY_VER="$MAGISK_VER($MAGISK_VER_CODE)" | ||||
| fi | ||||
| print_title "Magisk $PRETTY_VER Installer" | ||||
|  | ||||
| is_mounted /data || mount /data || is_mounted /cache || mount /cache | ||||
| mount_partitions | ||||
| check_data | ||||
| get_flags | ||||
| find_boot_image | ||||
|  | ||||
| [ -z $BOOTIMAGE ] && abort "! Unable to detect target image" | ||||
| ui_print "- Target image: $BOOTIMAGE" | ||||
|  | ||||
| # Detect version and architecture | ||||
| api_level_arch_detect | ||||
|  | ||||
| [ $API -lt 21 ] && abort "! Magisk only support Android 5.0 and above" | ||||
|  | ||||
| ui_print "- Device platform: $ARCH" | ||||
|  | ||||
|  | ||||
| ################## | ||||
| # Image Patching | ||||
| ################## | ||||
|  | ||||
| install_magisk | ||||
|  | ||||
| # Cleanups | ||||
| $BOOTMODE || recovery_cleanup | ||||
| rm -rf $TMPDIR | ||||
|  | ||||
| ui_print "- Done" | ||||
| exit 0 | ||||
							
								
								
									
										1
									
								
								hidg_contexts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								hidg_contexts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| /dev/hidg[0-9]+               u:object_r:null_device:s0 | ||||
| @ -1,6 +1,6 @@ | ||||
| id=ghid | ||||
| name=ghid | ||||
| version=0.12.78 | ||||
| versionCode=78 | ||||
| version=0.12.44 | ||||
| versionCode=44 | ||||
| author=lordwelch | ||||
| description=creates hidg device files in /dev | ||||
| description=creates ghid device files in /dev | ||||
|  | ||||
							
								
								
									
										5
									
								
								overlay.d/ghid.rc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								overlay.d/ghid.rc
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
| on property:sys.usb.ffs.ready=1 && property:sys.usb.config=adb && property:sys.usb.configfs=1 | ||||
|     exec u:r:magisk:s0 root root -- /system/bin/ghid.sh setup ${sys.usb.config} | ||||
|  | ||||
| on property:sys.usb.ffs.ready=1 && property:sys.usb.state=adb && property:sys.usb.configfs=1 | ||||
|     exec u:r:magisk:s0 root root -- /system/bin/ghid.sh fix ${sys.usb.config} | ||||
							
								
								
									
										4
									
								
								post-fs-data.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								post-fs-data.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | ||||
| { | ||||
|     grep -v /dev/hidg $FILE_CONTEXTS | ||||
|     cat "$MODPATH/hidg_contexts" | ||||
| } >"$MODPATH/system/etc/selinux/plat_file_contexts" | ||||
| @ -1,8 +0,0 @@ | ||||
| #!/system/bin/sh | ||||
| ueventd=$(getprop init.svc.ueventd) | ||||
| if [ "$ueventd" = "running" ]; then | ||||
| 	# ueventd ensures that the correct permissions get applied, it may also apply the correct selabel, not sure | ||||
| 	stop ueventd | ||||
| 	start ueventd | ||||
| fi | ||||
| /system/bin/ghid.sh init | ||||
							
								
								
									
										76
									
								
								system/bin/ghid.sh
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										76
									
								
								system/bin/ghid.sh
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @ -2,17 +2,17 @@ | ||||
| # $1 setup | ||||
| controller=$(getprop sys.usb.controller) | ||||
| moddir=[MODDIR] | ||||
|  | ||||
| exec >>"$moddir"/ghid.log | ||||
| exec 2>>"$moddir"/ghid.log | ||||
| selected=keyboard-standard | ||||
| exec >>$moddir/ghid.log | ||||
| exec 2>>$moddir/ghid.log | ||||
| date | ||||
| set -o xtrace | ||||
| set -o nohup | ||||
| set +o errexit | ||||
| set +o sh | ||||
| set +o posix | ||||
| exec >>"$moddir"/oghid.log | ||||
| exec 2>>"$moddir"/oghid.log | ||||
| exec >>$moddir/oghid.log | ||||
| exec 2>>$moddir/oghid.log | ||||
|  | ||||
| remove_ghid() { | ||||
|         echo "disabling ghid" | ||||
| @ -21,56 +21,78 @@ remove_ghid() { | ||||
| } | ||||
|  | ||||
| enable_ghid() { | ||||
|     . "$moddir/definitions/keyboard-standard" | ||||
|         for f in $selected; do | ||||
|                 echo "enabling ghid" | ||||
|                 running=true | ||||
|                 . "$moddir/definitions/$f" | ||||
|                 if [ ! -d /config/usb_gadget/g1/functions/hid.usb0 ]; then | ||||
|                         mkdir /config/usb_gadget/g1/functions/hid.usb0 | ||||
|                 fi | ||||
|                 current_protocol="$(cat /config/usb_gadget/g1/functions/hid.usb0/protocol)" | ||||
|                 current_subclass="$(cat /config/usb_gadget/g1/functions/hid.usb0/subclass)" | ||||
|                 current_report_length="$(cat /config/usb_gadget/g1/functions/hid.usb0/report_length)" | ||||
|                 echo "current ghid" | ||||
|                 echo current_protocol $current_protocol | ||||
|                 echo current_subclass $current_subclass | ||||
|                 echo current_report_length $current_report_length | ||||
|  | ||||
|     if [ -e /config/usb_gadget/g1/functions/hid.usb0 ] && [ "$current_protocol" = "$protocol" ] && [ "$current_subclass" = "$subclass" ] && [ "$current_report_length" = "$report_length" ] && diff "$moddir/reports/$report_name" /config/usb_gadget/g1/functions/hid.usb0/report_desc; then | ||||
|                 if [ -e /config/usb_gadget/g1/functions/hid.usb0 -a "$current_protocol" == "$protocol" -a "$current_subclass" == "$subclass" -a "$current_report_length" == "$report_length" ]  && diff "$moddir/reports/$report_name" /config/usb_gadget/g1/functions/hid.usb0/report_desc ; then | ||||
|                         echo nothing to update | ||||
|         cd /config/usb_gadget/g1/configs/b.1/ | ||||
|         /data/adb/magisk/busybox ln -nsf ../../../../usb_gadget/g1/functions/hid.usb0 ./fhid | ||||
|                         return 0 | ||||
|                 fi | ||||
|  | ||||
|                 echo new ghid | ||||
|  | ||||
|     echo protocol: "$protocol" | ||||
|     echo subclass: "$subclass" | ||||
|     echo report_length: "$report_length" | ||||
|  | ||||
|     echo "$protocol" >/config/usb_gadget/g1/functions/hid.usb0/protocol | ||||
|     echo "$subclass" >/config/usb_gadget/g1/functions/hid.usb0/subclass | ||||
|     echo "$report_length" >/config/usb_gadget/g1/functions/hid.usb0/report_length | ||||
|     cat "$moddir/reports/$report_name" >/config/usb_gadget/g1/functions/hid.usb0/report_desc | ||||
|                 echo $protocol | ||||
|                 echo $subclass | ||||
|                 echo $report_length | ||||
|  | ||||
|                 rm /config/usb_gadget/g1/configs/b.1/fhid | ||||
|                 echo $protocol >/config/usb_gadget/g1/functions/hid.usb0/protocol | ||||
|                 echo $subclass >/config/usb_gadget/g1/functions/hid.usb0/subclass | ||||
|                 echo $report_length >/config/usb_gadget/g1/functions/hid.usb0/report_length | ||||
|                 cp "$moddir/reports/$report_name" /config/usb_gadget/g1/functions/hid.usb0/report_desc | ||||
|                 cd /config/usb_gadget/g1/configs/b.1/ | ||||
|                 /data/adb/magisk/busybox ln -nsf ../../../../usb_gadget/g1/functions/hid.usb0 ./fhid | ||||
|  | ||||
|     # Normally we would let init take care of this but if we are connected when we boot up, | ||||
|     # init will have already set this before we can setup the hid device | ||||
|     if [ "$(getprop sys.boot_completed)" != "1" ]; then | ||||
|         done | ||||
|         echo none >/config/usb_gadget/g1/UDC | ||||
|         echo "$controller" >/config/usb_gadget/g1/UDC | ||||
|     fi | ||||
|  | ||||
| } | ||||
|  | ||||
| echo success ghid was run with: "$@" | ||||
|  | ||||
| # if ! [[ "$1" == "setup" ]]; then | ||||
| #         exit 1 | ||||
| # fi | ||||
| # shift | ||||
|  | ||||
|  | ||||
| case "$1" in | ||||
| "init") | ||||
|         "setup" ) | ||||
|                 shift | ||||
|                 case "$1" in | ||||
|                         ""|"none" ) | ||||
|                                 remove_ghid | ||||
|                                 ;; | ||||
|                         * ) | ||||
|                                 enable_ghid | ||||
|                         ;; | ||||
| "remove") | ||||
|     remove_ghid | ||||
|                 esac | ||||
|                 ;; | ||||
|         "fix" ) | ||||
|                 shift | ||||
|                 chcon u:object_r:null_device:s0 /dev/hidg* | ||||
|                 chmod 666 /dev/hidg* | ||||
|  | ||||
|                 # sleep 5 | ||||
|                 chcon u:object_r:null_device:s0 /dev/hidg* | ||||
|                 chmod 666 /dev/hidg* | ||||
|                 ls -alZ /dev/hidg* | ||||
|                 ;; | ||||
|         * ) | ||||
|                 shift | ||||
|                 exit 0 | ||||
|         ;; | ||||
| esac | ||||
|  | ||||
| restorecon /dev/hidg* | ||||
| exit 0 | ||||
|  | ||||
							
								
								
									
										63
									
								
								utils.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								utils.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,63 @@ | ||||
| # get_flags() { | ||||
| #   # override variables | ||||
| #   getvar KEEPVERITY | ||||
| #   getvar KEEPFORCEENCRYPT | ||||
| #   getvar RECOVERYMODE | ||||
| #   if [ -z $KEEPVERITY ]; then | ||||
| #     if $SYSTEM_ROOT; then | ||||
| #       KEEPVERITY=true | ||||
| #       ui_print "- System-as-root, keep dm/avb-verity" | ||||
| #     else | ||||
| #       KEEPVERITY=false | ||||
| #     fi | ||||
| #   fi | ||||
| #   ISENCRYPTED=false | ||||
| #   grep ' /data ' /proc/mounts | grep -q 'dm-' && ISENCRYPTED=true | ||||
| #   [ "$(getprop ro.crypto.state)" = "encrypted" ] && ISENCRYPTED=true | ||||
| #   if [ -z $KEEPFORCEENCRYPT ]; then | ||||
| #     # No data access means unable to decrypt in recovery | ||||
| #     if $ISENCRYPTED || ! $DATA; then | ||||
| #       KEEPFORCEENCRYPT=true | ||||
| #       ui_print "- Encrypted data, keep forceencrypt" | ||||
| #     else | ||||
| #       KEEPFORCEENCRYPT=false | ||||
| #     fi | ||||
| #   fi | ||||
| #   [ -z $RECOVERYMODE ] && RECOVERYMODE=false | ||||
| # } | ||||
|  | ||||
| install_magisk() { | ||||
|   cd $TMPDIR | ||||
|  | ||||
|   mkdir boot_patching | ||||
|   cd boot_patching/ | ||||
|  | ||||
|   # Dump image for MTD/NAND character device boot partitions | ||||
|   if [ -c $BOOTIMAGE ]; then | ||||
|     nanddump -f boot.img $BOOTIMAGE | ||||
|     local BOOTNAND=$BOOTIMAGE | ||||
|     BOOTIMAGE=boot.img | ||||
|   fi | ||||
|  | ||||
|   if [ $API -ge 21 ]; then | ||||
|     eval $BOOTSIGNER -verify < $BOOTIMAGE && BOOTSIGNED=true | ||||
|     $BOOTSIGNED && ui_print "- Boot image is signed with AVB 1.0" | ||||
|   fi | ||||
|  | ||||
|   # Source the boot patcher | ||||
|   . "$MODPATH/boot_patch.sh" | ||||
|  | ||||
|   if [ -f new-boot.img ]; then | ||||
|     ui_print "- Flashing new boot image" | ||||
|  | ||||
|     # Restore the original boot partition path | ||||
|     [ "$BOOTNAND" ] && BOOTIMAGE=$BOOTNAND | ||||
|     flash_image new-boot.img "$BOOTIMAGE" || abort "! Insufficient partition size" | ||||
|  | ||||
|     rm -f new-boot.img | ||||
|  | ||||
|     run_migrations | ||||
|   fi | ||||
|  | ||||
|   $MAGISKBIN/magiskboot cleanup | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	