diff options
| author | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-06-09 02:37:33 -0400 | 
|---|---|---|
| committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-06-09 02:37:33 -0400 | 
| commit | f6e7ffdf3fe8e3ed5e659f747946461350ade5a8 (patch) | |
| tree | d261964cafdd51154b1ad757574f508da2d9ad76 /src/core/machine-id-setup.c | |
| parent | 566cac15ed36506e2bb766313a5d4e0825bc6499 (diff) | |
| parent | 022ed72eff07ca6c1409747e774ef5b35724c9df (diff) | |
Merge tag 'v230-3.parabola1' into parabola
Diffstat (limited to 'src/core/machine-id-setup.c')
| -rw-r--r-- | src/core/machine-id-setup.c | 49 | 
1 files changed, 19 insertions, 30 deletions
| diff --git a/src/core/machine-id-setup.c b/src/core/machine-id-setup.c index 9e6b3d3292..0145fe2894 100644 --- a/src/core/machine-id-setup.c +++ b/src/core/machine-id-setup.c @@ -101,14 +101,23 @@ static int read_machine_id(int fd, char id[34]) {          return 0;  } -static int write_machine_id(int fd, char id[34]) { +static int write_machine_id(int fd, const char id[34]) { +        int r; +          assert(fd >= 0);          assert(id);          if (lseek(fd, 0, SEEK_SET) < 0)                  return -errno; -        return loop_write(fd, id, 33, false); +        r = loop_write(fd, id, 33, false); +        if (r < 0) +                return r; + +        if (fsync(fd) < 0) +                return -errno; + +        return 0;  }  static int generate_machine_id(char id[34], const char *root) { @@ -120,10 +129,7 @@ static int generate_machine_id(char id[34], const char *root) {          assert(id); -        if (isempty(root)) -                dbus_machine_id = "/var/lib/dbus/machine-id"; -        else -                dbus_machine_id = strjoina(root, "/var/lib/dbus/machine-id"); +        dbus_machine_id = prefix_roota(root, "/var/lib/dbus/machine-id");          /* First, try reading the D-Bus machine id, unless it is a symlink */          fd = open(dbus_machine_id, O_RDONLY|O_CLOEXEC|O_NOCTTY|O_NOFOLLOW); @@ -203,18 +209,8 @@ int machine_id_setup(const char *root, sd_id128_t machine_id) {          char id[34]; /* 32 + \n + \0 */          int r; -        if (isempty(root))  { -                etc_machine_id = "/etc/machine-id"; -                run_machine_id = "/run/machine-id"; -        } else { -                char *x; - -                x = strjoina(root, "/etc/machine-id"); -                etc_machine_id = path_kill_slashes(x); - -                x = strjoina(root, "/run/machine-id"); -                run_machine_id = path_kill_slashes(x); -        } +        etc_machine_id = prefix_roota(root, "/etc/machine-id"); +        run_machine_id = prefix_roota(root, "/run/machine-id");          RUN_WITH_UMASK(0000) {                  /* We create this 0444, to indicate that this isn't really @@ -274,10 +270,10 @@ int machine_id_setup(const char *root, sd_id128_t machine_id) {          RUN_WITH_UMASK(0022) {                  r = write_string_file(run_machine_id, id, WRITE_STRING_FILE_CREATE); -        } -        if (r < 0) { -                (void) unlink(run_machine_id); -                return log_error_errno(r, "Cannot write %s: %m", run_machine_id); +                if (r < 0) { +                        (void) unlink(run_machine_id); +                        return log_error_errno(r, "Cannot write %s: %m", run_machine_id); +                }          }          /* And now, let's mount it over */ @@ -301,14 +297,7 @@ int machine_id_commit(const char *root) {          char id[34]; /* 32 + \n + \0 */          int r; -        if (isempty(root)) -                etc_machine_id = "/etc/machine-id"; -        else { -                char *x; - -                x = strjoina(root, "/etc/machine-id"); -                etc_machine_id = path_kill_slashes(x); -        } +        etc_machine_id = prefix_roota(root, "/etc/machine-id");          r = path_is_mount_point(etc_machine_id, 0);          if (r < 0) | 
