Developing Zygisk Modules
This repository hosts a template zygisk module for developers to start developing Zygisk modules. Before developing Zygisk modules, you should first check out the official documentation for Magisk Modules. Do not fork this repository for your new module; either manually clone this repository, or press the "Use this template" button in the GitHub UI.
This repository is archived because it is meant to be read-only; the project is not abandoned. For any issues, please report them to the main Magisk repository.
API
- The canonical URL of the latest public Zygisk API is module/jni/zygisk.hpp.
- The header file is self documented; directly refer to the header source code for all Zygisk API details.
- Magisk is committed to maintain backwards compatibility forever. That is, whenever there is an API update for Zygisk in a newer Magisk version, Magisk can always load Zygisk modules built for an older Zygisk API.
- If you do not need the new features introduced in newer API versions, it's perfectly fine to stay on the older API version to maintain maximum compatibility.
Zygisk API | Minimal Magisk | Diff |
---|---|---|
v4 | 26000 | v3..v4 |
v3 | 24300 | v2..v3 |
v2 | 24000 | N/A |
Notes
- This repository can be opened with Android Studio.
- Developing Zygisk modules requires a modern C++ compiler. Please use NDK r21 or higher.
- All the C++ code is in the module/jni folder.
- DO NOT modify the default configurations in
Application.mk
unless you know what you are doing.
C++ STL
- The
APP_STL
variable inApplication.mk
is set tonone
. DO NOT use any C++ STL included in NDK. - If you'd like to use C++ STL, you have to use the
libcxx
included as a git submodule in this repository. Zygisk modules' code are injected into Zygote, and the includedlibc++
is setup to be lightweight and fully self contained that prevents conflicts with the hosting program. - If you do not need STL, link to the system
libstdc++
so that you can at least call thenew
operator. - Both configurations are demonstrated in the example
Android.mk
.
Building
- In the
module
folder, callndk-build
to compile your modules. - Your module libraries will be in
libs/<abi>/lib<module_name>.so
. - Copy the libraries into your module's
zygisk
folder, with the ABI as it's file name:
module_id
βββ module.prop
βββ zygisk
βββ arm64-v8a.so
βββ armeabi-v7a.so
βββ x86.so
βββ x86_64.so
License
Although the main Magisk project is licensed under GPLv3, the Zygisk API and its headers are not. Every source code in this repository is released under 0BSD (a public domain equivalent license), so you don't have to worry about any licensing issues while developing Zygisk modules.