diff options
| -rw-r--r-- | README | 4 | ||||
| -rw-r--r-- | src/core/manager.c | 4 | ||||
| -rw-r--r-- | src/machine/machinectl.c | 2 | ||||
| -rw-r--r-- | src/shared/bus-util.c | 31 | ||||
| -rw-r--r-- | src/shared/bus-util.h | 2 | ||||
| -rw-r--r-- | src/systemctl/systemctl.c | 2 | ||||
| -rw-r--r-- | test/test-functions | 21 | 
7 files changed, 46 insertions, 20 deletions
| @@ -237,10 +237,6 @@ SYSV INIT.D SCRIPTS:          needs to look like, and provide an implementation at the marked places.  WARNINGS: -        systemd will freeze execution during boot if /etc/mtab exists -        but is not a symlink to /proc/mounts. Please ensure that -        /etc/mtab is a proper symlink. -          systemd will warn you during boot if /usr is on a different          file system than /. While in systemd itself very little will          break if /usr is on a separate partition, many of its diff --git a/src/core/manager.c b/src/core/manager.c index 711b0cdcee..39e3cbbfe1 100644 --- a/src/core/manager.c +++ b/src/core/manager.c @@ -989,7 +989,7 @@ Manager* manager_free(Manager *m) {          free(m->switch_root_init);          for (i = 0; i < _RLIMIT_MAX; i++) -                free(m->rlimit[i]); +                m->rlimit[i] = mfree(m->rlimit[i]);          assert(hashmap_isempty(m->units_requiring_mounts_for));          hashmap_free(m->units_requiring_mounts_for); @@ -2923,6 +2923,8 @@ int manager_set_default_rlimits(Manager *m, struct rlimit **default_rlimit) {          assert(m);          for (i = 0; i < _RLIMIT_MAX; i++) { +                m->rlimit[i] = mfree(m->rlimit[i]); +                  if (!default_rlimit[i])                          continue; diff --git a/src/machine/machinectl.c b/src/machine/machinectl.c index 685bbafdf1..38a75f85d5 100644 --- a/src/machine/machinectl.c +++ b/src/machine/machinectl.c @@ -1571,7 +1571,7 @@ static int start_machine(int argc, char *argv[], void *userdata) {                          return log_oom();          } -        r = bus_wait_for_jobs(w, arg_quiet); +        r = bus_wait_for_jobs(w, arg_quiet, NULL);          if (r < 0)                  return r; diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 5c6dc34700..b9a8ee4074 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -2041,13 +2041,21 @@ static const struct {          { "start-limit", "start of the service was attempted too often" }  }; -static void log_job_error_with_service_result(const char* service, const char *result) { -        _cleanup_free_ char *service_shell_quoted = NULL; +static void log_job_error_with_service_result(const char* service, const char *result, const char *extra_args) { +        _cleanup_free_ char *service_shell_quoted = NULL, *systemctl_extra_args = NULL;          assert(service);          service_shell_quoted = shell_maybe_quote(service); +        systemctl_extra_args = strjoin("systemctl ", extra_args, " ", NULL); +        if (!systemctl_extra_args) { +                log_oom(); +                return; +        } + +        systemctl_extra_args = strstrip(systemctl_extra_args); +          if (!isempty(result)) {                  unsigned i; @@ -2056,27 +2064,30 @@ static void log_job_error_with_service_result(const char* service, const char *r                                  break;                  if (i < ELEMENTSOF(explanations)) { -                        log_error("Job for %s failed because %s. See \"systemctl status %s\" and \"journalctl -xe\" for details.\n", +                        log_error("Job for %s failed because %s. See \"%s status %s\" and \"journalctl -xe\" for details.\n",                                    service,                                    explanations[i].explanation, +                                  systemctl_extra_args,                                    strna(service_shell_quoted));                          goto finish;                  }          } -        log_error("Job for %s failed. See \"systemctl status %s\" and \"journalctl -xe\" for details.\n", +        log_error("Job for %s failed. See \"%s status %s\" and \"journalctl -xe\" for details.\n",                    service, +                  systemctl_extra_args,                    strna(service_shell_quoted));  finish:          /* For some results maybe additional explanation is required */          if (streq_ptr(result, "start-limit")) -                log_info("To force a start use \"systemctl reset-failed %1$s\" followed by \"systemctl start %1$s\" again.", +                log_info("To force a start use \"%1$s reset-failed %2$s\" followed by \"%1$s start %2$s\" again.", +                         systemctl_extra_args,                           strna(service_shell_quoted));  } -static int check_wait_response(BusWaitForJobs *d, bool quiet) { +static int check_wait_response(BusWaitForJobs *d, bool quiet, const char *extra_args) {          int r = 0;          assert(d->result); @@ -2103,7 +2114,7 @@ static int check_wait_response(BusWaitForJobs *d, bool quiet) {                                  if (q < 0)                                          log_debug_errno(q, "Failed to get Result property of service %s: %m", d->name); -                                log_job_error_with_service_result(d->name, result); +                                log_job_error_with_service_result(d->name, result, extra_args);                          } else                                  log_error("Job failed. See \"journalctl -xe\" for details.");                  } @@ -2127,7 +2138,7 @@ static int check_wait_response(BusWaitForJobs *d, bool quiet) {          return r;  } -int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet) { +int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet, const char *extra_args) {          int r = 0;          assert(d); @@ -2140,7 +2151,7 @@ int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet) {                          return log_error_errno(q, "Failed to wait for response: %m");                  if (d->result) { -                        q = check_wait_response(d, quiet); +                        q = check_wait_response(d, quiet, extra_args);                          /* Return the first error as it is most likely to be                           * meaningful. */                          if (q < 0 && r == 0) @@ -2175,7 +2186,7 @@ int bus_wait_for_jobs_one(BusWaitForJobs *d, const char *path, bool quiet) {          if (r < 0)                  return log_oom(); -        return bus_wait_for_jobs(d, quiet); +        return bus_wait_for_jobs(d, quiet, NULL);  }  int bus_deserialize_and_dump_unit_file_changes(sd_bus_message *m, bool quiet, UnitFileChange **changes, unsigned *n_changes) { diff --git a/src/shared/bus-util.h b/src/shared/bus-util.h index a5e3b6a0b5..18fc827754 100644 --- a/src/shared/bus-util.h +++ b/src/shared/bus-util.h @@ -182,7 +182,7 @@ typedef struct BusWaitForJobs BusWaitForJobs;  int bus_wait_for_jobs_new(sd_bus *bus, BusWaitForJobs **ret);  void bus_wait_for_jobs_free(BusWaitForJobs *d);  int bus_wait_for_jobs_add(BusWaitForJobs *d, const char *path); -int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet); +int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet, const char *extra_args);  int bus_wait_for_jobs_one(BusWaitForJobs *d, const char *path, bool quiet);  DEFINE_TRIVIAL_CLEANUP_FUNC(BusWaitForJobs*, bus_wait_for_jobs_free); diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c index cbf71268c6..3f2c308b8f 100644 --- a/src/systemctl/systemctl.c +++ b/src/systemctl/systemctl.c @@ -2794,7 +2794,7 @@ static int start_unit(int argc, char *argv[], void *userdata) {          if (!arg_no_block) {                  int q; -                q = bus_wait_for_jobs(w, arg_quiet); +                q = bus_wait_for_jobs(w, arg_quiet, arg_scope != UNIT_FILE_SYSTEM ? "--user" : NULL);                  if (q < 0)                          return q; diff --git a/test/test-functions b/test/test-functions index 9288200717..80d048c0d2 100644 --- a/test/test-functions +++ b/test/test-functions @@ -117,8 +117,25 @@ setup_basic_environment() {      strip_binaries      install_depmod_files      generate_module_dependencies -    # softlink mtab -    ln -fs /proc/self/mounts $initdir/etc/mtab +} + +install_valgrind() { +    if ! type -p valgrind; then +        dfatal "Failed to install valgrind" +        exit 1 +    fi + +    local _valgrind_bins=$(strace -e execve valgrind /bin/true 2>&1 >/dev/null | perl -lne 'print $1 if /^execve\("([^"]+)"/') +    dracut_install $_valgrind_bins + +    local _valgrind_libs=$(LD_DEBUG=files valgrind /bin/true 2>&1 >/dev/null | perl -lne 'print $1 if m{calling init: (/.*vgpreload_.*)}') +    dracut_install $_valgrind_libs + +    local _valgrind_dbg_and_supp=$( +        strace -e open valgrind /bin/true 2>&1 >/dev/null | +        perl -lne 'if (my ($fname) = /^open\("([^"]+).*= (?!-)\d+/) { print $fname if $fname =~ /debug|\.supp$/ }' +    ) +    dracut_install $_valgrind_dbg_and_supp  }  install_dmevent() { | 
