The Magic Mask for Android
Go to file
topjohnwu c3968a26cf Remove dynamic loading code
All these code are moved into a private repo. The stub is actually
just a stub now; mixing dynamic load and stub is confusing.
2020-03-27 01:25:05 -07:00
app Disable animations in superuser fragment 2020-03-27 00:53:38 -07:00
docs Update logo.png 2020-03-23 05:12:30 -07:00
gradle/wrapper Update AS 2020-01-12 04:51:52 +08:00
native core: clean up /data/adb/magisk.img, etc. as well 2020-03-26 03:39:49 -07:00
scripts Make version reporting consistent 2020-03-23 01:17:13 -07:00
shared Set stub version in stub 2020-01-03 02:19:10 +08:00
signing Small SignAPK improvements 2020-01-31 04:07:12 +08:00
snet Update snet extension 2019-08-08 04:18:32 -07:00
stub Remove dynamic loading code 2020-03-27 01:25:05 -07:00
tools Clean elf after building shared binaries 2019-08-22 02:51:17 +08:00
.gitattributes Small native code reorganization 2020-03-09 01:50:30 -07:00
.gitignore Make main app fully independent from the stub 2019-10-17 02:55:42 -04:00
.gitmodules Add BusyBox SELinux support 2020-01-20 20:48:05 +08:00
build.gradle Updated the app to use navigation components instead of custom solution 2020-03-26 03:42:52 -07:00
build.py Update dependencies 2020-02-21 23:40:20 -08:00
config.prop.sample Assign signing keystore location in config 2019-10-17 16:20:01 -04:00
gradle.properties Updated build tools & enabled incremental kapt 2019-05-09 15:27:37 +02:00
gradlew Update Gradle wrapper to 5.6.1 2019-09-01 01:17:22 +08:00
gradlew.bat Update Gradle wrapper to 5.6.1 2019-09-01 01:17:22 +08:00
LICENSE Use GPL v3 license and update copyright messages 2017-04-22 17:12:54 +08:00
README.MD Update shields.io URL for caching 2020-03-25 09:08:10 -07:00
settings.gradle Remove net module 2019-08-04 18:33:20 -07:00

ZIP Downloads APK Downloads

Introduction

Magisk is a suite of open source tools for customizing Android, supporting devices higher than Android 4.2. It covers fundamental parts of Android customization: root, boot scripts, SELinux patches, AVB2.0 / dm-verity / forceencrypt removals etc.

Here are some feature highlights:

  • MagiskSU: Provide root access to your device
  • Magisk Modules: Modify read-only partitions by installing modules
  • MagiskHide: Hide Magisk from root detections / system integrity checks

Download


Android Version Support

  • Android 4.2+: MagiskSU and Magisk Modules Only
  • Android 4.4+: All core features available
  • Android 6.0+: Guaranteed MagiskHide support
  • Android 7.0+: Full MagiskHide protection
  • Android 9.0+: Magisk Manager stealth mode

Bug Reports

Canary Channels are cutting edge builds for those adventurous. To access canary builds, install either Canary Magisk Manager, switch to a Canary Channel in settings and upgrade.

Only bug reports from Canary DEBUG builds will be accepted.

For installation issues, upload both boot image and install logs.
For Magisk issues, upload boot logcat or dmesg.
For Magisk Manager crashes, record and upload the logcat when the crash occurs.

Building Magisk

  • Clone sources: git clone --recurse-submodules https://github.com/topjohnwu/Magisk.git
  • Magisk builds on any OS Android Studio supports. Install Android Studio and import the project.
  • Python 3.6+. For Windows only, install Colorama with pip install colorama in admin shell.
  • Use the JDK bundled in Android Studio:
    • macOS: export JAVA_HOME="/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home"
    • Linux: export PATH="/path/to/androidstudio/jre/bin:$PATH"
    • Windows: Add C:\Path\To\Android Studio\jre\bin to environment variable PATH
  • Set environment variable ANDROID_HOME to the Android SDK folder
  • Download / clone FrankeNDK and set environment variable ANDROID_NDK_HOME to the folder
  • Set configurations in config.prop. A sample file config.prop.sample is provided.
  • Run build.py to see help messages. For each supported actions, use -h to access help (e.g. ./build.py all -h)
  • By default, the script builds everything in debug mode. If you want to build Magisk Manager in release mode (with the -r, --release flag), you need a Java Keystore (only JKS format is supported) to sign APKs and zips. For more information, check Google's Documentation.

Translation Contributions

Default string resources for Magisk Manager and its stub APK are located here:

  • app/src/main/res/values/strings.xml
  • stub/src/main/res/values/strings.xml

Translate each and place them in the respective locations ([module]/src/main/res/values-[lang]/strings.xml).

License

Magisk, including all git submodules are free software:
you can redistribute it and/or modify it under the terms of the
GNU General Public License as published by the Free Software Foundation,
either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.