diff options
| author | Nils Carlson <pyssling@ludd.ltu.se> | 2015-07-06 00:00:59 +0200 | 
|---|---|---|
| committer | Nils Carlson <pyssling@ludd.ltu.se> | 2016-01-12 22:10:41 +0000 | 
| commit | ee48dbd55f544d9ee4a17497b5757be7e854c869 (patch) | |
| tree | e290abed946e3c8dc1f77efeafe2aec61095265c /src/core/machine-id-setup.c | |
| parent | a41a7181c9af8f9ac93a85a2cf133294dd202c8e (diff) | |
core: Add machine-id setting
Allow for overriding all other machine-ids which may be present on
the system using a kernel command line systemd.machine_id or
--machine-id= option.
This is especially useful for network booted systems where the
machine-id needs to be static, or for containers where a specific
machine-id is wanted.
Diffstat (limited to 'src/core/machine-id-setup.c')
| -rw-r--r-- | src/core/machine-id-setup.c | 23 | 
1 files changed, 15 insertions, 8 deletions
| diff --git a/src/core/machine-id-setup.c b/src/core/machine-id-setup.c index 145ba2a28d..09b0449c80 100644 --- a/src/core/machine-id-setup.c +++ b/src/core/machine-id-setup.c @@ -198,7 +198,7 @@ static int generate_machine_id(char id[34], const char *root) {          return 0;  } -int machine_id_setup(const char *root) { +int machine_id_setup(const char *root, sd_id128_t machine_id) {          const char *etc_machine_id, *run_machine_id;          _cleanup_close_ int fd = -1;          bool writable = true; @@ -248,15 +248,22 @@ int machine_id_setup(const char *root) {                  }          } -        if (read_machine_id(fd, id) >= 0) -                return 0; +        /* A machine id argument overrides all other machined-ids */ +        if (!sd_id128_is_null(machine_id)) { +                sd_id128_to_string(machine_id, id); +                id[32] = '\n'; +                id[33] = 0; +        } else { +                if (read_machine_id(fd, id) >= 0) +                        return 0; -        /* Hmm, so, the id currently stored is not useful, then let's -         * generate one */ +                /* Hmm, so, the id currently stored is not useful, then let's +                 * generate one */ -        r = generate_machine_id(id, root); -        if (r < 0) -                return r; +                r = generate_machine_id(id, root); +                if (r < 0) +                        return r; +        }          if (writable)                  if (write_machine_id(fd, id) >= 0) | 
