#include #include #include #include #include #include "magiskhide.hpp" using namespace std; static void lazy_unmount(const char* mountpoint) { if (umount2(mountpoint, MNT_DETACH) != -1) LOGD("hide: Unmounted (%s)\n", mountpoint); } void hide_daemon(int pid, int client) { if (fork_dont_care() == 0) { hide_unmount(pid); write_int(client, 0); _exit(0); } } #define TMPFS_MNT(dir) (mentry->mnt_type == "tmpfs"sv && str_starts(mentry->mnt_dir, "/" #dir)) void hide_unmount(int pid) { if (pid > 0) { if (switch_mnt_ns(pid)) return; LOGD("hide: handling PID=[%d]\n", pid); } vector targets; // Unmount dummy skeletons and MAGISKTMP targets.push_back(MAGISKTMP); auto magiskpts = MAGISKTMP + "/" SHELLPTS; if (access(magiskpts.data(), F_OK) == 0) { targets.push_back(magiskpts); } parse_mnt("/proc/self/mounts", [&](mntent *mentry) { if (TMPFS_MNT(system) || TMPFS_MNT(vendor) || TMPFS_MNT(product) || TMPFS_MNT(system_ext)) targets.emplace_back(mentry->mnt_dir); return true; }); for (auto &s : reversed(targets)) lazy_unmount(s.data()); targets.clear(); // Unmount all Magisk created mounts parse_mnt("/proc/self/mounts", [&](mntent *mentry) { if (str_contains(mentry->mnt_fsname, BLOCKDIR)) targets.emplace_back(mentry->mnt_dir); return true; }); for (auto &s : reversed(targets)) lazy_unmount(s.data()); }