2017-04-06 06:12:29 +08:00
|
|
|
/* magisk.h - Top header
|
|
|
|
*/
|
|
|
|
|
2017-04-05 03:44:13 +08:00
|
|
|
#ifndef _MAGISK_H_
|
|
|
|
#define _MAGISK_H_
|
|
|
|
|
2017-04-15 03:23:09 +08:00
|
|
|
#include <stdlib.h>
|
2017-04-05 03:44:13 +08:00
|
|
|
#include <errno.h>
|
|
|
|
#include <string.h>
|
2017-04-09 07:25:10 +08:00
|
|
|
#include <pthread.h>
|
2017-04-05 03:44:13 +08:00
|
|
|
#include <android/log.h>
|
|
|
|
|
2017-04-18 21:31:12 +08:00
|
|
|
#define MAGISK_VER_STR xstr(MAGISK_VERSION) ":MAGISK"
|
2017-04-15 03:23:09 +08:00
|
|
|
|
|
|
|
#define str(a) #a
|
|
|
|
#define xstr(a) str(a)
|
|
|
|
|
|
|
|
#define REQUESTOR_DAEMON_PATH "\0MAGISK"
|
2017-04-08 07:37:43 +08:00
|
|
|
#define REQUESTOR_DAEMON_PATH_LEN 7
|
|
|
|
|
2017-04-05 03:44:13 +08:00
|
|
|
#define LOG_TAG "Magisk"
|
|
|
|
|
2017-04-16 23:13:53 +08:00
|
|
|
#ifndef ARG_MAX
|
|
|
|
#define ARG_MAX 4096
|
|
|
|
#endif
|
|
|
|
|
2017-05-01 01:58:52 +08:00
|
|
|
#define SELINUX_PATH "/sys/fs/selinux/"
|
|
|
|
#define SELINUX_ENFORCE SELINUX_PATH "enforce"
|
|
|
|
#define SELINUX_POLICY SELINUX_PATH "policy"
|
|
|
|
#define SELINUX_LOAD SELINUX_PATH "load"
|
|
|
|
|
2017-04-09 07:25:10 +08:00
|
|
|
// Global handler for PLOGE
|
|
|
|
extern __thread void (*err_handler)(void);
|
|
|
|
|
2017-04-24 21:43:30 +08:00
|
|
|
// Common error handlers
|
2017-04-15 03:23:09 +08:00
|
|
|
static inline void exit_proc() { exit(1); }
|
|
|
|
static inline void exit_thread() { pthread_exit(NULL); }
|
2017-04-24 21:43:30 +08:00
|
|
|
static inline void do_nothing() {}
|
2017-04-15 03:23:09 +08:00
|
|
|
|
|
|
|
// Dummy function to depress debug message
|
|
|
|
static inline void stub(const char *fmt, ...) {}
|
2017-04-09 07:25:10 +08:00
|
|
|
|
2017-04-05 03:44:13 +08:00
|
|
|
#ifdef DEBUG
|
|
|
|
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
|
|
|
|
#else
|
|
|
|
#define LOGD(...) stub(__VA_ARGS__)
|
|
|
|
#endif
|
2017-04-06 06:12:29 +08:00
|
|
|
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)
|
2017-04-05 06:08:53 +08:00
|
|
|
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN, LOG_TAG, __VA_ARGS__)
|
2017-04-05 03:44:13 +08:00
|
|
|
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
|
2017-04-06 06:12:29 +08:00
|
|
|
|
2017-04-15 03:23:09 +08:00
|
|
|
#define PLOGE(fmt, args...) { LOGE(fmt " failed with %d: %s", ##args, errno, strerror(errno)); err_handler(); }
|
2017-04-09 07:25:10 +08:00
|
|
|
|
2017-04-06 06:12:29 +08:00
|
|
|
extern char *argv0; /* For changing process name */
|
2017-04-05 03:44:13 +08:00
|
|
|
|
2017-04-15 18:10:54 +08:00
|
|
|
extern char *applet[];
|
|
|
|
extern int (*applet_main[]) (int, char *[]);
|
2017-05-02 04:55:55 +08:00
|
|
|
extern int null_fd;
|
2017-04-15 18:10:54 +08:00
|
|
|
|
2017-04-05 06:08:53 +08:00
|
|
|
// Multi-call entrypoints
|
|
|
|
int magiskhide_main(int argc, char *argv[]);
|
|
|
|
int magiskpolicy_main(int argc, char *argv[]);
|
2017-04-15 03:23:09 +08:00
|
|
|
int su_client_main(int argc, char *argv[]);
|
2017-04-05 06:08:53 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
int resetprop_main(int argc, char *argv[]);
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-04-05 03:44:13 +08:00
|
|
|
#endif
|