Make sure logcat process does not become a zombie

This commit is contained in:
topjohnwu 2019-02-14 17:36:18 -05:00
parent 4872df6a46
commit 9430dbb96c
5 changed files with 48 additions and 14 deletions

View File

@ -645,11 +645,23 @@ static void dump_logs() {
if (test != 0) if (test != 0)
return; return;
rename(LOGFILE, LOGFILE ".bak"); rename(LOGFILE, LOGFILE ".bak");
int fd = xopen(LOGFILE, O_WRONLY | O_APPEND | O_CREAT | O_CLOEXEC, 0644);
exec_t exec { .fd = fd };
exec_command(exec, "/system/bin/logcat", "-s", "Magisk");
log_dump = true; log_dump = true;
close(fd); // Start a daemon thread and wait indefinitely
new_daemon_thread([](auto) -> void* {
int fd = xopen(LOGFILE, O_WRONLY | O_APPEND | O_CREAT | O_CLOEXEC, 0644);
exec_t exec {
.fd = fd,
.fork = fork_no_zombie
};
int pid = exec_command(exec, "/system/bin/logcat", "-s", "Magisk");
close(fd);
if (pid < 0) {
log_dump = false;
return nullptr;
}
waitpid(pid, nullptr, 0);
return nullptr;
});
} }
/**************** /****************

View File

@ -140,20 +140,17 @@ static void main_daemon() {
pthread_sigmask(SIG_SETMASK, &block_set, nullptr); pthread_sigmask(SIG_SETMASK, &block_set, nullptr);
// Loop forever to listen for requests // Loop forever to listen for requests
while(true) { for (;;) {
int *client = new int; int *client = new int;
*client = xaccept4(fd, nullptr, nullptr, SOCK_CLOEXEC); *client = xaccept4(fd, nullptr, nullptr, SOCK_CLOEXEC);
pthread_t thread; new_daemon_thread(request_handler, client);
xpthread_create(&thread, nullptr, request_handler, client);
// Detach the thread, we will never join it
pthread_detach(thread);
} }
} }
int switch_mnt_ns(int pid) { int switch_mnt_ns(int pid) {
char mnt[32]; char mnt[32];
snprintf(mnt, sizeof(mnt), "/proc/%d/ns/mnt", pid); snprintf(mnt, sizeof(mnt), "/proc/%d/ns/mnt", pid);
if(access(mnt, R_OK) == -1) return 1; // Maybe process died.. if (access(mnt, R_OK) == -1) return 1; // Maybe process died..
int fd, ret; int fd, ret;
fd = xopen(mnt, O_RDONLY); fd = xopen(mnt, O_RDONLY);

View File

@ -366,11 +366,9 @@ void auto_start_magiskhide() {
db_settings dbs; db_settings dbs;
get_db_settings(&dbs, HIDE_CONFIG); get_db_settings(&dbs, HIDE_CONFIG);
if (dbs[HIDE_CONFIG]) { if (dbs[HIDE_CONFIG]) {
pthread_t thread; new_daemon_thread([](auto) -> void* {
xpthread_create(&thread, nullptr, [](void*) -> void* {
launch_magiskhide(-1); launch_magiskhide(-1);
return nullptr; return nullptr;
}, nullptr); });
pthread_detach(thread);
} }
} }

View File

@ -82,6 +82,7 @@ unsigned get_shell_uid();
unsigned get_system_uid(); unsigned get_system_uid();
unsigned get_radio_uid(); unsigned get_radio_uid();
int fork_dont_care(); int fork_dont_care();
int fork_no_zombie();
void gen_rand_str(char *buf, int len); void gen_rand_str(char *buf, int len);
int strend(const char *s1, const char *s2); int strend(const char *s1, const char *s2);
@ -147,6 +148,9 @@ std::vector<std::string> file_to_vector(const char *filename);
// misc.cpp // misc.cpp
int new_daemon_thread(void *(*start_routine) (void *), void *arg = nullptr,
const pthread_attr_t *attr = nullptr);
struct exec_t { struct exec_t {
bool err = false; bool err = false;
int fd = -2; int fd = -2;

View File

@ -10,6 +10,7 @@
#include <syscall.h> #include <syscall.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/wait.h> #include <sys/wait.h>
#include <sys/prctl.h>
#include <sys/sysmacros.h> #include <sys/sysmacros.h>
#include <logging.h> #include <logging.h>
@ -50,6 +51,20 @@ int fork_dont_care() {
return 0; return 0;
} }
int fork_no_zombie() {
int pid = xfork();
if (pid)
return pid;
// Unblock all signals
sigset_t block_set;
sigfillset(&block_set);
pthread_sigmask(SIG_UNBLOCK, &block_set, nullptr);
prctl(PR_SET_PDEATHSIG, SIGTERM);
if (getppid() == 1)
exit(1);
return 0;
}
void gen_rand_str(char *buf, int len) { void gen_rand_str(char *buf, int len) {
const char base[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; const char base[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
int urandom; int urandom;
@ -201,3 +216,11 @@ int exec_command_sync(exec_t &exec) {
return WEXITSTATUS(status); return WEXITSTATUS(status);
} }
int new_daemon_thread(void *(*start_routine) (void *), void *arg, const pthread_attr_t *attr) {
pthread_t thread;
int ret = xpthread_create(&thread, attr, start_routine, arg);
if (ret == 0)
pthread_detach(thread);
return ret;
}