diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/cryptsetup/cryptsetup.c | 8 | ||||
| -rw-r--r-- | src/libsystemd-network/dhcp-identifier.h | 4 | ||||
| -rw-r--r-- | src/nspawn/nspawn-mount.c | 23 | ||||
| -rw-r--r-- | src/shared/bus-util.c | 2 | ||||
| -rw-r--r-- | src/systemctl/systemctl.c | 8 | 
5 files changed, 26 insertions, 19 deletions
| diff --git a/src/cryptsetup/cryptsetup.c b/src/cryptsetup/cryptsetup.c index 2ef966257a..9927621ea0 100644 --- a/src/cryptsetup/cryptsetup.c +++ b/src/cryptsetup/cryptsetup.c @@ -719,8 +719,12 @@ int main(int argc, char *argv[]) {                  int k;                  k = crypt_init_by_name(&cd, argv[2]); -                if (k) { -                        log_error_errno(k, "crypt_init() failed: %m"); +                if (k == -ENODEV) { +                        log_info("Volume %s already inactive.", argv[2]); +                        r = EXIT_SUCCESS; +                        goto finish; +                } else if (k) { +                        log_error_errno(k, "crypt_init_by_name() failed: %m");                          goto finish;                  } diff --git a/src/libsystemd-network/dhcp-identifier.h b/src/libsystemd-network/dhcp-identifier.h index babae15c5b..e6486b78f8 100644 --- a/src/libsystemd-network/dhcp-identifier.h +++ b/src/libsystemd-network/dhcp-identifier.h @@ -75,7 +75,7 @@ int dhcp_identifier_set_iaid(int ifindex, uint8_t *mac, size_t mac_len, void *_i  static inline int dhcp_validate_duid_len(uint16_t duid_type, size_t duid_len) {          struct duid d; -        assert_return(duid_len > 0 && duid_len <= MAX_DUID_LEN, -EINVAL); +        assert(duid_len > 0);          switch (duid_type) {          case DUID_TYPE_LLT: @@ -95,6 +95,8 @@ static inline int dhcp_validate_duid_len(uint16_t duid_type, size_t duid_len) {                          return -EINVAL;                  break;          default: +                if (duid_len > sizeof(d.raw)) +                        return -EINVAL;                  /* accept unknown type in order to be forward compatible */                  break;          } diff --git a/src/nspawn/nspawn-mount.c b/src/nspawn/nspawn-mount.c index 64cb6b3ce3..8e2d2d543c 100644 --- a/src/nspawn/nspawn-mount.c +++ b/src/nspawn/nspawn-mount.c @@ -438,21 +438,22 @@ static int mount_bind(const char *dest, CustomMount *m) {                  r = mkdir_parents_label(where, 0755);                  if (r < 0)                          return log_error_errno(r, "Failed to make parents of %s: %m", where); + +                /* Create the mount point. Any non-directory file can be +                * mounted on any non-directory file (regular, fifo, socket, +                * char, block). +                */ +                if (S_ISDIR(source_st.st_mode)) +                        r = mkdir_label(where, 0755); +                else +                        r = touch(where); +                if (r < 0) +                        return log_error_errno(r, "Failed to create mount point %s: %m", where); +          } else {                  return log_error_errno(errno, "Failed to stat %s: %m", where);          } -        /* Create the mount point. Any non-directory file can be -         * mounted on any non-directory file (regular, fifo, socket, -         * char, block). -         */ -        if (S_ISDIR(source_st.st_mode)) -                r = mkdir_label(where, 0755); -        else -                r = touch(where); -        if (r < 0 && r != -EEXIST) -                return log_error_errno(r, "Failed to create mount point %s: %m", where); -          if (mount(m->source, where, NULL, mount_flags, mount_opts) < 0)                  return log_error_errno(errno, "mount(%s) failed: %m", where); diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 90b312a1a7..d9dd3c6a11 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -1068,7 +1068,7 @@ static int map_basic(sd_bus *bus, const char *member, sd_bus_message *m, sd_bus_          }          case SD_BUS_TYPE_UINT32: { -                uint64_t u; +                uint32_t u;                  uint32_t *p = userdata;                  r = sd_bus_message_read_basic(m, type, &u); diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c index 2afb7bad1a..3407d93c80 100644 --- a/src/systemctl/systemctl.c +++ b/src/systemctl/systemctl.c @@ -1896,13 +1896,13 @@ static void output_machines_list(struct machine_info *machine_infos, unsigned n)                          printf("%s%s%s ", on_state, circle ? draw_special_char(DRAW_BLACK_CIRCLE) : " ", off_state);                  if (m->is_host) -                        printf("%-*s (host) %s%-*s%s %s%*u%s %*u\n", +                        printf("%-*s (host) %s%-*s%s %s%*" PRIu32 "%s %*" PRIu32 "\n",                                 (int) (namelen - (sizeof(" (host)")-1)), strna(m->name),                                 on_state, statelen, strna(m->state), off_state,                                 on_failed, failedlen, m->n_failed_units, off_failed,                                 jobslen, m->n_jobs);                  else -                        printf("%-*s %s%-*s%s %s%*u%s %*u\n", +                        printf("%-*s %s%-*s%s %s%*" PRIu32 "%s %*" PRIu32 "\n",                                 namelen, strna(m->name),                                 on_state, statelen, strna(m->state), off_state,                                 on_failed, failedlen, m->n_failed_units, off_failed, @@ -4637,8 +4637,8 @@ static int show_system_status(sd_bus *bus) {          printf("    State: %s%s%s\n",                 on, strna(mi.state), off); -        printf("     Jobs: %u queued\n", mi.n_jobs); -        printf("   Failed: %u units\n", mi.n_failed_units); +        printf("     Jobs: %" PRIu32 " queued\n", mi.n_jobs); +        printf("   Failed: %" PRIu32 " units\n", mi.n_failed_units);          printf("    Since: %s; %s\n",                 format_timestamp(since2, sizeof(since2), mi.timestamp), | 
