mirror of
https://github.com/topjohnwu/Magisk.git
synced 2024-12-19 14:37:44 +00:00
003e44fb84
We used to construct /sbin tmpfs overlay in early-init stage after SELinux is properly initialized. However the way it is implemented (forking daemon from magiskinit with complicated file waiting triggers) is extremely complicated and error prone. This commit moves the construction of the sbin overlay to pre-init stage. The catch is that since SELinux is not present at that point, proper selabel has to be reconstructed afterwards. Some additional SEPolicy rules are added to make sure init can access magisk binaries, and the secontext relabeling task is assigned to the main Magisk daemon.
34 lines
1.2 KiB
C++
34 lines
1.2 KiB
C++
#pragma once
|
|
|
|
#include <logging.h>
|
|
|
|
#define MAIN_SOCKET "d30138f2310a9fb9c54a3e0c21f58591"
|
|
#define JAVA_PACKAGE_NAME "com.topjohnwu.magisk"
|
|
#define LOGFILE "/cache/magisk.log"
|
|
#define UNBLOCKFILE "/dev/.magisk_unblock"
|
|
#define DISABLEFILE "/cache/.disable_magisk"
|
|
#define MAGISKTMP "/sbin/.magisk"
|
|
#define MIRRDIR MAGISKTMP "/mirror"
|
|
#define BLOCKDIR MAGISKTMP "/block"
|
|
#define BBPATH MAGISKTMP "/busybox"
|
|
#define MODULEMNT MAGISKTMP "/modules"
|
|
#define SECURE_DIR "/data/adb"
|
|
#define MODULEROOT SECURE_DIR "/modules"
|
|
#define MODULEUPGRADE SECURE_DIR "/modules_update"
|
|
#define DATABIN SECURE_DIR "/magisk"
|
|
#define MAGISKDB SECURE_DIR "/magisk.db"
|
|
#define BOOTCOUNT SECURE_DIR "/.boot_count"
|
|
#define MANAGERAPK DATABIN "/magisk.apk"
|
|
|
|
// Legacy crap
|
|
#define LEGACYCORE MODULEROOT "/.core"
|
|
|
|
constexpr const char *applet_names[] = { "su", "resetprop", "magiskhide", nullptr };
|
|
|
|
// Multi-call entrypoints
|
|
int magisk_main(int argc, char *argv[]);
|
|
int magiskhide_main(int argc, char *argv[]);
|
|
int magiskpolicy_main(int argc, char *argv[]);
|
|
int su_client_main(int argc, char *argv[]);
|
|
int resetprop_main(int argc, char *argv[]);
|