2021-01-08 14:25:44 +01:00
|
|
|
/*
|
|
|
|
* Original code: https://github.com/RikkaApps/Riru/blob/master/riru/src/main/cpp/jni_native_method.cpp
|
|
|
|
* The code is modified and sublicensed to GPLv3 for incorporating into Magisk.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2018-2021, RikkaW
|
|
|
|
* Copyright (c) 2021, John 'topjohnwu' Wu
|
|
|
|
*/
|
|
|
|
|
2021-01-10 02:41:25 +01:00
|
|
|
#define ENABLE_LEGACY_DP 1 // Nobody should use outdated developer preview...
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
// All possible missing arguments
|
|
|
|
static union {
|
|
|
|
struct {
|
2021-01-10 02:41:25 +01:00
|
|
|
jintArray fds_to_ignore;
|
2021-01-09 13:28:26 +01:00
|
|
|
jboolean is_child_zygote;
|
2021-01-10 02:41:25 +01:00
|
|
|
jboolean is_top_app;
|
|
|
|
jobjectArray pkg_data_info_list;
|
|
|
|
jobjectArray whitelisted_data_info_list;
|
|
|
|
jboolean mount_data_dirs;
|
|
|
|
jboolean mount_storage_dirs;
|
2021-01-09 13:28:26 +01:00
|
|
|
};
|
2021-01-10 02:41:25 +01:00
|
|
|
size_t args_buf[8]; // Easy access to wipe all variables at once
|
2021-01-09 13:28:26 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#define DCL_JNI(ret, name, sig, ...) \
|
|
|
|
const static char name##_sig[] = sig; \
|
|
|
|
static ret name(__VA_ARGS__)
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------
|
|
|
|
|
|
|
|
#define pre_fork() \
|
2021-01-10 02:41:25 +01:00
|
|
|
HookContext ctx{}; \
|
|
|
|
memset(args_buf, 0, sizeof(args_buf)); \
|
|
|
|
nativeForkAndSpecialize_pre(&ctx, env, clazz, uid, gid, gids, runtime_flags, \
|
|
|
|
rlimits, mount_external, se_info, nice_name, fds_to_close, fds_to_ignore, is_child_zygote, \
|
|
|
|
instruction_set, app_data_dir, is_top_app, pkg_data_info_list, whitelisted_data_info_list, \
|
|
|
|
mount_data_dirs, mount_storage_dirs)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define orig_fork(ver, ...) \
|
2021-01-10 02:41:25 +01:00
|
|
|
ctx.pid = reinterpret_cast<decltype(&nativeForkAndSpecialize_##ver)> \
|
2021-01-09 13:28:26 +01:00
|
|
|
(JNI::Zygote::nativeForkAndSpecialize_orig->fnPtr)(__VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define post_fork() \
|
2021-01-10 02:41:25 +01:00
|
|
|
nativeForkAndSpecialize_post(&ctx, env, clazz); \
|
|
|
|
return ctx.pid
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define DCL_FORK_AND_SPECIALIZE(ver, sig, ...) \
|
|
|
|
DCL_JNI(jint, nativeForkAndSpecialize_##ver, sig, __VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(m,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[ILjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(m, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, nice_name, fds_to_close, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(o,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[ILjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(o, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, nice_name, fds_to_close, fds_to_ignore, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(p,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(p, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
2021-01-10 02:41:25 +01:00
|
|
|
nice_name, fds_to_close, fds_to_ignore, is_child_zygote, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(q_alt,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;Z)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir, jboolean is_top_app) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(q_alt, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
2021-01-10 02:41:25 +01:00
|
|
|
nice_name, fds_to_close, fds_to_ignore, is_child_zygote, instruction_set, app_data_dir, is_top_app);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if ENABLE_LEGACY_DP
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(r_dp2,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir, jboolean is_top_app, jobjectArray pkg_data_info_list) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(r_dp2, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
2021-01-10 02:41:25 +01:00
|
|
|
nice_name, fds_to_close, fds_to_ignore, is_child_zygote, instruction_set, app_data_dir,
|
|
|
|
is_top_app, pkg_data_info_list);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(r_dp3,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;Z)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir, jboolean is_top_app, jobjectArray pkg_data_info_list,
|
|
|
|
jboolean mount_storage_dirs) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(r_dp3, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, nice_name, fds_to_close, fds_to_ignore, is_child_zygote, instruction_set,
|
|
|
|
app_data_dir, is_top_app, pkg_data_info_list, mount_storage_dirs);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
#endif // ENABLE_LEGACY_DP
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(r,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;[Ljava/lang/String;ZZ)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
2021-01-10 02:41:25 +01:00
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir, jboolean is_top_app, jobjectArray pkg_data_info_list,
|
|
|
|
jobjectArray whitelisted_data_info_list, jboolean mount_data_dirs, jboolean mount_storage_dirs) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(r, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
2021-01-10 02:41:25 +01:00
|
|
|
nice_name, fds_to_close, fds_to_ignore, is_child_zygote, instruction_set, app_data_dir, is_top_app,
|
|
|
|
pkg_data_info_list, whitelisted_data_info_list, mount_data_dirs, mount_storage_dirs);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(samsung_m,
|
|
|
|
"(II[II[[IILjava/lang/String;IILjava/lang/String;[ILjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jint category, jint accessInfo,
|
2021-01-10 02:41:25 +01:00
|
|
|
jstring nice_name, jintArray fds_to_close, jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(samsung_m, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, category, accessInfo, nice_name, fds_to_close, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(samsung_n,
|
|
|
|
"(II[II[[IILjava/lang/String;IILjava/lang/String;[ILjava/lang/String;Ljava/lang/String;I)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jint category, jint accessInfo,
|
2021-01-10 02:41:25 +01:00
|
|
|
jstring nice_name, jintArray fds_to_close, jstring instruction_set, jstring app_data_dir, jint a1) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(samsung_n, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, category, accessInfo, nice_name, fds_to_close, instruction_set, app_data_dir, a1);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(samsung_o,
|
|
|
|
"(II[II[[IILjava/lang/String;IILjava/lang/String;[I[ILjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jint category, jint accessInfo,
|
2021-01-10 02:41:25 +01:00
|
|
|
jstring nice_name, jintArray fds_to_close, jintArray fds_to_ignore, jstring instruction_set,
|
|
|
|
jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(samsung_o, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, category, accessInfo, nice_name, fds_to_close, fds_to_ignore,
|
|
|
|
instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_AND_SPECIALIZE(samsung_p,
|
|
|
|
"(II[II[[IILjava/lang/String;IILjava/lang/String;[I[IZLjava/lang/String;Ljava/lang/String;)I",
|
2021-01-08 14:25:44 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jint category, jint accessInfo,
|
2021-01-10 02:41:25 +01:00
|
|
|
jstring nice_name, jintArray fds_to_close, jintArray fds_to_ignore, jboolean is_child_zygote,
|
|
|
|
jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_fork();
|
2021-01-09 13:28:26 +01:00
|
|
|
orig_fork(samsung_p, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
2021-01-10 02:41:25 +01:00
|
|
|
se_info, category, accessInfo, nice_name, fds_to_close, fds_to_ignore, is_child_zygote,
|
|
|
|
instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_fork();
|
|
|
|
}
|
|
|
|
|
|
|
|
#define DCL_FORK(ver) { \
|
|
|
|
"nativeForkAndSpecialize", \
|
|
|
|
nativeForkAndSpecialize_##ver##_sig, \
|
|
|
|
(void *) &nativeForkAndSpecialize_##ver \
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define pre_spec() \
|
2021-01-10 02:41:25 +01:00
|
|
|
HookContext ctx{}; \
|
|
|
|
memset(args_buf, 0, sizeof(args_buf)); \
|
|
|
|
nativeSpecializeAppProcess_pre(&ctx, \
|
|
|
|
env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info, nice_name, \
|
|
|
|
is_child_zygote, instruction_set, app_data_dir, is_top_app, pkg_data_info_list, \
|
|
|
|
whitelisted_data_info_list, mount_data_dirs, mount_storage_dirs)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define orig_spec(ver, ...) \
|
|
|
|
reinterpret_cast<decltype(&nativeSpecializeAppProcess_##ver)> \
|
|
|
|
(JNI::Zygote::nativeSpecializeAppProcess_orig->fnPtr)(__VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-10 02:41:25 +01:00
|
|
|
#define post_spec() \
|
|
|
|
nativeSpecializeAppProcess_post(&ctx, env, clazz)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define DCL_SPECIALIZE_APP(ver, sig, ...) \
|
|
|
|
DCL_JNI(void, nativeSpecializeAppProcess_##ver, sig, __VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(q,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;ZLjava/lang/String;Ljava/lang/String;)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(q, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
|
|
|
nice_name, is_child_zygote, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(q_alt,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;ZLjava/lang/String;Ljava/lang/String;Z)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir,
|
|
|
|
jboolean is_top_app) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(q_alt, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
|
|
|
nice_name, is_child_zygote, instruction_set, app_data_dir, is_top_app);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if ENABLE_LEGACY_DP
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(r_dp2,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;ZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir,
|
|
|
|
jboolean is_top_app, jobjectArray pkg_data_info_list) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(r_dp2, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
|
|
|
nice_name, is_child_zygote, instruction_set, app_data_dir, is_top_app, pkg_data_info_list);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(r_dp3,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;ZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;Z)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir,
|
|
|
|
jboolean is_top_app, jobjectArray pkg_data_info_list, jboolean mount_storage_dirs) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(r_dp3, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info,
|
|
|
|
nice_name, is_child_zygote, instruction_set, app_data_dir, is_top_app, pkg_data_info_list,
|
|
|
|
mount_storage_dirs);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
#endif // ENABLE_LEGACY_DP
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(r,
|
|
|
|
"(II[II[[IILjava/lang/String;Ljava/lang/String;ZLjava/lang/String;Ljava/lang/String;Z[Ljava/lang/String;[Ljava/lang/String;ZZ)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jstring nice_name,
|
|
|
|
jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir,
|
|
|
|
jboolean is_top_app, jobjectArray pkg_data_info_list, jobjectArray whitelisted_data_info_list,
|
|
|
|
jboolean mount_data_dirs, jboolean mount_storage_dirs) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(r, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external, se_info, nice_name,
|
|
|
|
is_child_zygote, instruction_set, app_data_dir, is_top_app, pkg_data_info_list,
|
|
|
|
whitelisted_data_info_list, mount_data_dirs, mount_storage_dirs);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_SPECIALIZE_APP(samsung_q,
|
|
|
|
"(II[II[[IILjava/lang/String;IILjava/lang/String;ZLjava/lang/String;Ljava/lang/String;)V",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, jint uid, jint gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jint mount_external, jstring se_info, jint space, jint accessInfo,
|
|
|
|
jstring nice_name, jboolean is_child_zygote, jstring instruction_set, jstring app_data_dir) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_spec();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_spec(samsung_q, env, clazz, uid, gid, gids, runtime_flags, rlimits, mount_external,
|
|
|
|
se_info, space, accessInfo, nice_name, is_child_zygote, instruction_set, app_data_dir);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_spec();
|
|
|
|
}
|
|
|
|
|
|
|
|
#define DCL_SPEC(ver) { \
|
|
|
|
"nativeSpecializeAppProcess", \
|
|
|
|
nativeSpecializeAppProcess_##ver##_sig, \
|
|
|
|
(void *) &nativeSpecializeAppProcess_##ver \
|
|
|
|
}
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define pre_server() \
|
2021-01-10 02:41:25 +01:00
|
|
|
HookContext ctx{}; \
|
|
|
|
memset(args_buf, 0, sizeof(args_buf)); \
|
|
|
|
nativeForkSystemServer_pre(&ctx, env, clazz, uid, gid, gids, runtime_flags, \
|
|
|
|
rlimits, permitted_capabilities, effective_capabilities)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define orig_server(ver, ...) \
|
2021-01-10 02:41:25 +01:00
|
|
|
ctx.pid = reinterpret_cast<decltype(&nativeForkSystemServer_##ver)> \
|
2021-01-09 13:28:26 +01:00
|
|
|
(JNI::Zygote::nativeForkSystemServer_orig->fnPtr)(__VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define post_server() \
|
2021-01-10 02:41:25 +01:00
|
|
|
nativeForkSystemServer_post(&ctx, env, clazz); \
|
|
|
|
return ctx.pid
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
#define DCL_FORK_SERVER(ver, sig, ...) \
|
|
|
|
DCL_JNI(jint, nativeForkSystemServer_##ver, sig, __VA_ARGS__)
|
2021-01-08 14:25:44 +01:00
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_SERVER(m, "(II[II[[IJJ)I",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, uid_t uid, gid_t gid, jintArray gids, jint runtime_flags,
|
|
|
|
jobjectArray rlimits, jlong permitted_capabilities, jlong effective_capabilities) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_server();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_server(m, env, clazz, uid, gid, gids, runtime_flags, rlimits, permitted_capabilities,
|
|
|
|
effective_capabilities);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_server();
|
|
|
|
}
|
|
|
|
|
2021-01-09 13:28:26 +01:00
|
|
|
DCL_FORK_SERVER(samsung_q, "(II[IIII[[IJJ)I",
|
2021-01-10 02:41:25 +01:00
|
|
|
JNIEnv *env, jclass clazz, uid_t uid, gid_t gid, jintArray gids, jint runtime_flags,
|
|
|
|
jint space, jint accessInfo, jobjectArray rlimits, jlong permitted_capabilities,
|
|
|
|
jlong effective_capabilities) {
|
2021-01-08 14:25:44 +01:00
|
|
|
pre_server();
|
2021-01-10 02:41:25 +01:00
|
|
|
orig_server(samsung_q, env, clazz, uid, gid, gids, runtime_flags, space, accessInfo, rlimits,
|
|
|
|
permitted_capabilities, effective_capabilities);
|
2021-01-08 14:25:44 +01:00
|
|
|
post_server();
|
|
|
|
}
|
|
|
|
|
|
|
|
#define DCL_SERVER(ver) { \
|
|
|
|
"nativeForkSystemServer", \
|
|
|
|
nativeForkSystemServer_##ver##_sig, \
|
|
|
|
(void *) &nativeForkSystemServer_##ver \
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* On Android 9+, in very rare cases, SystemProperties.set("sys.user." + userId + ".ce_available", "true")
|
|
|
|
* will throw an exception (no idea if this is caused by hooking) and user data will be wiped.
|
|
|
|
* Hook it and clear the exception to prevent this problem from happening.
|
|
|
|
*
|
|
|
|
* https://cs.android.com/android/platform/superproject/+/android-9.0.0_r34:frameworks/base/services/core/java/com/android/server/pm/UserDataPreparer.java;l=107;bpv=0;bpt=0
|
|
|
|
*/
|
|
|
|
static void SystemProperties_set(JNIEnv *env, jobject clazz, jstring keyJ, jstring valJ) {
|
|
|
|
const char *key = env->GetStringUTFChars(keyJ, JNI_FALSE);
|
|
|
|
char user[16];
|
|
|
|
bool no_throw = sscanf(key, "sys.user.%[^.].ce_available", user) == 1;
|
|
|
|
env->ReleaseStringUTFChars(keyJ, key);
|
|
|
|
|
|
|
|
reinterpret_cast<decltype(&SystemProperties_set)>
|
|
|
|
(JNI::SystemProperties::native_set_orig->fnPtr)(env, clazz, keyJ, valJ);
|
|
|
|
|
|
|
|
jthrowable exception = env->ExceptionOccurred();
|
|
|
|
if (exception && no_throw) {
|
|
|
|
LOGW("prevented data destroy");
|
|
|
|
|
|
|
|
env->ExceptionDescribe();
|
|
|
|
env->ExceptionClear();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace JNI {
|
|
|
|
|
|
|
|
namespace Zygote {
|
|
|
|
const JNINativeMethod nativeForkAndSpecialize_methods[] = {
|
|
|
|
DCL_FORK(m), DCL_FORK(o), DCL_FORK(p),
|
|
|
|
DCL_FORK(q_alt), DCL_FORK(r),
|
|
|
|
DCL_FORK(samsung_m), DCL_FORK(samsung_n),
|
|
|
|
DCL_FORK(samsung_o), DCL_FORK(samsung_p),
|
|
|
|
#if ENABLE_LEGACY_DP
|
|
|
|
DCL_FORK(r_dp2), DCL_FORK(r_dp3)
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
const int nativeForkAndSpecialize_methods_num = std::size(nativeForkAndSpecialize_methods);
|
|
|
|
|
|
|
|
const JNINativeMethod nativeSpecializeAppProcess_methods[] = {
|
|
|
|
DCL_SPEC(q), DCL_SPEC(q_alt),
|
|
|
|
DCL_SPEC(r), DCL_SPEC(samsung_q),
|
|
|
|
#if ENABLE_LEGACY_DP
|
|
|
|
DCL_SPEC(r_dp2), DCL_SPEC(r_dp3)
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
const int nativeSpecializeAppProcess_methods_num = std::size(nativeSpecializeAppProcess_methods);
|
|
|
|
|
|
|
|
const JNINativeMethod nativeForkSystemServer_methods[] = {
|
|
|
|
DCL_SERVER(m), DCL_SERVER(samsung_q)
|
|
|
|
};
|
|
|
|
const int nativeForkSystemServer_methods_num = std::size(nativeForkSystemServer_methods);
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace SystemProperties {
|
|
|
|
const JNINativeMethod native_set_methods[] = {{
|
|
|
|
"native_set",
|
|
|
|
"(Ljava/lang/String;Ljava/lang/String;)V",
|
|
|
|
(void *) &SystemProperties_set
|
|
|
|
}};
|
|
|
|
}
|
|
|
|
}
|