This repository has been archived on 2024-08-02. You can view files and clone it, but cannot push or open issues or pull requests.
Magisk_boot_flasher/README.md
2021-11-26 16:21:25 +01:00

83 lines
3.0 KiB
Markdown

# Overview
This scripts aims in simplifing patching and installing Magisk after a LineageOS **for microG** update.
It has been made to run on Linux x86 or x64 and patch a boot image for an ARM device.
It detects LineageOS **for microG** version via adb, download the ROM, extracts `payload.bin` and dumps `boot.img`, patches it with Magisk, and flashes it.
:warning: **This has only been tested on a FP3 device, at the time of writing with LineageOS for microG 18.1 (November 18, 2021 build) Magisk v23.0** :warning:
## Run on an other device
Before to run this script for an other device, please make sure you understand what you run and every step of the script.
**I won't be responsible if anything goes wrong.**
The script is designed to:
* run the script `boot_patch.sh boot.img` with KEEPVERITY and KEEPFORCEENCRYPT to true
* install Magisk by patching the **boot image** and **not the recovery image**.
* run to flash the boot image in **boot_a** or **boot_b** partition (the FP3 way) and **not boot partition**
If you fit the conditions above, you have to make sure the patch `KEEPVERITY=true KEEPFORCEENCRYPT=true sh boot_patch.sh` outputs the same boot image than the Magisk Manager app:
* patch boot via Magisk Manager app
* run `boot_patch.sh boot.img` manually
* compare both files `magisk_patched-*.img` and `new-boot.img` with diff or by comparing hashes.
If **and only if** both output files are the same and you meet all the conditions, you can try the python script.
# Prerequisites
## In PATH
You need to have on your system (in your PATH):
* adb
* fastboot
* payload-dumper-go
* python (3)
* dos2unix
## USB debugging
You need to have USB debugging Enabled and configured.
Check your devices appears when running `adb devices` with device connected via USB.
## Using
Replace the `device` variable by your device code, as [listed here](https://download.lineage.microg.org/).
Plug your phone via USB and make sure adb is properly set up: your device should appear when running `adb devices`.
Run `python magisk_boot_flasher.py`.
# Run patch boot locally
That's how we can run Magisk's `boot_patch.sh` on Linux x86 or x64 and patch a boot image for an ARM device
> Tested with Magisk v23.0 with FP3
* Get Magisk `.apk`
* Extract it
Keep in the same folder:
* `assets/boot_patch.sh` -> `boot_patch.sh`
* `assets/util_functions.sh` -> `util_functions.sh`
* `lib/armeabi-v7a/libmagisk32.so` -> `magisk32`
* `lib/armeabi-v7a/libmagisk64.so` -> `magisk64`
* `lib/armeabi-v7a/libmagiskinit.so` -> `magiskinit`
* `lib/x86/libmagiskboot.so` -> `magiskboot`
* `lib/armeabi-v7a/libmagiskinit.so` -> `magiskinit`
You can delete all the rest.
In util_functions.sh:
* Change function `ui_print()` to contain only `echo "$1"`
* Change every `getprop` command, to `adb shell getprop`, to go run it on device rather than locally.
You can now run:
`sh boot_patch.sh boot.img`
The outpout file `new-boot.img` has the exact same sha256 hash as the `magisk_patched-*.img`, so we can consider it works :)