diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/remount-fs/remount-fs.c | 62 | 
1 files changed, 26 insertions, 36 deletions
| diff --git a/src/remount-fs/remount-fs.c b/src/remount-fs/remount-fs.c index 912a42654e..9fc56284d2 100644 --- a/src/remount-fs/remount-fs.c +++ b/src/remount-fs/remount-fs.c @@ -22,6 +22,7 @@  #include <errno.h>  #include <mntent.h>  #include <string.h> +#include <sys/prctl.h>  #include <sys/stat.h>  #include <sys/wait.h>  #include <unistd.h> @@ -31,7 +32,9 @@  #include "mount-setup.h"  #include "mount-util.h"  #include "path-util.h" +#include "process-util.h"  #include "signal-util.h" +#include "strv.h"  #include "util.h"  /* Goes through /etc/fstab and remounts all API file systems, applying @@ -39,10 +42,10 @@   * respected */  int main(int argc, char *argv[]) { -        int ret = EXIT_FAILURE; +        _cleanup_hashmap_free_free_ Hashmap *pids = NULL;          _cleanup_endmntent_ FILE *f = NULL;          struct mntent* me; -        Hashmap *pids = NULL; +        int r;          if (argc > 1) {                  log_error("This program takes no argument."); @@ -57,21 +60,21 @@ int main(int argc, char *argv[]) {          f = setmntent("/etc/fstab", "r");          if (!f) { -                if (errno == ENOENT) -                        return EXIT_SUCCESS; +                if (errno == ENOENT) { +                        r = 0; +                        goto finish; +                } -                log_error_errno(errno, "Failed to open /etc/fstab: %m"); -                return EXIT_FAILURE; +                r = log_error_errno(errno, "Failed to open /etc/fstab: %m"); +                goto finish;          }          pids = hashmap_new(NULL);          if (!pids) { -                log_error("Failed to allocate set"); +                r = log_oom();                  goto finish;          } -        ret = EXIT_SUCCESS; -          while ((me = getmntent(f))) {                  pid_t pid;                  int k; @@ -87,25 +90,18 @@ int main(int argc, char *argv[]) {                  pid = fork();                  if (pid < 0) { -                        log_error_errno(errno, "Failed to fork: %m"); -                        ret = EXIT_FAILURE; -                        continue; +                        r = log_error_errno(errno, "Failed to fork: %m"); +                        goto finish;                  }                  if (pid == 0) { -                        const char *arguments[5];                          /* Child */                          (void) reset_all_signal_handlers();                          (void) reset_signal_mask(); +                        (void) prctl(PR_SET_PDEATHSIG, SIGTERM); -                        arguments[0] = MOUNT_PATH; -                        arguments[1] = me->mnt_dir; -                        arguments[2] = "-o"; -                        arguments[3] = "remount"; -                        arguments[4] = NULL; - -                        execv(MOUNT_PATH, (char **) arguments); +                        execv(MOUNT_PATH, STRV_MAKE(MOUNT_PATH, me->mnt_dir, "-o", "remount"));                          log_error_errno(errno, "Failed to execute " MOUNT_PATH ": %m");                          _exit(EXIT_FAILURE); @@ -115,20 +111,19 @@ int main(int argc, char *argv[]) {                  s = strdup(me->mnt_dir);                  if (!s) { -                        log_oom(); -                        ret = EXIT_FAILURE; -                        continue; +                        r = log_oom(); +                        goto finish;                  } -                  k = hashmap_put(pids, PID_TO_PTR(pid), s);                  if (k < 0) { -                        log_error_errno(k, "Failed to add PID to set: %m"); -                        ret = EXIT_FAILURE; -                        continue; +                        free(s); +                        r = log_oom(); +                        goto finish;                  }          } +        r = 0;          while (!hashmap_isempty(pids)) {                  siginfo_t si = {};                  char *s; @@ -138,9 +133,8 @@ int main(int argc, char *argv[]) {                          if (errno == EINTR)                                  continue; -                        log_error_errno(errno, "waitid() failed: %m"); -                        ret = EXIT_FAILURE; -                        break; +                        r = log_error_errno(errno, "waitid() failed: %m"); +                        goto finish;                  }                  s = hashmap_remove(pids, PID_TO_PTR(si.si_pid)); @@ -151,7 +145,7 @@ int main(int argc, char *argv[]) {                                  else                                          log_error(MOUNT_PATH " for %s terminated by signal %s.", s, signal_to_string(si.si_status)); -                                ret = EXIT_FAILURE; +                                r = -ENOEXEC;                          }                          free(s); @@ -159,9 +153,5 @@ int main(int argc, char *argv[]) {          }  finish: - -        if (pids) -                hashmap_free_free(pids); - -        return ret; +        return r < 0 ? EXIT_FAILURE : EXIT_SUCCESS;  } | 
