Use pidfd_open for setns

which is more efficient on newer kernel
This commit is contained in:
LoveSy 2024-04-09 14:19:38 +08:00 committed by John Wu
parent 941a363c5a
commit c6f0762510

View File

@ -208,16 +208,22 @@ uint32_t binary_gcd(uint32_t u, uint32_t v) {
} }
int switch_mnt_ns(int pid) { int switch_mnt_ns(int pid) {
int ret = -1;
int fd = syscall(__NR_pidfd_open, pid, 0);
if (fd > 0) {
ret = setns(fd, CLONE_NEWNS);
close(fd);
}
if (ret < 0) {
char mnt[32]; char mnt[32];
ssprintf(mnt, sizeof(mnt), "/proc/%d/ns/mnt", pid); ssprintf(mnt, sizeof(mnt), "/proc/%d/ns/mnt", pid);
if (access(mnt, R_OK) == -1) return 1; // Maybe process died.. fd = open(mnt, O_RDONLY);
if (fd < 0) return 1; // Maybe process died..
int fd, ret;
fd = xopen(mnt, O_RDONLY);
if (fd < 0) return 1;
// Switch to its namespace // Switch to its namespace
ret = xsetns(fd, 0); ret = xsetns(fd, 0);
close(fd); close(fd);
}
return ret; return ret;
} }