From 4492b5d80489482802a3708e2aeaa7c5b5d20e09 Mon Sep 17 00:00:00 2001 From: Yu Watanabe Date: Sun, 28 Aug 2022 04:15:35 +0900 Subject: [PATCH] devnum-util: split-out device_path_make_inaccessible() --- src/basic/devnum-util.c | 37 ++++++++++++++++++++----------------- src/basic/devnum-util.h | 1 + 2 files changed, 21 insertions(+), 17 deletions(-) diff --git a/src/basic/devnum-util.c b/src/basic/devnum-util.c index 70c07315c5..bd1b4d6c39 100644 --- a/src/basic/devnum-util.c +++ b/src/basic/devnum-util.c @@ -57,6 +57,24 @@ int device_path_make_major_minor(mode_t mode, dev_t devnum, char **ret) { return 0; } +int device_path_make_inaccessible(mode_t mode, char **ret) { + char *s; + + assert(ret); + + if (S_ISCHR(mode)) + s = strdup("/run/systemd/inaccessible/chr"); + else if (S_ISBLK(mode)) + s = strdup("/run/systemd/inaccessible/blk"); + else + return -ENODEV; + if (!s) + return -ENOMEM; + + *ret = s; + return 0; +} + int device_path_make_canonical(mode_t mode, dev_t devnum, char **ret) { _cleanup_free_ char *p = NULL; int r; @@ -65,25 +83,10 @@ int device_path_make_canonical(mode_t mode, dev_t devnum, char **ret) { assert(ret); - if (major(devnum) == 0 && minor(devnum) == 0) { - char *s; - + if (major(devnum) == 0 && minor(devnum) == 0) /* A special hack to make sure our 'inaccessible' device nodes work. They won't have symlinks in * /dev/block/ and /dev/char/, hence we handle them specially here. */ - - if (S_ISCHR(mode)) - s = strdup("/run/systemd/inaccessible/chr"); - else if (S_ISBLK(mode)) - s = strdup("/run/systemd/inaccessible/blk"); - else - return -ENODEV; - - if (!s) - return -ENOMEM; - - *ret = s; - return 0; - } + return device_path_make_inaccessible(mode, ret); r = device_path_make_major_minor(mode, devnum, &p); if (r < 0) diff --git a/src/basic/devnum-util.h b/src/basic/devnum-util.h index 3f1894b2fd..38aa4efa87 100644 --- a/src/basic/devnum-util.h +++ b/src/basic/devnum-util.h @@ -29,6 +29,7 @@ int parse_devnum(const char *s, dev_t *ret); }) int device_path_make_major_minor(mode_t mode, dev_t devnum, char **ret); +int device_path_make_inaccessible(mode_t mode, char **ret); int device_path_make_canonical(mode_t mode, dev_t devnum, char **ret); int device_path_parse_major_minor(const char *path, mode_t *ret_mode, dev_t *ret_devnum); -- 2.25.1