1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-20 14:03:39 +03:00

Revert "tree-wide: Mount file descriptors via /proc/<pid>/fd"

(cherry picked from commit 7b9da3861a2d27dd31c360674947005a19f3cbe7)
This commit is contained in:
Lennart Poettering 2023-09-08 21:28:26 +02:00 committed by Luca Boccassi
parent 93bb992079
commit d5c180b96e
8 changed files with 16 additions and 32 deletions

View File

@ -8,8 +8,6 @@
#include <sys/socket.h>
#include "macro.h"
#include "format-util.h"
#include "process-util.h"
#include "stdio-util.h"
/* maximum length of fdname */
@ -114,17 +112,14 @@ static inline int dir_fd_is_root_or_cwd(int dir_fd) {
return dir_fd == AT_FDCWD ? true : path_is_root_at(dir_fd, NULL);
}
/* The maximum length a buffer for a /proc/<pid>/fd/<fd> path needs. We intentionally don't use /proc/self/fd
* as these paths might be read by other programs (for example when mounting file descriptors the source path
* ends up in /proc/mounts and related files) for which /proc/self/fd will be interpreted differently than
* /proc/<pid>/fd. */
/* The maximum length a buffer for a /proc/self/fd/<fd> path needs */
#define PROC_FD_PATH_MAX \
(STRLEN("/proc//fd/") + DECIMAL_STR_MAX(pid_t) + DECIMAL_STR_MAX(int))
(STRLEN("/proc/self/fd/") + DECIMAL_STR_MAX(int))
static inline char *format_proc_fd_path(char buf[static PROC_FD_PATH_MAX], int fd) {
assert(buf);
assert(fd >= 0);
assert_se(snprintf_ok(buf, PROC_FD_PATH_MAX, "/proc/" PID_FMT "/fd/%i", getpid_cached(), fd));
assert_se(snprintf_ok(buf, PROC_FD_PATH_MAX, "/proc/self/fd/%i", fd));
return buf;
}

View File

@ -5,9 +5,8 @@
#include <errno.h>
#include <sys/ioctl.h>
#include <net/if.h>
#include <linux/if_arp.h> /* Must be included after <net/if.h> */
#include <linux/if_infiniband.h> /* Must be included after <net/if.h> */
#include <linux/if_arp.h>
#include <linux/if_infiniband.h>
#include "sd-dhcp6-client.h"

View File

@ -1,9 +1,8 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include <netinet/in.h>
#include <net/if.h>
#include <linux/if_arp.h> /* Must be included after <net/if.h> */
#include <linux/if.h> /* Must be included after <net/if.h> */
#include <linux/if_arp.h>
#include <linux/if.h>
#include "sd-dhcp-server.h"

View File

@ -3,8 +3,7 @@
#include <netinet/in.h>
#include <sys/socket.h>
#include <unistd.h>
#include <net/if.h>
#include <linux/if.h> /* Must be included after <net/if.h> */
#include <linux/if.h>
#include <linux/fib_rules.h>
#include <linux/nexthop.h>
#include <linux/nl80211.h>

View File

@ -1,8 +1,7 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include <netinet/in.h>
#include <net/if.h>
#include <linux/if.h> /* Must be included after <net/if.h> */
#include <linux/if.h>
#include "alloc-util.h"
#include "dns-domain.h"

View File

@ -1,7 +1,6 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include <net/if.h>
#include <linux/if.h> /* Must be included after <net/if.h> */
#include <linux/if.h>
#include <unistd.h>
#include "sd-network.h"

View File

@ -382,16 +382,11 @@ TEST(close_all_fds) {
}
TEST(format_proc_fd_path) {
_cleanup_free_ char *expected = NULL;
for (int i = 0; i < 4; i++) {
assert_se(asprintf(&expected, "/proc/" PID_FMT "/fd/%i", getpid_cached(), i) >= 0);
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(i), expected));
expected = mfree(expected);
}
assert_se(asprintf(&expected, "/proc/" PID_FMT "/fd/2147483647", getpid_cached()) >= 0);
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(2147483647), expected));
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(0), "/proc/self/fd/0"));
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(1), "/proc/self/fd/1"));
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(2), "/proc/self/fd/2"));
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(3), "/proc/self/fd/3"));
assert_se(streq_ptr(FORMAT_PROC_FD_PATH(2147483647), "/proc/self/fd/2147483647"));
}
TEST(fd_reopen) {

View File

@ -1,7 +1,6 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include <net/if.h>
#include <linux/netdevice.h> /* Must be included after <net/if.h> */
#include <linux/netdevice.h>
#include <netinet/ether.h>
#include <unistd.h>