diff options
| author | Lennart Poettering <lennart@poettering.net> | 2011-12-31 00:59:37 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2011-12-31 00:59:37 +0100 | 
| commit | dc1ecd78e9f046880d10ddb45cf9b06df1084b10 (patch) | |
| tree | 696491346a7fa69f8620a99cb7c0d2d87f2da7cf /src/remount-api-vfs.c | |
| parent | 69b1c67463de64fb32ba75f586f0c9d2716f3e02 (diff) | |
| parent | 74ef2d16ada74db3059d825ce8d24ea74946bf8f (diff) | |
Merge branch 'journal'
Diffstat (limited to 'src/remount-api-vfs.c')
| -rw-r--r-- | src/remount-api-vfs.c | 23 | 
1 files changed, 17 insertions, 6 deletions
| diff --git a/src/remount-api-vfs.c b/src/remount-api-vfs.c index 8bbc021dc4..7b146551a8 100644 --- a/src/remount-api-vfs.c +++ b/src/remount-api-vfs.c @@ -54,12 +54,14 @@ int main(int argc, char *argv[]) {          umask(0022); -        if (!(f = setmntent("/etc/fstab", "r"))) { +        f = setmntent("/etc/fstab", "r"); +        if (!f) {                  log_error("Failed to open /etc/fstab: %m");                  goto finish;          } -        if (!(pids = hashmap_new(trivial_hash_func, trivial_compare_func))) { +        pids = hashmap_new(trivial_hash_func, trivial_compare_func); +        if (!pids) {                  log_error("Failed to allocate set");                  goto finish;          } @@ -76,9 +78,10 @@ int main(int argc, char *argv[]) {                  log_debug("Remounting %s", me->mnt_dir); -                if ((pid = fork()) < 0) { +                pid = fork(); +                if (pid < 0) {                          log_error("Failed to fork: %m"); -                        ret = 1; +                        ret = EXIT_FAILURE;                          continue;                  } @@ -101,8 +104,15 @@ int main(int argc, char *argv[]) {                  /* Parent */                  s = strdup(me->mnt_dir); +                if (!s) { +                        log_error("Out of memory."); +                        ret = EXIT_FAILURE; +                        continue; +                } + -                if ((k = hashmap_put(pids, UINT_TO_PTR(pid), s)) < 0) { +                k = hashmap_put(pids, UINT_TO_PTR(pid), s); +                if (k < 0) {                          log_error("Failed to add PID to set: %s", strerror(-k));                          ret = EXIT_FAILURE;                          continue; @@ -124,7 +134,8 @@ int main(int argc, char *argv[]) {                          break;                  } -                if ((s = hashmap_remove(pids, UINT_TO_PTR(si.si_pid)))) { +                s = hashmap_remove(pids, UINT_TO_PTR(si.si_pid)); +                if (s) {                          if (!is_clean_exit(si.si_code, si.si_status)) {                                  if (si.si_code == CLD_EXITED)                                          log_error("/bin/mount for %s exited with exit status %i.", s, si.si_status); | 
