diff options
Diffstat (limited to 'src/basic/util.c')
| -rw-r--r-- | src/basic/util.c | 198 | 
1 files changed, 44 insertions, 154 deletions
| diff --git a/src/basic/util.c b/src/basic/util.c index bc61ec0115..c63ec0ceb0 100644 --- a/src/basic/util.c +++ b/src/basic/util.c @@ -72,6 +72,7 @@   * otherwise conflicts with sys/mount.h. Yay, Linux is great! */  #include <linux/fs.h> +#include "build.h"  #include "def.h"  #include "device-nodes.h"  #include "env-util.h" @@ -2550,90 +2551,6 @@ int fchmod_and_fchown(int fd, mode_t mode, uid_t uid, gid_t gid) {          return 0;  } -cpu_set_t* cpu_set_malloc(unsigned *ncpus) { -        cpu_set_t *r; -        unsigned n = 1024; - -        /* Allocates the cpuset in the right size */ - -        for (;;) { -                if (!(r = CPU_ALLOC(n))) -                        return NULL; - -                if (sched_getaffinity(0, CPU_ALLOC_SIZE(n), r) >= 0) { -                        CPU_ZERO_S(CPU_ALLOC_SIZE(n), r); - -                        if (ncpus) -                                *ncpus = n; - -                        return r; -                } - -                CPU_FREE(r); - -                if (errno != EINVAL) -                        return NULL; - -                n *= 2; -        } -} - -int parse_cpu_set( -                const char *rvalue, -                cpu_set_t **cpu_set, -                const char *unit, -                const char *filename, -                unsigned line, -                const char *lvalue) { - -        const char *whole_rvalue = rvalue; -        _cleanup_cpu_free_ cpu_set_t *c = NULL; -        unsigned ncpus = 0; - -        assert(filename); -        assert(lvalue); -        assert(rvalue); - -        for (;;) { -                _cleanup_free_ char *word = NULL; -                unsigned cpu; -                int r; - -                r = extract_first_word(&rvalue, &word, WHITESPACE, EXTRACT_QUOTES); -                if (r < 0) { -                        log_syntax(unit, LOG_ERR, filename, line, r, -                                   "Invalid value for %s: %s", lvalue, whole_rvalue); -                        return r; -                } -                if (r == 0) -                        break; - -                r = safe_atou(word, &cpu); - -                if (!c) -                        if (!(c = cpu_set_malloc(&ncpus))) -                                return log_oom(); - -                if (r < 0 || cpu >= ncpus) { -                        log_syntax(unit, LOG_ERR, filename, line, -r, -                                   "Failed to parse CPU affinity '%s'", rvalue); -                        return -EBADMSG; -                } - -                CPU_SET_S(cpu, CPU_ALLOC_SIZE(ncpus), c); -        } -        if (!isempty(rvalue)) -                log_syntax(unit, LOG_ERR, filename, line, EINVAL, -                           "Trailing garbage, ignoring."); - -        /* On success, sets *cpu_set and returns ncpus for the system. */ -        if (c) { -                *cpu_set = c; -                c = NULL; -        } -        return (int) ncpus; -} -  int files_same(const char *filea, const char *fileb) {          struct stat a, b; @@ -5427,15 +5344,13 @@ int update_reboot_param_file(const char *param) {          int r = 0;          if (param) { -                  r = write_string_file(REBOOT_PARAM_FILE, param, WRITE_STRING_FILE_CREATE);                  if (r < 0) -                        log_error("Failed to write reboot param to " -                                  REBOOT_PARAM_FILE": %s", strerror(-r)); +                        return log_error_errno(r, "Failed to write reboot param to "REBOOT_PARAM_FILE": %m");          } else -                unlink(REBOOT_PARAM_FILE); +                (void) unlink(REBOOT_PARAM_FILE); -        return r; +        return 0;  }  int umount_recursive(const char *prefix, int flags) { @@ -6069,6 +5984,7 @@ int extract_first_word_and_warn(                  const char *filename,                  unsigned line,                  const char *rvalue) { +          /* Try to unquote it, if it fails, warn about it and try again but this           * time using EXTRACT_CUNESCAPE_RELAX to keep the backslashes verbatim           * in invalid escape sequences. */ @@ -6077,17 +5993,17 @@ int extract_first_word_and_warn(          save = *p;          r = extract_first_word(p, ret, separators, flags); -        if (r < 0 && !(flags&EXTRACT_CUNESCAPE_RELAX)) { +        if (r < 0 && !(flags & EXTRACT_CUNESCAPE_RELAX)) { +                  /* Retry it with EXTRACT_CUNESCAPE_RELAX. */                  *p = save;                  r = extract_first_word(p, ret, separators, flags|EXTRACT_CUNESCAPE_RELAX);                  if (r < 0) -                        log_syntax(unit, LOG_ERR, filename, line, EINVAL, -                                   "Unbalanced quoting in command line, ignoring: \"%s\"", rvalue); +                        log_syntax(unit, LOG_ERR, filename, line, r, "Unbalanced quoting in command line, ignoring: \"%s\"", rvalue);                  else -                        log_syntax(unit, LOG_WARNING, filename, line, EINVAL, -                                   "Invalid escape sequences in command line: \"%s\"", rvalue); +                        log_syntax(unit, LOG_WARNING, filename, line, 0, "Invalid escape sequences in command line: \"%s\"", rvalue);          } +          return r;  } @@ -6201,15 +6117,6 @@ int ptsname_malloc(int fd, char **ret) {  int openpt_in_namespace(pid_t pid, int flags) {          _cleanup_close_ int pidnsfd = -1, mntnsfd = -1, usernsfd = -1, rootfd = -1;          _cleanup_close_pair_ int pair[2] = { -1, -1 }; -        union { -                struct cmsghdr cmsghdr; -                uint8_t buf[CMSG_SPACE(sizeof(int))]; -        } control = {}; -        struct msghdr mh = { -                .msg_control = &control, -                .msg_controllen = sizeof(control), -        }; -        struct cmsghdr *cmsg;          siginfo_t si;          pid_t child;          int r; @@ -6243,15 +6150,7 @@ int openpt_in_namespace(pid_t pid, int flags) {                  if (unlockpt(master) < 0)                          _exit(EXIT_FAILURE); -                cmsg = CMSG_FIRSTHDR(&mh); -                cmsg->cmsg_level = SOL_SOCKET; -                cmsg->cmsg_type = SCM_RIGHTS; -                cmsg->cmsg_len = CMSG_LEN(sizeof(int)); -                memcpy(CMSG_DATA(cmsg), &master, sizeof(int)); - -                mh.msg_controllen = cmsg->cmsg_len; - -                if (sendmsg(pair[1], &mh, MSG_NOSIGNAL) < 0) +                if (send_one_fd(pair[1], master, 0) < 0)                          _exit(EXIT_FAILURE);                  _exit(EXIT_SUCCESS); @@ -6265,26 +6164,7 @@ int openpt_in_namespace(pid_t pid, int flags) {          if (si.si_code != CLD_EXITED || si.si_status != EXIT_SUCCESS)                  return -EIO; -        if (recvmsg(pair[0], &mh, MSG_NOSIGNAL|MSG_CMSG_CLOEXEC) < 0) -                return -errno; - -        CMSG_FOREACH(cmsg, &mh) -                if (cmsg->cmsg_level == SOL_SOCKET && cmsg->cmsg_type == SCM_RIGHTS) { -                        int *fds; -                        unsigned n_fds; - -                        fds = (int*) CMSG_DATA(cmsg); -                        n_fds = (cmsg->cmsg_len - CMSG_LEN(0)) / sizeof(int); - -                        if (n_fds != 1) { -                                close_many(fds, n_fds); -                                return -EIO; -                        } - -                        return fds[0]; -                } - -        return -EIO; +        return receive_one_fd(pair[0], 0);  }  ssize_t fgetxattrat_fake(int dirfd, const char *filename, const char *attribute, void *value, size_t size, int flags) { @@ -6884,7 +6764,7 @@ int fgetxattr_malloc(int fd, const char *name, char **value) {          }  } -int send_one_fd(int transport_fd, int fd) { +int send_one_fd(int transport_fd, int fd, int flags) {          union {                  struct cmsghdr cmsghdr;                  uint8_t buf[CMSG_SPACE(sizeof(int))]; @@ -6894,7 +6774,6 @@ int send_one_fd(int transport_fd, int fd) {                  .msg_controllen = sizeof(control),          };          struct cmsghdr *cmsg; -        ssize_t k;          assert(transport_fd >= 0);          assert(fd >= 0); @@ -6906,14 +6785,13 @@ int send_one_fd(int transport_fd, int fd) {          memcpy(CMSG_DATA(cmsg), &fd, sizeof(int));          mh.msg_controllen = CMSG_SPACE(sizeof(int)); -        k = sendmsg(transport_fd, &mh, MSG_NOSIGNAL); -        if (k < 0) +        if (sendmsg(transport_fd, &mh, MSG_NOSIGNAL | flags) < 0)                  return -errno;          return 0;  } -int receive_one_fd(int transport_fd) { +int receive_one_fd(int transport_fd, int flags) {          union {                  struct cmsghdr cmsghdr;                  uint8_t buf[CMSG_SPACE(sizeof(int))]; @@ -6922,33 +6800,45 @@ int receive_one_fd(int transport_fd) {                  .msg_control = &control,                  .msg_controllen = sizeof(control),          }; -        struct cmsghdr *cmsg; -        ssize_t k; +        struct cmsghdr *cmsg, *found = NULL;          assert(transport_fd >= 0);          /* -         * Receive a single FD via @transport_fd. We don't care for the -         * transport-type, but the caller must assure that no other CMSG types -         * than SCM_RIGHTS is enabled. We also retrieve a single FD at most, so -         * for packet-based transports, the caller must ensure to send only a -         * single FD per packet. -         * This is best used in combination with send_one_fd(). +         * Receive a single FD via @transport_fd. We don't care for +         * the transport-type. We retrieve a single FD at most, so for +         * packet-based transports, the caller must ensure to send +         * only a single FD per packet.  This is best used in +         * combination with send_one_fd().           */ -        k = recvmsg(transport_fd, &mh, MSG_NOSIGNAL | MSG_CMSG_CLOEXEC); -        if (k < 0) +        if (recvmsg(transport_fd, &mh, MSG_NOSIGNAL | MSG_CMSG_CLOEXEC | flags) < 0)                  return -errno; -        cmsg = CMSG_FIRSTHDR(&mh); -        if (!cmsg || CMSG_NXTHDR(&mh, cmsg) || -            cmsg->cmsg_level != SOL_SOCKET || -            cmsg->cmsg_type != SCM_RIGHTS || -            cmsg->cmsg_len != CMSG_LEN(sizeof(int)) || -            *(const int *)CMSG_DATA(cmsg) < 0) { +        CMSG_FOREACH(cmsg, &mh) { +                if (cmsg->cmsg_level == SOL_SOCKET && +                    cmsg->cmsg_type == SCM_RIGHTS && +                    cmsg->cmsg_len == CMSG_LEN(sizeof(int))) { +                        assert(!found); +                        found = cmsg; +                        break; +                } +        } + +        if (!found) {                  cmsg_close_all(&mh);                  return -EIO;          } -        return *(const int *)CMSG_DATA(cmsg); +        return *(int*) CMSG_DATA(found); +} + +void nop_signal_handler(int sig) { +        /* nothing here */ +} + +int version(void) { +        puts(PACKAGE_STRING "\n" +             SYSTEMD_FEATURES); +        return 0;  } | 
