diff options
author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2021-06-21 19:44:35 +0200 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2021-06-23 10:34:58 +0200 |
commit | 9c6535367d07650bb531beb6cce57497862a36da (patch) | |
tree | b1d70708e39b8bb4c214816582a7ddbdf56b3b8b /src | |
parent | meson: sort file list (diff) | |
download | systemd-9c6535367d07650bb531beb6cce57497862a36da.tar.xz systemd-9c6535367d07650bb531beb6cce57497862a36da.zip |
basic,shared: move make_mount_point_inode_*() to shared/
Those pull in selinux for labelling, and we should avoid selinux in basic/.
Diffstat (limited to 'src')
-rw-r--r-- | src/basic/mountpoint-util.c | 23 | ||||
-rw-r--r-- | src/basic/mountpoint-util.h | 4 | ||||
-rw-r--r-- | src/shared/mount-util.c | 23 | ||||
-rw-r--r-- | src/shared/mount-util.h | 5 | ||||
-rw-r--r-- | src/test/test-mount-util.c | 49 | ||||
-rw-r--r-- | src/test/test-mountpoint-util.c | 49 |
6 files changed, 77 insertions, 76 deletions
diff --git a/src/basic/mountpoint-util.c b/src/basic/mountpoint-util.c index 1d617e87b2..8c836a1b74 100644 --- a/src/basic/mountpoint-util.c +++ b/src/basic/mountpoint-util.c @@ -8,7 +8,6 @@ #include "fd-util.h" #include "fileio.h" #include "fs-util.h" -#include "label.h" #include "missing_stat.h" #include "missing_syscall.h" #include "mkdir.h" @@ -510,25 +509,3 @@ int mount_propagation_flags_from_string(const char *name, unsigned long *ret) { return -EINVAL; return 0; } - -int make_mount_point_inode_from_stat(const struct stat *st, const char *dest, mode_t mode) { - assert(st); - assert(dest); - - if (S_ISDIR(st->st_mode)) - return mkdir_label(dest, mode); - else - return mknod(dest, S_IFREG|(mode & ~0111), 0); -} - -int make_mount_point_inode_from_path(const char *source, const char *dest, mode_t mode) { - struct stat st; - - assert(source); - assert(dest); - - if (stat(source, &st) < 0) - return -errno; - - return make_mount_point_inode_from_stat(&st, dest, mode); -} diff --git a/src/basic/mountpoint-util.h b/src/basic/mountpoint-util.h index cebcec5e78..aadb2123d9 100644 --- a/src/basic/mountpoint-util.h +++ b/src/basic/mountpoint-util.h @@ -23,7 +23,3 @@ int dev_is_devtmpfs(void); const char *mount_propagation_flags_to_string(unsigned long flags); int mount_propagation_flags_from_string(const char *name, unsigned long *ret); - -/* Creates a mount point (not parents) based on the source path or stat - ie, a file or a directory */ -int make_mount_point_inode_from_stat(const struct stat *st, const char *dest, mode_t mode); -int make_mount_point_inode_from_path(const char *source, const char *dest, mode_t mode); diff --git a/src/shared/mount-util.c b/src/shared/mount-util.c index ef128dd595..ff95fbc569 100644 --- a/src/shared/mount-util.c +++ b/src/shared/mount-util.c @@ -16,6 +16,7 @@ #include "fileio.h" #include "fs-util.h" #include "hashmap.h" +#include "label.h" #include "libmount-util.h" #include "missing_mount.h" #include "missing_syscall.h" @@ -1071,3 +1072,25 @@ int remount_idmap( return 0; } + +int make_mount_point_inode_from_stat(const struct stat *st, const char *dest, mode_t mode) { + assert(st); + assert(dest); + + if (S_ISDIR(st->st_mode)) + return mkdir_label(dest, mode); + else + return mknod(dest, S_IFREG|(mode & ~0111), 0); +} + +int make_mount_point_inode_from_path(const char *source, const char *dest, mode_t mode) { + struct stat st; + + assert(source); + assert(dest); + + if (stat(source, &st) < 0) + return -errno; + + return make_mount_point_inode_from_stat(&st, dest, mode); +} diff --git a/src/shared/mount-util.h b/src/shared/mount-util.h index 0169083980..36501c2c4a 100644 --- a/src/shared/mount-util.h +++ b/src/shared/mount-util.h @@ -3,6 +3,7 @@ #include <mntent.h> #include <stdio.h> +#include <sys/stat.h> #include <unistd.h> #include "alloc-util.h" @@ -108,3 +109,7 @@ int mount_image_in_namespace(pid_t target, const char *propagate_path, const cha int make_mount_point(const char *path); int remount_idmap(const char *p, uid_t uid_shift, uid_t uid_range); + +/* Creates a mount point (not parents) based on the source path or stat - ie, a file or a directory */ +int make_mount_point_inode_from_stat(const struct stat *st, const char *dest, mode_t mode); +int make_mount_point_inode_from_path(const char *source, const char *dest, mode_t mode); diff --git a/src/test/test-mount-util.c b/src/test/test-mount-util.c index 0cbf68aa00..d3d004071b 100644 --- a/src/test/test-mount-util.c +++ b/src/test/test-mount-util.c @@ -7,7 +7,9 @@ #include "capability-util.h" #include "fd-util.h" #include "fileio.h" +#include "fs-util.h" #include "missing_mount.h" +#include "mkdir.h" #include "mount-util.h" #include "namespace-util.h" #include "path-util.h" @@ -217,6 +219,52 @@ static void test_bind_remount_one(void) { assert_se(wait_for_terminate_and_check("test-remount-one", pid, WAIT_LOG) == EXIT_SUCCESS); } +static void test_make_mount_point_inode(void) { + _cleanup_(rm_rf_physical_and_freep) char *d = NULL; + const char *src_file, *src_dir, *dst_file, *dst_dir; + struct stat st; + + log_info("/* %s */", __func__); + + assert_se(mkdtemp_malloc(NULL, &d) >= 0); + + src_file = strjoina(d, "/src/file"); + src_dir = strjoina(d, "/src/dir"); + dst_file = strjoina(d, "/dst/file"); + dst_dir = strjoina(d, "/dst/dir"); + + assert_se(mkdir_p(src_dir, 0755) >= 0); + assert_se(mkdir_parents(dst_file, 0755) >= 0); + assert_se(touch(src_file) >= 0); + + assert_se(make_mount_point_inode_from_path(src_file, dst_file, 0755) >= 0); + assert_se(make_mount_point_inode_from_path(src_dir, dst_dir, 0755) >= 0); + + assert_se(stat(dst_dir, &st) == 0); + assert_se(S_ISDIR(st.st_mode)); + assert_se(stat(dst_file, &st) == 0); + assert_se(S_ISREG(st.st_mode)); + assert_se(!(S_IXUSR & st.st_mode)); + assert_se(!(S_IXGRP & st.st_mode)); + assert_se(!(S_IXOTH & st.st_mode)); + + assert_se(unlink(dst_file) == 0); + assert_se(rmdir(dst_dir) == 0); + + assert_se(stat(src_file, &st) == 0); + assert_se(make_mount_point_inode_from_stat(&st, dst_file, 0755) >= 0); + assert_se(stat(src_dir, &st) == 0); + assert_se(make_mount_point_inode_from_stat(&st, dst_dir, 0755) >= 0); + + assert_se(stat(dst_dir, &st) == 0); + assert_se(S_ISDIR(st.st_mode)); + assert_se(stat(dst_file, &st) == 0); + assert_se(S_ISREG(st.st_mode)); + assert_se(!(S_IXUSR & st.st_mode)); + assert_se(!(S_IXGRP & st.st_mode)); + assert_se(!(S_IXOTH & st.st_mode)); +} + int main(int argc, char *argv[]) { test_setup_logging(LOG_DEBUG); @@ -224,6 +272,7 @@ int main(int argc, char *argv[]) { test_mount_flags_to_string(); test_bind_remount_recursive(); test_bind_remount_one(); + test_make_mount_point_inode(); return 0; } diff --git a/src/test/test-mountpoint-util.c b/src/test/test-mountpoint-util.c index 128daa6de8..983e1842d6 100644 --- a/src/test/test-mountpoint-util.c +++ b/src/test/test-mountpoint-util.c @@ -8,10 +8,8 @@ #include "def.h" #include "fd-util.h" #include "fileio.h" -#include "fs-util.h" #include "hashmap.h" #include "log.h" -#include "mkdir.h" #include "mountpoint-util.h" #include "path-util.h" #include "rm-rf.h" @@ -290,52 +288,6 @@ static void test_fd_is_mount_point(void) { assert_se(IN_SET(fd_is_mount_point(fd, "root/", 0), -ENOENT, 0)); } -static void test_make_mount_point_inode(void) { - _cleanup_(rm_rf_physical_and_freep) char *d = NULL; - const char *src_file, *src_dir, *dst_file, *dst_dir; - struct stat st; - - log_info("/* %s */", __func__); - - assert_se(mkdtemp_malloc(NULL, &d) >= 0); - - src_file = strjoina(d, "/src/file"); - src_dir = strjoina(d, "/src/dir"); - dst_file = strjoina(d, "/dst/file"); - dst_dir = strjoina(d, "/dst/dir"); - - assert_se(mkdir_p(src_dir, 0755) >= 0); - assert_se(mkdir_parents(dst_file, 0755) >= 0); - assert_se(touch(src_file) >= 0); - - assert_se(make_mount_point_inode_from_path(src_file, dst_file, 0755) >= 0); - assert_se(make_mount_point_inode_from_path(src_dir, dst_dir, 0755) >= 0); - - assert_se(stat(dst_dir, &st) == 0); - assert_se(S_ISDIR(st.st_mode)); - assert_se(stat(dst_file, &st) == 0); - assert_se(S_ISREG(st.st_mode)); - assert_se(!(S_IXUSR & st.st_mode)); - assert_se(!(S_IXGRP & st.st_mode)); - assert_se(!(S_IXOTH & st.st_mode)); - - assert_se(unlink(dst_file) == 0); - assert_se(rmdir(dst_dir) == 0); - - assert_se(stat(src_file, &st) == 0); - assert_se(make_mount_point_inode_from_stat(&st, dst_file, 0755) >= 0); - assert_se(stat(src_dir, &st) == 0); - assert_se(make_mount_point_inode_from_stat(&st, dst_dir, 0755) >= 0); - - assert_se(stat(dst_dir, &st) == 0); - assert_se(S_ISDIR(st.st_mode)); - assert_se(stat(dst_file, &st) == 0); - assert_se(S_ISREG(st.st_mode)); - assert_se(!(S_IXUSR & st.st_mode)); - assert_se(!(S_IXGRP & st.st_mode)); - assert_se(!(S_IXOTH & st.st_mode)); -} - int main(int argc, char *argv[]) { test_setup_logging(LOG_DEBUG); @@ -360,7 +312,6 @@ int main(int argc, char *argv[]) { test_mnt_id(); test_path_is_mount_point(); test_fd_is_mount_point(); - test_make_mount_point_inode(); return 0; } |