From d0336e97da2dcec99108b19eb83f59027ddb839f Mon Sep 17 00:00:00 2001 From: Jesse205 Date: Mon, 15 May 2023 14:03:00 +0000 Subject: [PATCH] deploy: 8ada1955168028b28c21560ac030228566730532 --- 404.html | 6 +++--- README.html | 6 +++--- app_changes.html | 6 +++--- boot.html | 6 +++--- build.html | 8 ++++---- changes.html | 6 +++--- details.html | 6 +++--- faq.html | 6 +++--- guides.html | 8 ++++---- hashmap.json | 2 +- index.html | 6 +++--- install.html | 6 +++--- ota.html | 6 +++--- releases/18000.html | 6 +++--- releases/18100.html | 6 +++--- releases/19000.html | 6 +++--- releases/19100.html | 6 +++--- releases/19200.html | 6 +++--- releases/19300.html | 6 +++--- releases/19400.html | 6 +++--- releases/20000.html | 6 +++--- releases/20100.html | 6 +++--- releases/20200.html | 6 +++--- releases/20300.html | 6 +++--- releases/20400.html | 6 +++--- releases/21000.html | 6 +++--- releases/21100.html | 6 +++--- releases/21200.html | 6 +++--- releases/21400.html | 6 +++--- releases/22000.html | 6 +++--- releases/22100.html | 6 +++--- releases/23000.html | 6 +++--- releases/24000.html | 6 +++--- releases/24100.html | 6 +++--- releases/24200.html | 6 +++--- releases/24300.html | 6 +++--- releases/25000.html | 6 +++--- releases/25100.html | 6 +++--- releases/25200.html | 6 +++--- releases/26000.html | 6 +++--- releases/26100.html | 6 +++--- releases/index.html | 6 +++--- tools.html | 8 ++++---- 43 files changed, 130 insertions(+), 130 deletions(-) diff --git a/404.html b/404.html index bfc49ce5..5479ac53 100644 --- a/404.html +++ b/404.html @@ -13,9 +13,9 @@ -
Skip to content

404

PAGE NOT FOUND

But if you don't change your direction, and if you keep looking, you may end up where you are heading.

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content

404

PAGE NOT FOUND

But if you don't change your direction, and if you keep looking, you may end up where you are heading.

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/README.html b/README.html index bfcf9b73..ceac73da 100644 --- a/README.html +++ b/README.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

Magisk 中文文档

这是由 Jesse205 根据 Magisk 官方文档 翻译的中文文档,并补充了一些内容。

注:此仓库分别存在 Gitee 与 Github 上,Gitee 为主仓库,Github 为镜像仓库

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

Magisk 中文文档

这是由 Jesse205 根据 Magisk 官方文档 翻译的中文文档,并补充了一些内容。

注:此仓库分别存在 Gitee 与 Github 上,Gitee 为主仓库,Github 为镜像仓库

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/app_changes.html b/app_changes.html index 50420455..351d8131 100644 --- a/app_changes.html +++ b/app_changes.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

Magisk Manager 更新日志

v8.0.7

  • 修复升级时的sepolicy规则迁移

v8.0.6

  • 轻微的UI更改

  • 更新内部脚本

v8.0.5

  • 修复sepolicy规则复制

v8.0.4

  • 大量的稳定性更改和小错误修复
  • 在日志菜单中保存日志时,收集设备属性、应用程序日志和Magisk日志

v8.0.3

  • 切换到新的Magisk模块仓库设置,以允许第三方仓库
  • 在超级用户请求对话框中添加抽头劫持保护
  • 稳定性更改和错误修复

v8.0.2

  • Fix an issue with requesting permission on devices older than Android 10
  • Make more files download through CDN

v8.0.1

  • Fix vbmeta.img patching for Samsung AP.tar files. This fixes bootloops on devices like Galaxy S10 after flashing updated AP files.
  • Properly truncate existing files before writing to prevent corrupted files
  • Prevent a possible UI loop when device ran into very low memory
  • Switch to use JSDelivr CDN for several files

v8.0.0

  • 100% full app rewrite! Will highlight functional changes below.
  • Add detailed device info in home screen to assist user installation
  • Support Magisk v21.0 communication protocol
  • Support patching modern Samsung AP.tar

v7.5.1

  • Fix toggling app components in MagiskHide screen
  • Update translations

v7.5.0

  • Support new MagiskSU communication method (ContentProvider)
  • Fix several issues with hidden stub APK
  • Support using BiometricPrompt (face unlock)

v7.4.0

  • Hide Magisk Manager with stub APKs on Android 9.0+
  • Allow customizing app name when hiding Magisk Manager
  • Generate random keys to sign the hidden Magisk Manager to prevent signature detections
  • Fix fingerprint UI infinite loop

v7.3.5

  • Sort installed modules by name
  • Better pre-5.0 support
  • Fix potential issues when patching tar files

v7.3.4

  • App is now fully written in Kotlin!
  • New downloading system
  • Add new "Recovery Mode" to Advanced Settings

v7.3.0/1/2

  • HUGE code base modernization, thanks @diareuse!
  • More sweet changes coming in the future!
  • Reboot device using proper API (no more abrupt reboot)
  • New floating button in Magisk logs to go to bottom

v7.2.0

  • Huge UI overhaul
  • More sweet changes coming in the future!

v7.1.2

  • Support patching Samsung AP firmware
  • Much better module downloading mechanism

v7.1.1

  • Fix a bug that causes some modules using new format not showing up

v7.1.0

  • Support the new module format
  • Support per-application component granularity MagiskHide targets (only on v19+)
  • Ask for fingerprint before deleting rules if enabled
  • Fix the bug that causes repackaging to lose settings
  • Several UI fixes

v7.0.0

  • Major UI redesign!
  • Render Markdown natively (no more buggy WebView!)
  • Support down to Android 4.1 (native Magisk only support Android 4.2 though)
  • Significantly improve Magisk log display performance
  • Fix post OTA scripts for A/B devices
  • Reduce memory usages when verifying and signing boot image
  • Drop support for Magisk lower than v18.0

v6.1.0

  • Introduce new downloading methods: no longer uses buggy system Download Manager
  • Introduce many new notifications for better user experience
  • Add support for Magisk v18.0
  • Change application name to "Manager" after hiding(repackaging) to prevent app name detection
  • Add built-in systemless hosts module (access in settings)
  • Auto launch the newly installed app after hiding(repackaging) and restoring Magisk Manager
  • Fix bug causing incomplete module.prop in modules to have improper UI

v6.0.1

  • Update to use new online module's organizing method
  • When fingerprint authentication is enabled, toggling root permissions in "Superuser" section now requires fingerprint beforehand
  • Fix crashes when entering MagiskHide section on some devices
  • Remove support to Magisk version lower than v15.0
  • Ask storage permissions before patching stock boot image
  • Update dark theme CardView color

v6.0.0

  • Update to latest AndroidX support library
  • Fix crashes when online repos contain incomplete metadata
  • Optimize BootSigner to use as little memory as possible, prevent OutOfMemoryError
  • Support new communication scheme between Magisk v17.2 and Magisk Manager
  • Enable excessive obfuscation to prevent APK analysis root detections (still not 100% obfuscated due to backwards compatibility with stable channel)

v5.9.0/v5.9.1

  • No more on boot notifications
  • Support new mechanism for installing to inactive slot for OTAs on A/B devices
  • Fix restore Magisk Manager settings on Android P
  • Verify existing file checksums to prevent unnecessary re-downloads
  • Update SNET extension to use new Google API, fix "Invalid Response" errors
  • Move fingerprint settings to magisk database to prevent the settings to be easily removed
  • Fingerprint settings are now guarded with fingerprint authentications before it can get changed
  • Prevent any files to be downloaded to /sdcard/MagiskManager

v5.8.3

  • Prevent invalid modules in the online repo crashing the app
  • Update Stable and Beta channel URLs

v5.8.1

  • Fix a bug that cause the root shell initializer not running in BusyBox environment

v5.8.0

  • Remain hidden when upgrading within repackaged Magisk Manager
  • New feature: support reconstructing a proper Magisk environment if error detected (e.g. after factory reset)
  • New uninstall method: download uninstaller and completely remove Magisk + Magisk Manager, following with a reboot
  • Hidden apps are now shown on the top of the list in MagiskHide fragment
  • Tons of under-the-hood bug fixes and improvements

v5.7.0

  • Add app shortcuts for Android 7.1+
  • Bump minimal module minMagisk requirement to 1500
  • Adjustments for new sepolicies on v16.4+
  • Fix crashes when refreshing the online repo

v5.6.4

  • Remove the blacklisted apps using SafetyNet (e.g. Pokemon GO)

v5.6.3

  • Fix repo loading UI logic

v5.6.2

  • Cleanup folders if installation failed
  • Add support for Android P

v5.6.1

  • Fix database crashes on F2FS with SQLite 3.21.0+
  • Optimize several settings options
  • Use native XML for settings migration

v5.6.0

  • Remove JNI requirement, Magisk Manager is now pure Java
  • Update the method of handling su database, may fix the issue that root requests won't save
  • Add the option to restore Magisk Manager after repackaging with random package name
  • Massive under-the-hood

v5.5.5

  • Fix crashes on Lollipop and some devices not following AOSP standards

v5.5.4

  • Fix dtbo on-boot detection, should follow configured dtbo patching behavior on Pixel 2 devices
  • Add fingerprint authentication for Superuser requests

v5.5.3

  • Update translations
  • Update internal scripts (in sync with Magisk)
  • Minor adjustments

v5.5.2

  • Support sorting online repos with last update
  • Fix issue that advanced installation settings won't stick
  • Prevent sudb crashing Magisk Manager

v5.5.1

  • Fix an issue in setting up superuser database, which causes some users to experience tons of root issues

v5.5.0

  • Fix dynamic resource loading, prevent crashes when checking SafetyNet
  • Update SignAPK to use very little RAM for supporting old devices
  • Support settings migration after hiding Magisk Manager
  • Add reboot menu in modules section
  • Add dark theme to superuser request dialogs
  • Properly handle new HIGHCOMP and add recommended KEEPVERITY and KEEPFORCEENCRYPT flags for installation
  • Support new paths for v14.6
  • Massive improvements in repackaging Magisk Manager

v5.4.3

  • Add flags to intent to prevent crashes
  • Update translations

v5.4.2

  • Support new paths and setup of v14.5
  • Support repackaging Magisk Manager for hiding (only works on v14.5+)
  • Support hardlinking global su database into app data
  • Support signing boot images (AVB 1.0)
  • Update app icon to adaptive icons
  • Remove app from MagiskHide list if uninstalled
  • Add support to save detailed logs when installing Magisk or modules
  • Fix download progress error if module is larger than 20MB
  • Changed the way how downloaded repos are processed, should be rock stable
  • Prevent crashes when database is corrupted - clear db instead
  • Fix saving wrong UID issue on multiuser mode
  • Add custom update channel support - you can now switch to your own update server!
  • Some UI adjustments and asynchronous UI performance improvements

v5.4.0

  • SafetyNet checks now require external code extension (for 100% FOSS)
  • Repo loading will now show real-time progress instead of blank screen
  • Show progress when downloading an online module
  • Allow secondary users to access superuser settings if allowed
  • Fix several places where external storage is needed but forgot to request
  • Fetching online repo info from sever is significantly faster thanks to multithreading
  • Pulling down Download page will now force a full refresh, thanks to the faster loading speed
  • Using new resetprop tool to properly detect MagiskHide status

v5.3.5

  • Fix error when MagiskManager folder doesn't exist
  • Offload many logic to scripts: script fixes will also be picked up in the app
  • Add installing Magisk to second slot on A/B partition devices
  • Support file based encryption: store necessary files into DE storage
  • Update uninstall method to self remove app and prompt user to manually reboot

v5.3.0

  • Add hide Magisk Manager feature - hide the app from detection
  • Add update channel settings - you can now receive beta updates through the app
  • Proper runtime permission implementation - request storage permission only when needed
  • Add boot image file patch feature - you can patch boot images without root!
  • Rewrite Magisk direct install method - merge with boot image file patch mode
  • Add feature to restore stock boot image - convenient for applying OTAs

v5.2.0

  • Fix force close which occurs when failure in flashing zips
  • Remove several external dependencies and rewrite a large portion of components
  • Improve MarkDown support: showing README.MD is much faster and will properly render Unicode characters (e.g. Chinese characters)
  • Add language settings: you can now switch to languages other than system default
  • Remove busybox included within APK; download through Internet if needed
  • Use Magisk internal busybox if detected
  • Busybox is added to the highest priority in PATH to create reliable shell environment
  • Always use global namespace for internal shell if possible

v5.1.1

  • Fix Magisk Manager hanging when reading files with no end newline
  • Massive rewrite AsyncTasks to prevent potential memory leak
  • Fix some minor issues with notifications
  • Improve update notification and popup behavior
  • Update internal uninstaller script

v5.1.0

  • Introduce a new flash log activity, so you know what is actually happening, just like flashing in custom recoveries!
  • Rewritten Java native shall interface: merged root shell and normal shell
  • Cleaned up implementation of repo recyclerview and adapters

v5.0.6

  • Fix crash when installing modules downloading from repos

v5.0.5

  • Fix update notifications on Android O
  • Fix crash when trying to install Magisk Manager update
  • Update translations

v5.0.4

  • Fix bug in su timeout

v5.0.3

  • Fix FC on boot on Android O
  • Adapt to Android O broadcast limitations: re-authenticate app when update is disabled on Android O

v5.0.2

  • Rewrite zip signing part, zips downloaded from repo will be properly signed and adjusted for custom recoveries

v5.0.1

  • Add namespace mode options
  • Fix a bug in Manager OTA system

v5.0.0

  • Support the new Magisk unified binary
  • Properly handle application install / uninstall root management issues
  • Add multiuser mode support
  • Add application upgrade re-authentication feature
  • Add basic integrity check for SafetyNet
  • Merged install fragment and status fragment into Magisk fragment
  • Fix theme switching glitch
  • Update translations

v4.3.3

  • Re-build APK with stable build tools

v4.3.2

  • Improve usage of Github API to support unlimited amount of online repos
  • Update translations (thanks to all contributors!!)

v4.3.1

  • Update proper Magisk busybox detection, will not be confused by busybox installed by default in custom roms

v4.3.0

  • Add Core Only Mode option
  • Fix crashes when selecting release note on Samsung devices
  • Hide modules using template lower than version 3

v4.2.7

  • Update translations
  • Update uninstall scripts

v4.2.6

  • Samsung crashes finally fixed (confirmed!)
  • Add settings to disable update notifications
  • Adjust Dark theme colors
  • Refined download section, now support download only when root is not detected
  • Fix crashes in boot image selection

v4.2

  • Change Repo cache to database
  • Dark theme refined
  • Alert Dialog buttons now properly aligned
  • Support very large online modules' zip processing
  • You can now download online modules without installing
  • Add notifications when new Magisk version is available
  • Removed changelog, donation link, support link in download cards
  • Read and display README.md for online modules

v4.1

  • Change MagiskHide startup
  • Reduce static data (= less memory leaks/issues)
  • Translation updates

v4.0

  • Whole new Superuser section for MagiskSU management!
  • Add Superuser tab in Logs section
  • Add lots of Superuser settings
  • Handle MagiskSU requests, logging, notifications
  • Controls MagiskHide initialization
  • Add disable button
  • Add uninstall button
  • Tons of improvements, not practical to list all 😃

v3.1

  • Fix online repo inaccessible issue
  • Fix repo list card expanding issues
  • Change SafetyNet check to manually triggered
  • Update translations
  • Tons of bug fixes preventing potential crashes

v3.0

  • Now on Play Store
  • Add Status Section, you can check Safety Net, root status, and Magisk status in one place
  • Add Install Section, you can manually choose the boot image location and advanced options

v2.5

  • Add Magisk Hide section, you can now add/remove apps from Magisk Hide list
  • Support custom Magisk Version names, any string is now accepted (for custom builds)
  • Fixed modules and repos not sorted by name

v2.1

  • Add Magisk Hide settings
  • Add search bar in "Downloads Sections"
  • Fix crashes when no root is available
  • Fix trash can icon not updated when removing module
  • Prevent crash when Magisk Version is set incorrectly

v2.0

  • Massive refactor
  • Material Design
  • Module Management
  • Download Section
  • And much more....

v1.0

  • 初始版本

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

Magisk Manager 更新日志

v8.0.7

  • 修复升级时的sepolicy规则迁移

v8.0.6

  • 轻微的UI更改

  • 更新内部脚本

v8.0.5

  • 修复sepolicy规则复制

v8.0.4

  • 大量的稳定性更改和小错误修复
  • 在日志菜单中保存日志时,收集设备属性、应用程序日志和Magisk日志

v8.0.3

  • 切换到新的Magisk模块仓库设置,以允许第三方仓库
  • 在超级用户请求对话框中添加抽头劫持保护
  • 稳定性更改和错误修复

v8.0.2

  • Fix an issue with requesting permission on devices older than Android 10
  • Make more files download through CDN

v8.0.1

  • Fix vbmeta.img patching for Samsung AP.tar files. This fixes bootloops on devices like Galaxy S10 after flashing updated AP files.
  • Properly truncate existing files before writing to prevent corrupted files
  • Prevent a possible UI loop when device ran into very low memory
  • Switch to use JSDelivr CDN for several files

v8.0.0

  • 100% full app rewrite! Will highlight functional changes below.
  • Add detailed device info in home screen to assist user installation
  • Support Magisk v21.0 communication protocol
  • Support patching modern Samsung AP.tar

v7.5.1

  • Fix toggling app components in MagiskHide screen
  • Update translations

v7.5.0

  • Support new MagiskSU communication method (ContentProvider)
  • Fix several issues with hidden stub APK
  • Support using BiometricPrompt (face unlock)

v7.4.0

  • Hide Magisk Manager with stub APKs on Android 9.0+
  • Allow customizing app name when hiding Magisk Manager
  • Generate random keys to sign the hidden Magisk Manager to prevent signature detections
  • Fix fingerprint UI infinite loop

v7.3.5

  • Sort installed modules by name
  • Better pre-5.0 support
  • Fix potential issues when patching tar files

v7.3.4

  • App is now fully written in Kotlin!
  • New downloading system
  • Add new "Recovery Mode" to Advanced Settings

v7.3.0/1/2

  • HUGE code base modernization, thanks @diareuse!
  • More sweet changes coming in the future!
  • Reboot device using proper API (no more abrupt reboot)
  • New floating button in Magisk logs to go to bottom

v7.2.0

  • Huge UI overhaul
  • More sweet changes coming in the future!

v7.1.2

  • Support patching Samsung AP firmware
  • Much better module downloading mechanism

v7.1.1

  • Fix a bug that causes some modules using new format not showing up

v7.1.0

  • Support the new module format
  • Support per-application component granularity MagiskHide targets (only on v19+)
  • Ask for fingerprint before deleting rules if enabled
  • Fix the bug that causes repackaging to lose settings
  • Several UI fixes

v7.0.0

  • Major UI redesign!
  • Render Markdown natively (no more buggy WebView!)
  • Support down to Android 4.1 (native Magisk only support Android 4.2 though)
  • Significantly improve Magisk log display performance
  • Fix post OTA scripts for A/B devices
  • Reduce memory usages when verifying and signing boot image
  • Drop support for Magisk lower than v18.0

v6.1.0

  • Introduce new downloading methods: no longer uses buggy system Download Manager
  • Introduce many new notifications for better user experience
  • Add support for Magisk v18.0
  • Change application name to "Manager" after hiding(repackaging) to prevent app name detection
  • Add built-in systemless hosts module (access in settings)
  • Auto launch the newly installed app after hiding(repackaging) and restoring Magisk Manager
  • Fix bug causing incomplete module.prop in modules to have improper UI

v6.0.1

  • Update to use new online module's organizing method
  • When fingerprint authentication is enabled, toggling root permissions in "Superuser" section now requires fingerprint beforehand
  • Fix crashes when entering MagiskHide section on some devices
  • Remove support to Magisk version lower than v15.0
  • Ask storage permissions before patching stock boot image
  • Update dark theme CardView color

v6.0.0

  • Update to latest AndroidX support library
  • Fix crashes when online repos contain incomplete metadata
  • Optimize BootSigner to use as little memory as possible, prevent OutOfMemoryError
  • Support new communication scheme between Magisk v17.2 and Magisk Manager
  • Enable excessive obfuscation to prevent APK analysis root detections (still not 100% obfuscated due to backwards compatibility with stable channel)

v5.9.0/v5.9.1

  • No more on boot notifications
  • Support new mechanism for installing to inactive slot for OTAs on A/B devices
  • Fix restore Magisk Manager settings on Android P
  • Verify existing file checksums to prevent unnecessary re-downloads
  • Update SNET extension to use new Google API, fix "Invalid Response" errors
  • Move fingerprint settings to magisk database to prevent the settings to be easily removed
  • Fingerprint settings are now guarded with fingerprint authentications before it can get changed
  • Prevent any files to be downloaded to /sdcard/MagiskManager

v5.8.3

  • Prevent invalid modules in the online repo crashing the app
  • Update Stable and Beta channel URLs

v5.8.1

  • Fix a bug that cause the root shell initializer not running in BusyBox environment

v5.8.0

  • Remain hidden when upgrading within repackaged Magisk Manager
  • New feature: support reconstructing a proper Magisk environment if error detected (e.g. after factory reset)
  • New uninstall method: download uninstaller and completely remove Magisk + Magisk Manager, following with a reboot
  • Hidden apps are now shown on the top of the list in MagiskHide fragment
  • Tons of under-the-hood bug fixes and improvements

v5.7.0

  • Add app shortcuts for Android 7.1+
  • Bump minimal module minMagisk requirement to 1500
  • Adjustments for new sepolicies on v16.4+
  • Fix crashes when refreshing the online repo

v5.6.4

  • Remove the blacklisted apps using SafetyNet (e.g. Pokemon GO)

v5.6.3

  • Fix repo loading UI logic

v5.6.2

  • Cleanup folders if installation failed
  • Add support for Android P

v5.6.1

  • Fix database crashes on F2FS with SQLite 3.21.0+
  • Optimize several settings options
  • Use native XML for settings migration

v5.6.0

  • Remove JNI requirement, Magisk Manager is now pure Java
  • Update the method of handling su database, may fix the issue that root requests won't save
  • Add the option to restore Magisk Manager after repackaging with random package name
  • Massive under-the-hood

v5.5.5

  • Fix crashes on Lollipop and some devices not following AOSP standards

v5.5.4

  • Fix dtbo on-boot detection, should follow configured dtbo patching behavior on Pixel 2 devices
  • Add fingerprint authentication for Superuser requests

v5.5.3

  • Update translations
  • Update internal scripts (in sync with Magisk)
  • Minor adjustments

v5.5.2

  • Support sorting online repos with last update
  • Fix issue that advanced installation settings won't stick
  • Prevent sudb crashing Magisk Manager

v5.5.1

  • Fix an issue in setting up superuser database, which causes some users to experience tons of root issues

v5.5.0

  • Fix dynamic resource loading, prevent crashes when checking SafetyNet
  • Update SignAPK to use very little RAM for supporting old devices
  • Support settings migration after hiding Magisk Manager
  • Add reboot menu in modules section
  • Add dark theme to superuser request dialogs
  • Properly handle new HIGHCOMP and add recommended KEEPVERITY and KEEPFORCEENCRYPT flags for installation
  • Support new paths for v14.6
  • Massive improvements in repackaging Magisk Manager

v5.4.3

  • Add flags to intent to prevent crashes
  • Update translations

v5.4.2

  • Support new paths and setup of v14.5
  • Support repackaging Magisk Manager for hiding (only works on v14.5+)
  • Support hardlinking global su database into app data
  • Support signing boot images (AVB 1.0)
  • Update app icon to adaptive icons
  • Remove app from MagiskHide list if uninstalled
  • Add support to save detailed logs when installing Magisk or modules
  • Fix download progress error if module is larger than 20MB
  • Changed the way how downloaded repos are processed, should be rock stable
  • Prevent crashes when database is corrupted - clear db instead
  • Fix saving wrong UID issue on multiuser mode
  • Add custom update channel support - you can now switch to your own update server!
  • Some UI adjustments and asynchronous UI performance improvements

v5.4.0

  • SafetyNet checks now require external code extension (for 100% FOSS)
  • Repo loading will now show real-time progress instead of blank screen
  • Show progress when downloading an online module
  • Allow secondary users to access superuser settings if allowed
  • Fix several places where external storage is needed but forgot to request
  • Fetching online repo info from sever is significantly faster thanks to multithreading
  • Pulling down Download page will now force a full refresh, thanks to the faster loading speed
  • Using new resetprop tool to properly detect MagiskHide status

v5.3.5

  • Fix error when MagiskManager folder doesn't exist
  • Offload many logic to scripts: script fixes will also be picked up in the app
  • Add installing Magisk to second slot on A/B partition devices
  • Support file based encryption: store necessary files into DE storage
  • Update uninstall method to self remove app and prompt user to manually reboot

v5.3.0

  • Add hide Magisk Manager feature - hide the app from detection
  • Add update channel settings - you can now receive beta updates through the app
  • Proper runtime permission implementation - request storage permission only when needed
  • Add boot image file patch feature - you can patch boot images without root!
  • Rewrite Magisk direct install method - merge with boot image file patch mode
  • Add feature to restore stock boot image - convenient for applying OTAs

v5.2.0

  • Fix force close which occurs when failure in flashing zips
  • Remove several external dependencies and rewrite a large portion of components
  • Improve MarkDown support: showing README.MD is much faster and will properly render Unicode characters (e.g. Chinese characters)
  • Add language settings: you can now switch to languages other than system default
  • Remove busybox included within APK; download through Internet if needed
  • Use Magisk internal busybox if detected
  • Busybox is added to the highest priority in PATH to create reliable shell environment
  • Always use global namespace for internal shell if possible

v5.1.1

  • Fix Magisk Manager hanging when reading files with no end newline
  • Massive rewrite AsyncTasks to prevent potential memory leak
  • Fix some minor issues with notifications
  • Improve update notification and popup behavior
  • Update internal uninstaller script

v5.1.0

  • Introduce a new flash log activity, so you know what is actually happening, just like flashing in custom recoveries!
  • Rewritten Java native shall interface: merged root shell and normal shell
  • Cleaned up implementation of repo recyclerview and adapters

v5.0.6

  • Fix crash when installing modules downloading from repos

v5.0.5

  • Fix update notifications on Android O
  • Fix crash when trying to install Magisk Manager update
  • Update translations

v5.0.4

  • Fix bug in su timeout

v5.0.3

  • Fix FC on boot on Android O
  • Adapt to Android O broadcast limitations: re-authenticate app when update is disabled on Android O

v5.0.2

  • Rewrite zip signing part, zips downloaded from repo will be properly signed and adjusted for custom recoveries

v5.0.1

  • Add namespace mode options
  • Fix a bug in Manager OTA system

v5.0.0

  • Support the new Magisk unified binary
  • Properly handle application install / uninstall root management issues
  • Add multiuser mode support
  • Add application upgrade re-authentication feature
  • Add basic integrity check for SafetyNet
  • Merged install fragment and status fragment into Magisk fragment
  • Fix theme switching glitch
  • Update translations

v4.3.3

  • Re-build APK with stable build tools

v4.3.2

  • Improve usage of Github API to support unlimited amount of online repos
  • Update translations (thanks to all contributors!!)

v4.3.1

  • Update proper Magisk busybox detection, will not be confused by busybox installed by default in custom roms

v4.3.0

  • Add Core Only Mode option
  • Fix crashes when selecting release note on Samsung devices
  • Hide modules using template lower than version 3

v4.2.7

  • Update translations
  • Update uninstall scripts

v4.2.6

  • Samsung crashes finally fixed (confirmed!)
  • Add settings to disable update notifications
  • Adjust Dark theme colors
  • Refined download section, now support download only when root is not detected
  • Fix crashes in boot image selection

v4.2

  • Change Repo cache to database
  • Dark theme refined
  • Alert Dialog buttons now properly aligned
  • Support very large online modules' zip processing
  • You can now download online modules without installing
  • Add notifications when new Magisk version is available
  • Removed changelog, donation link, support link in download cards
  • Read and display README.md for online modules

v4.1

  • Change MagiskHide startup
  • Reduce static data (= less memory leaks/issues)
  • Translation updates

v4.0

  • Whole new Superuser section for MagiskSU management!
  • Add Superuser tab in Logs section
  • Add lots of Superuser settings
  • Handle MagiskSU requests, logging, notifications
  • Controls MagiskHide initialization
  • Add disable button
  • Add uninstall button
  • Tons of improvements, not practical to list all 😃

v3.1

  • Fix online repo inaccessible issue
  • Fix repo list card expanding issues
  • Change SafetyNet check to manually triggered
  • Update translations
  • Tons of bug fixes preventing potential crashes

v3.0

  • Now on Play Store
  • Add Status Section, you can check Safety Net, root status, and Magisk status in one place
  • Add Install Section, you can manually choose the boot image location and advanced options

v2.5

  • Add Magisk Hide section, you can now add/remove apps from Magisk Hide list
  • Support custom Magisk Version names, any string is now accepted (for custom builds)
  • Fixed modules and repos not sorted by name

v2.1

  • Add Magisk Hide settings
  • Add search bar in "Downloads Sections"
  • Fix crashes when no root is available
  • Fix trash can icon not updated when removing module
  • Prevent crash when Magisk Version is set incorrectly

v2.0

  • Massive refactor
  • Material Design
  • Module Management
  • Download Section
  • And much more....

v1.0

  • 初始版本

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/boot.html b/boot.html index d104e9bd..8150b899 100644 --- a/boot.html +++ b/boot.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

Android 引导诡计

术语

  • rootdir:根目录 (/)。所有 文件、文件夹或文件系统 都存储在 rootdir 中或挂载在 rootdir 下。在 Android 上,文件系统可以是 rootfssystem 分区。
  • initramfs:Android 启动映像中的一个部分,Linux 内核将使用它作为rootfs。人们也可以使用术语 ramdisk
  • recoveryboot 分区:这两个实际上非常相似:都是包含 ramdisk 和 Linux 内核的 Android 启动映像(加上其他一些东西)。 唯一的区别是,启动 boot 分区将把我们带到 Android,而 recovery 有一个用于修复和升级设备的极简自带 Linux 环境。
  • SAR:系统作为根(System-as-root)。也就是说,设备使用 system 作为rootdir,而不是 rootfs
  • A/B, A-only:对于支持无缝系统更新的设备,它将具有所有只读分区的2个插槽(partition);我们称这些为A/B设备。为了区分,非A/B设备将称为A-only
  • 2SI:两阶段初始化。Android 10+ 的启动方式。稍后提供更多信息。

以下是一些参数,可帮助您更精确地定义设备的 Android 版本:

  • LV:推出版本。设备推出时使用的安卓版本。也就是说,设备首次上市时预装的 Android 版本。
  • RV:运行版本。设备当前运行的 Android 版本。

我们将使用 Android API 级别 来表示 LV 和 RV 。API 级别和 Android 版本之间的映射可以在 (https://source.android.google.cn/setup/start/build-numbers#platform-code-names-versions-api-levels-and-ndk-releases) 中看到。例如:Pixel XL 随 Android 7.1 发布,并运行 Android 10,这些参数将为 (LV = 25, RV = 29)

引导方法

Android 启动可以大致分为 3 种主要的不同方法。我们提供了一个一般的经验法则,以确定您的设备最有可能使用哪种方法,但例外情况单独列出。

方法初始根目录最终根目录
Arootfsrootfs
Bsystemsystem
Crootfssystem
  • 方法 A - 传统 ramdisk:这是所有 Android 设备过去启动的方式(过去的美好时光)。内核使用 initramfs 作为 rootdir,exec /init 来引导。
    • 不属于方法 B 和 C 标准中的设备
  • 方法 B - 传统 SAR:此方法首次出现在 Pixel 1 上。内核直接挂载 system 分区作为 rootdir 并且 exec /init 来引导。
    • 具有 (LV = 28) 的设备
    • 谷歌:Pixel 1 和 2。Pixel3 和 3a 为 (RV = 28)
    • 一加:6 - 7
    • 也许一些 (LV < 29) Android Go 设备?
  • 方法 C - 2SI ramdisk SAR:此方法首次出现在 Pixel 3 Android 10 开发者预览版中。内核使用 initramfs 作为 rootdir,在 rootfs 中使用 exec /init。这个 init 负责挂载 system 分区并将其用作新的 rootdir,最后执行 /system/bin/init 来引导。
    • 具有 (LV >= 29) 的设备
    • 具有 (LV < 28, RV >= 29) 的设备,不包括已在使用方法 B 的设备
    • 谷歌:Pixel 3 和 3a 为 (RV >= 29)

讨论

从文档来看,谷歌对 SAR 的定义只考虑了内核如何引导设备(上表中的初始根目录),这意味着从谷歌的角度来看,只有使用方法B的设备才被正式视为 SAR 设备。

然而,对于 Magisk 来说,真正的区别在于设备在完全启动时使用的是什么(上表中的最终根目录),这意味着就 Magisk 而言,方法 B 和方法 C 都是 SAR 的一种形式,但实施方式不同。除非另有特别说明,否则本文件后面提到的每一个 SAR 实例都将参考 Magisk 的定义

通俗地说,方法 C 的标准有点复杂:您的设备足够现代,可以使用 Android 10+ 启动,或者您在使用方法 A 的设备上运行 Android 10+ 第三方 ROM。

  • 任何运行 Android 10+ 的设备都将自动使用方法 C
  • 方法 B 设备卡在方法 B 上,唯一的例外是 Pixel 3 和 3a,Google 对设备进行了改造以适应新方法。

SAR 是 Project Treble 中非常重要的一部分,因为 rootdir 应该与平台绑定。这也是方法 B 和 C 带有 (LV >= ver) 标准的原因,因为谷歌每年都强制所有 OEM 遵守更新的要求。

一些历史

当谷歌发布第一代 Pixel 时,它还推出了 A/B(无缝)系统更新。由于存储大小问题,与仅 A 相比有几个区别,最相关的是删除 recovery 分区和 recovery ramdisk ,合并到boot中。

让我们回到 Google 第一次设计 A/B 的时候。如果使用 SAR(当时只有引导方法 B 存在),内核不需要 initramfs 来引导 Android(因为 rootdir 在 system 中)。这意味着我们可以很聪明,只需将 recovery ramdisk(包含极简的 Linux 环境)塞入 boot ,删除 recovery ,然后让内核根据引导加载程序的信息选择要使用的任何根目录(ramdisk 或 system)。

随着时间从 Android 7.1 到 Android 10 的流逝,谷歌推出了动态分区。这对 SAR 来说是个坏消息,因为 Linux 内核无法直接理解这种新的分区格式,因此无法直接将 system 挂载为 rootdir。这是他们想出引导方法 C 的时候:总是引导到 initramfs ,并让 userspace 处理其余的引导。这包括决定是否启动到 Android 或 recovery,或者他们正式称之为 USES_RECOVERY_AS_BOOT

一些使用带有 2SI 的 A/B 的现代设备还带有 recovery_a/_b 分区。谷歌的标准正式支持这一点。当 recovery 存储在单独的分区中时,这些设备将只使用 boot ramdisk 引导到 Android。

将事物拼凑在一起

有了上面的所有知识,现在我们可以将所有 Android 设备分类为以下不同类型:

类型引导方式分区2SIboot 里的 ramdisk
IAA-onlyNoboot ramdisk
IIBA/BAnyrecovery ramdisk
IIIBA-onlyAnyN/A
IVCAnyYes混合 ramdisk

这些类型按首次可用时的时间顺序排序。

  • I 类:好的旧传统 ramdisk 引导
  • II 类:旧版 A/B 设备。Pixel 1 是这种类型的第一个设备,同时也是第一个 A/B 和 SAR 设备。
  • III 类:2018年末-2019年仅限A级的设备就 Magisk 而言,这是迄今为止最糟糕的一种设备类型
  • IV 类:所有使用引导方法 C 的设备都是 IV 型设备。A/B IV 类 ramdisk 可以根据引导加载程序的信息启动到 Android 或 recovery;A-only IV 类 ramdisk 只能引导到 Android。

关于 III 类设备的更多详细信息:Magisk 始终安装在引导映像的 ramdisk 中。对于所有其他类型的设备,由于其 boot 分区包含 ramdisk,因此可以通过 Magisk app 或第三方 recovery 中的刷入 ZIP 修补引导映像来轻松安装 Magisk。然而,对于 III 型设备,它们仅限于将 Magisk 安装到 recovery 分区中。Magisk 在正常启动时无法运行;相反,III 类设备用户必须始终重新启动到 recovery,以保持 Magisk 访问。

一些 III 类设备的引导加载程序仍然会接受并提供手动添加到内核“引导”映像中的 initramfs(例如一些小米手机),但许多设备不接受(例如三星 S10,Note 10)。这完全取决于 OEM 如何实现其引导加载程序。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

Android 引导诡计

术语

  • rootdir:根目录 (/)。所有 文件、文件夹或文件系统 都存储在 rootdir 中或挂载在 rootdir 下。在 Android 上,文件系统可以是 rootfssystem 分区。
  • initramfs:Android 启动映像中的一个部分,Linux 内核将使用它作为rootfs。人们也可以使用术语 ramdisk
  • recoveryboot 分区:这两个实际上非常相似:都是包含 ramdisk 和 Linux 内核的 Android 启动映像(加上其他一些东西)。 唯一的区别是,启动 boot 分区将把我们带到 Android,而 recovery 有一个用于修复和升级设备的极简自带 Linux 环境。
  • SAR:系统作为根(System-as-root)。也就是说,设备使用 system 作为rootdir,而不是 rootfs
  • A/B, A-only:对于支持无缝系统更新的设备,它将具有所有只读分区的2个插槽(partition);我们称这些为A/B设备。为了区分,非A/B设备将称为A-only
  • 2SI:两阶段初始化。Android 10+ 的启动方式。稍后提供更多信息。

以下是一些参数,可帮助您更精确地定义设备的 Android 版本:

  • LV:推出版本。设备推出时使用的安卓版本。也就是说,设备首次上市时预装的 Android 版本。
  • RV:运行版本。设备当前运行的 Android 版本。

我们将使用 Android API 级别 来表示 LV 和 RV 。API 级别和 Android 版本之间的映射可以在 (https://source.android.google.cn/setup/start/build-numbers#platform-code-names-versions-api-levels-and-ndk-releases) 中看到。例如:Pixel XL 随 Android 7.1 发布,并运行 Android 10,这些参数将为 (LV = 25, RV = 29)

引导方法

Android 启动可以大致分为 3 种主要的不同方法。我们提供了一个一般的经验法则,以确定您的设备最有可能使用哪种方法,但例外情况单独列出。

方法初始根目录最终根目录
Arootfsrootfs
Bsystemsystem
Crootfssystem
  • 方法 A - 传统 ramdisk:这是所有 Android 设备过去启动的方式(过去的美好时光)。内核使用 initramfs 作为 rootdir,exec /init 来引导。
    • 不属于方法 B 和 C 标准中的设备
  • 方法 B - 传统 SAR:此方法首次出现在 Pixel 1 上。内核直接挂载 system 分区作为 rootdir 并且 exec /init 来引导。
    • 具有 (LV = 28) 的设备
    • 谷歌:Pixel 1 和 2。Pixel3 和 3a 为 (RV = 28)
    • 一加:6 - 7
    • 也许一些 (LV < 29) Android Go 设备?
  • 方法 C - 2SI ramdisk SAR:此方法首次出现在 Pixel 3 Android 10 开发者预览版中。内核使用 initramfs 作为 rootdir,在 rootfs 中使用 exec /init。这个 init 负责挂载 system 分区并将其用作新的 rootdir,最后执行 /system/bin/init 来引导。
    • 具有 (LV >= 29) 的设备
    • 具有 (LV < 28, RV >= 29) 的设备,不包括已在使用方法 B 的设备
    • 谷歌:Pixel 3 和 3a 为 (RV >= 29)

讨论

从文档来看,谷歌对 SAR 的定义只考虑了内核如何引导设备(上表中的初始根目录),这意味着从谷歌的角度来看,只有使用方法B的设备才被正式视为 SAR 设备。

然而,对于 Magisk 来说,真正的区别在于设备在完全启动时使用的是什么(上表中的最终根目录),这意味着就 Magisk 而言,方法 B 和方法 C 都是 SAR 的一种形式,但实施方式不同。除非另有特别说明,否则本文件后面提到的每一个 SAR 实例都将参考 Magisk 的定义

通俗地说,方法 C 的标准有点复杂:您的设备足够现代,可以使用 Android 10+ 启动,或者您在使用方法 A 的设备上运行 Android 10+ 第三方 ROM。

  • 任何运行 Android 10+ 的设备都将自动使用方法 C
  • 方法 B 设备卡在方法 B 上,唯一的例外是 Pixel 3 和 3a,Google 对设备进行了改造以适应新方法。

SAR 是 Project Treble 中非常重要的一部分,因为 rootdir 应该与平台绑定。这也是方法 B 和 C 带有 (LV >= ver) 标准的原因,因为谷歌每年都强制所有 OEM 遵守更新的要求。

一些历史

当谷歌发布第一代 Pixel 时,它还推出了 A/B(无缝)系统更新。由于存储大小问题,与仅 A 相比有几个区别,最相关的是删除 recovery 分区和 recovery ramdisk ,合并到boot中。

让我们回到 Google 第一次设计 A/B 的时候。如果使用 SAR(当时只有引导方法 B 存在),内核不需要 initramfs 来引导 Android(因为 rootdir 在 system 中)。这意味着我们可以很聪明,只需将 recovery ramdisk(包含极简的 Linux 环境)塞入 boot ,删除 recovery ,然后让内核根据引导加载程序的信息选择要使用的任何根目录(ramdisk 或 system)。

随着时间从 Android 7.1 到 Android 10 的流逝,谷歌推出了动态分区。这对 SAR 来说是个坏消息,因为 Linux 内核无法直接理解这种新的分区格式,因此无法直接将 system 挂载为 rootdir。这是他们想出引导方法 C 的时候:总是引导到 initramfs ,并让 userspace 处理其余的引导。这包括决定是否启动到 Android 或 recovery,或者他们正式称之为 USES_RECOVERY_AS_BOOT

一些使用带有 2SI 的 A/B 的现代设备还带有 recovery_a/_b 分区。谷歌的标准正式支持这一点。当 recovery 存储在单独的分区中时,这些设备将只使用 boot ramdisk 引导到 Android。

将事物拼凑在一起

有了上面的所有知识,现在我们可以将所有 Android 设备分类为以下不同类型:

类型引导方式分区2SIboot 里的 ramdisk
IAA-onlyNoboot ramdisk
IIBA/BAnyrecovery ramdisk
IIIBA-onlyAnyN/A
IVCAnyYes混合 ramdisk

这些类型按首次可用时的时间顺序排序。

  • I 类:好的旧传统 ramdisk 引导
  • II 类:旧版 A/B 设备。Pixel 1 是这种类型的第一个设备,同时也是第一个 A/B 和 SAR 设备。
  • III 类:2018年末-2019年仅限A级的设备就 Magisk 而言,这是迄今为止最糟糕的一种设备类型
  • IV 类:所有使用引导方法 C 的设备都是 IV 型设备。A/B IV 类 ramdisk 可以根据引导加载程序的信息启动到 Android 或 recovery;A-only IV 类 ramdisk 只能引导到 Android。

关于 III 类设备的更多详细信息:Magisk 始终安装在引导映像的 ramdisk 中。对于所有其他类型的设备,由于其 boot 分区包含 ramdisk,因此可以通过 Magisk app 或第三方 recovery 中的刷入 ZIP 修补引导映像来轻松安装 Magisk。然而,对于 III 型设备,它们仅限于将 Magisk 安装到 recovery 分区中。Magisk 在正常启动时无法运行;相反,III 类设备用户必须始终重新启动到 recovery,以保持 Magisk 访问。

一些 III 类设备的引导加载程序仍然会接受并提供手动添加到内核“引导”映像中的 initramfs(例如一些小米手机),但许多设备不接受(例如三星 S10,Note 10)。这完全取决于 OEM 如何实现其引导加载程序。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/build.html b/build.html index 64089367..d4fb8173 100644 --- a/build.html +++ b/build.html @@ -16,12 +16,12 @@ -
Skip to content
本页内容

构建和开发 Magisk

设置环境

  • 支持的平台:
    • Linux x64
    • macOS x64 (Intel)
    • macOS arm64 (Apple Silicon)
    • Windows x64
  • 仅 Windows: 启用开发者模式。因为需要支持符号链接。
  • 安装 Python 3.8+:
    • 在 Unix 上,使用您喜欢的软件包管理器安装 python3
    • 在 Windows 上,在官方网站上下载并安装 Python 最新的版本.
      请在安装过程中选择 “Add Python to PATH(将 Python 添加到 PATH)”
    • (在 Windows 上,可选):运行 pip install colorama 以安装 colorama python 包
  • 安装 Git:
    • 在 Unix 上,使用您喜欢的软件包管理器安装 git
    • 在 Windows 上,在官方网站上下载并安装最新的 Git 版本.
      请确保在安装过程前 “启用符号链接”
  • 安装 Android Studio 并按照说明进行初始设置。
  • 将环境变量 ANDROID_SDK_ROOT 设置为 Android SDK 文件夹。此路径可以在 Android Studio 设置中找到。
  • 设置 JDK:
    • 建议的选项是将环境变量 ANDROID_STUDIO 设置为 Android Studio 的安装路径。构建脚本将自动查找并使用捆绑的 JDK。
    • 您也可以自己设置 JDK 17,但本指南不包含说明。
  • 克隆源代码:
bash
git clone --recurse-submodules https://github.com/topjohnwu/Magisk.git
  • 运行 ./build.py ndk 让脚本下载并安装 NDK

构建

  • 要构建所有内容并创建最终的 Magisk APK,请运行 ./build.py all
  • 您还可以构建特定的子组件。调用 build.py 查看您的选项
    对于每个操作,使用 -h 访问帮助(例如 ./build.py binary -h
  • 使用 config.prop 配置构建。提供了示例 config.prop.sample

IDE 支持

  • Magisk 的存储库可以作为一个项目直接使用 Android Studio 打开。
  • 项目中的 Kotlin、Java、C++ 和 C 代码应该在 Android Studio 中得到开箱即用的适当支持。
  • 在处理原生(native)代码之前运行 ./build.py binary ,因为某些生成的代码仅在构建过程中创建。

在 Android Studio 中开发 Rust

由于 Magisk NDK 软件包 ONDK(与 ./build.py ndk 一起安装的软件包)包含一个完全独立的 Clang + Rust 工具链,因此单独构建 Magisk 项目不需要配置工具链。但是,由于 Intellij Rust 插件的工作方式,您必须进行一些额外的设置才能使 Android Studio 与 Magisk 的 Rust 代码库一起使用:

  • 安装官方 Rust 工具链管理器 rustup
  • 链接 ONDK Rust 工具链并将其设置为默认值:
bash
# 将 ONDK 工具链与名称“magisk”链接起来
+    
Skip to content
本页内容

构建和开发 Magisk

设置环境

  • 支持的平台:
    • Linux x64
    • macOS x64 (Intel)
    • macOS arm64 (Apple Silicon)
    • Windows x64
  • 仅 Windows: 启用开发者模式。因为需要支持符号链接。
  • 安装 Python 3.8+:
    • 在 Unix 上,使用您喜欢的软件包管理器安装 python3
    • 在 Windows 上,在官方网站上下载并安装 Python 最新的版本.
      请在安装过程中选择 “Add Python to PATH(将 Python 添加到 PATH)”
    • (在 Windows 上,可选):运行 pip install colorama 以安装 colorama python 包
  • 安装 Git:
    • 在 Unix 上,使用您喜欢的软件包管理器安装 git
    • 在 Windows 上,在官方网站上下载并安装最新的 Git 版本.
      请确保在安装过程前 “启用符号链接”
  • 安装 Android Studio 并按照说明进行初始设置。
  • 将环境变量 ANDROID_SDK_ROOT 设置为 Android SDK 文件夹。此路径可以在 Android Studio 设置中找到。
  • 设置 JDK:
    • 建议的选项是将环境变量 ANDROID_STUDIO 设置为 Android Studio 的安装路径。构建脚本将自动查找并使用捆绑的 JDK。
    • 您也可以自己设置 JDK 17,但本指南不包含说明。
  • 克隆源代码:
bash
git clone --recurse-submodules https://github.com/topjohnwu/Magisk.git
  • 运行 ./build.py ndk 让脚本下载并安装 NDK

构建

  • 要构建所有内容并创建最终的 Magisk APK,请运行 ./build.py all
  • 您还可以构建特定的子组件。调用 build.py 查看您的选项
    对于每个操作,使用 -h 访问帮助(例如 ./build.py binary -h
  • 使用 config.prop 配置构建。提供了示例 config.prop.sample

IDE 支持

  • Magisk 的存储库可以作为一个项目直接使用 Android Studio 打开。
  • 项目中的 Kotlin、Java、C++ 和 C 代码应该在 Android Studio 中得到开箱即用的适当支持。
  • 在处理原生(native)代码之前运行 ./build.py binary ,因为某些生成的代码仅在构建过程中创建。

在 Android Studio 中开发 Rust

由于 Magisk NDK 软件包 ONDK(与 ./build.py ndk 一起安装的软件包)包含一个完全独立的 Clang + Rust 工具链,因此单独构建 Magisk 项目不需要配置工具链。但是,由于 Intellij Rust 插件的工作方式,您必须进行一些额外的设置才能使 Android Studio 与 Magisk 的 Rust 代码库一起使用:

  • 安装官方 Rust 工具链管理器 rustup
  • 链接 ONDK Rust 工具链并将其设置为默认值:
bash
# 将 ONDK 工具链与名称“magisk”链接起来
 rustup toolchain link magisk "$ANDROID_SDK_ROOT/ndk/magisk/toolchains/rust"
 # 设置为默认
-rustup default magisk
  • 在 Android Studio 中安装 Intellij Rust 插件
  • 在 首选项(Preferences) > 语言和框架(Languages & Frameworks) > Rust 中,将 $ANDROID_SDK_ROOT/ndk/magisk/toolchains/rust/bin 设置为工具链位置
  • 打开 native/src/Cargo.toml ,然后在“未找到 Cargo 项目(No Cargo projects found)”横幅中选择“附加(Attach)”

签名和分发

  • 在发布版本中,Magisk 的 root 守护程序将使用对 Magisk APK 进行密钥签名的证书作为参考,拒绝并强制卸载任何不匹配的 Magisk 应用,保护用户免受恶意和未经验证的 Magisk APK 的侵害。
  • 要在 Magisk 本身上进行任何开发,请切换到 官方调试版本并重新安装 Magisk 以关闭签名检查。
  • 要分发使用您自己的密钥签名的自己的 Magisk 构建,请在 config.prop 中设置您的签名配置。
  • 查看 Google 的文档,了解有关生成自己的密钥的更多详细信息。

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +rustup default magisk
  • 在 Android Studio 中安装 Intellij Rust 插件
  • 在 首选项(Preferences) > 语言和框架(Languages & Frameworks) > Rust 中,将 $ANDROID_SDK_ROOT/ndk/magisk/toolchains/rust/bin 设置为工具链位置
  • 打开 native/src/Cargo.toml ,然后在“未找到 Cargo 项目(No Cargo projects found)”横幅中选择“附加(Attach)”

签名和分发

  • 在发布版本中,Magisk 的 root 守护程序将使用对 Magisk APK 进行密钥签名的证书作为参考,拒绝并强制卸载任何不匹配的 Magisk 应用,保护用户免受恶意和未经验证的 Magisk APK 的侵害。
  • 要在 Magisk 本身上进行任何开发,请切换到 官方调试版本并重新安装 Magisk 以关闭签名检查。
  • 要分发使用您自己的密钥签名的自己的 Magisk 构建,请在 config.prop 中设置您的签名配置。
  • 查看 Google 的文档,了解有关生成自己的密钥的更多详细信息。

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/changes.html b/changes.html index 6731200b..dc3c2308 100644 --- a/changes.html +++ b/changes.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

Magisk 更新日志

v26.1

  • [App] Fix crashing when revoking root permissions
  • [MagiskInit] Always prefer ext4 partitions over f2fs when selecting the pre-init partition
  • [General] Restore module files' context/owner/group from mirror. This is a regression introduced in v26.0

v26.0

  • [General] Bump minimum supported Android version to Android 6.0
  • [General] New magic mount backend. It supports loading modules into system with overlayfs files injected
  • [Zygisk] Release new API version 4
  • [Zygisk] Prevent crashing daemon in error
  • [Zygisk] Rewrite zygote code injection with new loader library approach
  • [Zygisk] Rewrite code unloading implementation
  • [MagiskBoot] Support amonet microloader devices
  • [MagiskBoot] Always use lz4_legacy compression on v4 boot images. This fixes boot image patching issues on Android U preview.
  • [MagiskInit] Support replacing existing *.rc files in overlay.d
  • [MagiskInit] Rewrite sepolicy.rules mounting and loading implementation
  • [App] Make stub patching 100% offline
  • [App] Support patching init_boot.img for Samsung ODIN firmware
  • [MagiskPolicy] Fix minor bug in command line argument parsing
  • [MagiskPolicy] Update rules to support Android U

v25.2

  • [MagiskInit] Fix a potential issue when stub cpio is used
  • [MagiskInit] Fix reboot to recovery when stub cpio is used
  • [MagiskInit] Fix sepolicy.rules symlink for rootfs devices
  • [General] Better data encryption detection
  • [General] Move the whole logging infrastructure into Rust

v25.1

  • [MagiskBoot] Fix ramdisk backup being incorrectly skipped
  • [MagiskBoot] Add new feature to detect unsupported dtb and abort during installation
  • [Zygisk] Change binary hijack paths
  • [App] Fix incorrect recovery mode detection and installation
  • [MagiskInit] Fix config not properly exported in legacy SAR devices
  • [General] Enforce the Magisk app to always match or be newer than magiskd

v25.0

  • [MagiskInit] Update 2SI implementation, significantly increase device compatibility (e.g. Sony Xperia devices)
  • [MagiskInit] Introduce new sepolicy injection mechanism
  • [MagiskInit] Support Oculus Go
  • [MagiskInit] Support Android 13 GKIs (Pixel 6)
  • [MagiskBoot] Fix vbmeta extraction implementation
  • [App] Fix stub app on older Android versions
  • [App] [MagiskSU] Properly support apps using sharedUserId
  • [MagiskSU] Fix a possible crash in magiskd
  • [MagiskSU] Prune unused UIDs as soon as system_server restarts to prevent UID reuse attacks
  • [MagiskSU] Verify and enforce the installed Magisk app's certificate to match the distributor's signature
  • [MagiskSU] [Zygisk] Proper package management and detection
  • [Zygisk] Fix function hooking on devices running Android 12 with old kernels
  • [Zygisk] Fix Zygisk's self code unloading implementation
  • [DenyList] Fix DenyList on shared UID apps
  • [BusyBox] Add workaround for devices running old kernels

v24.3

  • [General] Stop using getrandom syscall
  • [Zygisk] Update API to v3, adding new fields to AppSpecializeArgs
  • [App] Improve app repackaging installation workflow

v24.2

  • [MagiskSU] Fix buffer overflow
  • [MagiskSU] Fix owner managed multiuser superuser settings
  • [MagiskSU] Fix command logging when using su -c <cmd>
  • [MagiskSU] Prevent su request indefinite blocking
  • [MagiskBoot] Support lz4_legacy archive with multiple magic
  • [MagiskBoot] Fix lz4_lg compression
  • [DenyList] Allow targeting processes running as system UID
  • [Zygisk] Workaround Samsung's "early zygote"
  • [Zygisk] Improved Zygisk loading mechanism
  • [Zygisk] Fix application UID tracking
  • [Zygisk] Fix improper umask being set in zygote
  • [App] Fix BusyBox execution test
  • [App] Improve stub loading mechanism
  • [App] Major app upgrade flow improvements
  • [General] Improve commandline error handling and messaging

v24.1

  • [App] Stability improvements

v24.0

  • [General] MagiskHide is removed from Magisk
  • [General] Support Android 12
  • [General] Support devices that do not support 32-bit and only runs 64-bit code
  • [General] Update BusyBox to 1.34.1
  • [Zygisk] Introduce new feature: Zygisk
  • [Zygisk] Introduce DenyList feature to revert Magisk features in user selected processes
  • [MagiskBoot] Support patching 32-bit kernel zImages
  • [MagiskBoot] Support boot image header v4
  • [MagiskBoot] Support patching out skip_initramfs from dtb bootargs
  • [MagiskBoot] Add new env variable PATCHVBMETAFLAG to configure whether vbmeta flags should be patched
  • [MagiskInit] Support loading fstab from /system/etc (required for Pixel 6)
  • [MagiskInit] Support /proc/bootconfig for loading boot configurations
  • [MagiskInit] Better support for some Meizu devices
  • [MagiskInit] Better support for some OnePlus/Oppo/Realme devices
  • [MagiskInit] Support init.real on some Sony devices
  • [MagiskInit] Skip loading Magisk when detecting DSU
  • [MagiskPolicy] Load *_compat_cil_file from system_ext
  • [MagiskSU] Use isolated devpts if the kernel supports it
  • [MagiskSU] Fix root shell if isolated mount namespace is set
  • [resetprop] Deleted properties are now wiped from memory instead of just unlinking
  • [App] Build a single APK for all ABIs
  • [App] Switch to use standard bottom navigation bar
  • [App] Downloading modules from the centralized Magisk-Modules-Repo is removed
  • [App] Support user configuration of boot image vbmeta patching
  • [App] Restore the ability to install Magisk on the other slot on some A/B devices
  • [App] Allow modules to specify an update URL for in-app update + install

v23.0

  • [App] Update snet extension. This fixes SafetyNet API errors.
  • [App] Fix a bug in the stub app that causes APK installation to fail
  • [App] Hide annoying errors in logs when hidden as stub
  • [App] Fix issues when patching ODIN tar files when the app is hidden
  • [General] Remove all pre Android 5.0 support
  • [General] Update BusyBox to use proper libc
  • [General] Fix C++ undefined behaviors
  • [General] Several sepolicy.rule copy/installation fixes
  • [MagiskPolicy] Remove unnecessary sepolicy rules
  • [MagiskHide] Update package and process name validation logic
  • [MagiskHide] Some changes that prevents zygote deadlock

v22.1

  • [App] Prevent multiple installation sessions running in parallel
  • [App] Prevent OutOfMemory crashes when checking boot signature on PXA boot images
  • [General] Proper cgroup migration implementation
  • [General] Rewrite log writer from scratch, should resolve any crashes and deadlocks
  • [General] Many scripts updates fixing regressions
  • [MagiskHide] Prevent possible deadlock when signal arrives
  • [MagiskHide] Partial match process names if necessary
  • [MagiskBoot] Preserve and patch AVB 2.0 structures/headers in boot images
  • [MagiskBoot] Properly strip out data encryption flags
  • [MagiskBoot] Prevent possible integer overflow
  • [MagiskInit] Fix sepolicy.rule mounting strategy
  • [resetprop] Always delete existing ro. props before updating. This will fix bootloops that could be caused by modifying device fingerprint properties.

v22.0

  • [General] Magisk and Magisk Manager is now merged into the same package!
  • [App] The term "Magisk Manager" is no longer used elsewhere. We refer it as the Magisk app.
  • [App] Support hiding the Magisk app with advanced technique (stub APK loading) on Android 5.0+ (it used to be 9.0+)
  • [App] Disallow re-packaging the Magisk app on devices lower than Android 5.0
  • [App] Detect and warn about multiple invalid states and provide instructions on how to resolve it
  • [MagiskHide] Fix a bug when stopping MagiskHide does not take effect
  • [MagiskBoot] Fix bug when unpacking lz4_lg compressed boot images
  • [MagiskInit] Support Galaxy S21 series
  • [MagiskSU] Fix incorrect APEX paths that caused libsqlite.so fail to load

v21.4

  • [MagiskSU] Fix su -c behavior that broke many root apps
  • [General] Properly handle read/write over sockets (the broken pipe issue)

v21.3

  • [MagiskInit] Avoid mounting f2fs userdata as it may result in kernel crashes. This shall fix a lot of bootloops
  • [MagiskBoot] Fix a minor header checksum bug for DHTB header and ASUS blob image formats
  • [MagiskHide] Allowing hiding isolated processes if the mount namespace is separated

v21.2

  • [MagiskInit] Detect 2SI after mounting system_root on legacy SAR devices
  • [General] Make sure post-fs-data scripts cannot block more than 35 seconds
  • [General] Fix the magisk --install-module command
  • [General] Trim Windows newline when reading files
  • [General] Directly log to file to prevent logcat weirdness
  • [MagiskBoot] Fix header dump/load for header v3 images

v21.1

  • [MagiskBoot] Support boot header v3 (Pixel 5 and 4a 5G)
  • [MagiskBoot] Distinguish lz4_lg and lz4_legacy (Pixel 5 and 4a 5G)
  • [MagiskBoot] Support vendor boot images (for dev, not relevant for Magisk installation)
  • [MagiskInit] Support kernel cmdline androidboot.fstab_suffix
  • [MagiskInit] Support kernel initialized dm-verity on legacy SAR
  • [General] Significantly broaden sepolicy.rule compatibility
  • [General] Add Magisk binaries to PATH when executing boot scripts
  • [General] Update --remove-modules command implementation
  • [General] Make Magisk properly survive after factory reset on Android 11
  • [MagiskSU] Add APEX package com.android.i18n to LD_LIBRARY_PATH when linking libsqlite.so
  • [MagiskHide] Support hiding apps installed in secondary users (e.g. work profile)
  • [MagiskHide] Make zygote detection more robust

v21.0

  • [General] Support Android 11 🎉
  • [General] Add Safe Mode detection. Disable all modules when the device is booting into Safe Mode.
  • [General] Increase post-fs-data mode timeout from 10 seconds to 40 seconds
  • [MagiskInit] Rewritten 2SI support from scratch
  • [MagiskInit] Support when no /sbin folder exists (Android 11)
  • [MagiskInit] Dump fstab from device-tree to rootfs and force init to use it for 2SI devices
  • [MagiskInit] Strip out AVB for 2SI as it may cause bootloop
  • [Modules] Rewritten module mounting logic from scratch
  • [MagiskSU] For Android 8.0+, a completely new policy setup is used. This reduces compromises in Android's sandbox, providing more policy isolation and better security for root users.
  • [MagiskSU] Isolated mount namespace will now first inherit from parent process, then isolate itself from the world
  • [MagiskSU] Update communication protocol with Magisk Manager to work with the hardened SELinux setup
  • [MagiskPolicy] Optimize match all rules. This will significantly reduce policy binary size and save memory and improve general kernel performance.
  • [MagiskPolicy] Support declaring new types and attributes
  • [MagiskPolicy] Make policy statement closer to stock *.te format. Please check updated documentation or magiskpolicy --help for more details.
  • [MagiskBoot] Support compressed extra blobs
  • [MagiskBoot] Pad boot images to original size with zeros
  • [MagiskHide] Manipulate additional vendor properties

v20.4

  • [MagiskInit] Fix potential bootloop in A-only 2SI devices
  • [MagiskInit] Properly support Tegra partition naming
  • [General] Load libsqlite.so dynamically, which removes the need to use wrapper scripts on Android 10+
  • [General] Detect API level with a fallback method on some devices
  • [General] Workaround possible bug in x86 kernel readlinkat system call
  • [BusyBox] Enable SELinux features. Add chcon/runcon etc., and '-Z' option to many applets
  • [BusyBox] Introduce standalone mode. More details in release notes
  • [MagiskHide] Disable MagiskHide by default
  • [MagiskHide] Add more potential detectable system properties
  • [MagiskHide] Add workaround for Xiaomi devices bootloop when MagiskHide is enabled on cross region ROMs
  • [MagiskBoot] Support patching special Motorolla DTB format
  • [MagiskPolicy] Support 'genfscon' sepolicy rules
  • [Scripts] Support NAND based boot images (character nodes in /dev/block)
  • [Scripts] Better addon.d (both v1 and v2) support
  • [Scripts] Support Lineage Recovery for Android 10+

v20.3

  • [MagiskBoot] Fix lz4_legacy decompression

v20.2

  • [MagiskSU] Properly handle communication between daemon and application (root request prompt)
  • [MagiskInit] Fix logging in kmsg
  • [MagiskBoot] Support patching dtb/dtbo partition formats
  • [General] Support pre-init sepolicy patch in modules
  • [Scripts] Update magisk stock image backup format

v20.1

  • [MagiskSU] Support component name agnostic communication (for stub APK)
  • [MagiskBoot] Set proper header_size in boot image headers (fix vbmeta error on Samsung devices)
  • [MagiskHide] Scan zygote multiple times
  • [MagiskInit] Support recovery images without /sbin/recovery binary. This will fix some A/B devices unable to boot to recovery after flashing Magisk
  • [General] Move acct to prevent daemon being killed
  • [General] Make sure "--remove-modules" will execute uninstall.sh after removal

v20.0

  • [MagiskBoot] Support inject/modify mnt_point value in DTB fstab
  • [MagiskBoot] Support patching QCDT
  • [MagiskBoot] Support patching DTBH
  • [MagiskBoot] Support patching PXA-DT
  • [MagiskInit] [2SI] Support non A/B setup (Android 10)
  • [MagiskHide] Fix bug that reject process names with ":"
  • [MagicMount] Fix a bug that cause /product mirror not created

v19.4

  • [MagiskInit] [SAR] Boot system-as-root devices with system mounted as /
  • [MagiskInit] [2SI] Support 2-stage-init for A/B devices (Pixel 3 Android 10)
  • [MagiskInit] [initramfs] Delay sbin overlay creation to post-fs-data
  • [MagiskInit] [SARCompat] Old system-as-root implementation is deprecated, no more future changes
  • [MagiskInit] Add overlay.d support for root directory overlay for new system-as-root implementation
  • [MagiskSU] Unblock all signals in root shells (fix bash on Android)
  • [MagicMount] Support replacing files in /product
  • [MagiskHide] Support Android 10's Zygote blastula pool
  • [MagiskHide] All random strings now also have random length
  • [MagiskBoot] Allow no recompression for ramdisk.cpio
  • [MagiskBoot] Support some weird Huawei boot images
  • [General] Add new --remove-modules command to remove modules without root in ADB shell
  • [General] Support Android 10 new APEX libraries (Project Mainline)

v19.3

  • [MagiskHide] Hugely improve process monitor implementation, hopefully should no longer cause 100% CPU and daemon crashes
  • [MagiskInit] Wait for partitions to be ready for early mount, should fix bootloops on a handful of devices
  • [MagiskInit] Support EROFS used in EMUI 9.1
  • [MagiskSU] Properly implement mount namespace isolation
  • [MagiskBoot] Proper checksum calculation for header v2

v19.2

  • [General] Fix uninstaller
  • [General] Fix bootloops on some devices with tmpfs mounting to /data
  • [MagiskInit] Add Kirin hi6250 support
  • [MagiskSU] Stop claiming device focus for su logging/notify if feasible. This fix issues with users locking Magisk Manager with app lock, and prevent video apps get messed up when an app is requesting root in the background.

v19.1

  • [General] Support recovery based Magisk
  • [General] Support Android Q Beta 2
  • [MagiskInit] New sbin overlay setup process for better compatibility
  • [MagiskInit] Allow long pressing volume up to boot to recovery in recovery mode
  • [MagicMount] Use proper system_root mirror
  • [MagicMount] Use self created device nodes for mirrors
  • [MagicMount] Do not allow adding new files/folders in partition root folder (e.g. /system or /vendor)

v19.0

  • [General] Remove usage of magisk.img
  • [General] Add 64 bit magisk binary for native 64 bit support
  • [General] Support A only system-as-root devices that released with Android 9.0
  • [General] Support non EXT4 system and vendor partitions
  • [MagiskHide] Use Zygote ptracing for monitoring new processes
  • [MagiskHide] Targets are now per-application component
  • [MagiskInit] Support Android Q (no logical partition support yet!)
  • [MagiskPolicy] Support Android Q new split sepolicy setup
  • [MagiskInit] Move sbin overlay creation from main daemon post-fs-data to early-init
  • [General] Service scripts now run in parallel
  • [MagiskInit] Directly inject magisk services to init.rc
  • [General] Use lzma2 compressed ramdisk in extreme conditions
  • [MagicMount] Clone attributes from original file if exists
  • [MagiskSU] Use ACTION_REBOOT intent to workaround some OEM broadcast restrictions
  • [General] Use skip_mount instead of auto_mount: from opt-in to opt-out

v18.1

  • [General] Support EMUI 9.0
  • [General] Support Kirin 960 devices
  • [General] Support down to Android 4.2
  • [General] Major code base modernization under-the-hood

v18.0

  • [General] Migrate all code base to C++
  • [General] Modify database natively instead of going through Magisk Manager
  • [General] Deprecate path /sbin/.core, please start using /sbin/.magisk
  • [General] Boot scripts are moved from <magisk_img>/.core/<stage>.d to /data/adb/<stage>.d
  • [General] Remove native systemless hosts (Magisk Manager is updated with a built-in systemless hosts module)
  • [General] Allow module post-fs-data.sh scripts to disable/remove modules
  • [MagiskHide] Use component names instead of process names as targets
  • [MagiskHide] Add procfs protection on SDK 24+ (Nougat)
  • [MagiskHide] Remove the folder /.backup to prevent detection
  • [MagiskHide] Hide list is now stored in database instead of raw textfile in images
  • [MagiskHide] Add "--status" option to CLI
  • [MagiskHide] Stop unmounting non-custom related mount points
  • [MagiskSU] Add FLAG_INCLUDE_STOPPED_PACKAGES in broadcasts to force wake Magisk Manager
  • [MagiskSU] Fix a bug causing SIGWINCH not properly detected
  • [MagiskPolicy] Support new av rules: type_change, type_member
  • [MagiskPolicy] Remove all AUDITDENY rules after patching sepolicy to log all denies for debugging
  • [MagiskBoot] Properly support extra_cmdline in boot headers
  • [MagiskBoot] Try to repair broken v1 boot image headers
  • [MagiskBoot] Add new CPIO command: "exists"

v17.3

  • [MagiskBoot] Support boot image header v1 (Pixel 3)
  • [MagiskSU] No more linked lists for caching su_info
  • [MagiskSU] Parse command-lines in client side and send only options to daemon
  • [MagiskSU] Early ACK to prevent client freezes and early denies
  • [Daemon] Prevent bootloops in situations where /data is mounted twice
  • [Daemon] Prevent logcat failures when /system/bin is magic mounting, could cause MagiskHide to fail
  • [Scripts] Switch hexpatch to remove Samsung Defex to a more general pattern
  • [Scripts] Update data encryption detection for better custom recovery support

v17.2

  • [ResetProp] Update to AOSP upstream to support serialized system properties
  • [MagiskInit] Randomize Magisk service names to prevent detection (e.g. FGO)
  • [MagiskSU] New communication scheme to communicate with Magisk Manager

v17.0/17.1

  • [General] Bring back install to inactive slot for OTAs on A/B devices
  • [Script] Remove system based root in addon.d
  • [Script] Add proper addon.d-v2 for preserving Magisk on custom ROMs on A/B devices
  • [Script] Enable KEEPVERITY when the device is using system_root_image
  • [Script] Add hexpatch to remove Samsung defex in new Oreo kernels
  • [Daemon] Support non ext4 filesystems for mirrors (system/vendor)
  • [MagiskSU] Make pts sockets always run in dev_pts secontext, providing all terminal emulator root shell the same power as adb shells
  • [MagiskHide] Kill all processes with same UID of the target to workaround OOS embryo optimization
  • [MagiskInit] Move all sepolicy patches pre-init to prevent Pixel 2 (XL) boot service breakdown

v16.7

  • [Scripts] Fix boot image patching errors on Android P (workaround the strengthened seccomp)
  • [MagiskHide] Support hardlink based ns proc mnt (old kernel support)
  • [Daemon] Fix permission of /dev/null after logcat commands, fix ADB on EMUI
  • [Daemon] Log fatal errors only on debug builds
  • [MagiskInit] Detect early mount partname from fstab in device tree

v16.6

  • [General] Add wrapper script to overcome weird LD_XXX flags set in apps
  • [General] Prevent bootloop when flashing Magisk after full wipe on FBE devices
  • [Scripts] Support patching DTB placed in extra sections in boot images (Samsung S9/S9+)
  • [Scripts] Add support for addon.d-v2 (untested)
  • [Scripts] Fix custom recovery console output in addon.d
  • [Scripts] Fallback to parsing sysfs for detecting block devices
  • [Daemon] Check whether a valid Magisk Manager is installed on boot, if not, install stub APK embedded in magiskinit
  • [Daemon] Check whether Magisk Manager is repackaged (hidden), and prevent malware from hijacking com.topjohnwu.magisk
  • [Daemon] Introduce new daemon: magisklogd, a dedicated daemon to handle all logcat related monitoring
  • [Daemon] Replace old invincible mode with handshake between magiskd and magisklogd, one will respawn the other if disconnected
  • [Daemon] Support GSI adbd bind mounting
  • [MagiskInit] Support detecting block names in upper case (Samsung)
  • [MagiskBoot] Check DTB headers to prevent false detections within kernel binary
  • [MagiskHide] Compare mount namespace with PPID to make sure the namespace is actually separated, fix root loss
  • [MagiskSU] Simplify su_info caching system, should use less resources and computing power
  • [MagiskSU] Reduce the amount of broadcasting to Magisk Manager
  • [ImgTool] Separate all ext4 image related operations to a new applet called "imgtool"
  • [ImgTool] Use precise free space calculation methods
  • [ImgTool] Use our own set of loop devices hidden along side with sbin tmpfs overlay. This not only eliminates another possible detection method, but also fixes apps that mount OBB files as loop devices (huge thanks to dev of Pzizz for reporting this issue)

v16.4

  • [Daemon] Directly check logcat command instead of detecting logd, should fix logging and MagiskHide on several Samsung devices
  • [Daemon] Fix startup Magisk Manager APK installation on Android P
  • [MagiskPolicy] Switch from AOSP u:r:su:s0 to u:r:magisk:s0 to prevent conflicts
  • [MagiskPolicy] Remove unnecessary sepolicy rules to reduce security penalty
  • [Daemon] Massive re-design /sbin tmpfs overlay and daemon start up
  • [MagiskInit] Remove magiskinit_daemon, the actual magisk daemon (magiskd) shall handle everything itself
  • [Daemon] Remove post-fs stage as it is very limited and also will not work on A/B devices; replaced with simple mount in post-fs-data, which will run ASAP even before the daemon is started
  • [General] Remove all 64-bit binaries as there is no point in using them; all binaries are now 32-bit only. Some weirdly implemented root apps might break (e.g. Tasker, already reported to the developer), but it is not my fault 😃
  • [resetprop] Add Protobuf encode/decode to support manipulating persist properties on Android P
  • [MagiskHide] Include app sub-services as hiding targets. This might significantly increase the amount of apps that could be properly hidden

v16.3

  • [General] Remove symlinks used for backwards compatibility
  • [MagiskBoot] Fix a small size calculation bug

v16.2

  • [General] Force use system binaries in handling ext4 images (fix module installation on Android P)
  • [MagiskHide] Change property state to disable if logd is disabled

v16.1

  • [MagiskBoot] Fix MTK boot image packaging
  • [MagiskBoot] Add more Nook/Acclaim headers support
  • [MagiskBoot] Support unpacking DTB with empty kernel image
  • [MagiskBoot] Update high compression mode detection logic
  • [Daemon] Support new mke2fs tool on Android P
  • [resetprop] Support Android P new property context files
  • [MagiskPolicy] Add new rules for Android P

v16.0

  • [MagiskInit] Support non skip_initramfs devices with slot suffix (Huawei Treble)
  • [MagiskPolicy] Add rules for Magisk Manager
  • [Compiler] Workaround an NDK compiler bug that causes bootloops

v15.4

  • [MagiskBoot] Support Samsung PXA, DHTB header images
  • [MagiskBoot] Support ASUS blob images
  • [MagiskBoot] Support Nook Green Loader images
  • [MagiskBoot] Support pure ramdisk images
  • [MagiskInit] Prevent OnePlus angela sepolicy_debug from loading
  • [MagiskInit] Obfuscate Magisk socket entry to prevent detection and security
  • [Daemon] Fix subfolders in /sbin shadowed by overlay
  • [Daemon] Obfuscate binary names to prevent naive detections
  • [Daemon] Check logd before force trying to start logcat in a loop

v15.3

  • [Daemon] Fix the bug that only one script would be executed in post-fs-data.d/service.d
  • [Daemon] Add MS_SILENT flag when mounting, should fix some devices that cannot mount magisk.img
  • [MagiskBoot] Fix potential segmentation fault when patching ramdisk, should fix some installation failures

v15.2

  • [MagiskBoot] Fix dtb verity patches, should fix dm-verity bootloops on newer devices placing fstabs in dtb
  • [MagiskPolicy] Add new rules for proper Samsung support, should fix MagiskHide
  • [MagiskInit] Support non skip_initramfs devices using split sepolicies (e.g. Zenfone 4 Oreo)
  • [Daemon] Use specific logcat buffers, some devices does not support all log buffers
  • [scripts] Update scripts to double check whether boot slot is available, some devices set a boot slot without A/B partitions

v15.1

  • [MagiskBoot] Fix faulty code in ramdisk patches which causes bootloops in some config and fstab format combos

v15.0

  • [Daemon] Fix the bug that Magisk cannot properly detect /data encryption state
  • [Daemon] Add merging /cache/magisk.img and /data/adb/magisk_merge.img support
  • [Daemon] Update to upstream libsepol to support cutting edge split policy custom ROM cil compilations

v14.6 (1468)

  • [General] Move all files into a safe location: /data/adb
  • [Daemon] New invincible implementation: use magiskinit_daemon to monitor sockets
  • [Daemon] Rewrite logcat monitor to be more efficient
  • [Daemon] Fix a bug where logcat monitor may spawn infinite logcat processes
  • [MagiskSU] Update su to work the same as proper Linux implementation: Initialize window size; all environment variables will be migrated (except HOME, SHELL, USER, LOGNAME, these will be set accordingly), "--preserve-environment" option will preserve all variables, including those four exceptions. Check the Linux su manpage for more info
  • [MagiskBoot] Massive refactor, rewrite all cpio operations and CLI
  • [MagiskInit][magiskboot] Support ramdisk high compression mode

v14.5 (1456)

  • [Magiskinit] Fix bootloop issues on several devices
  • [misc] Build binaries with NDK r10e, should get rid of the nasty linker warning when executing magisk

v14.5 (1455)

  • [Daemon] Moved internal path to /sbin/.core, new image mountpoint is /sbin/.core/img
  • [MagiskSU] Support switching package name, used when Magisk Manager is hidden
  • [MagiskHide] Add temporary /magisk removal
  • [MagiskHide] All changes above contributes to hiding from nasty apps like FGO and several banking apps
  • [Magiskinit] Use magiskinit for all devices (dynamic initramfs)
  • [Magiskinit] Fix Xiaomi A1 support
  • [Magiskinit] Add Pixel 2 (XL) support
  • [Magiskboot] Add support to remove avb-verity in dtbo.img
  • [Magiskboot] Fix typo in handling MTK boot image headers
  • [script] Along with updates in Magisk Manager, add support to sign boot images (AVB 1.0)
  • [script] Add dtbo.img backup and restore support
  • [misc] Many small adjustments to properly support old platforms like Android 5.0

v14.3 (1437)

  • [MagiskBoot] Fix Pixel C installation
  • [MagiskBoot] Handle special lz4_legacy format properly, should fix all LG devices
  • [Daemon] New universal logcat monitor is added, support plug-and-play to worker threads
  • [Daemon] Invincible mode: daemon will be restarted by init, everything should seamlessly through daemon restarts
  • [Daemon] Add new restorecon action, will go through and fix all Magisk files with selinux unlabeled to system_file context
  • [Daemon] Add brute-force image resizing mode, should prevent the notorious Samsung crappy resize2fs from affecting the result
  • [resetprop] Add new "-p" flag, used to toggle whether alter/access the actual persist storage for persist props

v14.2

  • [MagicMount] Clone attributes to tmpfs mountpoint, should fix massive module breakage

v14.1

  • [MagiskInit] Introduce a new init binary to support skip_initramfs devices (Pixel family)
  • [script] Fix typo in update-binary for x86 devices
  • [script] Fix stock boot image backup not moved to proper location
  • [script] Add functions to support A/B slot and skip_initramfs devices
  • [script] Detect Meizu boot blocks
  • [MagiskBoot] Add decompress zImage support
  • [MagiskBoot] Support extracting dtb appended to zImage block
  • [MagiskBoot] Support patching fstab within dtb
  • [Daemon/MagiskSU] Proper file based encryption support
  • [Daemon] Create core folders if not exist
  • [resetprop] Fix a bug which delete props won't remove persist props not in memory
  • [MagicMount] Remove usage of dummy folder, directly mount tmpfs and construct file structure skeleton in place

v14.0

  • [script] Simplify installation scripts
  • [script] Fix a bug causing backing up and restoring stock boot images failure
  • [script] Installation and uninstallation will migrate old or broken stock boot image backups to proper format
  • [script] Fix an issue with selabel setting in util_functions.sh on Lollipop
  • [rc script] Enable logd in post-fs to start logging as early as possible
  • [MagiskHide] magisk.img mounted is no longer a requirement Devices with issues mounting magisk.img can now run in proper core-only mode
  • [MagiskBoot] Add native function to extract stock SHA1 from ramdisk
  • [b64xz] New tool to extract compressed and encoded binary dumps in shell script
  • [busybox] Add busybox to Magisk source, and embed multi-arch busybox binary into update-binary shell script
  • [busybox] Busybox is added into PATH for all boot scripts (post-fs-data.d, service.d, and all module scripts)
  • [MagiskSU] Fully fix multiuser issues
  • [Magic Mount] Fix a typo in cloning attributes
  • [Daemon] Fix the daemon crashing when boot scripts opens a subshell
  • [Daemon] Adjustments to prevent stock Samsung kernel restrictions on exec system calls for binaries started from /data
  • [Daemon] Workaround on Samsung device with weird fork behaviors

v13.3

  • [MagiskHide] Update to bypass Google CTS (2017.7.17)
  • [resetprop] Properly support removing persist props
  • [uninstaller] Remove Magisk Manager and persist props

v13.2

  • [magiskpolicy] Fix magiskpolicy segfault on old Android versions, should fix tons of older devices that couldn't use v13.1
  • [MagiskHide] Set proper selinux context while re-linking /sbin to hide Magisk, should potentially fix many issues
  • [MagiskBoot] Change lzma compression encoder flag from LZMA_CHECK_CRC64 to LZMA_CHECK_CRC32, kernel only supports latter
  • [General] Core-only mode now properly mounts systemless hosts and magiskhide

v13.1

  • [General] Merge MagiskSU, magiskhide, resetprop, magiskpolicy into one binary
  • [General] Add Android O support (tested on DP3)
  • [General] Dynamic link libselinux.so, libsqlite.so from system to greatly reduce binary size
  • [General] Remove bundled busybox because it causes a lot of issues
  • [General] Unlock all block devices for read-write support instead of emmc only (just figured not all devices uses emmc lol)
  • [Scripts] Run all ext4 image operations through magisk binary in flash scripts
  • [Scripts] Updated scripts to use magisk native commands to increase compatibility
  • [Scripts] Add addon.d survival support
  • [Scripts] Introduce util_functions.sh, used as a global shell script function source for all kinds of installation
  • [MagiskBoot] Moved boot patch logic into magiskboot binary
  • [MagiskSU] Does not fork new process for each request, add new threads instead
  • [MagiskSU] Added multiuser support
  • [MagiskSU] Introduce new timeout queue mechanism, prevent performance hit with poorly written su apps
  • [MagiskSU] Multiple settings moved from prop detection to database
  • [MagiskSU] Add namespace mode option support
  • [MagiskSU] Add master-mount option
  • [resetprop] Updated to latest AOSP upstream, support props from 5.0 to Android O
  • [resetprop] Renamed all functions to prevent calling functions from external libc
  • [magiskpolicy] Updated libsepol from official SELinux repo
  • [magiskpolicy] Added xperm patching support (in order to make Android O work properly)
  • [magiskpolicy] Updated rules for Android O, and Liveboot support
  • [MagiskHide] Remove pseudo permissive mode, directly hide permissive status instead
  • [MagiskHide] Remove unreliable list file monitor, change to daemon request mode
  • [MagiskHide] MagiskHide is now enabled by default
  • [MagiskHide] Update unmount policies, passes CTS in SafetyNet!
  • [MagiskHide] Add more props for hiding
  • [MagiskHide] Remove background magiskhide daemon, spawn short life process for unmounting purpose
  • [Magic Mount] Ditched shell script based mounting, use proper C program to parse and mount files. Speed is SIGNIFICANTLY improved

v12.0

  • [General] Move most binaries into magisk.img (Samsung cannot run su daemon in /data)
  • [General] Move sepolicy live patch to late_start service This shall fix the long boot times, especially on Samsung devices
  • [General] Add Samsung RKP hexpatch back, should now work on Samsung stock kernels
  • [General] Fix installation with SuperSU
  • [MagiskHide] Support other logcat am_proc_start patterns
  • [MagiskHide] Change /sys/fs/selinux/enforce(policy) permissions if required Samsung devices cannot switch selinux states, if running on permissive custom kernel, the users will stuck at permissive If this scenario is detected, change permissions to hide the permissive state, leads to SafetyNet passes
  • [MagiskHide] Add built in prop rules to fake KNOX status Samsung apps requiring KNOX status to be 0x0 should now work (Samsung Pay not tested)
  • [MagiskHide] Remove all ro.build props, since they cause more issues than they benefit...
  • [MagiskBoot] Add lz4 legacy format support (most linux kernel using lz4 for compression is using this)
  • [MagiskBoot] Fix MTK kernels with MTK headers

v11.5/11.6

  • [Magic Mount] Fix mounting issues with devices that have separate /vendor partitions
  • [MagiskBoot] Whole new boot image patching tool, please check release note for more info
  • [magiskpolicy] Rename sepolicy-inject to magiskpolicy
  • [magiskpolicy] Update a rule to allow chcon everything properly
  • [MagiskHide] Prevent multirom crashes
  • [MagiskHide] Add patches for ro.debuggable, ro.secure, ro.build.type, ro.build.tags, ro.build.selinux
  • [MagiskHide] Change /sys/fs/selinux/enforce, /sys/fs/selinux/policy permissions for Samsung compatibility
  • [MagiskSU] Fix read-only partition mounting issues
  • [MagiskSU] Disable -cn option, the option will do nothing, preserved for compatibility

v11.1

  • [sepolicy-inject] Add missing messages
  • [magiskhide] Start MagiskHide with scripts

v11.0

  • [Magic Mount] Support replacing symlinks. Symlinks cannot be a target of a bind mounted, so they are treated the same as new files
  • [Magic Mount] Fix the issue when file/folder name contains spaces
  • [BusyBox] Updated to v1.26.2. Should fix the black screen issues of FlashFire
  • [resetprop] Support reading prop files that contains spaces in prop values
  • [MagiskSU] Adapt communication to Magisk Manager; stripped out unused data transfer
  • [MagiskSU] Implement SuperUser access option (Disable, APP only, ADB Only, APP & ADB) phh Superuser app has this option but the feature isn't implemented within the su binary
  • [MagiskSU] Fixed all issues with su -c "commands" (run commands with root) This feature is supposed to only allow one single option, but apparently adb shell su -c "command" doesn't work this way, and plenty of root apps don't follow the rule. The su binary will now consider everything after -c as a part of the command.
  • [MagiskSU] Removed legacy context hack for TiBack, what it currently does is slowing down the invocation
  • [MagiskSU] Preserve the current working directory after invoking su Previously phh superuser will change the path to /data/data after obtaining root shell. It will now stay in the same directory where you called su
  • [MagiskSU] Daemon now also runs in u:r:su:s0 context
  • [MagiskSU] Removed an unnecessary fork, reduce running processes and speed up the invocation
  • [MagiskSU] Add -cn option to the binary Not sure if this is still relevant, and also not sure if implemented correctly, but hey it's here
  • [sepolicy-inject] Complete re-write the command-line options, now nearly matches supolicy syntax
  • [sepolicy-inject] Support all matching mode for nearly every action (makes pseudo enforced possible)
  • [sepolicy-inject] Fixed an ancient bug that allocated memory isn't reset
  • [uninstaller] Now works as a independent script that can be executed at boot Fully support recovery with no /data access, Magisk uninstallation with Magisk Manager
  • [Addition] Busybox, MagiskHide, hosts settings can now be applied instantly; no reboots required
  • [Addition] Add post-fs-data.d and service.d
  • [Addition] Add option to disable Magisk (MagiskSU will still be started)

v10.2

  • [Magic Mount] Remove apps/priv-app from whitelist, should fix all crashes
  • [phh] Fix binary out-of-date issue
  • [scripts] Fix root disappear issue when upgrading within Magisk Manager

v10

  • [Magic Mount] Use a new way to mount system (vendor) mirrors
  • [Magic Mount] Use universal way to deal with /vendor, handle both separate partition or not
  • [Magic Mount] Adding anything to any place is now officially supported (including /system root and /vendor root)
  • [Magic Mount] Use symlinks for mirroring back if possible, reduce bind mounts for adding files
  • [Magisk Hide] Check init namespace, zygote namespace to prevent Magic Mount breakage (a.k.a root loss)
  • [Magisk Hide] Send SIGSTOP to pause target process ASAP to prevent crashing if unmounting too late
  • [Magisk Hide] Hiding should work under any conditions, including adding libs and /system root etc.
  • [phh] Root the device if no proper root detected
  • [phh] Move /sbin to /sbin_orig and link back, fix Samsung no-suid issue
  • [scripts] Improve SuperSU integration, now uses sukernel to patch ramdisk, support SuperSU built in ramdisk restore
  • [template] Add PROPFILE option to load system.prop

v9

  • [API Change] Remove the interface for post-fs modules
  • [resetprop] New tool "resetprop" is added to Magisk to replace most post-fs modules' functionality
  • [resetprop] Magisk will now patch "ro.boot.verifiedbootstate", "ro.boot.flash.locked", "ro.boot.veritymode" to bypass Safety Net
  • [Magic Mount] Move dummy skeleton / mirror / mountinfo filesystem tree to tmpfs
  • [Magic Mount] Rewritten dummy cloning mechanism from scratch, will result in minimal bind mounts, minimal file traversal, eliminate all possible issues that might happen in extreme cases
  • [Magic Mount] Adding new items to /system/bin, /system/vendor, /system/lib(64) is properly supported (devices with separate vendor partition is not supported yet)
  • [Magisk Hide] Rewritten from scratch, now run in daemon mode, proper list monitoring, proper mount detection, and maybe more.....
  • [Boot Image] Add support for Motorola boot image dtb, it shall now unpack correctly
  • [Uninstaller] Add removal of SuperSU custom patch script

v8

  • Add Magisk Hide to bypass SafetyNet
  • Improve SuperSU integration: no longer changes the SuperSU PATH
  • Support rc script entry points not located in init.rc

v7

  • Fully open source
  • Remove supolicy dependency, use my own sepolicy-injection
  • Run everything in its own selinux domain, should fix all selinux issues
  • Add Note 7 stock kernel hex patches
  • Add support to install Magisk in Magisk Manager
  • Add support for image merging for module flashing in Magisk Manager
  • Add root helpers for SuperSU auto module-ize and auto upgrading legacy phh superuser
  • New paths to toggle busybox, and support all root solutions
  • Remove root management API; both SuperSU and phh has their own superior solutions

v6

  • Fixed the algorithm for adding new files and dummy system
  • Updated the module template with a default permission, since people tend to forget them 😃

v5

  • Hotfix for older Android versions (detect policy before patching)
  • Update uninstaller to NOT uninstall Magisk Manager, since it cause problems

v4

  • Important: Uninstall v1 - v3 Magisk before upgrading with the uninstaller in the OP!!
  • Massive Rewrite Magisk Interface API! All previous mods are NOT compatible! Please download the latest version of the mods you use (root/xposed)
  • Mods are now installed independently in their own subfolder. This paves the way for future Magisk Manager versions to manage mods, just like how Xposed Modules are handled
  • Support small boot partition devices (Huawei devices)
  • Use minimal sepolicy patch in boot image for smaller ramdisk size. Live patch policies after bootup
  • Include updated open source sepolicy injection tool (source code available), support nearly all SuperSU supolicy tool's functionality

v3

  • Fix bootimg-extract for Exynos Samsung devices (thanks to @phhusson), should fix all Samsung device issues
  • Add supolicy back to patch sepolicy (stock Samsung do not accept permissive domain)
  • Update sepolicy-injection to patch su domain for Samsung devices to use phh's root
  • Update root disable method, using more aggressive approach
  • Use lazy unmount to unmount root from system, should fix some issues with custom roms
  • Use the highest possible compression rate for ramdisk, hope to fix some devices with no boot partition space
  • Detect boot partition space insufficient, will abort installer instead of breaking your device

v2

  • Fix verity patch. It should now work on all devices (might fix some of the unable-to-boot issues)
  • All scripts will now run in selinux permissive mode for maximum compatibility (this will NOT turn your device to permissive)
  • Add Nougat Developer Preview 5 support
  • Add systemless host support for AdBlock Apps (enabled by default)
  • Add support for new root disable method
  • Remove sepolicy patches that uses SuperSU's supolicy tool; it is now using a minimal set of modifications
  • Removed Magisk Manager in Magisk patch, it is now included in Magisk phh's superuser only

v1

  • Initial release

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

Magisk 更新日志

v26.1

  • [App] Fix crashing when revoking root permissions
  • [MagiskInit] Always prefer ext4 partitions over f2fs when selecting the pre-init partition
  • [General] Restore module files' context/owner/group from mirror. This is a regression introduced in v26.0

v26.0

  • [General] Bump minimum supported Android version to Android 6.0
  • [General] New magic mount backend. It supports loading modules into system with overlayfs files injected
  • [Zygisk] Release new API version 4
  • [Zygisk] Prevent crashing daemon in error
  • [Zygisk] Rewrite zygote code injection with new loader library approach
  • [Zygisk] Rewrite code unloading implementation
  • [MagiskBoot] Support amonet microloader devices
  • [MagiskBoot] Always use lz4_legacy compression on v4 boot images. This fixes boot image patching issues on Android U preview.
  • [MagiskInit] Support replacing existing *.rc files in overlay.d
  • [MagiskInit] Rewrite sepolicy.rules mounting and loading implementation
  • [App] Make stub patching 100% offline
  • [App] Support patching init_boot.img for Samsung ODIN firmware
  • [MagiskPolicy] Fix minor bug in command line argument parsing
  • [MagiskPolicy] Update rules to support Android U

v25.2

  • [MagiskInit] Fix a potential issue when stub cpio is used
  • [MagiskInit] Fix reboot to recovery when stub cpio is used
  • [MagiskInit] Fix sepolicy.rules symlink for rootfs devices
  • [General] Better data encryption detection
  • [General] Move the whole logging infrastructure into Rust

v25.1

  • [MagiskBoot] Fix ramdisk backup being incorrectly skipped
  • [MagiskBoot] Add new feature to detect unsupported dtb and abort during installation
  • [Zygisk] Change binary hijack paths
  • [App] Fix incorrect recovery mode detection and installation
  • [MagiskInit] Fix config not properly exported in legacy SAR devices
  • [General] Enforce the Magisk app to always match or be newer than magiskd

v25.0

  • [MagiskInit] Update 2SI implementation, significantly increase device compatibility (e.g. Sony Xperia devices)
  • [MagiskInit] Introduce new sepolicy injection mechanism
  • [MagiskInit] Support Oculus Go
  • [MagiskInit] Support Android 13 GKIs (Pixel 6)
  • [MagiskBoot] Fix vbmeta extraction implementation
  • [App] Fix stub app on older Android versions
  • [App] [MagiskSU] Properly support apps using sharedUserId
  • [MagiskSU] Fix a possible crash in magiskd
  • [MagiskSU] Prune unused UIDs as soon as system_server restarts to prevent UID reuse attacks
  • [MagiskSU] Verify and enforce the installed Magisk app's certificate to match the distributor's signature
  • [MagiskSU] [Zygisk] Proper package management and detection
  • [Zygisk] Fix function hooking on devices running Android 12 with old kernels
  • [Zygisk] Fix Zygisk's self code unloading implementation
  • [DenyList] Fix DenyList on shared UID apps
  • [BusyBox] Add workaround for devices running old kernels

v24.3

  • [General] Stop using getrandom syscall
  • [Zygisk] Update API to v3, adding new fields to AppSpecializeArgs
  • [App] Improve app repackaging installation workflow

v24.2

  • [MagiskSU] Fix buffer overflow
  • [MagiskSU] Fix owner managed multiuser superuser settings
  • [MagiskSU] Fix command logging when using su -c <cmd>
  • [MagiskSU] Prevent su request indefinite blocking
  • [MagiskBoot] Support lz4_legacy archive with multiple magic
  • [MagiskBoot] Fix lz4_lg compression
  • [DenyList] Allow targeting processes running as system UID
  • [Zygisk] Workaround Samsung's "early zygote"
  • [Zygisk] Improved Zygisk loading mechanism
  • [Zygisk] Fix application UID tracking
  • [Zygisk] Fix improper umask being set in zygote
  • [App] Fix BusyBox execution test
  • [App] Improve stub loading mechanism
  • [App] Major app upgrade flow improvements
  • [General] Improve commandline error handling and messaging

v24.1

  • [App] Stability improvements

v24.0

  • [General] MagiskHide is removed from Magisk
  • [General] Support Android 12
  • [General] Support devices that do not support 32-bit and only runs 64-bit code
  • [General] Update BusyBox to 1.34.1
  • [Zygisk] Introduce new feature: Zygisk
  • [Zygisk] Introduce DenyList feature to revert Magisk features in user selected processes
  • [MagiskBoot] Support patching 32-bit kernel zImages
  • [MagiskBoot] Support boot image header v4
  • [MagiskBoot] Support patching out skip_initramfs from dtb bootargs
  • [MagiskBoot] Add new env variable PATCHVBMETAFLAG to configure whether vbmeta flags should be patched
  • [MagiskInit] Support loading fstab from /system/etc (required for Pixel 6)
  • [MagiskInit] Support /proc/bootconfig for loading boot configurations
  • [MagiskInit] Better support for some Meizu devices
  • [MagiskInit] Better support for some OnePlus/Oppo/Realme devices
  • [MagiskInit] Support init.real on some Sony devices
  • [MagiskInit] Skip loading Magisk when detecting DSU
  • [MagiskPolicy] Load *_compat_cil_file from system_ext
  • [MagiskSU] Use isolated devpts if the kernel supports it
  • [MagiskSU] Fix root shell if isolated mount namespace is set
  • [resetprop] Deleted properties are now wiped from memory instead of just unlinking
  • [App] Build a single APK for all ABIs
  • [App] Switch to use standard bottom navigation bar
  • [App] Downloading modules from the centralized Magisk-Modules-Repo is removed
  • [App] Support user configuration of boot image vbmeta patching
  • [App] Restore the ability to install Magisk on the other slot on some A/B devices
  • [App] Allow modules to specify an update URL for in-app update + install

v23.0

  • [App] Update snet extension. This fixes SafetyNet API errors.
  • [App] Fix a bug in the stub app that causes APK installation to fail
  • [App] Hide annoying errors in logs when hidden as stub
  • [App] Fix issues when patching ODIN tar files when the app is hidden
  • [General] Remove all pre Android 5.0 support
  • [General] Update BusyBox to use proper libc
  • [General] Fix C++ undefined behaviors
  • [General] Several sepolicy.rule copy/installation fixes
  • [MagiskPolicy] Remove unnecessary sepolicy rules
  • [MagiskHide] Update package and process name validation logic
  • [MagiskHide] Some changes that prevents zygote deadlock

v22.1

  • [App] Prevent multiple installation sessions running in parallel
  • [App] Prevent OutOfMemory crashes when checking boot signature on PXA boot images
  • [General] Proper cgroup migration implementation
  • [General] Rewrite log writer from scratch, should resolve any crashes and deadlocks
  • [General] Many scripts updates fixing regressions
  • [MagiskHide] Prevent possible deadlock when signal arrives
  • [MagiskHide] Partial match process names if necessary
  • [MagiskBoot] Preserve and patch AVB 2.0 structures/headers in boot images
  • [MagiskBoot] Properly strip out data encryption flags
  • [MagiskBoot] Prevent possible integer overflow
  • [MagiskInit] Fix sepolicy.rule mounting strategy
  • [resetprop] Always delete existing ro. props before updating. This will fix bootloops that could be caused by modifying device fingerprint properties.

v22.0

  • [General] Magisk and Magisk Manager is now merged into the same package!
  • [App] The term "Magisk Manager" is no longer used elsewhere. We refer it as the Magisk app.
  • [App] Support hiding the Magisk app with advanced technique (stub APK loading) on Android 5.0+ (it used to be 9.0+)
  • [App] Disallow re-packaging the Magisk app on devices lower than Android 5.0
  • [App] Detect and warn about multiple invalid states and provide instructions on how to resolve it
  • [MagiskHide] Fix a bug when stopping MagiskHide does not take effect
  • [MagiskBoot] Fix bug when unpacking lz4_lg compressed boot images
  • [MagiskInit] Support Galaxy S21 series
  • [MagiskSU] Fix incorrect APEX paths that caused libsqlite.so fail to load

v21.4

  • [MagiskSU] Fix su -c behavior that broke many root apps
  • [General] Properly handle read/write over sockets (the broken pipe issue)

v21.3

  • [MagiskInit] Avoid mounting f2fs userdata as it may result in kernel crashes. This shall fix a lot of bootloops
  • [MagiskBoot] Fix a minor header checksum bug for DHTB header and ASUS blob image formats
  • [MagiskHide] Allowing hiding isolated processes if the mount namespace is separated

v21.2

  • [MagiskInit] Detect 2SI after mounting system_root on legacy SAR devices
  • [General] Make sure post-fs-data scripts cannot block more than 35 seconds
  • [General] Fix the magisk --install-module command
  • [General] Trim Windows newline when reading files
  • [General] Directly log to file to prevent logcat weirdness
  • [MagiskBoot] Fix header dump/load for header v3 images

v21.1

  • [MagiskBoot] Support boot header v3 (Pixel 5 and 4a 5G)
  • [MagiskBoot] Distinguish lz4_lg and lz4_legacy (Pixel 5 and 4a 5G)
  • [MagiskBoot] Support vendor boot images (for dev, not relevant for Magisk installation)
  • [MagiskInit] Support kernel cmdline androidboot.fstab_suffix
  • [MagiskInit] Support kernel initialized dm-verity on legacy SAR
  • [General] Significantly broaden sepolicy.rule compatibility
  • [General] Add Magisk binaries to PATH when executing boot scripts
  • [General] Update --remove-modules command implementation
  • [General] Make Magisk properly survive after factory reset on Android 11
  • [MagiskSU] Add APEX package com.android.i18n to LD_LIBRARY_PATH when linking libsqlite.so
  • [MagiskHide] Support hiding apps installed in secondary users (e.g. work profile)
  • [MagiskHide] Make zygote detection more robust

v21.0

  • [General] Support Android 11 🎉
  • [General] Add Safe Mode detection. Disable all modules when the device is booting into Safe Mode.
  • [General] Increase post-fs-data mode timeout from 10 seconds to 40 seconds
  • [MagiskInit] Rewritten 2SI support from scratch
  • [MagiskInit] Support when no /sbin folder exists (Android 11)
  • [MagiskInit] Dump fstab from device-tree to rootfs and force init to use it for 2SI devices
  • [MagiskInit] Strip out AVB for 2SI as it may cause bootloop
  • [Modules] Rewritten module mounting logic from scratch
  • [MagiskSU] For Android 8.0+, a completely new policy setup is used. This reduces compromises in Android's sandbox, providing more policy isolation and better security for root users.
  • [MagiskSU] Isolated mount namespace will now first inherit from parent process, then isolate itself from the world
  • [MagiskSU] Update communication protocol with Magisk Manager to work with the hardened SELinux setup
  • [MagiskPolicy] Optimize match all rules. This will significantly reduce policy binary size and save memory and improve general kernel performance.
  • [MagiskPolicy] Support declaring new types and attributes
  • [MagiskPolicy] Make policy statement closer to stock *.te format. Please check updated documentation or magiskpolicy --help for more details.
  • [MagiskBoot] Support compressed extra blobs
  • [MagiskBoot] Pad boot images to original size with zeros
  • [MagiskHide] Manipulate additional vendor properties

v20.4

  • [MagiskInit] Fix potential bootloop in A-only 2SI devices
  • [MagiskInit] Properly support Tegra partition naming
  • [General] Load libsqlite.so dynamically, which removes the need to use wrapper scripts on Android 10+
  • [General] Detect API level with a fallback method on some devices
  • [General] Workaround possible bug in x86 kernel readlinkat system call
  • [BusyBox] Enable SELinux features. Add chcon/runcon etc., and '-Z' option to many applets
  • [BusyBox] Introduce standalone mode. More details in release notes
  • [MagiskHide] Disable MagiskHide by default
  • [MagiskHide] Add more potential detectable system properties
  • [MagiskHide] Add workaround for Xiaomi devices bootloop when MagiskHide is enabled on cross region ROMs
  • [MagiskBoot] Support patching special Motorolla DTB format
  • [MagiskPolicy] Support 'genfscon' sepolicy rules
  • [Scripts] Support NAND based boot images (character nodes in /dev/block)
  • [Scripts] Better addon.d (both v1 and v2) support
  • [Scripts] Support Lineage Recovery for Android 10+

v20.3

  • [MagiskBoot] Fix lz4_legacy decompression

v20.2

  • [MagiskSU] Properly handle communication between daemon and application (root request prompt)
  • [MagiskInit] Fix logging in kmsg
  • [MagiskBoot] Support patching dtb/dtbo partition formats
  • [General] Support pre-init sepolicy patch in modules
  • [Scripts] Update magisk stock image backup format

v20.1

  • [MagiskSU] Support component name agnostic communication (for stub APK)
  • [MagiskBoot] Set proper header_size in boot image headers (fix vbmeta error on Samsung devices)
  • [MagiskHide] Scan zygote multiple times
  • [MagiskInit] Support recovery images without /sbin/recovery binary. This will fix some A/B devices unable to boot to recovery after flashing Magisk
  • [General] Move acct to prevent daemon being killed
  • [General] Make sure "--remove-modules" will execute uninstall.sh after removal

v20.0

  • [MagiskBoot] Support inject/modify mnt_point value in DTB fstab
  • [MagiskBoot] Support patching QCDT
  • [MagiskBoot] Support patching DTBH
  • [MagiskBoot] Support patching PXA-DT
  • [MagiskInit] [2SI] Support non A/B setup (Android 10)
  • [MagiskHide] Fix bug that reject process names with ":"
  • [MagicMount] Fix a bug that cause /product mirror not created

v19.4

  • [MagiskInit] [SAR] Boot system-as-root devices with system mounted as /
  • [MagiskInit] [2SI] Support 2-stage-init for A/B devices (Pixel 3 Android 10)
  • [MagiskInit] [initramfs] Delay sbin overlay creation to post-fs-data
  • [MagiskInit] [SARCompat] Old system-as-root implementation is deprecated, no more future changes
  • [MagiskInit] Add overlay.d support for root directory overlay for new system-as-root implementation
  • [MagiskSU] Unblock all signals in root shells (fix bash on Android)
  • [MagicMount] Support replacing files in /product
  • [MagiskHide] Support Android 10's Zygote blastula pool
  • [MagiskHide] All random strings now also have random length
  • [MagiskBoot] Allow no recompression for ramdisk.cpio
  • [MagiskBoot] Support some weird Huawei boot images
  • [General] Add new --remove-modules command to remove modules without root in ADB shell
  • [General] Support Android 10 new APEX libraries (Project Mainline)

v19.3

  • [MagiskHide] Hugely improve process monitor implementation, hopefully should no longer cause 100% CPU and daemon crashes
  • [MagiskInit] Wait for partitions to be ready for early mount, should fix bootloops on a handful of devices
  • [MagiskInit] Support EROFS used in EMUI 9.1
  • [MagiskSU] Properly implement mount namespace isolation
  • [MagiskBoot] Proper checksum calculation for header v2

v19.2

  • [General] Fix uninstaller
  • [General] Fix bootloops on some devices with tmpfs mounting to /data
  • [MagiskInit] Add Kirin hi6250 support
  • [MagiskSU] Stop claiming device focus for su logging/notify if feasible. This fix issues with users locking Magisk Manager with app lock, and prevent video apps get messed up when an app is requesting root in the background.

v19.1

  • [General] Support recovery based Magisk
  • [General] Support Android Q Beta 2
  • [MagiskInit] New sbin overlay setup process for better compatibility
  • [MagiskInit] Allow long pressing volume up to boot to recovery in recovery mode
  • [MagicMount] Use proper system_root mirror
  • [MagicMount] Use self created device nodes for mirrors
  • [MagicMount] Do not allow adding new files/folders in partition root folder (e.g. /system or /vendor)

v19.0

  • [General] Remove usage of magisk.img
  • [General] Add 64 bit magisk binary for native 64 bit support
  • [General] Support A only system-as-root devices that released with Android 9.0
  • [General] Support non EXT4 system and vendor partitions
  • [MagiskHide] Use Zygote ptracing for monitoring new processes
  • [MagiskHide] Targets are now per-application component
  • [MagiskInit] Support Android Q (no logical partition support yet!)
  • [MagiskPolicy] Support Android Q new split sepolicy setup
  • [MagiskInit] Move sbin overlay creation from main daemon post-fs-data to early-init
  • [General] Service scripts now run in parallel
  • [MagiskInit] Directly inject magisk services to init.rc
  • [General] Use lzma2 compressed ramdisk in extreme conditions
  • [MagicMount] Clone attributes from original file if exists
  • [MagiskSU] Use ACTION_REBOOT intent to workaround some OEM broadcast restrictions
  • [General] Use skip_mount instead of auto_mount: from opt-in to opt-out

v18.1

  • [General] Support EMUI 9.0
  • [General] Support Kirin 960 devices
  • [General] Support down to Android 4.2
  • [General] Major code base modernization under-the-hood

v18.0

  • [General] Migrate all code base to C++
  • [General] Modify database natively instead of going through Magisk Manager
  • [General] Deprecate path /sbin/.core, please start using /sbin/.magisk
  • [General] Boot scripts are moved from <magisk_img>/.core/<stage>.d to /data/adb/<stage>.d
  • [General] Remove native systemless hosts (Magisk Manager is updated with a built-in systemless hosts module)
  • [General] Allow module post-fs-data.sh scripts to disable/remove modules
  • [MagiskHide] Use component names instead of process names as targets
  • [MagiskHide] Add procfs protection on SDK 24+ (Nougat)
  • [MagiskHide] Remove the folder /.backup to prevent detection
  • [MagiskHide] Hide list is now stored in database instead of raw textfile in images
  • [MagiskHide] Add "--status" option to CLI
  • [MagiskHide] Stop unmounting non-custom related mount points
  • [MagiskSU] Add FLAG_INCLUDE_STOPPED_PACKAGES in broadcasts to force wake Magisk Manager
  • [MagiskSU] Fix a bug causing SIGWINCH not properly detected
  • [MagiskPolicy] Support new av rules: type_change, type_member
  • [MagiskPolicy] Remove all AUDITDENY rules after patching sepolicy to log all denies for debugging
  • [MagiskBoot] Properly support extra_cmdline in boot headers
  • [MagiskBoot] Try to repair broken v1 boot image headers
  • [MagiskBoot] Add new CPIO command: "exists"

v17.3

  • [MagiskBoot] Support boot image header v1 (Pixel 3)
  • [MagiskSU] No more linked lists for caching su_info
  • [MagiskSU] Parse command-lines in client side and send only options to daemon
  • [MagiskSU] Early ACK to prevent client freezes and early denies
  • [Daemon] Prevent bootloops in situations where /data is mounted twice
  • [Daemon] Prevent logcat failures when /system/bin is magic mounting, could cause MagiskHide to fail
  • [Scripts] Switch hexpatch to remove Samsung Defex to a more general pattern
  • [Scripts] Update data encryption detection for better custom recovery support

v17.2

  • [ResetProp] Update to AOSP upstream to support serialized system properties
  • [MagiskInit] Randomize Magisk service names to prevent detection (e.g. FGO)
  • [MagiskSU] New communication scheme to communicate with Magisk Manager

v17.0/17.1

  • [General] Bring back install to inactive slot for OTAs on A/B devices
  • [Script] Remove system based root in addon.d
  • [Script] Add proper addon.d-v2 for preserving Magisk on custom ROMs on A/B devices
  • [Script] Enable KEEPVERITY when the device is using system_root_image
  • [Script] Add hexpatch to remove Samsung defex in new Oreo kernels
  • [Daemon] Support non ext4 filesystems for mirrors (system/vendor)
  • [MagiskSU] Make pts sockets always run in dev_pts secontext, providing all terminal emulator root shell the same power as adb shells
  • [MagiskHide] Kill all processes with same UID of the target to workaround OOS embryo optimization
  • [MagiskInit] Move all sepolicy patches pre-init to prevent Pixel 2 (XL) boot service breakdown

v16.7

  • [Scripts] Fix boot image patching errors on Android P (workaround the strengthened seccomp)
  • [MagiskHide] Support hardlink based ns proc mnt (old kernel support)
  • [Daemon] Fix permission of /dev/null after logcat commands, fix ADB on EMUI
  • [Daemon] Log fatal errors only on debug builds
  • [MagiskInit] Detect early mount partname from fstab in device tree

v16.6

  • [General] Add wrapper script to overcome weird LD_XXX flags set in apps
  • [General] Prevent bootloop when flashing Magisk after full wipe on FBE devices
  • [Scripts] Support patching DTB placed in extra sections in boot images (Samsung S9/S9+)
  • [Scripts] Add support for addon.d-v2 (untested)
  • [Scripts] Fix custom recovery console output in addon.d
  • [Scripts] Fallback to parsing sysfs for detecting block devices
  • [Daemon] Check whether a valid Magisk Manager is installed on boot, if not, install stub APK embedded in magiskinit
  • [Daemon] Check whether Magisk Manager is repackaged (hidden), and prevent malware from hijacking com.topjohnwu.magisk
  • [Daemon] Introduce new daemon: magisklogd, a dedicated daemon to handle all logcat related monitoring
  • [Daemon] Replace old invincible mode with handshake between magiskd and magisklogd, one will respawn the other if disconnected
  • [Daemon] Support GSI adbd bind mounting
  • [MagiskInit] Support detecting block names in upper case (Samsung)
  • [MagiskBoot] Check DTB headers to prevent false detections within kernel binary
  • [MagiskHide] Compare mount namespace with PPID to make sure the namespace is actually separated, fix root loss
  • [MagiskSU] Simplify su_info caching system, should use less resources and computing power
  • [MagiskSU] Reduce the amount of broadcasting to Magisk Manager
  • [ImgTool] Separate all ext4 image related operations to a new applet called "imgtool"
  • [ImgTool] Use precise free space calculation methods
  • [ImgTool] Use our own set of loop devices hidden along side with sbin tmpfs overlay. This not only eliminates another possible detection method, but also fixes apps that mount OBB files as loop devices (huge thanks to dev of Pzizz for reporting this issue)

v16.4

  • [Daemon] Directly check logcat command instead of detecting logd, should fix logging and MagiskHide on several Samsung devices
  • [Daemon] Fix startup Magisk Manager APK installation on Android P
  • [MagiskPolicy] Switch from AOSP u:r:su:s0 to u:r:magisk:s0 to prevent conflicts
  • [MagiskPolicy] Remove unnecessary sepolicy rules to reduce security penalty
  • [Daemon] Massive re-design /sbin tmpfs overlay and daemon start up
  • [MagiskInit] Remove magiskinit_daemon, the actual magisk daemon (magiskd) shall handle everything itself
  • [Daemon] Remove post-fs stage as it is very limited and also will not work on A/B devices; replaced with simple mount in post-fs-data, which will run ASAP even before the daemon is started
  • [General] Remove all 64-bit binaries as there is no point in using them; all binaries are now 32-bit only. Some weirdly implemented root apps might break (e.g. Tasker, already reported to the developer), but it is not my fault 😃
  • [resetprop] Add Protobuf encode/decode to support manipulating persist properties on Android P
  • [MagiskHide] Include app sub-services as hiding targets. This might significantly increase the amount of apps that could be properly hidden

v16.3

  • [General] Remove symlinks used for backwards compatibility
  • [MagiskBoot] Fix a small size calculation bug

v16.2

  • [General] Force use system binaries in handling ext4 images (fix module installation on Android P)
  • [MagiskHide] Change property state to disable if logd is disabled

v16.1

  • [MagiskBoot] Fix MTK boot image packaging
  • [MagiskBoot] Add more Nook/Acclaim headers support
  • [MagiskBoot] Support unpacking DTB with empty kernel image
  • [MagiskBoot] Update high compression mode detection logic
  • [Daemon] Support new mke2fs tool on Android P
  • [resetprop] Support Android P new property context files
  • [MagiskPolicy] Add new rules for Android P

v16.0

  • [MagiskInit] Support non skip_initramfs devices with slot suffix (Huawei Treble)
  • [MagiskPolicy] Add rules for Magisk Manager
  • [Compiler] Workaround an NDK compiler bug that causes bootloops

v15.4

  • [MagiskBoot] Support Samsung PXA, DHTB header images
  • [MagiskBoot] Support ASUS blob images
  • [MagiskBoot] Support Nook Green Loader images
  • [MagiskBoot] Support pure ramdisk images
  • [MagiskInit] Prevent OnePlus angela sepolicy_debug from loading
  • [MagiskInit] Obfuscate Magisk socket entry to prevent detection and security
  • [Daemon] Fix subfolders in /sbin shadowed by overlay
  • [Daemon] Obfuscate binary names to prevent naive detections
  • [Daemon] Check logd before force trying to start logcat in a loop

v15.3

  • [Daemon] Fix the bug that only one script would be executed in post-fs-data.d/service.d
  • [Daemon] Add MS_SILENT flag when mounting, should fix some devices that cannot mount magisk.img
  • [MagiskBoot] Fix potential segmentation fault when patching ramdisk, should fix some installation failures

v15.2

  • [MagiskBoot] Fix dtb verity patches, should fix dm-verity bootloops on newer devices placing fstabs in dtb
  • [MagiskPolicy] Add new rules for proper Samsung support, should fix MagiskHide
  • [MagiskInit] Support non skip_initramfs devices using split sepolicies (e.g. Zenfone 4 Oreo)
  • [Daemon] Use specific logcat buffers, some devices does not support all log buffers
  • [scripts] Update scripts to double check whether boot slot is available, some devices set a boot slot without A/B partitions

v15.1

  • [MagiskBoot] Fix faulty code in ramdisk patches which causes bootloops in some config and fstab format combos

v15.0

  • [Daemon] Fix the bug that Magisk cannot properly detect /data encryption state
  • [Daemon] Add merging /cache/magisk.img and /data/adb/magisk_merge.img support
  • [Daemon] Update to upstream libsepol to support cutting edge split policy custom ROM cil compilations

v14.6 (1468)

  • [General] Move all files into a safe location: /data/adb
  • [Daemon] New invincible implementation: use magiskinit_daemon to monitor sockets
  • [Daemon] Rewrite logcat monitor to be more efficient
  • [Daemon] Fix a bug where logcat monitor may spawn infinite logcat processes
  • [MagiskSU] Update su to work the same as proper Linux implementation: Initialize window size; all environment variables will be migrated (except HOME, SHELL, USER, LOGNAME, these will be set accordingly), "--preserve-environment" option will preserve all variables, including those four exceptions. Check the Linux su manpage for more info
  • [MagiskBoot] Massive refactor, rewrite all cpio operations and CLI
  • [MagiskInit][magiskboot] Support ramdisk high compression mode

v14.5 (1456)

  • [Magiskinit] Fix bootloop issues on several devices
  • [misc] Build binaries with NDK r10e, should get rid of the nasty linker warning when executing magisk

v14.5 (1455)

  • [Daemon] Moved internal path to /sbin/.core, new image mountpoint is /sbin/.core/img
  • [MagiskSU] Support switching package name, used when Magisk Manager is hidden
  • [MagiskHide] Add temporary /magisk removal
  • [MagiskHide] All changes above contributes to hiding from nasty apps like FGO and several banking apps
  • [Magiskinit] Use magiskinit for all devices (dynamic initramfs)
  • [Magiskinit] Fix Xiaomi A1 support
  • [Magiskinit] Add Pixel 2 (XL) support
  • [Magiskboot] Add support to remove avb-verity in dtbo.img
  • [Magiskboot] Fix typo in handling MTK boot image headers
  • [script] Along with updates in Magisk Manager, add support to sign boot images (AVB 1.0)
  • [script] Add dtbo.img backup and restore support
  • [misc] Many small adjustments to properly support old platforms like Android 5.0

v14.3 (1437)

  • [MagiskBoot] Fix Pixel C installation
  • [MagiskBoot] Handle special lz4_legacy format properly, should fix all LG devices
  • [Daemon] New universal logcat monitor is added, support plug-and-play to worker threads
  • [Daemon] Invincible mode: daemon will be restarted by init, everything should seamlessly through daemon restarts
  • [Daemon] Add new restorecon action, will go through and fix all Magisk files with selinux unlabeled to system_file context
  • [Daemon] Add brute-force image resizing mode, should prevent the notorious Samsung crappy resize2fs from affecting the result
  • [resetprop] Add new "-p" flag, used to toggle whether alter/access the actual persist storage for persist props

v14.2

  • [MagicMount] Clone attributes to tmpfs mountpoint, should fix massive module breakage

v14.1

  • [MagiskInit] Introduce a new init binary to support skip_initramfs devices (Pixel family)
  • [script] Fix typo in update-binary for x86 devices
  • [script] Fix stock boot image backup not moved to proper location
  • [script] Add functions to support A/B slot and skip_initramfs devices
  • [script] Detect Meizu boot blocks
  • [MagiskBoot] Add decompress zImage support
  • [MagiskBoot] Support extracting dtb appended to zImage block
  • [MagiskBoot] Support patching fstab within dtb
  • [Daemon/MagiskSU] Proper file based encryption support
  • [Daemon] Create core folders if not exist
  • [resetprop] Fix a bug which delete props won't remove persist props not in memory
  • [MagicMount] Remove usage of dummy folder, directly mount tmpfs and construct file structure skeleton in place

v14.0

  • [script] Simplify installation scripts
  • [script] Fix a bug causing backing up and restoring stock boot images failure
  • [script] Installation and uninstallation will migrate old or broken stock boot image backups to proper format
  • [script] Fix an issue with selabel setting in util_functions.sh on Lollipop
  • [rc script] Enable logd in post-fs to start logging as early as possible
  • [MagiskHide] magisk.img mounted is no longer a requirement Devices with issues mounting magisk.img can now run in proper core-only mode
  • [MagiskBoot] Add native function to extract stock SHA1 from ramdisk
  • [b64xz] New tool to extract compressed and encoded binary dumps in shell script
  • [busybox] Add busybox to Magisk source, and embed multi-arch busybox binary into update-binary shell script
  • [busybox] Busybox is added into PATH for all boot scripts (post-fs-data.d, service.d, and all module scripts)
  • [MagiskSU] Fully fix multiuser issues
  • [Magic Mount] Fix a typo in cloning attributes
  • [Daemon] Fix the daemon crashing when boot scripts opens a subshell
  • [Daemon] Adjustments to prevent stock Samsung kernel restrictions on exec system calls for binaries started from /data
  • [Daemon] Workaround on Samsung device with weird fork behaviors

v13.3

  • [MagiskHide] Update to bypass Google CTS (2017.7.17)
  • [resetprop] Properly support removing persist props
  • [uninstaller] Remove Magisk Manager and persist props

v13.2

  • [magiskpolicy] Fix magiskpolicy segfault on old Android versions, should fix tons of older devices that couldn't use v13.1
  • [MagiskHide] Set proper selinux context while re-linking /sbin to hide Magisk, should potentially fix many issues
  • [MagiskBoot] Change lzma compression encoder flag from LZMA_CHECK_CRC64 to LZMA_CHECK_CRC32, kernel only supports latter
  • [General] Core-only mode now properly mounts systemless hosts and magiskhide

v13.1

  • [General] Merge MagiskSU, magiskhide, resetprop, magiskpolicy into one binary
  • [General] Add Android O support (tested on DP3)
  • [General] Dynamic link libselinux.so, libsqlite.so from system to greatly reduce binary size
  • [General] Remove bundled busybox because it causes a lot of issues
  • [General] Unlock all block devices for read-write support instead of emmc only (just figured not all devices uses emmc lol)
  • [Scripts] Run all ext4 image operations through magisk binary in flash scripts
  • [Scripts] Updated scripts to use magisk native commands to increase compatibility
  • [Scripts] Add addon.d survival support
  • [Scripts] Introduce util_functions.sh, used as a global shell script function source for all kinds of installation
  • [MagiskBoot] Moved boot patch logic into magiskboot binary
  • [MagiskSU] Does not fork new process for each request, add new threads instead
  • [MagiskSU] Added multiuser support
  • [MagiskSU] Introduce new timeout queue mechanism, prevent performance hit with poorly written su apps
  • [MagiskSU] Multiple settings moved from prop detection to database
  • [MagiskSU] Add namespace mode option support
  • [MagiskSU] Add master-mount option
  • [resetprop] Updated to latest AOSP upstream, support props from 5.0 to Android O
  • [resetprop] Renamed all functions to prevent calling functions from external libc
  • [magiskpolicy] Updated libsepol from official SELinux repo
  • [magiskpolicy] Added xperm patching support (in order to make Android O work properly)
  • [magiskpolicy] Updated rules for Android O, and Liveboot support
  • [MagiskHide] Remove pseudo permissive mode, directly hide permissive status instead
  • [MagiskHide] Remove unreliable list file monitor, change to daemon request mode
  • [MagiskHide] MagiskHide is now enabled by default
  • [MagiskHide] Update unmount policies, passes CTS in SafetyNet!
  • [MagiskHide] Add more props for hiding
  • [MagiskHide] Remove background magiskhide daemon, spawn short life process for unmounting purpose
  • [Magic Mount] Ditched shell script based mounting, use proper C program to parse and mount files. Speed is SIGNIFICANTLY improved

v12.0

  • [General] Move most binaries into magisk.img (Samsung cannot run su daemon in /data)
  • [General] Move sepolicy live patch to late_start service This shall fix the long boot times, especially on Samsung devices
  • [General] Add Samsung RKP hexpatch back, should now work on Samsung stock kernels
  • [General] Fix installation with SuperSU
  • [MagiskHide] Support other logcat am_proc_start patterns
  • [MagiskHide] Change /sys/fs/selinux/enforce(policy) permissions if required Samsung devices cannot switch selinux states, if running on permissive custom kernel, the users will stuck at permissive If this scenario is detected, change permissions to hide the permissive state, leads to SafetyNet passes
  • [MagiskHide] Add built in prop rules to fake KNOX status Samsung apps requiring KNOX status to be 0x0 should now work (Samsung Pay not tested)
  • [MagiskHide] Remove all ro.build props, since they cause more issues than they benefit...
  • [MagiskBoot] Add lz4 legacy format support (most linux kernel using lz4 for compression is using this)
  • [MagiskBoot] Fix MTK kernels with MTK headers

v11.5/11.6

  • [Magic Mount] Fix mounting issues with devices that have separate /vendor partitions
  • [MagiskBoot] Whole new boot image patching tool, please check release note for more info
  • [magiskpolicy] Rename sepolicy-inject to magiskpolicy
  • [magiskpolicy] Update a rule to allow chcon everything properly
  • [MagiskHide] Prevent multirom crashes
  • [MagiskHide] Add patches for ro.debuggable, ro.secure, ro.build.type, ro.build.tags, ro.build.selinux
  • [MagiskHide] Change /sys/fs/selinux/enforce, /sys/fs/selinux/policy permissions for Samsung compatibility
  • [MagiskSU] Fix read-only partition mounting issues
  • [MagiskSU] Disable -cn option, the option will do nothing, preserved for compatibility

v11.1

  • [sepolicy-inject] Add missing messages
  • [magiskhide] Start MagiskHide with scripts

v11.0

  • [Magic Mount] Support replacing symlinks. Symlinks cannot be a target of a bind mounted, so they are treated the same as new files
  • [Magic Mount] Fix the issue when file/folder name contains spaces
  • [BusyBox] Updated to v1.26.2. Should fix the black screen issues of FlashFire
  • [resetprop] Support reading prop files that contains spaces in prop values
  • [MagiskSU] Adapt communication to Magisk Manager; stripped out unused data transfer
  • [MagiskSU] Implement SuperUser access option (Disable, APP only, ADB Only, APP & ADB) phh Superuser app has this option but the feature isn't implemented within the su binary
  • [MagiskSU] Fixed all issues with su -c "commands" (run commands with root) This feature is supposed to only allow one single option, but apparently adb shell su -c "command" doesn't work this way, and plenty of root apps don't follow the rule. The su binary will now consider everything after -c as a part of the command.
  • [MagiskSU] Removed legacy context hack for TiBack, what it currently does is slowing down the invocation
  • [MagiskSU] Preserve the current working directory after invoking su Previously phh superuser will change the path to /data/data after obtaining root shell. It will now stay in the same directory where you called su
  • [MagiskSU] Daemon now also runs in u:r:su:s0 context
  • [MagiskSU] Removed an unnecessary fork, reduce running processes and speed up the invocation
  • [MagiskSU] Add -cn option to the binary Not sure if this is still relevant, and also not sure if implemented correctly, but hey it's here
  • [sepolicy-inject] Complete re-write the command-line options, now nearly matches supolicy syntax
  • [sepolicy-inject] Support all matching mode for nearly every action (makes pseudo enforced possible)
  • [sepolicy-inject] Fixed an ancient bug that allocated memory isn't reset
  • [uninstaller] Now works as a independent script that can be executed at boot Fully support recovery with no /data access, Magisk uninstallation with Magisk Manager
  • [Addition] Busybox, MagiskHide, hosts settings can now be applied instantly; no reboots required
  • [Addition] Add post-fs-data.d and service.d
  • [Addition] Add option to disable Magisk (MagiskSU will still be started)

v10.2

  • [Magic Mount] Remove apps/priv-app from whitelist, should fix all crashes
  • [phh] Fix binary out-of-date issue
  • [scripts] Fix root disappear issue when upgrading within Magisk Manager

v10

  • [Magic Mount] Use a new way to mount system (vendor) mirrors
  • [Magic Mount] Use universal way to deal with /vendor, handle both separate partition or not
  • [Magic Mount] Adding anything to any place is now officially supported (including /system root and /vendor root)
  • [Magic Mount] Use symlinks for mirroring back if possible, reduce bind mounts for adding files
  • [Magisk Hide] Check init namespace, zygote namespace to prevent Magic Mount breakage (a.k.a root loss)
  • [Magisk Hide] Send SIGSTOP to pause target process ASAP to prevent crashing if unmounting too late
  • [Magisk Hide] Hiding should work under any conditions, including adding libs and /system root etc.
  • [phh] Root the device if no proper root detected
  • [phh] Move /sbin to /sbin_orig and link back, fix Samsung no-suid issue
  • [scripts] Improve SuperSU integration, now uses sukernel to patch ramdisk, support SuperSU built in ramdisk restore
  • [template] Add PROPFILE option to load system.prop

v9

  • [API Change] Remove the interface for post-fs modules
  • [resetprop] New tool "resetprop" is added to Magisk to replace most post-fs modules' functionality
  • [resetprop] Magisk will now patch "ro.boot.verifiedbootstate", "ro.boot.flash.locked", "ro.boot.veritymode" to bypass Safety Net
  • [Magic Mount] Move dummy skeleton / mirror / mountinfo filesystem tree to tmpfs
  • [Magic Mount] Rewritten dummy cloning mechanism from scratch, will result in minimal bind mounts, minimal file traversal, eliminate all possible issues that might happen in extreme cases
  • [Magic Mount] Adding new items to /system/bin, /system/vendor, /system/lib(64) is properly supported (devices with separate vendor partition is not supported yet)
  • [Magisk Hide] Rewritten from scratch, now run in daemon mode, proper list monitoring, proper mount detection, and maybe more.....
  • [Boot Image] Add support for Motorola boot image dtb, it shall now unpack correctly
  • [Uninstaller] Add removal of SuperSU custom patch script

v8

  • Add Magisk Hide to bypass SafetyNet
  • Improve SuperSU integration: no longer changes the SuperSU PATH
  • Support rc script entry points not located in init.rc

v7

  • Fully open source
  • Remove supolicy dependency, use my own sepolicy-injection
  • Run everything in its own selinux domain, should fix all selinux issues
  • Add Note 7 stock kernel hex patches
  • Add support to install Magisk in Magisk Manager
  • Add support for image merging for module flashing in Magisk Manager
  • Add root helpers for SuperSU auto module-ize and auto upgrading legacy phh superuser
  • New paths to toggle busybox, and support all root solutions
  • Remove root management API; both SuperSU and phh has their own superior solutions

v6

  • Fixed the algorithm for adding new files and dummy system
  • Updated the module template with a default permission, since people tend to forget them 😃

v5

  • Hotfix for older Android versions (detect policy before patching)
  • Update uninstaller to NOT uninstall Magisk Manager, since it cause problems

v4

  • Important: Uninstall v1 - v3 Magisk before upgrading with the uninstaller in the OP!!
  • Massive Rewrite Magisk Interface API! All previous mods are NOT compatible! Please download the latest version of the mods you use (root/xposed)
  • Mods are now installed independently in their own subfolder. This paves the way for future Magisk Manager versions to manage mods, just like how Xposed Modules are handled
  • Support small boot partition devices (Huawei devices)
  • Use minimal sepolicy patch in boot image for smaller ramdisk size. Live patch policies after bootup
  • Include updated open source sepolicy injection tool (source code available), support nearly all SuperSU supolicy tool's functionality

v3

  • Fix bootimg-extract for Exynos Samsung devices (thanks to @phhusson), should fix all Samsung device issues
  • Add supolicy back to patch sepolicy (stock Samsung do not accept permissive domain)
  • Update sepolicy-injection to patch su domain for Samsung devices to use phh's root
  • Update root disable method, using more aggressive approach
  • Use lazy unmount to unmount root from system, should fix some issues with custom roms
  • Use the highest possible compression rate for ramdisk, hope to fix some devices with no boot partition space
  • Detect boot partition space insufficient, will abort installer instead of breaking your device

v2

  • Fix verity patch. It should now work on all devices (might fix some of the unable-to-boot issues)
  • All scripts will now run in selinux permissive mode for maximum compatibility (this will NOT turn your device to permissive)
  • Add Nougat Developer Preview 5 support
  • Add systemless host support for AdBlock Apps (enabled by default)
  • Add support for new root disable method
  • Remove sepolicy patches that uses SuperSU's supolicy tool; it is now using a minimal set of modifications
  • Removed Magisk Manager in Magisk patch, it is now included in Magisk phh's superuser only

v1

  • Initial release

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/details.html b/details.html index 855732ae..a1ee6625 100644 --- a/details.html +++ b/details.html @@ -16,7 +16,7 @@ -
Skip to content
本页内容

内部细节

文档结构

“Magisk tmpfs 目录”中的路径

Magisk 将安装一个 tmpfs 目录来存储一些临时数据。对于带有 /sbin 文件夹的设备,将选择该文件夹,因为它还将充当将二进制文件注入 PATH 的覆盖层。从 Android 11 开始,/sbin 文件夹可能不存在,因此 Magisk 将在 /dev 下随机创建一个文件夹,并将其用作基本文件夹。

shell
# 为了获得Magisk正在使用的当前基本文件夹,使用命令 `magisk--path`。
+    
Skip to content
本页内容

内部细节

文档结构

“Magisk tmpfs 目录”中的路径

Magisk 将安装一个 tmpfs 目录来存储一些临时数据。对于带有 /sbin 文件夹的设备,将选择该文件夹,因为它还将充当将二进制文件注入 PATH 的覆盖层。从 Android 11 开始,/sbin 文件夹可能不存在,因此 Magisk 将在 /dev 下随机创建一个文件夹,并将其用作基本文件夹。

shell
# 为了获得Magisk正在使用的当前基本文件夹,使用命令 `magisk--path`。
 # 二进制文件,如 magisk、magiskinit 和所有小程序的符号链接直接存储
 # 在此路径中。这意味着当这是/sbin,这些二进制文件将直接在 PATH 中。
 MAGISKTMP=$(magisk --path)
@@ -63,8 +63,8 @@
 # 和 magisk 二进制文件。用于支持模块安装、addon.d、 
 # Magisk app 等。
 DATABIN=$SECURE_DIR/magisk

Magisk引导过程

预初始化(Pre-Init)

magiskinit 将替换 init 作为第一个运行的程序。

  • 挂载早期所需的分区。在已停产 system-as-root 设备上,我们将 root 切换到系统;在 2SI 设备上,我们修补原始的 init ,将第二阶段的 init 文件重定向到 magiskinit,并执行它为我们装载分区。
  • 将 magisk 服务注入 init.rc
  • 在使用 monolithic 策略的设备上,从 /sepolicy 加载 sepolicy ;否则我们使用 FIFO 劫持 selinuxfs 中的节点,将 LD_PRELOAD 设置为钩住 security_load_policy,并在 2SI 设备上协助劫持,然后启动守护程序,等待 init 尝试加载 sepolicy。
  • 修补 sepolicy 规则。如果我们使用“劫持”方法,将修补的 sepolicy 加载到内核中,取消阻止 init 并退出守护进程
  • 执行原始的 init 以继续启动过程

解密后(post-fs-data)

/data 被解密和装载时会在 post-fs-data 上触发。守护程序 magiskd 将被启动,执行 post-fs-data 脚本,并神奇地安装模块文件。

后期启动(late_start)

在稍后的引导过程中,将触发类 late_start ,并启动 Magisk “服务”模式。在此模式下,执行服务(service)脚本。

重置属性(Resetprop)

通常,系统属性(properties)被设计为仅由 init 更新,并且对非 root 进程是只读的。使用 root,您可以通过使用诸如 setprop 之类的命令向 property_service(由 init 托管)发送请求来更改属性,但仍然禁止更改只读属性(以ro.开头的属性,如ro.build.product)和删除属性。

resetprop 是通过从 AOSP 中提取出与系统属性相关的源代码来实现的,并进行了修补,以允许直接修改属性区域或 prop_area,而无需通过 property_service 。由于我们绕过了 property_service ,因此需要注意一些:

  • 如果属性更改未通过 property_service ,则不会触发在 *.rc 脚本中注册的on property:foo=bar 操作。resetprop 的默认设置属性行为与 setprop 匹配,这将触发事件(通过首先删除属性,然后通过 property_service 设置它来实现)。如果您需要此特殊行为,则有一个标志 -n 可以禁用它。
  • 持久属性(以 persist. 开头的属性,如 persist.sys.usb.config )存储在 prop_area/data/property 中。默认情况下,删除属性不会将其从持久存储中删除,这意味着该属性将在下次重新启动后恢复;读取属性不会从持久存储中读取,因为这是 getprop 的行为。使用标志 -p ,删除属性将同时删除 prop_area/data/property 中的属性,读取属性将从 prop_area 和持久存储中读取。

SELinux 政策

Magisk 将修补现成的 sepolicy ,以确保 Root 和 Magisk 操作能够以安全可靠的方式完成。新域 magisk 是有效的,这就是 magiskd 和所有 root shell 将在其中运行的内容。magisk_file 是一种新的文件类型,设置为允许每个域(不受限制的文件上下文)访问。

在 Android 8.0 之前,所有允许的 su 客户端域都可以直接连接到 magiskd 并与守护进程建立连接,以获得远程 root shell。Magisk 还必须放宽一些 ioctl 操作,以便 root shell 能够正常运行。

在 Android 8.0 之后,为了减少 Android 沙盒中规则的放宽,部署了新的 SELinux 模型。 magisk 二进制文件标记为 magisk_exec 文件类型,并且执行 magisk 二进制文件(包括 su 命令)的 su 客户端域将通过使用 type_transition 规则传输到 magisk_client 。规则严格限制仅允许 magisk 域进程将文件归因于 magisk_exec 。不允许直接连接到 magiskd 的 sockets;访问守护进程的唯一方法是通过 magisk_client 进程。这些更改使我们能够保持沙盒完好无损,并将 Magisk 特定规则与其他策略分开。

完整的规则可以在 magiskpolicy/rules.cpp 中找到。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- + \ No newline at end of file diff --git a/faq.html b/faq.html index 407648ce..ad0db195 100644 --- a/faq.html +++ b/faq.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

常见问题

Q: 我安装了一个模块,然后启动时卡在了开机动画。求助!

如果在开发人员选项中启用了USB调试,请将手机连接到 PC。如果检测到设备(通过 adb devices 检查),请进入 ADB shell 并运行命令 magisk --remove-modules。这将删除所有模块并自动重新启动设备。

如果您没有启用 USB 调试,请重新启动到安全模式。大多数现代 Android 设备都支持在启动时按特殊键组合键以进入安全模式作为紧急选项。Magisk 将检测到安全模式被激活,所有模块将被禁用。然后重启回到正常模式(模块禁用状态持续),并通过 Magisk App 管理模块。

提示

如果您不知道什么是 ADB shell ,那么请在电脑上直接运行以下命令

shell
adb shell magisk --remove-modules

如果您还不知道什么是 ADB ,那么请查看《Android 调试桥 (adb)》

Q: 为什么 XXX应用会检测到 Root?

Magisk 不再处理 Root 隐藏。有大量 Magisk/Zygisk 模块专门提供这些功能,请在网络上查找它们。😉(您可以在“酷安”或者“哔哩哔哩”中搜索)

比较流行的模块是 Shamiko

Q: 在我隐藏 Magisk App 后,应用图标显示异常。

当隐藏 Magisk App 时,它将安装一个“存根”APK,其中没有任何内容。这个存根应用程序的唯一功能是将完整的 Magisk app APK 下载到其内部存储并动态加载。由于APK实际上是 empty,因此它不包含 APP 的图标资源。

当您打开隐藏的 Magisk App 时,它将为您提供在主屏幕中创建快捷方式的选项(其中包含正确的应用名称和图标),以方便您使用。您还可以手动要求应用在应用设置中创建图标。

Q: 为什么这个文档很多错误或者不通顺的地方

这个文档本质上还是机器翻译的,然而机器翻译的正确率有待提高。如果您发现了这些错误或者不通顺的地方,希望您可以向我们提交反馈

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

常见问题

Q: 我安装了一个模块,然后启动时卡在了开机动画。求助!

如果在开发人员选项中启用了USB调试,请将手机连接到 PC。如果检测到设备(通过 adb devices 检查),请进入 ADB shell 并运行命令 magisk --remove-modules。这将删除所有模块并自动重新启动设备。

如果您没有启用 USB 调试,请重新启动到安全模式。大多数现代 Android 设备都支持在启动时按特殊键组合键以进入安全模式作为紧急选项。Magisk 将检测到安全模式被激活,所有模块将被禁用。然后重启回到正常模式(模块禁用状态持续),并通过 Magisk App 管理模块。

提示

如果您不知道什么是 ADB shell ,那么请在电脑上直接运行以下命令

shell
adb shell magisk --remove-modules

如果您还不知道什么是 ADB ,那么请查看《Android 调试桥 (adb)》

Q: 为什么 XXX应用会检测到 Root?

Magisk 不再处理 Root 隐藏。有大量 Magisk/Zygisk 模块专门提供这些功能,请在网络上查找它们。😉(您可以在“酷安”或者“哔哩哔哩”中搜索)

比较流行的模块是 Shamiko

Q: 在我隐藏 Magisk App 后,应用图标显示异常。

当隐藏 Magisk App 时,它将安装一个“存根”APK,其中没有任何内容。这个存根应用程序的唯一功能是将完整的 Magisk app APK 下载到其内部存储并动态加载。由于APK实际上是 empty,因此它不包含 APP 的图标资源。

当您打开隐藏的 Magisk App 时,它将为您提供在主屏幕中创建快捷方式的选项(其中包含正确的应用名称和图标),以方便您使用。您还可以手动要求应用在应用设置中创建图标。

Q: 为什么这个文档很多错误或者不通顺的地方

这个文档本质上还是机器翻译的,然而机器翻译的正确率有待提高。如果您发现了这些错误或者不通顺的地方,希望您可以向我们提交反馈

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/guides.html b/guides.html index 4e3eea1b..605b7bf8 100644 --- a/guides.html +++ b/guides.html @@ -16,7 +16,7 @@ -
Skip to content
本页内容

开发者指南

BusyBox

Magisk 附带了一个完整的 BusyBox 二进制(包括完整的 SELinux 支持)。可执行文件位于 /data/adb/magisk/busybox 。Magisk 的 BusyBox 支持运行时可切换的“ASH独立外壳模式”。这种独立模式的意思是,当在 BusyBox 的 ash shell 中运行时,无论设置为 PATH ,每个命令都将直接使用 BusyBox 中的 applet。例如,像 lsrmchmod 这样的命令将不使用 PATH 中的内容(在 Android 的情况下,默认情况下将分别为 /system/bin/ls/system/bin/rm/system/bin/chmod ),而是直接调用内部 BusyBox 小程序。这确保脚本始终在可预测的环境中运行,并且无论在哪个 Android 版本上运行,都始终具有完整的命令集。要强制命令不使用BusyBox,必须使用完整路径调用可执行文件。

在 Magisk 上下文中运行的每个 shell 脚本都将在启用独立模式(Standalone Mode)的 BusyBox 的 ash shell 中执行。对于与第三方开发人员相关的内容,这包括所有启动脚本和模块安装脚本。

对于想在 Magisk 之外使用“独立模式”功能的开发者,有两种方法可以启用它:

  1. 将环境变量 ASH_STANDALONE 设置为 1
    示例:ASH_STANDALONE=1 /data/adb/magisk/busybox sh <script>
  2. 使用命令行选项切换:
    /data/adb/magisk/busybox sh -o standalone <script>

为了确保所有后续执行的 sh shell 也以独立模式运行,选项1是首选方法(这是 Magisk 和 Magisk app 内部使用的方法),因为环境变量向下继承到子进程。

Magisk 模块

Magisk 模块是放置在 /data/adb/modules 中的文件夹,结构如下:

txt
/data/adb/modules
+    
Skip to content
本页内容

开发者指南

BusyBox

Magisk 附带了一个完整的 BusyBox 二进制(包括完整的 SELinux 支持)。可执行文件位于 /data/adb/magisk/busybox 。Magisk 的 BusyBox 支持运行时可切换的“ASH独立外壳模式”。这种独立模式的意思是,当在 BusyBox 的 ash shell 中运行时,无论设置为 PATH ,每个命令都将直接使用 BusyBox 中的 applet。例如,像 lsrmchmod 这样的命令将不使用 PATH 中的内容(在 Android 的情况下,默认情况下将分别为 /system/bin/ls/system/bin/rm/system/bin/chmod ),而是直接调用内部 BusyBox 小程序。这确保脚本始终在可预测的环境中运行,并且无论在哪个 Android 版本上运行,都始终具有完整的命令集。要强制命令不使用BusyBox,必须使用完整路径调用可执行文件。

在 Magisk 上下文中运行的每个 shell 脚本都将在启用独立模式(Standalone Mode)的 BusyBox 的 ash shell 中执行。对于与第三方开发人员相关的内容,这包括所有启动脚本和模块安装脚本。

对于想在 Magisk 之外使用“独立模式”功能的开发者,有两种方法可以启用它:

  1. 将环境变量 ASH_STANDALONE 设置为 1
    示例:ASH_STANDALONE=1 /data/adb/magisk/busybox sh <script>
  2. 使用命令行选项切换:
    /data/adb/magisk/busybox sh -o standalone <script>

为了确保所有后续执行的 sh shell 也以独立模式运行,选项1是首选方法(这是 Magisk 和 Magisk app 内部使用的方法),因为环境变量向下继承到子进程。

Magisk 模块

Magisk 模块是放置在 /data/adb/modules 中的文件夹,结构如下:

txt
/data/adb/modules
 ├── .
 ├── .
 |
@@ -149,9 +149,9 @@
     start myservice
 
 service myservice ${MAGISKTMP}/myscript.sh
-    oneshot

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- + oneshot

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/hashmap.json b/hashmap.json index ef821918..eb633e74 100644 --- a/hashmap.json +++ b/hashmap.json @@ -1 +1 @@ -{"app_changes.md":"6856ae7f","boot.md":"a0ab583f","releases_index.md":"b47a879f","releases_24100.md":"6b9a3320","readme.md":"84921fc0","tools.md":"4de0b4c5","faq.md":"6d835abf","install.md":"7d7730d6","index.md":"43313836","releases_24200.md":"6091c70d","releases_18000.md":"7c18a94a","releases_24300.md":"3ff8f899","releases_25000.md":"6c7ad114","releases_19100.md":"e4827b55","ota.md":"93c63cee","guides.md":"19fb9662","releases_19200.md":"7a067985","releases_19300.md":"63682635","releases_19000.md":"13328490","releases_25200.md":"1983de15","releases_24000.md":"1958b910","build.md":"4713d06e","releases_26000.md":"dc2422e5","changes.md":"0bfaa152","releases_22100.md":"551a2e63","details.md":"8ac7ccaf","releases_26100.md":"6724a4c6","releases_19400.md":"cd99945f","releases_25100.md":"7021edff","releases_20300.md":"285288fe","releases_21400.md":"b582e920","releases_18100.md":"512c5ac9","releases_20200.md":"f6d2625d","releases_20400.md":"b4d99bf2","releases_21000.md":"792fbc82","releases_21200.md":"c9fd3f8c","releases_23000.md":"bacddf11","releases_22000.md":"8c658003","releases_20000.md":"74fa467b","releases_20100.md":"4cc41a26","releases_21100.md":"945acb51"} +{"readme.md":"84921fc0","app_changes.md":"6856ae7f","build.md":"4713d06e","changes.md":"0bfaa152","releases_19000.md":"13328490","releases_18100.md":"512c5ac9","releases_19200.md":"7a067985","releases_19300.md":"63682635","releases_19400.md":"cd99945f","releases_20000.md":"74fa467b","releases_20100.md":"4cc41a26","releases_20200.md":"f6d2625d","releases_20300.md":"285288fe","releases_20400.md":"b4d99bf2","releases_21000.md":"792fbc82","releases_21100.md":"945acb51","releases_21200.md":"c9fd3f8c","releases_21400.md":"b582e920","releases_22000.md":"8c658003","releases_22100.md":"551a2e63","releases_24200.md":"6091c70d","releases_19100.md":"e4827b55","releases_23000.md":"bacddf11","releases_24000.md":"1958b910","releases_24100.md":"6b9a3320","releases_24300.md":"3ff8f899","releases_25200.md":"1983de15","boot.md":"a0ab583f","details.md":"8ac7ccaf","releases_25100.md":"7021edff","releases_26000.md":"dc2422e5","tools.md":"4de0b4c5","releases_25000.md":"6c7ad114","releases_26100.md":"6724a4c6","releases_index.md":"b47a879f","ota.md":"93c63cee","faq.md":"6d835abf","install.md":"7d7730d6","index.md":"43313836","guides.md":"19fb9662","releases_18000.md":"7c18a94a"} diff --git a/index.html b/index.html index fb76c931..4dfa8856 100644 --- a/index.html +++ b/index.html @@ -16,7 +16,7 @@ -
Skip to content

Magisk 中文文档 由 Jesse205 翻译 非官方

logo 本文档翻译了 Magisk 官方文档 并补充了很多内容。

原始文档版本:2023年05月13日

以下部分面向开发者:

Magisk 许可(License)使用 百度翻译 汉化

WARNING

中文汉化版许可仅供参考,请以英文原版为准

txt
Magisk,包括所有 git 子模块都是自由软件:
+    
Skip to content

Magisk 中文文档 由 Jesse205 翻译 非官方

logo 本文档翻译了 Magisk 官方文档 并补充了很多内容。

原始文档版本:2023年05月13日

以下部分面向开发者:

Magisk 许可(License)使用 百度翻译 汉化

WARNING

中文汉化版许可仅供参考,请以英文原版为准

txt
Magisk,包括所有 git 子模块都是自由软件:
 您可以根据自由软件基金会发布的 GNU 通用公共许可证的条款(许可证的第3版,
 或(根据您的选择)任何更高版本重新分发和/或修改它。
 
@@ -36,8 +36,8 @@
 
 You should have received a copy of the GNU General Public License
 along with this program.  If not, see <http://www.gnu.org/licenses/>.

相关链接

友情链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- + \ No newline at end of file diff --git a/install.html b/install.html index fff867f9..0e6aea57 100644 --- a/install.html +++ b/install.html @@ -16,15 +16,15 @@ -
Skip to content
本页内容

安装

如果您已经安装了 Magisk ,强烈建议直接通过 Magisk 应用程序的「直接安装」方法进行升级。以下教程仅针对初始安装。

  • 如果您在使用运行着 EMUI 8 或更高版本的华为设备,请查看相应部分
  • 如果您使用的是搭载 Android 9.0 或更高版本的三星设备(2019 年新设备),请查看相应部分

入门

在你开始之前:

  • 本教程假设您了解如何使用 adbfastboot
  • 如果您还计划安装第三方内核(kernels),请在安装 Magisk 之后安装它
  • 必须解锁设备的引导加载程序(bootloader)

下载并安装最新的 Magisk 应用程序 (只需下载「Magisk-版本.apk」即可) 在主屏幕中,您应该看到:

Ramdisk 的结果确定您的设备在 boot 分区中是否有 ramdisk。如果您的设备没有启动 ramdisk,请在继续之前阅读 Recovery 中的 Magisk 部分。

信息

不幸的是,有一些例外情况,因为某些设备的引导加载程序会接受 ramdisk,即使它不应该接受。 在这种情况下,您必须按照说明进行操作,就好像您的设备的 boot 分区包含 ramdisk 一样。 没有什么办法检测到这一点,因此唯一可以确定的方法就是实际尝试。 幸运的是,据我们所知,只有部分小米设备具有此属性,所以大多数人可以忽略这条信息。

如果您的设备有启动 ramdisk,请获取 boot.img 或者 init_boot.img(如果存在。在出厂时搭载安卓13的设备通常是这样的,比如红米K60Pro)的副本。

如果您的设备没有启动 ramdisk,请获取 recovery.img 的副本。

您可以从官方固件包或第三方 ROM 刷机包中提取所需文件。

接下来,我们需要知道您的设备是否有单独的 vbmeta 分区。

  • 如果您的官方固件包包含 vbmeta.img ,那么您的设备有一个单独的 vbmeta 分区
  • 您还可以通过将设备连接到 PC 并运行以下命令进行检查:
shell
adb shell ls -l /dev/block/by-name
+    
Skip to content
本页内容

安装

如果您已经安装了 Magisk ,强烈建议直接通过 Magisk 应用程序的「直接安装」方法进行升级。以下教程仅针对初始安装。

  • 如果您在使用运行着 EMUI 8 或更高版本的华为设备,请查看相应部分
  • 如果您使用的是搭载 Android 9.0 或更高版本的三星设备(2019 年新设备),请查看相应部分

入门

在你开始之前:

  • 本教程假设您了解如何使用 adbfastboot
  • 如果您还计划安装第三方内核(kernels),请在安装 Magisk 之后安装它
  • 必须解锁设备的引导加载程序(bootloader)

下载并安装最新的 Magisk 应用程序 (只需下载「Magisk-版本.apk」即可) 在主屏幕中,您应该看到:

Ramdisk 的结果确定您的设备在 boot 分区中是否有 ramdisk。如果您的设备没有启动 ramdisk,请在继续之前阅读 Recovery 中的 Magisk 部分。

信息

不幸的是,有一些例外情况,因为某些设备的引导加载程序会接受 ramdisk,即使它不应该接受。 在这种情况下,您必须按照说明进行操作,就好像您的设备的 boot 分区包含 ramdisk 一样。 没有什么办法检测到这一点,因此唯一可以确定的方法就是实际尝试。 幸运的是,据我们所知,只有部分小米设备具有此属性,所以大多数人可以忽略这条信息。

如果您的设备有启动 ramdisk,请获取 boot.img 或者 init_boot.img(如果存在。在出厂时搭载安卓13的设备通常是这样的,比如红米K60Pro)的副本。

如果您的设备没有启动 ramdisk,请获取 recovery.img 的副本。

您可以从官方固件包或第三方 ROM 刷机包中提取所需文件。

接下来,我们需要知道您的设备是否有单独的 vbmeta 分区。

  • 如果您的官方固件包包含 vbmeta.img ,那么您的设备有一个单独的 vbmeta 分区
  • 您还可以通过将设备连接到 PC 并运行以下命令进行检查:
shell
adb shell ls -l /dev/block/by-name
 # 如果您遇到如 No such file or directory 的报错,那么请尝试把命令更换为
 adb shell ls -l /dev/block/bootdevice/by-name
 # 如果还是报错(比如华为设备),那么请联网搜索您的设备相对应的方法
  • 如果找到 vbmetavbmeta_avbmeta_b ,那么您的设备有一个单独的 vbmeta 分区
  • 否则,您的设备没有单独的 vbmeta 分区

快速回顾一下,此时,您应该已经知道并准备好了:

  1. 设备是否具有启动 ramdisk
  2. 设备是否有单独的 vbmeta 分区
  3. 基于 (1) 的 boot.imginit_boot.imgrecovery.img

让我们继续修补映像.

修补映像

  • 将 boot 、init_boot 或 recovery 映像( *.img 文件)复制到设备
  • 按下 Magisk 主屏幕中的 「安装」 按钮
  • 如果要修补 recovery 映像,请选中 「Recovery 模式」 选项
  • 如果您的设备没有单独的 vbmeta 分区,请选中 「修补 boot 映像中的 vbmeta」 选项
  • 在方式中选择 「选择并修补一个文件」 ,然后选择 boot 、init_boot 或 recovery 映像
  • 开始安装,并使用 ADB 将修补的映像复制到您的电脑:
shell
adb pull /sdcard/Download/magisk_patched_[随机字符].img PC上magisk_patched.img的路径

提示,你可以将文件从资源管理器直接拖到终端中来获得文件绝对路径。

不要使用 MTP,因为它可能会损坏大文件。

  • 将修补好的 boot 、init_boot 或 recovery 映像刷入到您的设备。
    对于大多数设备,可以重启到 fastboot 模式,并使用以下命令刷入:
shell
fastboot flash boot[_x] PC上magisk_patched_[随机字符].img的路径 # 或
 fastboot flash init_boot[_x] PC上magisk_patched_[随机字符].img的路径
 # 如果刚刚修补的是 recovery 映像则改用:
 fastboot flash recovery PC上magisk_patched_[随机字符].img的路径

[_x] 应该取决于您的设备,应为 _a_b 或者不写

  • 可选 如果您的设备有单独的 vbmeta 分区,则可以使用以下命令修补 vbmeta 分区
shell
fastboot flash vbmeta --disable-verity --disable-verification vbmeta.img

WARNING

此操作可能清除您的数据

  • 重启并启动 Magisk 应用程序(如果您清除数据,您将看到一个用于占位的 Magisk 应用程序),您将看到一个询问修复环境的对话框,点击它并等待重启
  • 瞧!

卸载

卸载 Magisk 的最简单方法是直接通过 Magisk 应用程序。如果您坚持使用第三方 Recovery,请将 Magisk APK 文件 重命名为 uninstall.zip 后像其他普通的刷机包一样刷入。

Recovery 中的 Magisk

如果您的设备在 boot 映像中没有 ramdisk ,Magisk 别无选择,只能劫持 Recovery 分区。对于这些设备,每次启用 Magisk 时都必须重新启动至 Recovery

当 Magisk 劫持 recovery 时,有一个特殊的机制允许您实际进入到 Recovery 模式。每个设备都有自己的启动到 Recovery 模式的按键组合,(例如几乎所有的小米设备均为「电源」+「音量增大」以及 Galaxy S10 的「电源」+「Bixby」+「音量增大」)。百度搜索(或者 Bing 搜索、Google 搜索)可以很容易地获得这些信息。一旦你按下组合键,设备就会显示启动屏幕(可能还会振动),释放所有按键即可启动 Magisk。如果您决定引导到实际的 Recovery 模式,请长按音量增大,直到看到 Recovery 屏幕

总之,在 recovery 中安装 Magisk 后 (从关机开始)

  • (正常开机) → (无 Magisk 的系统)
  • (按键组合) → (启动屏幕) → (释放所有按钮) → (带有 Magisk 的系统)
  • (按键组合) → (启动屏幕) → (长按音量增大) → (Recovery 模式)

(注意:在这种情况下,您不能使用 第三方 Recovery 来安装或升级 Magisk!!)

三星 (System-as-root)

警告

如果您的三星设备未安装 Android 9.0 或更高版本,则说明以下内容不适用于您的设备。

安装 Magisk 之前

  • 安装 Magisk 将熔断 KNOX
  • 首次安装 Magisk 需要完整的数据擦除(这不包括在解锁 bootloader 时的数据擦除)。请在继续之前备份您的数据。
  • 下载支持您设备的 Odin (仅 Windows) 或者 Heimdall (仅 Linux)。

解锁 Bootloader

在较新三星设备上解锁 bootloader 有一些注意事项。新引入的 VaultKeeper 服务会使 bootloader 在某些情况下拒绝任何非官方分区。

  • 允许在解锁 bootloader,在 开发者选项 → OEM 解锁
  • 重启到下载模式:将设备关机,然后按下设备的下载模式键组合
  • 长按音量上限可解锁引导加载程序这将擦除数据并自动重新启动
  • 完成初始设置。跳过所有步骤,因为数据将在后面的步骤中再次擦除。在设置过程中将设备连接到互联网
  • 启用开发者选项,**确认「OEM解锁」选项存在且呈灰色。**这意味着 VaultKeeper 服务释放了引导加载程序。
  • 您的 bootloader 现在在下载模式允许非官方映像

操作指南

  • 使用 samfirm.jsFrija,或 Samloader 直接从三星服务器下载设备的最新 zip 固件 。

  • 解压缩固件并将 AP 归档文件复制到设备。它通常命名为 AP_[device_model_sw_ver].tar.md5

  • 按下 Magisk 主屏幕中的 「安装」 按钮

  • 如果您的设备没有启动 ramdisk,勾选 「Recovery模式」 选项

  • 在方式中选择 「选择并修补一个文件」 ,然后选择 AP 归档文件

  • 开始安装,并使用 ADB 将修补的归档文件复制到您的电脑:

    shell
    adb pull /sdcard/Download/magisk_patched_[random_strings].tar

    注意:不要使用MTP,因为它可能会损坏大型文件。

  • 重新启动到下载模式。在您的 PC 上打开 Odin,将 magisk_patched.tar 作为 AP,连同原始固件中的 BLCPCSC不是 HOME_CSC,因为我们要清除数据)一起刷入。

  • 一旦 Odin 完成刷机,您的设备应该会自动重启。 如果被要求恢复出厂设置,请同意。

  • 如果您的设备没有启动 ramdisk,请立即重新启动到 recovery 以启用 Magisk(原因在 Recovery 中的 Magisk 中说明)。

  • 安装您已经下载的 Magisk 应用程序 并启动该应用程序。 它应该显示一个对话框,要求进行额外的设置。

  • 让应用程序完成它的工作并自动重启设备。

系统更新

一旦你的三星设备获得了 root 权限,你就不能再通过 OTA 进行 Android 系统更新了。要进行系统更新,您必须手动下载新的固件归档文件并完成上一节中编写的相同 AP 修补过程。这里唯一的区别在于Odin刷入步骤:不要使用 CSC 归档文件,而是使用 HOME_CSC 归档文件,因为我们正在执行升级,而不是初始安装

注意事项

  • 永远、永远不要尝试将 bootrecoveryvbmeta 分区恢复到原样! 您这样做会破坏您的设备,并且从中恢复的唯一方法是清除数据并进行完整的 Odin 恢复
  • 要使用新的固件升级您的设备,切勿出于上述原因直接使用原厂 AP 归档文件。 始终在 Magisk 应用程序中修补 AP 并改用它。
  • 永远不要只刷入 AP ,否则 Odin 可能会缩小 /data 文件系统的大小。升级时请刷入 AP + BL + CP + HOME_CSC

华为

DANGER

这部分现已从官方文档中移除。您正在浏览的是 2021.03.22 并补充后的版本。

Magisk 不再正式支持较新的华为设备,因为其设备上的 bootloader 不可通过官方途径解锁,更重要的是他们不遵循标准的 Android 分区方案。以下只是一些一般性指导。

使用了麒麟处理器的华为设备与大多数常见设备的分区方式不同。Magisk 通常安装在设备的 boot 分区,但是华为设备没有这个分区。根据您的设备运行的 EMUI 版本,说明会略有不同。

DANGER

请勿使用最新版本的 Magisk 应用!我推荐使用 Magisk v23.0 或使用 Magisk v20.4 (下载「Magisk-v20.4.zip」)搭配 Magisk Manager v7.5.1 (下载「MagiskManager-v7.5.1.apk」)

Magisk 兼容性列表
名称型号EMUI 版本Android 版本详情
华为畅享7SLA-AL00EMUI 5.1.2Android 7.0使用 Magisk v25.2 时会触发引导循环并直接重启至 eRecovery
荣耀畅玩4CCHM-TL00HEMUI 4.0Android 6.0使用新版 Magisk 会导致无法授权
荣耀畅玩6XBLN-AL10EMUI 8.0Android 8.0没有这个问题

获得官方映像

华为不发布官方出厂映像以及 OTA 归档文件,但大多数固件压缩包可以从华为固件下载站下载。 要从压缩包中的「UPDATE.APP」中提取映像,您必须使用 Huawei Update Extractor(仅限 Windows!)

EMUI 5 及以下

遵循入门的教程,唯一的不同在于请勿使用最新版本的 Magisk 应用!

提示:进入 fastboot 模式需要将手机使用数据线连接电脑,而进入 Recovery 模式则不能将手机使用连接到电脑!所以如果您在 fastboot 模式中刷入 Recovery 映像后请将手机与电脑断开连接后再按下「电源」+「音量增大」来进入 Recovery,否则您将进入的「eRecovery」。

EMUI 8

对于运行 EMUI 8 的设备,您的设备有一个名为 ramdisk 的分区,这是将要安装 Magisk 的地方。

  • 如果您打算使用第三方 Recovery,只需按照第三方 Recovery 的说明进行操作即可。

  • 如果您不打算使用第三方 Recovery,则必须从您的固件中提取 RAMDISK.img 。 按照上面的修补映像说明进行操作,但使用 RAMDISK.img 文件而不是 boot 映像!

  • 要将修补后的映像刷入您的设备,请使用 fastboot 命令:

    shell
    fastboot flash ramdisk /path/to/magisk_patched.img

请注意,您正在刷入 ramdisk,而不是 boot

EMUI 9 或更高版本

对于 EMUI 9+ 设备,ramdisk 分区不再存在。 作为解决方法,Magisk 将安装到 recovery_ramdisk 分区。 在按照以下说明操作之前,请先阅读 Recovery 中的 Magisk

注意:正如在 荣耀 View 10 上测试的那样,华为的内核似乎无法在早期启动时捕获按键事件,因此长按音量增大不会在我的设备上启动到 Recovery。 您的体验可能会有所不同。

  • 如果您打算使用第三方 Recovery,只需按照第三方 Recovery 的说明进行操作即可。
    警告:Magisk 将覆盖第三方 Recovery。

  • 如果您不打算使用第三方 Recovery,则必须从固件中提取 RECOVERY_RAMDIS.img (这不是拼写错误),而不是 recovery.img(部分设备依旧需要修补 recovery.img )。 按照上面的引导映像修补说明进行操作,但使用 RECOVERY_RAMDIS.img 文件而不是 boot 映像!

  • 要将修补后的映像刷入您的设备,请使用 fastboot 命令:

    shell
    fastboot flash recovery_ramdisk /path/to/magisk_patched.img

请注意,您正在刷入 recovery_ramdisk,而不是 boot

第三方 Recovery

警告

这种安装方法已被弃用,并且可以用很小的工作量来维护。

仅当您的设备启动 ramdisk 时,才能使用第三方 Recovery 进行安装。不建议在新的设备上通过第三方 Recovery 安装 Magisk。如果您遇到任何问题,请使用正确的修补映像方法。

  • 下载 Magisk APK
  • .apk 文件扩展名重命名为 .zip ,例如:Magisk-v25.2.apkMagisk-v25.2.zip 。如果重命名文件扩展名时遇到问题(如 Windows),请使用 Android 上的文件管理器或第三方 Recovery 中的文件管理功能重命名文件。
  • 像其他普通的刷机包一样刷 zip。
  • 重新启动并检查是否已安装 Magisk 应用程序。如果未自动安装,请手动安装 APK。
  • 启动 Magisk 应用程序,它将显示一个让您重新安装的对话框。请直接在 APP 内重新安装并重新启动(MTK 设备将在重启后自动给 boot 分区上锁,请使用 fastboot 或者第三方 recovery 修补映像)。

警告

模块的 sepolicy.rule 文可能存储在 cache 分区中。请不要擦除 CACHE 分区。

TIP

您也可以提供 adb sideload 刷入 Magisk。这对于不能正常解密 data 分区且无外置存储设备(SD 卡,U 盘等)的设备特别友好。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- + \ No newline at end of file diff --git a/ota.html b/ota.html index 195c02b6..759f20f4 100644 --- a/ota.html +++ b/ota.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

OTA 升级指南

Magisk 不修改大多数只读分区,这意味着应用官方 OTA 要简单得多。以下是几种不同类型的设备的教程,以应用 OTA 并在安装后保留 Magisk(如果可能)。这只是一个通用指南,因为每个设备的程序可能有所不同。

注意:为了应用 OTA,您必须确保自己没有以任何方式修改只读分区(如 /system/vendor )。即使将分区重新挂载到 rw 也会篡改块验证

必要条件

  • 请在开发人员选项中禁用自动系统更新,这样在未经您确认的情况下,它不会安装 OTA。

  • 当OTA可用时,首先转到(Magisk app → 卸载 → 恢复映像),不要重新启动,否则将卸载 Magisk。 这将使 Magisk 修改的分区从安装时的生成备份恢复到官方,以便通过 OTA 前的块验证。在执行以下步骤之前,需要执行此步骤

带 A/B 分区的设备

可以将 OTA 安装到非活动插槽,并让 Magisk app 将 Magisk 安装到更新的分区上。开箱即用的 OTA 安装工作无缝,安装后可以保存 Magisk。

  • 恢复官方映像后,按正常方式应用 OTA(设置 → 系统 → 系统更新)。
  • 等待安装完成(OTA 的 步骤1:“安装更新” 和 步骤2:“优化您的设备”),不要按“重新启动”按钮! 相反,请转到(Magisk app → 安装 → 安装到非活动插槽)将 Magisk 安装到更新的插槽。

  • 安装完成后,按下 Magisk app 中的重新启动按钮。在 hood 下,Magisk app 强制您的设备切换到更新的插槽,绕过任何可能的 OTA 后验证。

“非 A/B” 设备

不幸的是,在这些设备上应用 OTA 并没有真正好的方法。以下教程不会保留 Magisk;升级后,您必须手动重新 root 设备,这将需要通过电脑。这些只是“最佳实践”。

  • 如果您安装了第三方 recovery,则可以从以前的备份、在线转储或 OEM 提供的出厂映像中恢复。 如果您决定在不接触 recovery 分区的情况下开始安装 Magisk,您可以有几种选择,无论是哪种方式,您都可以最终使用 Magisk root 的设备,但 recovery 仍然保持不变:
    • 如果支持,请使用 fastboot boot <recovery_img> 启动第三方 Recovery 并安装 Magisk。
    • 如果您有官方映像转储的副本,请使用 Magisk app 的“修补映像”功能安装 Magisk
  • 恢复到官方映像和其他映像后,下载 OTA。可选地,一旦下载了 OTA 的更新 zip,就可以找到提取 zip 的方法(因为它通常涉及 root 用户)
  • 应用 OTA 并重启设备。这将使用您设备的官方映像 OTA 安装机制来升级您的系统。
  • 一旦完成,您将得到一个升级的、100% 官方的、未 root 的设备。你必须手动将 Magisk 刷回。如果您想经常接收官方 OTA,请考虑使用 步骤1 中所述的方法,在不接触恢复分区的情况下刷入 Magisk。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

OTA 升级指南

Magisk 不修改大多数只读分区,这意味着应用官方 OTA 要简单得多。以下是几种不同类型的设备的教程,以应用 OTA 并在安装后保留 Magisk(如果可能)。这只是一个通用指南,因为每个设备的程序可能有所不同。

注意:为了应用 OTA,您必须确保自己没有以任何方式修改只读分区(如 /system/vendor )。即使将分区重新挂载到 rw 也会篡改块验证

必要条件

  • 请在开发人员选项中禁用自动系统更新,这样在未经您确认的情况下,它不会安装 OTA。

  • 当OTA可用时,首先转到(Magisk app → 卸载 → 恢复映像),不要重新启动,否则将卸载 Magisk。 这将使 Magisk 修改的分区从安装时的生成备份恢复到官方,以便通过 OTA 前的块验证。在执行以下步骤之前,需要执行此步骤

带 A/B 分区的设备

可以将 OTA 安装到非活动插槽,并让 Magisk app 将 Magisk 安装到更新的分区上。开箱即用的 OTA 安装工作无缝,安装后可以保存 Magisk。

  • 恢复官方映像后,按正常方式应用 OTA(设置 → 系统 → 系统更新)。
  • 等待安装完成(OTA 的 步骤1:“安装更新” 和 步骤2:“优化您的设备”),不要按“重新启动”按钮! 相反,请转到(Magisk app → 安装 → 安装到非活动插槽)将 Magisk 安装到更新的插槽。

  • 安装完成后,按下 Magisk app 中的重新启动按钮。在 hood 下,Magisk app 强制您的设备切换到更新的插槽,绕过任何可能的 OTA 后验证。

“非 A/B” 设备

不幸的是,在这些设备上应用 OTA 并没有真正好的方法。以下教程不会保留 Magisk;升级后,您必须手动重新 root 设备,这将需要通过电脑。这些只是“最佳实践”。

  • 如果您安装了第三方 recovery,则可以从以前的备份、在线转储或 OEM 提供的出厂映像中恢复。 如果您决定在不接触 recovery 分区的情况下开始安装 Magisk,您可以有几种选择,无论是哪种方式,您都可以最终使用 Magisk root 的设备,但 recovery 仍然保持不变:
    • 如果支持,请使用 fastboot boot <recovery_img> 启动第三方 Recovery 并安装 Magisk。
    • 如果您有官方映像转储的副本,请使用 Magisk app 的“修补映像”功能安装 Magisk
  • 恢复到官方映像和其他映像后,下载 OTA。可选地,一旦下载了 OTA 的更新 zip,就可以找到提取 zip 的方法(因为它通常涉及 root 用户)
  • 应用 OTA 并重启设备。这将使用您设备的官方映像 OTA 安装机制来升级您的系统。
  • 一旦完成,您将得到一个升级的、100% 官方的、未 root 的设备。你必须手动将 Magisk 刷回。如果您想经常接收官方 OTA,请考虑使用 步骤1 中所述的方法,在不接触恢复分区的情况下刷入 Magisk。

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/18000.html b/releases/18000.html index b3b4723b..70919b96 100644 --- a/releases/18000.html +++ b/releases/18000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2018.12.7 Magisk v18.0

Here comes a stable release, this time with quite a few major updates!

MagiskHide Improvements

Starting from v18, the process monitor matches component names instead of process names. Android allow app services to name their process arbitrarily, and many apps starting to use dedicated services to detect root; it used to require adding all of these service process names to the list to hide Magisk effectively. Component names have the format: <package name>/<java class name>, which means we can always know which application spawned a given process.

TL;DR, ALL processes spawned from the applications on the hide list will be targeted.

Recently I discovered a very widespread Linux kernel bug affecting tons of Android devices (full write-up: Medium Article). This bug exposes the supposedly protected procfs, which is abused in some apps to detect Magisk with information leaked from other processes. Magisk will patch this bug on all Android 7.0+ devices. Yes, a fully effective MagiskHide requires the enhanced Android Sandbox in modern Android versions.

Path Changes

The name of the folder /sbin/.core is confusing and will no longer be used; it is replaced with /sbin/.magisk. Another major change is the location to store general boot scripts. As these boot scripts should still run even if magisk.img is not mounted, they are moved out of magisk.img, from <img>/.core/<stage>.d to /data/adb/<stage>.d (stage is either post-fs-data or service). Say goodbye to stupid paths like /sbin/.core/img/.core/post-fs-data.d!

Quick recap:

  • New magisk.img mountpoint: /sbin/.magisk/img
  • New internal busybox PATH: /sbin/.magisk/busybox
  • The folder <img>/.core is no longer used in any places. magisk.img is solely used for storing modules, no other functionality depends on it.
  • Symlinks are created so all old paths will still work. None of the existing apps/scripts depending on these internal paths should break, but please migrate to the new paths ASAP.

Dropping Legacy Support

The NEXT Magisk Manager upgrade (not this one) will only support v18+, please upgrade ASAP. Magisk Manager is always designed to be fully functional across a wide range of Magisk versions. However, to enforce full obfuscation, I will have to drop legacy support eventually.

This is also a good opportunity to push the whole community forward, all module developers should forget about backward compatibility (e.g. stop supporting the old Magisk paths, please don't torture yourself...). I expect very few structural changes in the near future, so again, please upgrade ASAP 😃

Modern C++ Code Base

Although this has nothing to do with the end user, tons of effort was done to migrate Magisk to a more modern C++ code base instead of the previous good plain old C. This makes the code easier to maintain and allows me to utilized many C++ language features.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2018.12.7 Magisk v18.0

Here comes a stable release, this time with quite a few major updates!

MagiskHide Improvements

Starting from v18, the process monitor matches component names instead of process names. Android allow app services to name their process arbitrarily, and many apps starting to use dedicated services to detect root; it used to require adding all of these service process names to the list to hide Magisk effectively. Component names have the format: <package name>/<java class name>, which means we can always know which application spawned a given process.

TL;DR, ALL processes spawned from the applications on the hide list will be targeted.

Recently I discovered a very widespread Linux kernel bug affecting tons of Android devices (full write-up: Medium Article). This bug exposes the supposedly protected procfs, which is abused in some apps to detect Magisk with information leaked from other processes. Magisk will patch this bug on all Android 7.0+ devices. Yes, a fully effective MagiskHide requires the enhanced Android Sandbox in modern Android versions.

Path Changes

The name of the folder /sbin/.core is confusing and will no longer be used; it is replaced with /sbin/.magisk. Another major change is the location to store general boot scripts. As these boot scripts should still run even if magisk.img is not mounted, they are moved out of magisk.img, from <img>/.core/<stage>.d to /data/adb/<stage>.d (stage is either post-fs-data or service). Say goodbye to stupid paths like /sbin/.core/img/.core/post-fs-data.d!

Quick recap:

  • New magisk.img mountpoint: /sbin/.magisk/img
  • New internal busybox PATH: /sbin/.magisk/busybox
  • The folder <img>/.core is no longer used in any places. magisk.img is solely used for storing modules, no other functionality depends on it.
  • Symlinks are created so all old paths will still work. None of the existing apps/scripts depending on these internal paths should break, but please migrate to the new paths ASAP.

Dropping Legacy Support

The NEXT Magisk Manager upgrade (not this one) will only support v18+, please upgrade ASAP. Magisk Manager is always designed to be fully functional across a wide range of Magisk versions. However, to enforce full obfuscation, I will have to drop legacy support eventually.

This is also a good opportunity to push the whole community forward, all module developers should forget about backward compatibility (e.g. stop supporting the old Magisk paths, please don't torture yourself...). I expect very few structural changes in the near future, so again, please upgrade ASAP 😃

Modern C++ Code Base

Although this has nothing to do with the end user, tons of effort was done to migrate Magisk to a more modern C++ code base instead of the previous good plain old C. This makes the code easier to maintain and allows me to utilized many C++ language features.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/18100.html b/releases/18100.html index a1be188c..2f4c4685 100644 --- a/releases/18100.html +++ b/releases/18100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.2.4 Magisk v18.1

What is a better way to celebrate Chinese New Year than a new Magisk update!

EMUI 9 Support

Welcome on board "again", Huawei! Even though Huawei had officially blocked bootloader unlocks, people still love to buy them (duh), and there are paid services that unlock Huawei bootloaders. So hey, get Magisk installed on that bad boy! One caveat is that since Huawei have changed the partitions, special workarounds has to be done. Details and instructions are in the newly created instruction page

Support Down to Android 4.2

Because why not, it was quite a lot of fun LOL. All devices running KitKat and higher will have all features enabled. MagiskHide and resetprop aren't possible on Jellybean, and Magic Mount (modules) is temporarily disabled; basically it only works as a root solution for now. Android 4.1 isn't 100% usable yet, so installation is also temporarily blocked. Eventually, all Jellybean devices will have full Magic Mount and MagiskSU support.

Major Magisk Manager Update

Aside from the obvious major UI overhaul, tons of little user experience and performance improvements are also added. The app is finally less crappy now 😃

Final Words

I'm aware that there are apps updated to detect Magisk, however no MagiskHide improvements efforts are done in this release; v18.1 is aimed to be as stable as possible. Stay tuned for future public betas, or if you are more adventurous, jump on the Canary Channel bandwagon for more aggressive hiding techniques 😃

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.2.4 Magisk v18.1

What is a better way to celebrate Chinese New Year than a new Magisk update!

EMUI 9 Support

Welcome on board "again", Huawei! Even though Huawei had officially blocked bootloader unlocks, people still love to buy them (duh), and there are paid services that unlock Huawei bootloaders. So hey, get Magisk installed on that bad boy! One caveat is that since Huawei have changed the partitions, special workarounds has to be done. Details and instructions are in the newly created instruction page

Support Down to Android 4.2

Because why not, it was quite a lot of fun LOL. All devices running KitKat and higher will have all features enabled. MagiskHide and resetprop aren't possible on Jellybean, and Magic Mount (modules) is temporarily disabled; basically it only works as a root solution for now. Android 4.1 isn't 100% usable yet, so installation is also temporarily blocked. Eventually, all Jellybean devices will have full Magic Mount and MagiskSU support.

Major Magisk Manager Update

Aside from the obvious major UI overhaul, tons of little user experience and performance improvements are also added. The app is finally less crappy now 😃

Final Words

I'm aware that there are apps updated to detect Magisk, however no MagiskHide improvements efforts are done in this release; v18.1 is aimed to be as stable as possible. Stay tuned for future public betas, or if you are more adventurous, jump on the Canary Channel bandwagon for more aggressive hiding techniques 😃

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/19000.html b/releases/19000.html index 18325782..bfb623cc 100644 --- a/releases/19000.html +++ b/releases/19000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.3.28 Magisk v19.0

I would say this is one of my most ambitious release of all time! Due to the extremely massive changes, this release will be a public beta. Calling it v18.2 doesn't do it justice, so v19.0 we go.

Magisk Module installer

Magisk module developers: pay extra attention! A completely new Magisk Module Installer replaces the old Magisk module template. This new format decouples ALL installation logic from modules, and encourages developers to use the provided API for installation. This new format is ENFORCED, meaning all existing modules should upgrade ASAP, and new modules are REQUIRED to follow the rules.

Carefully read through the updated docs!

Warning: All existing modules that does not use the new module format will be automatically removed on May 1st, 2019. Module devs: upgrade your existing modules ASAP!

Imageless Magisk

Since the existence of Magisk, all modules are stored within an EXT4 image which will be loop mounted at boot. This approach has a few problems: resizing the image is a huge headache (no live resizing, resize2fs on some devices refuse to work properly), and also MANY devices using F2FS ships a broken driver with the kernel, causing EXT4 loop devices unable to be mounted at all. All these problems come to an end now: modules are now directly stored in /data! Backwards compatibility is provided, for modules that uses the official module template, installation should work just fine.

Warning: Although module migration was tested, there are still chances that your modules will get lost in the process. Be prepared to reinstall your existing modules in that case.

Native 64 Bit is Back

At one point in history, Magisk uses native 64 binaries. However due to binary size considerations, all binaries was switched to 32 bit. Starting from v19, all static binaries are still 32 bit only, but the most important part: the main magisk binary now runs in native 64 bit on supported devices.

Zygote Ptrace Based MagiskHide

MagiskHide used to use logcat to monitor activity manager events for new process creation. That method is extremely unreliable: even with constant improvements since introduction, it is still not working 100% of the time. Here comes a fundamentally new approach: ptrace the zygote process and step through all fork events. In layman's term, this new method is able to target a process before it even starts to run! The code for it is extremely tricky, but it was tested for quite a while in the canary channel, so I'm confident enough to release this to the public 😃

Android Q

Full support for Android Q Beta 1 is also introduced in this release. However, you cannot use it on the Pixel 3 (XL) due to the fact that Google decided to use logical partitions on the 3rd gen Pixels starting with Q. A solution is still WIP, please stay tuned!

Final Words

What you can expect in upcoming releases: Samsung S10 support, and full logical partition support. Also, I AM aware of Google Pay issues, but these are not my main focus now since there are still tons of other issues for me to focus on. Several discussion threads on XDA provide seemingly working solutions, please do some research on your own.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.3.28 Magisk v19.0

I would say this is one of my most ambitious release of all time! Due to the extremely massive changes, this release will be a public beta. Calling it v18.2 doesn't do it justice, so v19.0 we go.

Magisk Module installer

Magisk module developers: pay extra attention! A completely new Magisk Module Installer replaces the old Magisk module template. This new format decouples ALL installation logic from modules, and encourages developers to use the provided API for installation. This new format is ENFORCED, meaning all existing modules should upgrade ASAP, and new modules are REQUIRED to follow the rules.

Carefully read through the updated docs!

Warning: All existing modules that does not use the new module format will be automatically removed on May 1st, 2019. Module devs: upgrade your existing modules ASAP!

Imageless Magisk

Since the existence of Magisk, all modules are stored within an EXT4 image which will be loop mounted at boot. This approach has a few problems: resizing the image is a huge headache (no live resizing, resize2fs on some devices refuse to work properly), and also MANY devices using F2FS ships a broken driver with the kernel, causing EXT4 loop devices unable to be mounted at all. All these problems come to an end now: modules are now directly stored in /data! Backwards compatibility is provided, for modules that uses the official module template, installation should work just fine.

Warning: Although module migration was tested, there are still chances that your modules will get lost in the process. Be prepared to reinstall your existing modules in that case.

Native 64 Bit is Back

At one point in history, Magisk uses native 64 binaries. However due to binary size considerations, all binaries was switched to 32 bit. Starting from v19, all static binaries are still 32 bit only, but the most important part: the main magisk binary now runs in native 64 bit on supported devices.

Zygote Ptrace Based MagiskHide

MagiskHide used to use logcat to monitor activity manager events for new process creation. That method is extremely unreliable: even with constant improvements since introduction, it is still not working 100% of the time. Here comes a fundamentally new approach: ptrace the zygote process and step through all fork events. In layman's term, this new method is able to target a process before it even starts to run! The code for it is extremely tricky, but it was tested for quite a while in the canary channel, so I'm confident enough to release this to the public 😃

Android Q

Full support for Android Q Beta 1 is also introduced in this release. However, you cannot use it on the Pixel 3 (XL) due to the fact that Google decided to use logical partitions on the 3rd gen Pixels starting with Q. A solution is still WIP, please stay tuned!

Final Words

What you can expect in upcoming releases: Samsung S10 support, and full logical partition support. Also, I AM aware of Google Pay issues, but these are not my main focus now since there are still tons of other issues for me to focus on. Several discussion threads on XDA provide seemingly working solutions, please do some research on your own.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/19100.html b/releases/19100.html index 986524ee..39f3fc11 100644 --- a/releases/19100.html +++ b/releases/19100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.5.1 Magisk v19.1

Finally, a lovely stable release!

For those that were using v18.1, here are some quick highlights of v19.0

  • Imageless Magisk: Although module migration was tested, there are still chances that your modules will get lost in the process. Be prepared to reinstall your existing modules in that case.
  • Native 64-bit support
  • Zygote Ptrace Based MagiskHide

Other than adding support for Samsung system-as-root devices, this release is mostly bug fixes from v19.0. Enjoy 😃

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.5.1 Magisk v19.1

Finally, a lovely stable release!

For those that were using v18.1, here are some quick highlights of v19.0

  • Imageless Magisk: Although module migration was tested, there are still chances that your modules will get lost in the process. Be prepared to reinstall your existing modules in that case.
  • Native 64-bit support
  • Zygote Ptrace Based MagiskHide

Other than adding support for Samsung system-as-root devices, this release is mostly bug fixes from v19.0. Enjoy 😃

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/19200.html b/releases/19200.html index 322455d4..1dbe1c3e 100644 --- a/releases/19200.html +++ b/releases/19200.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/19300.html b/releases/19300.html index 9e3da852..c36b7ad0 100644 --- a/releases/19300.html +++ b/releases/19300.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/19400.html b/releases/19400.html index 3e3deab4..090917e3 100644 --- a/releases/19400.html +++ b/releases/19400.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.9.19 Magisk v19.4

This version is heavily tested and tons of bugs were squashed before release. However due to the massive changes, it is decided to release a public beta for people/root app developers to adjust/update before things hit public stable.

New System-as-root Implementation

Magisk has supported system-as-root devices for a long time since the first Pixel came out. The goal is always to revert things back to the good old initramfs based root dir. However, this not only creates tons of issues on many devices, not easily hide-able with MagiskHide, but most importantly not even possible on Android 10. Starting with v19.4, Magisk will follow how Google has designed system-as-root: mounting system actually to / (root).

This implies several MASSIVE consequences for system-as-root devices:

  • /system is no longer a valid mount point. For existing root apps that remounts /system to rw, you will have to remount / instead of /system
  • The root directory (/) is no longer rootfs, but actually system. Remounting / to rw and modify files means you are writing to the actual system partition, NOT volatile storage as it used to be in rootfs. This is not recommended as user is not necessary aware that you are tampering an actual partition, sometimes dangerous if dm-verity/AVB-verity is enforced, or sometimes outright impossible since many devices now ship with read-only system partitions (e.g. EROFS, EXT4 dedup)
  • Several custom kernel rely on Magisk's root directory overlay system (overlay) for modifying /. This is no longer compatible with the new implementation. A new overlay system (overlay.d) will replace the existing one as an alternative (details in documentations). To provide backwards compatibility, Magisk will switch to "Compat Mode" when /overlay is detected, which simply reverts to the old system-as-root setup. Compat Mode will not work on Android 10 and will cause bootloop. Although things will still work as it used to, please upgrade to overlay.d ASAP.

Android 10 Support

Other than A-only devices running Android 10, Android 10 is fully supported with MagiskHide fully functioning. Android 10's biggest challenge is the new "2-Stage-Init" system-as-root implementation, which is the sole reason why A-only is not support yet. Stay tuned for further updates as that is the next thing on the list.

(For those interested in "2-Stage-Init" and other details of system-as-root, check this Twitter thread I tweeted)

Product Partition Support

Magisk Module developers can now finally properly modify files in /product! This partition is now an essential part in Android 10, and many files are moved from system to product. Please check documentations for more details.

A-Only System-as-root

A huge number of new devices have A-only system-as-root setups (Android 9.0). These unfortunate devices will have to install Magisk into the recovery partition. Please check the fully updated Installation Guide for more details.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.9.19 Magisk v19.4

This version is heavily tested and tons of bugs were squashed before release. However due to the massive changes, it is decided to release a public beta for people/root app developers to adjust/update before things hit public stable.

New System-as-root Implementation

Magisk has supported system-as-root devices for a long time since the first Pixel came out. The goal is always to revert things back to the good old initramfs based root dir. However, this not only creates tons of issues on many devices, not easily hide-able with MagiskHide, but most importantly not even possible on Android 10. Starting with v19.4, Magisk will follow how Google has designed system-as-root: mounting system actually to / (root).

This implies several MASSIVE consequences for system-as-root devices:

  • /system is no longer a valid mount point. For existing root apps that remounts /system to rw, you will have to remount / instead of /system
  • The root directory (/) is no longer rootfs, but actually system. Remounting / to rw and modify files means you are writing to the actual system partition, NOT volatile storage as it used to be in rootfs. This is not recommended as user is not necessary aware that you are tampering an actual partition, sometimes dangerous if dm-verity/AVB-verity is enforced, or sometimes outright impossible since many devices now ship with read-only system partitions (e.g. EROFS, EXT4 dedup)
  • Several custom kernel rely on Magisk's root directory overlay system (overlay) for modifying /. This is no longer compatible with the new implementation. A new overlay system (overlay.d) will replace the existing one as an alternative (details in documentations). To provide backwards compatibility, Magisk will switch to "Compat Mode" when /overlay is detected, which simply reverts to the old system-as-root setup. Compat Mode will not work on Android 10 and will cause bootloop. Although things will still work as it used to, please upgrade to overlay.d ASAP.

Android 10 Support

Other than A-only devices running Android 10, Android 10 is fully supported with MagiskHide fully functioning. Android 10's biggest challenge is the new "2-Stage-Init" system-as-root implementation, which is the sole reason why A-only is not support yet. Stay tuned for further updates as that is the next thing on the list.

(For those interested in "2-Stage-Init" and other details of system-as-root, check this Twitter thread I tweeted)

Product Partition Support

Magisk Module developers can now finally properly modify files in /product! This partition is now an essential part in Android 10, and many files are moved from system to product. Please check documentations for more details.

A-Only System-as-root

A huge number of new devices have A-only system-as-root setups (Android 9.0). These unfortunate devices will have to install Magisk into the recovery partition. Please check the fully updated Installation Guide for more details.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/20000.html b/releases/20000.html index 01432ec3..d4c02456 100644 --- a/releases/20000.html +++ b/releases/20000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.10.11 Magisk v20.0

The following release notes are mostly the same as v19.4. Compared to v19.4 beta, the most notable change is adding tons of support for more devices on Android 10, along with several bug fixes.

New System-as-root Implementation

Magisk has supported system-as-root devices for a long time since the first Pixel came out. The goal is always to revert things back to the good old initramfs based root dir. However, this not only creates tons of issues on many devices, not easily hide-able with MagiskHide, but most importantly not even possible on Android 10. Magisk will now start to follow how Google has designed system-as-root: mounting system actually to / (root).

This implies several MASSIVE consequences for system-as-root devices:

  • /system is no longer a valid mount point. For existing root apps that remounts /system to rw, you will have to remount / instead of /system
  • The root directory (/) is no longer rootfs, but actually system. Remounting / to rw and modify files means you are writing to the actual system partition, NOT volatile storage as it used to be in rootfs. This is not recommended as user is not necessary aware that you are tampering an actual partition, sometimes dangerous if dm-verity/AVB-verity is enforced, or sometimes outright impossible since many devices now ship with read-only system partitions (e.g. EROFS, EXT4 dedup)
  • Several custom kernel rely on Magisk's root directory overlay system (overlay) for modifying /. This is no longer compatible with the new implementation. A new overlay system (overlay.d) will replace the existing one as an alternative (details in documentations). To provide backwards compatibility, Magisk will switch to "Compat Mode" when /overlay is detected, which simply reverts to the old system-as-root setup. Compat Mode will not work on Android 10 and will cause bootloop. Although things will still work as it used to, please upgrade to overlay.d ASAP.

Android 10 Support

Android 10 is now fully supported with MagiskHide working as expected. Android 10's biggest challenge is the new "2-Stage-Init" system-as-root implementation, which requires modding early mount fstab in a specific way, and in many devices' cases involves patching DTBs in the boot image.

(For those interested in "2-Stage-Init" and other details of system-as-root, check this Twitter thread I tweeted)

Product Partition Support

Magisk Module developers can now finally properly modify files in /product! This partition is now an essential part in Android 10, and many files are moved from system to product. Please check documentations for more details.

A-Only System-as-root

A huge number of new devices have A-only system-as-root setups (Android 9.0). These unfortunate devices will have to install Magisk into the recovery partition. Please check the fully updated Installation Guide for more details.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.10.11 Magisk v20.0

The following release notes are mostly the same as v19.4. Compared to v19.4 beta, the most notable change is adding tons of support for more devices on Android 10, along with several bug fixes.

New System-as-root Implementation

Magisk has supported system-as-root devices for a long time since the first Pixel came out. The goal is always to revert things back to the good old initramfs based root dir. However, this not only creates tons of issues on many devices, not easily hide-able with MagiskHide, but most importantly not even possible on Android 10. Magisk will now start to follow how Google has designed system-as-root: mounting system actually to / (root).

This implies several MASSIVE consequences for system-as-root devices:

  • /system is no longer a valid mount point. For existing root apps that remounts /system to rw, you will have to remount / instead of /system
  • The root directory (/) is no longer rootfs, but actually system. Remounting / to rw and modify files means you are writing to the actual system partition, NOT volatile storage as it used to be in rootfs. This is not recommended as user is not necessary aware that you are tampering an actual partition, sometimes dangerous if dm-verity/AVB-verity is enforced, or sometimes outright impossible since many devices now ship with read-only system partitions (e.g. EROFS, EXT4 dedup)
  • Several custom kernel rely on Magisk's root directory overlay system (overlay) for modifying /. This is no longer compatible with the new implementation. A new overlay system (overlay.d) will replace the existing one as an alternative (details in documentations). To provide backwards compatibility, Magisk will switch to "Compat Mode" when /overlay is detected, which simply reverts to the old system-as-root setup. Compat Mode will not work on Android 10 and will cause bootloop. Although things will still work as it used to, please upgrade to overlay.d ASAP.

Android 10 Support

Android 10 is now fully supported with MagiskHide working as expected. Android 10's biggest challenge is the new "2-Stage-Init" system-as-root implementation, which requires modding early mount fstab in a specific way, and in many devices' cases involves patching DTBs in the boot image.

(For those interested in "2-Stage-Init" and other details of system-as-root, check this Twitter thread I tweeted)

Product Partition Support

Magisk Module developers can now finally properly modify files in /product! This partition is now an essential part in Android 10, and many files are moved from system to product. Please check documentations for more details.

A-Only System-as-root

A huge number of new devices have A-only system-as-root setups (Android 9.0). These unfortunate devices will have to install Magisk into the recovery partition. Please check the fully updated Installation Guide for more details.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/20100.html b/releases/20100.html index d945246e..4bd94ee7 100644 --- a/releases/20100.html +++ b/releases/20100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2019.11.2 Magisk v20.1

Lots of bug fixes from v20.0, and some cool new features!

Updated Magisk Manager Hiding

Starting with Magisk v20.1 paired with Magisk Manager v7.4.0, a new hiding mode is introduced for Android 9.0+. On supported devices, Magisk Manager will download and customize a heavily obfuscated stub APK and use it as a replacement. The stub app will then download the full app into its private internal data, then dynamically load and run the actual full Magisk Manager.

Note, not all Android 9.0+ devices will be able to use this feature. To use an obfuscated stub as Magisk Manager, the Magisk daemon will have to rely on a special way to communicate with the app, and some OEMs (most likely Chinese manufacturers) block certain broadcasts, breaking the communication channel.

Magisk Manager will verify compatibility before it uses stubs to hide itself on Android 9.0+. The verification relies on Magisk v20.1+, which means you have to fully upgrade and reboot in order to opt in this feature. If you are already running a hidden Magisk Manager, restore and upgrade Magisk Manager, upgrade Magisk and reboot, then re-hide the app.

For those incompatible with the hiding-with-stub feature, there are also a few updates that everyone, regardless whether using stubs or not, can enjoy:

  • You can now customize the app name of the repackaged Magisk Manager
  • Magisk Manager will generate new keys to sign the repackaged APK to prevent signature detection

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2019.11.2 Magisk v20.1

Lots of bug fixes from v20.0, and some cool new features!

Updated Magisk Manager Hiding

Starting with Magisk v20.1 paired with Magisk Manager v7.4.0, a new hiding mode is introduced for Android 9.0+. On supported devices, Magisk Manager will download and customize a heavily obfuscated stub APK and use it as a replacement. The stub app will then download the full app into its private internal data, then dynamically load and run the actual full Magisk Manager.

Note, not all Android 9.0+ devices will be able to use this feature. To use an obfuscated stub as Magisk Manager, the Magisk daemon will have to rely on a special way to communicate with the app, and some OEMs (most likely Chinese manufacturers) block certain broadcasts, breaking the communication channel.

Magisk Manager will verify compatibility before it uses stubs to hide itself on Android 9.0+. The verification relies on Magisk v20.1+, which means you have to fully upgrade and reboot in order to opt in this feature. If you are already running a hidden Magisk Manager, restore and upgrade Magisk Manager, upgrade Magisk and reboot, then re-hide the app.

For those incompatible with the hiding-with-stub feature, there are also a few updates that everyone, regardless whether using stubs or not, can enjoy:

  • You can now customize the app name of the repackaged Magisk Manager
  • Magisk Manager will generate new keys to sign the repackaged APK to prevent signature detection

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/20200.html b/releases/20200.html index 601513a4..44932b3d 100644 --- a/releases/20200.html +++ b/releases/20200.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.1.2 Magisk v20.2

Happy New Year! Let's start 2020 with a new Magisk release 😃

Pre-Init sepolicy Patches for Modules

Magisk v20.2 add support for modules to include its own custom sepolicy patches. Developers used to use boot scripts along with the magiskpolicy tool to do live sepolicy patches; however, this method leads to numerous issues as Android is no longer designed to allow live sepolicy patches, and on some devices (e.g. Huawei) this method is outright inapplicable.

To address this issue, Magisk allow module devs to create a new file called sepolicy.rule in their modules. The module installer script and Magisk daemon will make sure this file is stored in somewhere accessible pre-init to allow magiskinit to do its job every time your device boots up.

New Module Installer Format

The old template is actually pretty convoluted: developers are expected to implement specific callback functions in their install.sh, and the zip file structure does not directly represent how modules are actually stored on your device. The new module installer format makes creating new modules very easy, but still give experienced developers tons of freedom to do anything they want in the installation process.

For details regarding sepolicy.rule and the new module installer format, please read the updated Developer Guides. Note that the old "Module Installer Template" is obsolete; creating a Magisk module no longer requires a "template" as it is now a straightforward process.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.1.2 Magisk v20.2

Happy New Year! Let's start 2020 with a new Magisk release 😃

Pre-Init sepolicy Patches for Modules

Magisk v20.2 add support for modules to include its own custom sepolicy patches. Developers used to use boot scripts along with the magiskpolicy tool to do live sepolicy patches; however, this method leads to numerous issues as Android is no longer designed to allow live sepolicy patches, and on some devices (e.g. Huawei) this method is outright inapplicable.

To address this issue, Magisk allow module devs to create a new file called sepolicy.rule in their modules. The module installer script and Magisk daemon will make sure this file is stored in somewhere accessible pre-init to allow magiskinit to do its job every time your device boots up.

New Module Installer Format

The old template is actually pretty convoluted: developers are expected to implement specific callback functions in their install.sh, and the zip file structure does not directly represent how modules are actually stored on your device. The new module installer format makes creating new modules very easy, but still give experienced developers tons of freedom to do anything they want in the installation process.

For details regarding sepolicy.rule and the new module installer format, please read the updated Developer Guides. Note that the old "Module Installer Template" is obsolete; creating a Magisk module no longer requires a "template" as it is now a straightforward process.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/20300.html b/releases/20300.html index 5fe73db1..8544f9ba 100644 --- a/releases/20300.html +++ b/releases/20300.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.1.10 Magisk v20.3

Magisk

  • Fix magiskboot crashing when dealing with lz4_legacy format

Magisk Manager

  • Fix MagiskHide app component toggles

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.1.10 Magisk v20.3

Magisk

  • Fix magiskboot crashing when dealing with lz4_legacy format

Magisk Manager

  • Fix MagiskHide app component toggles

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/20400.html b/releases/20400.html index 6537a4f2..20a3502e 100644 --- a/releases/20400.html +++ b/releases/20400.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.3.23 Magisk v20.4

Miscellaneous

This release is mainly focused on stability and bug squashing. Please be aware that MagiskHide is no longer enabled by default. Since Google has enabled hardware-based key attestation in SafetyNet (FAQ), there is no effective way to pass full CTS SafetyNet anymore (although Google seems to have temporarily reverted the change).

I decided that the fully redesigned Magisk Manager isn't fully ready for prime time yet, so this time around no Magisk Manager update is released. The WIP manager will continue to be improved and is available for testing on the canary channel.

BusyBox Standalone Mode

Starting with Magisk v20.4, all Magisk related scripts, including boot scripts and module installation scripts, will run on BusyBox's shell (ash) in standalone mode. In BusyBox ash standalone mode, every single command will be forced to use the one that is in Magisk's BusyBox (if available). For instance, no matter how you change the environment variable PATH, the rm command will always use the one in BusyBox, not the one in system, external BusyBox, vendor, or included in custom recovery.

The reason behind this change is that all scripts will be guaranteed to have 100% consistent results no matter how the environment is setup. The internal BusyBox is significantly beefed up with patches from @osm0sis, and also with SELinux features enabled. It shall offer a very complete, reliable, and consistent scripting environment. If in any case you require to use a command outside of BusyBox, please call it with the full path (e.g. /system/bin/nslookup)

Magisk Changelog

  • [MagiskInit] Fix potential bootloop in A-only 2SI devices
  • [MagiskInit] Properly support Tegra partition naming
  • [General] Load libsqlite.so dynamically, which removes the need to use wrapper scripts on Android 10+
  • [General] Detect API level with a fallback method on some devices
  • [General] Workaround possible bug in x86 kernel readlinkat system call
  • [BusyBox] Enable SELinux features. Add chcon/runcon etc., and '-Z' option to many applets
  • [BusyBox] Introduce standalone mode. More details in release notes
  • [MagiskHide] Disable MagiskHide by default
  • [MagiskHide] Add more potential detectable system properties
  • [MagiskHide] Add workaround for Xiaomi devices bootloop when MagiskHide is enabled on cross region ROMs
  • [MagiskBoot] Support patching special Motorolla DTB format
  • [MagiskPolicy] Support 'genfscon' sepolicy rules
  • [Scripts] Support NAND based boot images (character nodes in /dev/block)
  • [Scripts] Better addon.d (both v1 and v2) support
  • [Scripts] Support Lineage Recovery for Android 10+

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.3.23 Magisk v20.4

Miscellaneous

This release is mainly focused on stability and bug squashing. Please be aware that MagiskHide is no longer enabled by default. Since Google has enabled hardware-based key attestation in SafetyNet (FAQ), there is no effective way to pass full CTS SafetyNet anymore (although Google seems to have temporarily reverted the change).

I decided that the fully redesigned Magisk Manager isn't fully ready for prime time yet, so this time around no Magisk Manager update is released. The WIP manager will continue to be improved and is available for testing on the canary channel.

BusyBox Standalone Mode

Starting with Magisk v20.4, all Magisk related scripts, including boot scripts and module installation scripts, will run on BusyBox's shell (ash) in standalone mode. In BusyBox ash standalone mode, every single command will be forced to use the one that is in Magisk's BusyBox (if available). For instance, no matter how you change the environment variable PATH, the rm command will always use the one in BusyBox, not the one in system, external BusyBox, vendor, or included in custom recovery.

The reason behind this change is that all scripts will be guaranteed to have 100% consistent results no matter how the environment is setup. The internal BusyBox is significantly beefed up with patches from @osm0sis, and also with SELinux features enabled. It shall offer a very complete, reliable, and consistent scripting environment. If in any case you require to use a command outside of BusyBox, please call it with the full path (e.g. /system/bin/nslookup)

Magisk Changelog

  • [MagiskInit] Fix potential bootloop in A-only 2SI devices
  • [MagiskInit] Properly support Tegra partition naming
  • [General] Load libsqlite.so dynamically, which removes the need to use wrapper scripts on Android 10+
  • [General] Detect API level with a fallback method on some devices
  • [General] Workaround possible bug in x86 kernel readlinkat system call
  • [BusyBox] Enable SELinux features. Add chcon/runcon etc., and '-Z' option to many applets
  • [BusyBox] Introduce standalone mode. More details in release notes
  • [MagiskHide] Disable MagiskHide by default
  • [MagiskHide] Add more potential detectable system properties
  • [MagiskHide] Add workaround for Xiaomi devices bootloop when MagiskHide is enabled on cross region ROMs
  • [MagiskBoot] Support patching special Motorolla DTB format
  • [MagiskPolicy] Support 'genfscon' sepolicy rules
  • [Scripts] Support NAND based boot images (character nodes in /dev/block)
  • [Scripts] Better addon.d (both v1 and v2) support
  • [Scripts] Support Lineage Recovery for Android 10+

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/21000.html b/releases/21000.html index ed05fc37..7cd6e7c8 100644 --- a/releases/21000.html +++ b/releases/21000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.10.3 Magisk v21.0

Long time no see! v21.0 is the largest release in Magisk's history. It comes with full Android 11 support (tons of stuff had to be rewritten from scratch!), and a completely redesigned Magisk Manager. These are the reasons why this particular public release took me over half a year to wrap up.

To the end user, not much has changed other than the fact that Magisk Manager has completely changed its appearance. However developers should pay attention to some changes due to adjustments for Android 11. Full changelogs are too massive to fit, so here I'll point out the main changes and links to updated documentations.

Highlights

  • Android 11 support 🎉
  • Completely redesigned Magisk Manager
  • Safe Mode detection: if you installed a module that bootloops your device, reboot into Safe Mode and all modules will be disabled. More instructions on how to deal with broken modules is linked here.

The following are for advanced users/developer:

  • On Android 8.0+, Magisk now uses a new SELinux setup that keeps Android sandbox less compromised. This provides better security to rooted users, and also separates Magisk rules from original rules. Details here.
  • On Android 11, /sbin may no longer exist. For developers, this means the Magisk's internal tmpfs directory is no longer always /sbin, and instead randomly created every boot. To get the tmpfs path, use the command magisk --path (more details here). For custom kernel developers that uses overlay.d, updated docs are here.
  • magiskpolicy gained more features and some minor syntax changes, details here.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.10.3 Magisk v21.0

Long time no see! v21.0 is the largest release in Magisk's history. It comes with full Android 11 support (tons of stuff had to be rewritten from scratch!), and a completely redesigned Magisk Manager. These are the reasons why this particular public release took me over half a year to wrap up.

To the end user, not much has changed other than the fact that Magisk Manager has completely changed its appearance. However developers should pay attention to some changes due to adjustments for Android 11. Full changelogs are too massive to fit, so here I'll point out the main changes and links to updated documentations.

Highlights

  • Android 11 support 🎉
  • Completely redesigned Magisk Manager
  • Safe Mode detection: if you installed a module that bootloops your device, reboot into Safe Mode and all modules will be disabled. More instructions on how to deal with broken modules is linked here.

The following are for advanced users/developer:

  • On Android 8.0+, Magisk now uses a new SELinux setup that keeps Android sandbox less compromised. This provides better security to rooted users, and also separates Magisk rules from original rules. Details here.
  • On Android 11, /sbin may no longer exist. For developers, this means the Magisk's internal tmpfs directory is no longer always /sbin, and instead randomly created every boot. To get the tmpfs path, use the command magisk --path (more details here). For custom kernel developers that uses overlay.d, updated docs are here.
  • magiskpolicy gained more features and some minor syntax changes, details here.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/21100.html b/releases/21100.html index 3ed4a3c5..a241d561 100644 --- a/releases/21100.html +++ b/releases/21100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.11.13 Magisk v21.1

v21.1 is a maintenance update from v21.0, mostly addressing bugs, refining some details, and adding new boot image format support (for Pixel 5 and 4a 5G). Checkout the full v21.0 release notes if coming from older releases.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.11.13 Magisk v21.1

v21.1 is a maintenance update from v21.0, mostly addressing bugs, refining some details, and adding new boot image format support (for Pixel 5 and 4a 5G). Checkout the full v21.0 release notes if coming from older releases.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/21200.html b/releases/21200.html index 068e4366..73e958e3 100644 --- a/releases/21200.html +++ b/releases/21200.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2020.12.28 Magisk v21.2

v21.2 is a maintenance update, mostly addressing bugs, and expanding device compatibility. Checkout the full v21.0 release notes if coming from older releases.

v21.2

  • [MagiskInit] Detect 2SI after mounting system_root on legacy SAR devices
  • [General] Make sure post-fs-data scripts cannot block more than 35 seconds
  • [General] Fix the magisk --install-module command
  • [General] Trim Windows newline when reading files
  • [General] Directly log to file to prevent logcat weirdness
  • [MagiskBoot] Fix header dump/load for header v3 images

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2020.12.28 Magisk v21.2

v21.2 is a maintenance update, mostly addressing bugs, and expanding device compatibility. Checkout the full v21.0 release notes if coming from older releases.

v21.2

  • [MagiskInit] Detect 2SI after mounting system_root on legacy SAR devices
  • [General] Make sure post-fs-data scripts cannot block more than 35 seconds
  • [General] Fix the magisk --install-module command
  • [General] Trim Windows newline when reading files
  • [General] Directly log to file to prevent logcat weirdness
  • [MagiskBoot] Fix header dump/load for header v3 images

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/21400.html b/releases/21400.html index 11e5eb3f..8f5e0ebf 100644 --- a/releases/21400.html +++ b/releases/21400.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2021.1.17 Magisk v21.4

Update: v21.4 adds more regression hot fixes.

Happy 2021! v21.3 adds a workaround for devices with buggy F2FS Linux kernel drivers. This F2FS bug may cause bootloops on many devices. Checkout the full v21.0 release notes if coming from older releases.

v21.4

  • [MagiskSU] Fix su -c behavior that broke many root apps
  • [General] Properly handle read/write over sockets (the broken pipe issue)

v21.3

  • [MagiskInit] Avoid mounting f2fs userdata as it may result in kernel crashes. This shall fix a lot of bootloops
  • [MagiskBoot] Fix a minor header checksum bug for DHTB header and ASUS blob image formats
  • [MagiskHide] Allowing hiding isolated processes if the mount namespace is separated

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2021.1.17 Magisk v21.4

Update: v21.4 adds more regression hot fixes.

Happy 2021! v21.3 adds a workaround for devices with buggy F2FS Linux kernel drivers. This F2FS bug may cause bootloops on many devices. Checkout the full v21.0 release notes if coming from older releases.

v21.4

  • [MagiskSU] Fix su -c behavior that broke many root apps
  • [General] Properly handle read/write over sockets (the broken pipe issue)

v21.3

  • [MagiskInit] Avoid mounting f2fs userdata as it may result in kernel crashes. This shall fix a lot of bootloops
  • [MagiskBoot] Fix a minor header checksum bug for DHTB header and ASUS blob image formats
  • [MagiskHide] Allowing hiding isolated processes if the mount namespace is separated

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/22000.html b/releases/22000.html index f095ff01..bb71d3ec 100644 --- a/releases/22000.html +++ b/releases/22000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2021.2.23 Magisk v22.0

RESTORE THE EXISTING MAGISK MANAGER BACK TO NORMAL BEFORE UPGRADING IF HIDDEN!

Another major Magisk release! This time our focus is not the core Magisk implementation, but rather on improving the whole Magisk user experience.

Magisk Manager is dead.
Long live the Magisk app!

Ever since the first Magisk release, Magisk (the core components) and Magisk Manager (the companion app) are released separately and isn't necessarily always in sync. This leads to some confusion and a lot of complexity when downloading/installing Magisk through the app. Starting from v22.0, the Magisk app (renamed from Magisk Manager) includes everything it needs within the APK itself, making installation a 100% offline process.

Custom recovery lovers, no worries! The Magisk app APK itself is a custom recovery flashable zip, just like MAGIC™🌈. Check out the updated installation guide for more info.

App Hiding

Another major breakthrough in this release is that devices lower than Android 9.0 can now also use the advanced app hiding technique to hide the Magisk app. Due to this incompatible change, RESTORE THE EXISTING MAGISK MANAGER BACK TO NORMAL BEFORE UPGRADING IF HIDDEN!

Bug Fixes

  • [MagiskHide] Fix a bug when stopping MagiskHide does not take effect
  • [MagiskBoot] Fix bug when unpacking lz4_lg compressed boot images
  • [MagiskInit] Support Galaxy S21 series
  • [MagiskSU] Fix incorrect APEX paths that caused libsqlite.so fail to load

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2021.2.23 Magisk v22.0

RESTORE THE EXISTING MAGISK MANAGER BACK TO NORMAL BEFORE UPGRADING IF HIDDEN!

Another major Magisk release! This time our focus is not the core Magisk implementation, but rather on improving the whole Magisk user experience.

Magisk Manager is dead.
Long live the Magisk app!

Ever since the first Magisk release, Magisk (the core components) and Magisk Manager (the companion app) are released separately and isn't necessarily always in sync. This leads to some confusion and a lot of complexity when downloading/installing Magisk through the app. Starting from v22.0, the Magisk app (renamed from Magisk Manager) includes everything it needs within the APK itself, making installation a 100% offline process.

Custom recovery lovers, no worries! The Magisk app APK itself is a custom recovery flashable zip, just like MAGIC™🌈. Check out the updated installation guide for more info.

App Hiding

Another major breakthrough in this release is that devices lower than Android 9.0 can now also use the advanced app hiding technique to hide the Magisk app. Due to this incompatible change, RESTORE THE EXISTING MAGISK MANAGER BACK TO NORMAL BEFORE UPGRADING IF HIDDEN!

Bug Fixes

  • [MagiskHide] Fix a bug when stopping MagiskHide does not take effect
  • [MagiskBoot] Fix bug when unpacking lz4_lg compressed boot images
  • [MagiskInit] Support Galaxy S21 series
  • [MagiskSU] Fix incorrect APEX paths that caused libsqlite.so fail to load

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/22100.html b/releases/22100.html index 6f086f3e..19b4618c 100644 --- a/releases/22100.html +++ b/releases/22100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2021.4.9 Magisk v22.1

This release is focused on fixing regressions and bugs. Check the v22.0 release notes if coming from older releases.

Note: Magisk v22 is the last major version to support Jellybean and Kitkat. Magisk v23 will only support Android 5.0 and higher.

Bug Fixes

  • [App] Prevent multiple installation sessions running in parallel
  • [App] Prevent OutOfMemory crashes when checking boot signature on PXA boot images
  • [General] Proper cgroup migration implementation
  • [General] Rewrite log writer from scratch, should resolve any crashes and deadlocks
  • [General] Many scripts updates fixing regressions
  • [MagiskHide] Prevent possible deadlock when signal arrives
  • [MagiskHide] Partial match process names if necessary
  • [MagiskBoot] Preserve and patch AVB 2.0 structures/headers in boot images
  • [MagiskBoot] Properly strip out data encryption flags
  • [MagiskBoot] Prevent possible integer overflow
  • [MagiskInit] Fix sepolicy.rule mounting strategy
  • [resetprop] Always delete existing ro. props before updating. This will fix bootloops that could be caused by modifying device fingerprint properties.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2021.4.9 Magisk v22.1

This release is focused on fixing regressions and bugs. Check the v22.0 release notes if coming from older releases.

Note: Magisk v22 is the last major version to support Jellybean and Kitkat. Magisk v23 will only support Android 5.0 and higher.

Bug Fixes

  • [App] Prevent multiple installation sessions running in parallel
  • [App] Prevent OutOfMemory crashes when checking boot signature on PXA boot images
  • [General] Proper cgroup migration implementation
  • [General] Rewrite log writer from scratch, should resolve any crashes and deadlocks
  • [General] Many scripts updates fixing regressions
  • [MagiskHide] Prevent possible deadlock when signal arrives
  • [MagiskHide] Partial match process names if necessary
  • [MagiskBoot] Preserve and patch AVB 2.0 structures/headers in boot images
  • [MagiskBoot] Properly strip out data encryption flags
  • [MagiskBoot] Prevent possible integer overflow
  • [MagiskInit] Fix sepolicy.rule mounting strategy
  • [resetprop] Always delete existing ro. props before updating. This will fix bootloops that could be caused by modifying device fingerprint properties.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/23000.html b/releases/23000.html index 7381f70f..572d1290 100644 --- a/releases/23000.html +++ b/releases/23000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2021.5.12 Magisk v23.0

This release is focused on fixing regressions and bugs.

Note: Magisk v22 is the last major version to support Jellybean and Kitkat. Magisk v23 only supports Android 5.0 and higher.

Bug Fixes

  • [App] Update snet extension. This fixes SafetyNet API errors.
  • [App] Fix a bug in the stub app that causes APK installation to fail
  • [App] Hide annoying errors in logs when hidden as stub
  • [App] Fix issues when patching ODIN tar files when the app is hidden
  • [General] Remove all pre Android 5.0 support
  • [General] Update BusyBox to use proper libc
  • [General] Fix C++ undefined behaviors
  • [General] Several sepolicy.rule copy/installation fixes
  • [MagiskPolicy] Remove unnecessary sepolicy rules
  • [MagiskHide] Update package and process name validation logic
  • [MagiskHide] Some changes that prevents zygote deadlock

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2021.5.12 Magisk v23.0

This release is focused on fixing regressions and bugs.

Note: Magisk v22 is the last major version to support Jellybean and Kitkat. Magisk v23 only supports Android 5.0 and higher.

Bug Fixes

  • [App] Update snet extension. This fixes SafetyNet API errors.
  • [App] Fix a bug in the stub app that causes APK installation to fail
  • [App] Hide annoying errors in logs when hidden as stub
  • [App] Fix issues when patching ODIN tar files when the app is hidden
  • [General] Remove all pre Android 5.0 support
  • [General] Update BusyBox to use proper libc
  • [General] Fix C++ undefined behaviors
  • [General] Several sepolicy.rule copy/installation fixes
  • [MagiskPolicy] Remove unnecessary sepolicy rules
  • [MagiskHide] Update package and process name validation logic
  • [MagiskHide] Some changes that prevents zygote deadlock

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/24000.html b/releases/24000.html index cf8584e4..0991e9e1 100644 --- a/releases/24000.html +++ b/releases/24000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.1.26 Magisk v24.0

It has been a while since the last public release, long time no see! A personal update for those unaware: I am now working at Google on the Android Platform Security team. Without further ado, let's jump right into it!

MagiskHide Removal

I have lost interest in fighting this battle for quite a while; plus, the existing MagiskHide implementation is flawed in so many ways. Decoupling Magisk from root hiding is, in my opinion, beneficial to the community. Ever since my announcement on Twitter months ago, highly effective "root hiding" modules (much MUCH better than MagiskHide) has been flourishing, which again shows that people are way more capable than I am on this subject. So why not give those determined their time to shine, and let me focus on improving Magisk instead of drowning in the everlasting cat-and-mouse game 😉.

Sunsetting Magisk-Modules-Repo

Due to lack of time and maintenance, the centralized Magisk-Modules-Repo was frozen, and the functionality to download modules from the repo is removed in v24.0. As a supplement, module developers can now specify an updateJson URL in their modules. The Magisk app will use that to check, download, and install module updates.

Introducing Zygisk

Zygisk is Magisk in Zygote, the next big thing for Magisk! When this feature is enabled, a part of Magisk will run in the Zygote daemon process, allowing module developers to run code directly in every Android apps' processes. If you've heard of Riru, then Zygisk is inspired by that project and is functionally similar, though the implementation is quite different internally. I cannot wait to see what module developers can achieve using Zygisk!

Documentation

For developers, details about updateJson and building Zygisk modules can all be found in the updated documentation.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.1.26 Magisk v24.0

It has been a while since the last public release, long time no see! A personal update for those unaware: I am now working at Google on the Android Platform Security team. Without further ado, let's jump right into it!

MagiskHide Removal

I have lost interest in fighting this battle for quite a while; plus, the existing MagiskHide implementation is flawed in so many ways. Decoupling Magisk from root hiding is, in my opinion, beneficial to the community. Ever since my announcement on Twitter months ago, highly effective "root hiding" modules (much MUCH better than MagiskHide) has been flourishing, which again shows that people are way more capable than I am on this subject. So why not give those determined their time to shine, and let me focus on improving Magisk instead of drowning in the everlasting cat-and-mouse game 😉.

Sunsetting Magisk-Modules-Repo

Due to lack of time and maintenance, the centralized Magisk-Modules-Repo was frozen, and the functionality to download modules from the repo is removed in v24.0. As a supplement, module developers can now specify an updateJson URL in their modules. The Magisk app will use that to check, download, and install module updates.

Introducing Zygisk

Zygisk is Magisk in Zygote, the next big thing for Magisk! When this feature is enabled, a part of Magisk will run in the Zygote daemon process, allowing module developers to run code directly in every Android apps' processes. If you've heard of Riru, then Zygisk is inspired by that project and is functionally similar, though the implementation is quite different internally. I cannot wait to see what module developers can achieve using Zygisk!

Documentation

For developers, details about updateJson and building Zygisk modules can all be found in the updated documentation.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/24100.html b/releases/24100.html index eb6e0619..b6bce336 100644 --- a/releases/24100.html +++ b/releases/24100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.1.28 Magisk v24.1

For those coming from v24.0, v24.1 only has some minor app improvements. The following are copied from v24.0 release notes.

It has been a while since the last public release, long time no see! A personal update for those unaware: I am now working at Google on the Android Platform Security team. Without further ado, let's jump right into it!

MagiskHide Removal

I have lost interest in fighting this battle for quite a while; plus, the existing MagiskHide implementation is flawed in so many ways. Decoupling Magisk from root hiding is, in my opinion, beneficial to the community. Ever since my announcement on Twitter months ago, highly effective "root hiding" modules (much MUCH better than MagiskHide) has been flourishing, which again shows that people are way more capable than I am on this subject. So why not give those determined their time to shine, and let me focus on improving Magisk instead of drowning in the everlasting cat-and-mouse game 😉.

Sunsetting Magisk-Modules-Repo

Due to lack of time and maintenance, the centralized Magisk-Modules-Repo was frozen, and the functionality to download modules from the repo is removed in v24.0. As a supplement, module developers can now specify an updateJson URL in their modules. The Magisk app will use that to check, download, and install module updates.

Introducing Zygisk

Zygisk is Magisk in Zygote, the next big thing for Magisk! When this feature is enabled, a part of Magisk will run in the Zygote daemon process, allowing module developers to run code directly in every Android apps' processes. If you've heard of Riru, then Zygisk is inspired by that project and is functionally similar, though the implementation is quite different internally. I cannot wait to see what module developers can achieve using Zygisk!

Documentation

For developers, details about updateJson and building Zygisk modules can all be found in the updated documentation.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.1.28 Magisk v24.1

For those coming from v24.0, v24.1 only has some minor app improvements. The following are copied from v24.0 release notes.

It has been a while since the last public release, long time no see! A personal update for those unaware: I am now working at Google on the Android Platform Security team. Without further ado, let's jump right into it!

MagiskHide Removal

I have lost interest in fighting this battle for quite a while; plus, the existing MagiskHide implementation is flawed in so many ways. Decoupling Magisk from root hiding is, in my opinion, beneficial to the community. Ever since my announcement on Twitter months ago, highly effective "root hiding" modules (much MUCH better than MagiskHide) has been flourishing, which again shows that people are way more capable than I am on this subject. So why not give those determined their time to shine, and let me focus on improving Magisk instead of drowning in the everlasting cat-and-mouse game 😉.

Sunsetting Magisk-Modules-Repo

Due to lack of time and maintenance, the centralized Magisk-Modules-Repo was frozen, and the functionality to download modules from the repo is removed in v24.0. As a supplement, module developers can now specify an updateJson URL in their modules. The Magisk app will use that to check, download, and install module updates.

Introducing Zygisk

Zygisk is Magisk in Zygote, the next big thing for Magisk! When this feature is enabled, a part of Magisk will run in the Zygote daemon process, allowing module developers to run code directly in every Android apps' processes. If you've heard of Riru, then Zygisk is inspired by that project and is functionally similar, though the implementation is quite different internally. I cannot wait to see what module developers can achieve using Zygisk!

Documentation

For developers, details about updateJson and building Zygisk modules can all be found in the updated documentation.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/24200.html b/releases/24200.html index 9c9405c6..3dd56a16 100644 --- a/releases/24200.html +++ b/releases/24200.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.3.1 Magisk v24.2

Maintenance release fixing various issues.

  • [MagiskSU] Fix buffer overflow
  • [MagiskSU] Fix owner managed multiuser superuser settings
  • [MagiskSU] Fix command logging when using su -c <cmd>
  • [MagiskSU] Prevent su request indefinite blocking
  • [MagiskBoot] Support lz4_legacy archive with multiple magic
  • [MagiskBoot] Fix lz4_lg compression
  • [DenyList] Allow targeting processes running as system UID
  • [Zygisk] Workaround Samsung's "early zygote"
  • [Zygisk] Improved Zygisk loading mechanism
  • [Zygisk] Fix application UID tracking
  • [Zygisk] Fix improper umask being set in zygote
  • [App] Fix BusyBox execution test
  • [App] Improve stub loading mechanism
  • [App] Major app upgrade flow improvements
  • [General] Improve commandline error handling and messaging

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.3.1 Magisk v24.2

Maintenance release fixing various issues.

  • [MagiskSU] Fix buffer overflow
  • [MagiskSU] Fix owner managed multiuser superuser settings
  • [MagiskSU] Fix command logging when using su -c <cmd>
  • [MagiskSU] Prevent su request indefinite blocking
  • [MagiskBoot] Support lz4_legacy archive with multiple magic
  • [MagiskBoot] Fix lz4_lg compression
  • [DenyList] Allow targeting processes running as system UID
  • [Zygisk] Workaround Samsung's "early zygote"
  • [Zygisk] Improved Zygisk loading mechanism
  • [Zygisk] Fix application UID tracking
  • [Zygisk] Fix improper umask being set in zygote
  • [App] Fix BusyBox execution test
  • [App] Improve stub loading mechanism
  • [App] Major app upgrade flow improvements
  • [General] Improve commandline error handling and messaging

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/24300.html b/releases/24300.html index 42c6f0fc..c8255ab8 100644 --- a/releases/24300.html +++ b/releases/24300.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.3.10 Magisk v24.3

For those coming from v24.1, check the full changelog for changes introduced in v24.2.

  • [General] Stop using getrandom syscall
  • [Zygisk] Update API to v3, adding new fields to AppSpecializeArgs
  • [App] Improve app repackaging installation workflow

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.3.10 Magisk v24.3

For those coming from v24.1, check the full changelog for changes introduced in v24.2.

  • [General] Stop using getrandom syscall
  • [Zygisk] Update API to v3, adding new fields to AppSpecializeArgs
  • [App] Improve app repackaging installation workflow

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/25000.html b/releases/25000.html index 318eaadc..74f82de1 100644 --- a/releases/25000.html +++ b/releases/25000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.6.7 Magisk v25.0

Another major release! A lot of the changes aren't visible at the surface, but v25 is actually a really substantial upgrade!

MagiskInit Rewrite

A significant portion of magiskinit (the critical software that runs before your device boots up) is completely rewritten from scratch. Ever since Android introduced Project Treble in Android 8.0, Magisk has been constantly fighting against the increasingly complex partitioning and early mount setups of all kinds of devices, sometimes with weird OEM specific implementations. It got to a point that magiskinit had become so complicated that few people (including myself!) were aware of every detail, and maintaining this piece of software like this was clearly not sustainable. After many months of planning (yes, this whole re-architecture has been in my head for a long time) and some help from external contributors, a whole new sepolicy injection mechanism is introduced into Magisk, solving the "SELinux Problem" once and for all.

Since this is a full paradigm shift on how Magisk hot-patch the device at boot, several behaviors that many developers implicitly relied on might not exist. For example, Magisk no longer patches fstabs in most scenarios, which means AVB will remain intact; some custom kernels rely on AVB being stripped out for them by Magisk.

MagiskSU Security Enhancements

The superuser functionality of Magisk has not seen much changes ever since its introduction. v25 focuses on making root permission management more accurate and secure:

  • Add a whole new package tracking system to ensure malicious UID reuse attack cannot be performed
  • Properly support and implement the UX in the Magisk app for packages using sharedUserId
  • Enforce root manager APK signature verification to combat the rampant unofficial Magisk app "mods"

Many might not realize, but using a trusted, unmodified Magisk app is really important. Magisk's root daemon treats the Magisk app differently and gives it blanket root access without any restrictions. A modded Magisk app can potentially backdoor your device.

And in case some of you are about to put on your tin foil hats, this is not designed to "vendor lock-in"; the goal is to make sure your root management app comes from the same developer of the underlying root implementation. Magisk's build system allows custom distributors to use its own signing keys, and in addition, I am also providing official debug builds which skips any signature verification for development.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.6.7 Magisk v25.0

Another major release! A lot of the changes aren't visible at the surface, but v25 is actually a really substantial upgrade!

MagiskInit Rewrite

A significant portion of magiskinit (the critical software that runs before your device boots up) is completely rewritten from scratch. Ever since Android introduced Project Treble in Android 8.0, Magisk has been constantly fighting against the increasingly complex partitioning and early mount setups of all kinds of devices, sometimes with weird OEM specific implementations. It got to a point that magiskinit had become so complicated that few people (including myself!) were aware of every detail, and maintaining this piece of software like this was clearly not sustainable. After many months of planning (yes, this whole re-architecture has been in my head for a long time) and some help from external contributors, a whole new sepolicy injection mechanism is introduced into Magisk, solving the "SELinux Problem" once and for all.

Since this is a full paradigm shift on how Magisk hot-patch the device at boot, several behaviors that many developers implicitly relied on might not exist. For example, Magisk no longer patches fstabs in most scenarios, which means AVB will remain intact; some custom kernels rely on AVB being stripped out for them by Magisk.

MagiskSU Security Enhancements

The superuser functionality of Magisk has not seen much changes ever since its introduction. v25 focuses on making root permission management more accurate and secure:

  • Add a whole new package tracking system to ensure malicious UID reuse attack cannot be performed
  • Properly support and implement the UX in the Magisk app for packages using sharedUserId
  • Enforce root manager APK signature verification to combat the rampant unofficial Magisk app "mods"

Many might not realize, but using a trusted, unmodified Magisk app is really important. Magisk's root daemon treats the Magisk app differently and gives it blanket root access without any restrictions. A modded Magisk app can potentially backdoor your device.

And in case some of you are about to put on your tin foil hats, this is not designed to "vendor lock-in"; the goal is to make sure your root management app comes from the same developer of the underlying root implementation. Magisk's build system allows custom distributors to use its own signing keys, and in addition, I am also providing official debug builds which skips any signature verification for development.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/25100.html b/releases/25100.html index 8473691f..bc348772 100644 --- a/releases/25100.html +++ b/releases/25100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.6.19 Magisk v25.1

v25.1 fixes some minor bugs over v25.0. The following are the same as v25.0 release notes.

Another major release! A lot of the changes aren't visible at the surface, but v25 is actually a really substantial upgrade!

MagiskInit Rewrite

A significant portion of magiskinit (the critical software that runs before your device boots up) is completely rewritten from scratch. Ever since Android introduced Project Treble in Android 8.0, Magisk has been constantly fighting against the increasingly complex partitioning and early mount setups of all kinds of devices, sometimes with weird OEM specific implementations. It got to a point that magiskinit had become so complicated that few people (including myself!) were aware of every detail, and maintaining this piece of software like this was clearly not sustainable. After many months of planning (yes, this whole re-architecture has been in my head for a long time) and some help from external contributors, a whole new sepolicy injection mechanism is introduced into Magisk, solving the "SELinux Problem" once and for all.

Since this is a full paradigm shift on how Magisk hot-patch the device at boot, several behaviors that many developers implicitly relied on might not exist. For example, Magisk no longer patches fstabs in most scenarios, which means AVB will remain intact; some custom kernels rely on AVB being stripped out for them by Magisk.

MagiskSU Security Enhancements

The superuser functionality of Magisk has not seen much changes ever since its introduction. v25 focuses on making root permission management more accurate and secure:

  • Add a whole new package tracking system to ensure malicious UID reuse attack cannot be performed
  • Properly support and implement the UX in the Magisk app for packages using sharedUserId
  • Enforce root manager APK signature verification to combat the rampant unofficial Magisk app "mods"

Many might not realize, but using a trusted, unmodified Magisk app is really important. Magisk's root daemon treats the Magisk app differently and gives it blanket root access without any restrictions. A modded Magisk app can potentially backdoor your device.

And in case some of you are about to put on your tin foil hats, this is not designed to "vendor lock-in"; the goal is to make sure your root management app comes from the same developer of the underlying root implementation. Magisk's build system allows custom distributors to use its own signing keys, and in addition, I am also providing official debug builds which skips any signature verification for development.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.6.19 Magisk v25.1

v25.1 fixes some minor bugs over v25.0. The following are the same as v25.0 release notes.

Another major release! A lot of the changes aren't visible at the surface, but v25 is actually a really substantial upgrade!

MagiskInit Rewrite

A significant portion of magiskinit (the critical software that runs before your device boots up) is completely rewritten from scratch. Ever since Android introduced Project Treble in Android 8.0, Magisk has been constantly fighting against the increasingly complex partitioning and early mount setups of all kinds of devices, sometimes with weird OEM specific implementations. It got to a point that magiskinit had become so complicated that few people (including myself!) were aware of every detail, and maintaining this piece of software like this was clearly not sustainable. After many months of planning (yes, this whole re-architecture has been in my head for a long time) and some help from external contributors, a whole new sepolicy injection mechanism is introduced into Magisk, solving the "SELinux Problem" once and for all.

Since this is a full paradigm shift on how Magisk hot-patch the device at boot, several behaviors that many developers implicitly relied on might not exist. For example, Magisk no longer patches fstabs in most scenarios, which means AVB will remain intact; some custom kernels rely on AVB being stripped out for them by Magisk.

MagiskSU Security Enhancements

The superuser functionality of Magisk has not seen much changes ever since its introduction. v25 focuses on making root permission management more accurate and secure:

  • Add a whole new package tracking system to ensure malicious UID reuse attack cannot be performed
  • Properly support and implement the UX in the Magisk app for packages using sharedUserId
  • Enforce root manager APK signature verification to combat the rampant unofficial Magisk app "mods"

Many might not realize, but using a trusted, unmodified Magisk app is really important. Magisk's root daemon treats the Magisk app differently and gives it blanket root access without any restrictions. A modded Magisk app can potentially backdoor your device.

And in case some of you are about to put on your tin foil hats, this is not designed to "vendor lock-in"; the goal is to make sure your root management app comes from the same developer of the underlying root implementation. Magisk's build system allows custom distributors to use its own signing keys, and in addition, I am also providing official debug builds which skips any signature verification for development.

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/25200.html b/releases/25200.html index 9733f394..7d40909f 100644 --- a/releases/25200.html +++ b/releases/25200.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2022.7.20 Magisk v25.2

Maintenance release fixing various issues.

  • [MagiskInit] Fix a potential issue when stub cpio is used
  • [MagiskInit] Fix reboot to recovery when stub cpio is used
  • [MagiskInit] Fix sepolicy.rules symlink for rootfs devices
  • [General] Better data encryption detection
  • [General] Move the whole logging infrastructure into Rust

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2022.7.20 Magisk v25.2

Maintenance release fixing various issues.

  • [MagiskInit] Fix a potential issue when stub cpio is used
  • [MagiskInit] Fix reboot to recovery when stub cpio is used
  • [MagiskInit] Fix sepolicy.rules symlink for rootfs devices
  • [General] Better data encryption detection
  • [General] Move the whole logging infrastructure into Rust

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/26000.html b/releases/26000.html index 5541ed38..1ad995b6 100644 --- a/releases/26000.html +++ b/releases/26000.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2023.4.5 Magisk v26.0

Hey! Long time no see!

Bumping Minimum Android Version to 6.0

Magisk's support for Android Lollipop has been pretty broken for a while without it being noticed. Also, none of the active developers of Magisk have actual hardware to run Android Lollipop. We rely on using the official Android emulator for regression testing on older platforms, however Google never shipped a Lollipop emulator image with SELinux support, leaving us with no option but to drop Lollipop support since we don't feel comfortable supporting Android Lollipop without adequate testing.

New Magic Mount Implementation

Magic Mount, the feature that make modules modify partitions, has gone through a major rewrite. The existing implementation doesn't work well with OEMs injecting overlays into their system using overlayfs. The new implementation fundamentally changes how filesystem mirrors are created, giving us a more accurate clone of the unmodified filesystem.

New sepolicy.rule Implementation

Magisk allows modules to provide custom SELinux patches by including the file sepolicy.rule. Due to the complicated nature of SELinux patching, the compatibility of this functionality has been pretty spotty; many devices are not supported. In this release, a brand new pre-init partition detection mechanism has been designed to support even more devices. Due to complicated reasons, this detection mechanism cannot be performed in a custom recovery environment.

This means that any installation of Magisk v26+ using custom recovery will be incomplete; a subsequent re-installation through the Magisk app after booting up is required.

Zygisk Updates

The new Zygisk API v4 is now live! It comes with new features and a refined PLT function hook API. The implementaton of Zygisk has also gone through some major refactoring, including new code loading/unloading mechanisms and a new PLT function hook implementation.

Head over to the Zygisk Module Sample repository to check out the new API and documentation!

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2023.4.5 Magisk v26.0

Hey! Long time no see!

Bumping Minimum Android Version to 6.0

Magisk's support for Android Lollipop has been pretty broken for a while without it being noticed. Also, none of the active developers of Magisk have actual hardware to run Android Lollipop. We rely on using the official Android emulator for regression testing on older platforms, however Google never shipped a Lollipop emulator image with SELinux support, leaving us with no option but to drop Lollipop support since we don't feel comfortable supporting Android Lollipop without adequate testing.

New Magic Mount Implementation

Magic Mount, the feature that make modules modify partitions, has gone through a major rewrite. The existing implementation doesn't work well with OEMs injecting overlays into their system using overlayfs. The new implementation fundamentally changes how filesystem mirrors are created, giving us a more accurate clone of the unmodified filesystem.

New sepolicy.rule Implementation

Magisk allows modules to provide custom SELinux patches by including the file sepolicy.rule. Due to the complicated nature of SELinux patching, the compatibility of this functionality has been pretty spotty; many devices are not supported. In this release, a brand new pre-init partition detection mechanism has been designed to support even more devices. Due to complicated reasons, this detection mechanism cannot be performed in a custom recovery environment.

This means that any installation of Magisk v26+ using custom recovery will be incomplete; a subsequent re-installation through the Magisk app after booting up is required.

Zygisk Updates

The new Zygisk API v4 is now live! It comes with new features and a refined PLT function hook API. The implementaton of Zygisk has also gone through some major refactoring, including new code loading/unloading mechanisms and a new PLT function hook implementation.

Head over to the Zygisk Module Sample repository to check out the new API and documentation!

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/26100.html b/releases/26100.html index 9a3bc473..400f6dfe 100644 --- a/releases/26100.html +++ b/releases/26100.html @@ -16,9 +16,9 @@ -
Skip to content
本页内容

2023.4.11 Magisk v26.1

Changes from v26.0

  • [App] Fix crashing when revoking root permissions
  • [MagiskInit] Always prefer ext4 partitions over f2fs when selecting the pre-init partition
  • [General] Restore module files' context/owner/group from mirror. This is a regression introduced in v26.0

(The following is the same as v26.0 release notes)

Hey! Long time no see!

Bumping Minimum Android Version to 6.0

Magisk's support for Android Lollipop has been pretty broken for a while without it being noticed. Also, none of the active developers of Magisk have actual hardware to run Android Lollipop. We rely on using the official Android emulator for regression testing on older platforms, however Google never shipped a Lollipop emulator image with SELinux support, leaving us with no option but to drop Lollipop support since we don't feel comfortable supporting Android Lollipop without adequate testing.

New Magic Mount Implementation

Magic Mount, the feature that make modules modify partitions, has gone through a major rewrite. The existing implementation doesn't work well with OEMs injecting overlays into their system using overlayfs. The new implementation fundamentally changes how filesystem mirrors are created, giving us a more accurate clone of the unmodified filesystem.

New sepolicy.rule Implementation

Magisk allows modules to provide custom SELinux patches by including the file sepolicy.rule. Due to the complicated nature of SELinux patching, the compatibility of this functionality has been pretty spotty; many devices are not supported. In this release, a brand new pre-init partition detection mechanism has been designed to support even more devices. Due to complicated reasons, this detection mechanism cannot be performed in a custom recovery environment.

This means that any installation of Magisk v26+ using custom recovery will be incomplete; a subsequent re-installation through the Magisk app after booting up is required.

Zygisk Updates

The new Zygisk API v4 is now live! It comes with new features and a refined PLT function hook API. The implementaton of Zygisk has also gone through some major refactoring, including new code loading/unloading mechanisms and a new PLT function hook implementation.

Head over to the Zygisk Module Sample repository to check out the new API and documentation!

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- +
Skip to content
本页内容

2023.4.11 Magisk v26.1

Changes from v26.0

  • [App] Fix crashing when revoking root permissions
  • [MagiskInit] Always prefer ext4 partitions over f2fs when selecting the pre-init partition
  • [General] Restore module files' context/owner/group from mirror. This is a regression introduced in v26.0

(The following is the same as v26.0 release notes)

Hey! Long time no see!

Bumping Minimum Android Version to 6.0

Magisk's support for Android Lollipop has been pretty broken for a while without it being noticed. Also, none of the active developers of Magisk have actual hardware to run Android Lollipop. We rely on using the official Android emulator for regression testing on older platforms, however Google never shipped a Lollipop emulator image with SELinux support, leaving us with no option but to drop Lollipop support since we don't feel comfortable supporting Android Lollipop without adequate testing.

New Magic Mount Implementation

Magic Mount, the feature that make modules modify partitions, has gone through a major rewrite. The existing implementation doesn't work well with OEMs injecting overlays into their system using overlayfs. The new implementation fundamentally changes how filesystem mirrors are created, giving us a more accurate clone of the unmodified filesystem.

New sepolicy.rule Implementation

Magisk allows modules to provide custom SELinux patches by including the file sepolicy.rule. Due to the complicated nature of SELinux patching, the compatibility of this functionality has been pretty spotty; many devices are not supported. In this release, a brand new pre-init partition detection mechanism has been designed to support even more devices. Due to complicated reasons, this detection mechanism cannot be performed in a custom recovery environment.

This means that any installation of Magisk v26+ using custom recovery will be incomplete; a subsequent re-installation through the Magisk app after booting up is required.

Zygisk Updates

The new Zygisk API v4 is now live! It comes with new features and a refined PLT function hook API. The implementaton of Zygisk has also gone through some major refactoring, including new code loading/unloading mechanisms and a new PLT function hook implementation.

Head over to the Zygisk Module Sample repository to check out the new API and documentation!

Full Changelog: here

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file diff --git a/releases/index.html b/releases/index.html index 2426e95d..6b2b90c0 100644 --- a/releases/index.html +++ b/releases/index.html @@ -16,9 +16,9 @@ - - + + \ No newline at end of file diff --git a/tools.html b/tools.html index 98669f45..1a7d8237 100644 --- a/tools.html +++ b/tools.html @@ -16,7 +16,7 @@ -
Skip to content
本页内容

Magisk 工具

Magisk 为开发人员提供了大量安装工具、守护程序和实用程序。本文档涵盖了4个二进制文件和所有包含的小程序。二进制文件和小程序如下所示:

txt
magiskboot                 /* binary */
+    
Skip to content
本页内容

Magisk 工具

Magisk 为开发人员提供了大量安装工具、守护程序和实用程序。本文档涵盖了4个二进制文件和所有包含的小程序。二进制文件和小程序如下所示:

txt
magiskboot                 /* binary */
 magiskinit                 /* binary */
 magiskpolicy               /* binary */
 supolicy -> magiskpolicy
@@ -246,9 +246,9 @@
    -n      设置 props 而不经过 property_service
            (此标志仅影响 setprop)
    -p      从/向持久存储读取/写入属性
-           (此标志仅影响 getprop 和 delprop)

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

- + (此标志仅影响 getprop 和 delprop)

参考链接

原始文档版本: 2023年05月13日
在 GPL-3.0 许可下发布

+ \ No newline at end of file