shared: clean up mkdir.h/label.h situation

Previously the mkdir_label() family of calls was implemented in
src/shared/mkdir-label.c but its functions partly declared ins
src/shared/label.h and partly in src/basic/mkdir.h (!!). That's weird
(and wrong).

Let's clean this up, and add a proper mkdir-label.h matching the .c
file.
This commit is contained in:
Lennart Poettering 2021-11-12 15:44:50 +01:00
parent ed304a5d73
commit 35cd0ba516
58 changed files with 80 additions and 77 deletions

View file

@ -9,21 +9,16 @@ typedef enum MkdirFlags {
} MkdirFlags;
int mkdirat_errno_wrapper(int dirfd, const char *pathname, mode_t mode);
int mkdir_safe(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags);
int mkdir_parents(const char *path, mode_t mode);
int mkdir_parents_safe(const char *prefix, const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags);
int mkdir_p(const char *path, mode_t mode);
int mkdir_p_safe(const char *prefix, const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags);
int mkdir_p_root(const char *root, const char *p, uid_t uid, gid_t gid, mode_t m);
/* mandatory access control(MAC) versions */
int mkdir_safe_label(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags);
int mkdir_parents_label(const char *path, mode_t mod);
int mkdir_p_label(const char *path, mode_t mode);
/* internally used */
/* The following are used to implement the mkdir_xyz_label() calls, don't use otherwise. */
typedef int (*mkdirat_func_t)(int dir_fd, const char *pathname, mode_t mode);
int mkdir_safe_internal(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags, mkdirat_func_t _mkdir);
int mkdir_parents_internal(const char *prefix, const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags, mkdirat_func_t _mkdir);
int mkdir_p_internal(const char *prefix, const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags, mkdirat_func_t _mkdir);
int mkdir_p_root(const char *root, const char *p, uid_t uid, gid_t gid, mode_t m);

View file

@ -21,7 +21,7 @@
#include "format-util.h"
#include "io-util.h"
#include "label.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mount.h"
#include "mountpoint-util.h"

View file

@ -1,7 +1,7 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include "core-varlink.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "strv.h"
#include "user-util.h"
#include "varlink.h"

View file

@ -33,7 +33,7 @@
#include "fd-util.h"
#include "fs-util.h"
#include "log.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "process-util.h"
#include "selinux-access.h"
#include "serialize.h"

View file

@ -71,7 +71,7 @@
#include "memory-util.h"
#include "missing_fs.h"
#include "missing_ioprio.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "namespace.h"

View file

@ -4,7 +4,7 @@
#include "generator-setup.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "rm-rf.h"
int lookup_paths_mkdir_generator(LookupPaths *p) {

View file

@ -60,7 +60,7 @@
#include "manager.h"
#include "manager-dump.h"
#include "manager-serialize.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-setup.h"
#include "os-util.h"
#include "pager.h"

View file

@ -58,7 +58,7 @@
#include "manager-dump.h"
#include "manager-serialize.h"
#include "memory-util.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-lookup.h"
#include "path-util.h"

View file

@ -17,7 +17,7 @@
#include "libmount-util.h"
#include "log.h"
#include "manager.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-setup.h"
#include "mount.h"
#include "mountpoint-util.h"

View file

@ -21,7 +21,7 @@
#include "list.h"
#include "loop-util.h"
#include "loopback-setup.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "namespace-util.h"

View file

@ -14,7 +14,7 @@
#include "glob-util.h"
#include "inotify-util.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path.h"
#include "path-util.h"
#include "serialize.h"

View file

@ -28,7 +28,7 @@
#include "ip-protocol-list.h"
#include "label.h"
#include "log.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "process-util.h"

View file

@ -37,7 +37,7 @@
#include "log.h"
#include "macro.h"
#include "missing_audit.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "process-util.h"
#include "rm-rf.h"

View file

@ -37,7 +37,7 @@
#include "macro.h"
#include "main-func.h"
#include "memory-util.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "process-util.h"
#include "signal-util.h"

View file

@ -5,7 +5,7 @@
#include "alloc-util.h"
#include "dropin.h"
#include "generator.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "proc-cmdline.h"
@ -138,7 +138,7 @@ static int generate_wants_symlinks(void) {
if (!f)
return log_oom();
mkdir_parents_label(p, 0755);
(void) mkdir_parents_label(p, 0755);
if (symlink(f, p) < 0)
r = log_error_errno(errno,

View file

@ -10,7 +10,7 @@
#include "fileio.h"
#include "generator.h"
#include "log.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "process-util.h"
#include "strv.h"
@ -31,7 +31,7 @@ static int add_symlink(const char *fservice, const char *tservice) {
from = strjoina(SYSTEM_DATA_UNIT_DIR "/", fservice);
to = strjoina(arg_dest, "/getty.target.wants/", tservice);
mkdir_parents_label(to, 0755);
(void) mkdir_parents_label(to, 0755);
r = symlink(from, to);
if (r < 0) {

View file

@ -10,7 +10,7 @@
#include "generator.h"
#include "log.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "proc-cmdline.h"
#include "special.h"
#include "string-util.h"
@ -84,7 +84,7 @@ static int process_resume(void) {
if (!lnk)
return log_oom();
mkdir_parents_label(lnk, 0755);
(void) mkdir_parents_label(lnk, 0755);
if (symlink(SYSTEM_DATA_UNIT_DIR "/systemd-hibernate-resume@.service", lnk) < 0)
return log_error_errno(errno, "Failed to create symlink %s: %m", lnk);

View file

@ -14,7 +14,7 @@
#include "import-util.h"
#include "install-file.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-argument.h"
#include "ratelimit.h"
#include "rm-rf.h"

View file

@ -18,7 +18,7 @@
#include "install-file.h"
#include "io-util.h"
#include "machine-pool.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "qcow2-util.h"
#include "ratelimit.h"

View file

@ -18,7 +18,7 @@
#include "install-file.h"
#include "io-util.h"
#include "machine-pool.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "process-util.h"
#include "qcow2-util.h"

View file

@ -19,7 +19,7 @@
#include "machine-pool.h"
#include "main-func.h"
#include "missing_capability.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "percent-util.h"

View file

@ -17,7 +17,7 @@
#include "import-util.h"
#include "install-file.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "pull-common.h"
#include "pull-job.h"

View file

@ -16,7 +16,7 @@
#include "import-util.h"
#include "install-file.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "process-util.h"
#include "pull-common.h"

View file

@ -18,7 +18,7 @@
#include "keymap-util.h"
#include "locale-util.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "nulstr-util.h"
#include "process-util.h"
#include "string-util.h"

View file

@ -36,7 +36,7 @@
#include "logind-user-dbus.h"
#include "logind.h"
#include "missing_capability.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "process-util.h"

View file

@ -17,7 +17,7 @@
#include "io-util.h"
#include "logind-dbus.h"
#include "logind-inhibit.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "string-table.h"

View file

@ -16,7 +16,7 @@
#include "logind-seat-dbus.h"
#include "logind-seat.h"
#include "logind-session-dbus.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "stdio-util.h"

View file

@ -26,7 +26,7 @@
#include "logind-session-dbus.h"
#include "logind-session.h"
#include "logind-user-dbus.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "process-util.h"

View file

@ -21,7 +21,7 @@
#include "logind-dbus.h"
#include "logind-user-dbus.h"
#include "logind-user.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "percent-util.h"

View file

@ -27,6 +27,7 @@
#include "logind-user-dbus.h"
#include "logind.h"
#include "main-func.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "process-util.h"
#include "selinux-util.h"

View file

@ -12,7 +12,7 @@
#include "label.h"
#include "limits-util.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "path-util.h"

View file

@ -19,7 +19,7 @@
#include "hashmap.h"
#include "machine-dbus.h"
#include "machine.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "process-util.h"

View file

@ -18,10 +18,10 @@
#include "fd-util.h"
#include "format-util.h"
#include "hostname-util.h"
#include "label.h"
#include "machined-varlink.h"
#include "machined.h"
#include "main-func.h"
#include "mkdir-label.h"
#include "process-util.h"
#include "service-util.h"
#include "signal-util.h"

View file

@ -11,7 +11,7 @@
#include "daemon-util.h"
#include "firewall-util.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "networkd-conf.h"
#include "networkd-manager.h"
#include "signal-util.h"

View file

@ -10,7 +10,7 @@
#include "format-util.h"
#include "fs-util.h"
#include "label.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "nspawn-mount.h"

View file

@ -6,7 +6,7 @@
#include "generator.h"
#include "log.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "string-util.h"
#include "util.h"

View file

@ -11,7 +11,7 @@
#include "capability-util.h"
#include "daemon-util.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "resolved-bus.h"
#include "resolved-conf.h"
#include "resolved-manager.h"

View file

@ -33,7 +33,7 @@
#include "macro.h"
#include "memory-util.h"
#include "missing_syscall.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "process-util.h"
#include "random-util.h"
#include "signal-util.h"

View file

@ -20,6 +20,7 @@
#include "io-util.h"
#include "macro.h"
#include "missing_syscall.h"
#include "mkdir-label.h"
#include "mountpoint-util.h"
#include "nulstr-util.h"
#include "rm-rf.h"

View file

@ -8,6 +8,7 @@
#include "dev-setup.h"
#include "label.h"
#include "log.h"
#include "mkdir-label.h"
#include "nulstr-util.h"
#include "path-util.h"
#include "umask-util.h"

View file

@ -46,7 +46,7 @@
#include "hostname-setup.h"
#include "id128-util.h"
#include "import-util.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "namespace-util.h"

View file

@ -13,7 +13,7 @@
#include "generator.h"
#include "log.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "special.h"
#include "specifier.h"
@ -63,7 +63,7 @@ int generator_add_symlink(const char *dir, const char *dst, const char *dep_type
from = path_is_absolute(src) ? src : strjoina("../", src);
to = strjoina(dir, "/", dst, ".", dep_type, "/", basename(src));
mkdir_parents_label(to, 0755);
(void) mkdir_parents_label(to, 0755);
if (symlink(from, to) < 0)
if (errno != EEXIST)
return log_error_errno(errno, "Failed to create symlink \"%s\": %m", to);

View file

@ -12,7 +12,7 @@
#include "hwdb-internal.h"
#include "hwdb-util.h"
#include "label.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "nulstr-util.h"
#include "path-util.h"
#include "sort-util.h"

View file

@ -26,7 +26,7 @@
#include "locale-util.h"
#include "log.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-lookup.h"
#include "path-util.h"
#include "rm-rf.h"
@ -461,7 +461,7 @@ static int create_symlink(
* the right place, or negative on error.
*/
mkdir_parents_label(new_path, 0755);
(void) mkdir_parents_label(new_path, 0755);
if (symlink(old_path, new_path) >= 0) {
unit_file_changes_add(changes, n_changes, UNIT_FILE_SYMLINK, new_path, old_path);

View file

@ -15,12 +15,6 @@ static inline int label_fix(const char *path, LabelFixFlags flags) {
return label_fix_container(path, path, flags);
}
int mkdirat_label(int dirfd, const char *path, mode_t mode);
static inline int mkdir_label(const char *path, mode_t mode) {
return mkdirat_label(AT_FDCWD, path, mode);
}
int symlink_label(const char *old_path, const char *new_path);
int symlink_atomic_label(const char *from, const char *to);
int mknod_label(const char *pathname, mode_t mode, dev_t dev);

View file

@ -209,6 +209,7 @@ shared_sources = files('''
macvlan-util.h
main-func.h
mkdir-label.c
mkdir-label.h
mkfs-util.c
mkfs-util.h
module-util.h

View file

@ -1,13 +1,6 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
#include "label.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "selinux-util.h"
#include "smack-util.h"
#include "user-util.h"

17
src/shared/mkdir-label.h Normal file
View file

@ -0,0 +1,17 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#pragma once
#include <fcntl.h>
#include <sys/types.h>
#include "mkdir.h"
int mkdirat_label(int dirfd, const char *path, mode_t mode);
static inline int mkdir_label(const char *path, mode_t mode) {
return mkdirat_label(AT_FDCWD, path, mode);
}
int mkdir_safe_label(const char *path, mode_t mode, uid_t uid, gid_t gid, MkdirFlags flags);
int mkdir_parents_label(const char *path, mode_t mod);
int mkdir_p_label(const char *path, mode_t mode);

View file

@ -20,7 +20,7 @@
#include "label.h"
#include "log.h"
#include "macro.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-setup.h"
#include "mount-util.h"
#include "mountpoint-util.h"

View file

@ -22,7 +22,7 @@
#include "libmount-util.h"
#include "missing_mount.h"
#include "missing_syscall.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "namespace-util.h"

View file

@ -14,7 +14,7 @@
#include "log.h"
#include "macro.h"
#include "missing_socket.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "selinux-util.h"
#include "socket-util.h"
#include "umask-util.h"

View file

@ -13,7 +13,7 @@
#include "fd-util.h"
#include "log.h"
#include "missing_syscall.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "path-util.h"

View file

@ -5,7 +5,7 @@
#include "fd-util.h"
#include "fileio.h"
#include "fs-util.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "pager.h"
#include "path-util.h"
#include "pretty-print.h"

View file

@ -15,7 +15,7 @@
#include "fs-util.h"
#include "log.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "namespace-util.h"
#include "selinux-util.h"

View file

@ -12,7 +12,7 @@
#include "fd-util.h"
#include "fs-util.h"
#include "main-func.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "network-util.h"
#include "process-util.h"
#include "signal-util.h"

View file

@ -42,7 +42,7 @@
#include "main-func.h"
#include "missing_stat.h"
#include "missing_syscall.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "mount-util.h"
#include "mountpoint-util.h"
#include "offline-passwd.h"

View file

@ -30,7 +30,7 @@
#include "macro.h"
#include "main-func.h"
#include "memory-util.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "path-util.h"
#include "pretty-print.h"
#include "process-util.h"

View file

@ -17,7 +17,7 @@
#include "format-util.h"
#include "fs-util.h"
#include "hexdecoct.h"
#include "mkdir.h"
#include "mkdir-label.h"
#include "parse-util.h"
#include "path-util.h"
#include "random-util.h"