diff options
| -rw-r--r-- | hwdb/70-mouse.hwdb | 4 | ||||
| -rw-r--r-- | src/bootchart/bootchart.c | 16 | ||||
| -rw-r--r-- | src/core/automount.c | 1 | ||||
| -rw-r--r-- | src/core/busname.c | 3 | ||||
| -rw-r--r-- | src/core/job.c | 313 | ||||
| -rw-r--r-- | src/core/mount.c | 3 | ||||
| -rw-r--r-- | src/core/service.c | 5 | ||||
| -rw-r--r-- | src/core/slice.c | 1 | ||||
| -rw-r--r-- | src/core/socket.c | 1 | ||||
| -rw-r--r-- | src/core/swap.c | 1 | ||||
| -rw-r--r-- | src/core/target.c | 1 | ||||
| -rw-r--r-- | src/core/unit.c | 81 | ||||
| -rw-r--r-- | src/core/unit.h | 1 | ||||
| -rw-r--r-- | src/login/logind-dbus.c | 2 | ||||
| -rw-r--r-- | src/udev/ata_id/ata_id.c | 14 | ||||
| -rw-r--r-- | src/udev/udevd.c | 18 | ||||
| -rw-r--r-- | src/user-sessions/user-sessions.c | 2 | 
17 files changed, 209 insertions, 258 deletions
| diff --git a/hwdb/70-mouse.hwdb b/hwdb/70-mouse.hwdb index 1633321502..bc4b597bbf 100644 --- a/hwdb/70-mouse.hwdb +++ b/hwdb/70-mouse.hwdb @@ -247,6 +247,10 @@ mouse:usb:v046dpc05a:name:Logitech USB Optical Mouse:  mouse:usb:v046dpc065:name:Logitech USB Laser Mouse:   MOUSE_DPI=1000@125 +# Logitech MX Master +mouse:usb:v046dp4041:name:Logitech MX Master: + MOUSE_DPI=1000@166 +  # Logitech MK260 Wireless Combo Receiver aka M-R0011  mouse:usb:v046dpc52e:name:Logitech USB Receiver:   MOUSE_DPI=1000@200 diff --git a/src/bootchart/bootchart.c b/src/bootchart/bootchart.c index 3360bc85be..1625d51fa8 100644 --- a/src/bootchart/bootchart.c +++ b/src/bootchart/bootchart.c @@ -387,9 +387,6 @@ int main(int argc, char *argv[]) {          for (samples = 0; !exiting && samples < arg_samples_len; samples++) {                  int res;                  double sample_stop; -                struct timespec req; -                time_t newint_s; -                long newint_ns;                  double elapsed;                  double timeleft; @@ -427,18 +424,17 @@ int main(int argc, char *argv[]) {                  elapsed = (sample_stop - sampledata->sampletime) * 1000000000.0;                  timeleft = interval - elapsed; -                newint_s = (time_t)(timeleft / 1000000000.0); -                newint_ns = (long)(timeleft - (newint_s * 1000000000.0)); -                  /*                   * check if we have not consumed our entire timeslice. If we                   * do, don't sleep and take a new sample right away.                   * we'll lose all the missed samples and overrun our total                   * time                   */ -                if (newint_ns > 0 || newint_s > 0) { -                        req.tv_sec = newint_s; -                        req.tv_nsec = newint_ns; +                if (timeleft > 0) { +                        struct timespec req; + +                        req.tv_sec = (time_t)(timeleft / 1000000000.0); +                        req.tv_nsec = (long)(timeleft - (req.tv_sec * 1000000000.0));                          res = nanosleep(&req, NULL);                          if (res) { @@ -452,7 +448,7 @@ int main(int argc, char *argv[]) {                  } else {                          overrun++;                          /* calculate how many samples we lost and scrap them */ -                        arg_samples_len -= (int)(newint_ns / interval); +                        arg_samples_len -= (int)(-timeleft / interval);                  }                  LIST_PREPEND(link, head, sampledata);          } diff --git a/src/core/automount.c b/src/core/automount.c index d847dc1629..90b331f70e 100644 --- a/src/core/automount.c +++ b/src/core/automount.c @@ -1066,7 +1066,6 @@ const UnitVTable automount_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Set up automount %s.",                          [JOB_FAILED]     = "Failed to set up automount %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                  },                  .finished_stop_job = {                          [JOB_DONE]       = "Unset automount %s.", diff --git a/src/core/busname.c b/src/core/busname.c index 2085721546..9530a87311 100644 --- a/src/core/busname.c +++ b/src/core/busname.c @@ -1065,13 +1065,10 @@ const UnitVTable busname_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Listening on %s.",                          [JOB_FAILED]     = "Failed to listen on %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.", -                        [JOB_TIMEOUT]    = "Timed out starting %s.",                  },                  .finished_stop_job = {                          [JOB_DONE]       = "Closed %s.",                          [JOB_FAILED]     = "Failed stopping %s.", -                        [JOB_TIMEOUT]    = "Timed out stopping %s.",                  },          },  }; diff --git a/src/core/job.c b/src/core/job.c index 1448e5b69a..15f5cc0cc9 100644 --- a/src/core/job.c +++ b/src/core/job.c @@ -495,10 +495,48 @@ static void job_change_type(Job *j, JobType newtype) {          j->type = newtype;  } +static int job_perform_on_unit(Job **j) { +        /* While we execute this operation the job might go away (for +         * example: because it finishes immediately or is replaced by a new, +         * conflicting job.) To make sure we don't access a freed job later on +         * we store the id here, so that we can verify the job is still +         * valid. */ +        Manager *m  = (*j)->manager; +        Unit *u     = (*j)->unit; +        JobType t   = (*j)->type; +        uint32_t id = (*j)->id; +        int r; + +        switch (t) { +                case JOB_START: +                        r = unit_start(u); +                        break; + +                case JOB_RESTART: +                        t = JOB_STOP; +                case JOB_STOP: +                        r = unit_stop(u); +                        break; + +                case JOB_RELOAD: +                        r = unit_reload(u); +                        break; + +                default: +                        assert_not_reached("Invalid job type"); +        } + +        /* Log if the job still exists and the start/stop/reload function +         * actually did something. */ +        *j = manager_get_job(m, id); +        if (*j && r > 0) +                unit_status_emit_starting_stopping_reloading(u, t); + +        return r; +} +  int job_run_and_invalidate(Job *j) {          int r; -        uint32_t id; -        Manager *m = j->manager;          assert(j);          assert(j->installed); @@ -517,23 +555,9 @@ int job_run_and_invalidate(Job *j) {          job_set_state(j, JOB_RUNNING);          job_add_to_dbus_queue(j); -        /* While we execute this operation the job might go away (for -         * example: because it is replaced by a new, conflicting -         * job.) To make sure we don't access a freed job later on we -         * store the id here, so that we can verify the job is still -         * valid. */ -        id = j->id;          switch (j->type) { -                case JOB_START: -                        r = unit_start(j->unit); - -                        /* If this unit cannot be started, then simply wait */ -                        if (r == -EBADR) -                                r = 0; -                        break; -                  case JOB_VERIFY_ACTIVE: {                          UnitActiveState t = unit_active_state(j->unit);                          if (UNIT_IS_ACTIVE_OR_RELOADING(t)) @@ -545,17 +569,19 @@ int job_run_and_invalidate(Job *j) {                          break;                  } +                case JOB_START:                  case JOB_STOP:                  case JOB_RESTART: -                        r = unit_stop(j->unit); +                        r = job_perform_on_unit(&j); -                        /* If this unit cannot stopped, then simply wait. */ +                        /* If the unit type does not support starting/stopping, +                         * then simply wait. */                          if (r == -EBADR)                                  r = 0;                          break;                  case JOB_RELOAD: -                        r = unit_reload(j->unit); +                        r = job_perform_on_unit(&j);                          break;                  case JOB_NOP: @@ -566,7 +592,6 @@ int job_run_and_invalidate(Job *j) {                          assert_not_reached("Unknown job type");          } -        j = manager_get_job(m, id);          if (j) {                  if (r == -EALREADY)                          r = job_finish_and_invalidate(j, JOB_DONE, true); @@ -588,161 +613,110 @@ int job_run_and_invalidate(Job *j) {  }  _pure_ static const char *job_get_status_message_format(Unit *u, JobType t, JobResult result) { +        const char *format;          const UnitStatusMessageFormats *format_table; +        static const char *const generic_finished_start_job[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = "Started %s.", +                [JOB_TIMEOUT]     = "Timed out starting %s.", +                [JOB_FAILED]      = "Failed to start %s.", +                [JOB_DEPENDENCY]  = "Dependency failed for %s.", +                [JOB_ASSERT]      = "Assertion failed for %s.", +                [JOB_UNSUPPORTED] = "Starting of %s not supported.", +        }; +        static const char *const generic_finished_stop_job[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = "Stopped %s.", +                [JOB_FAILED]      = "Stopped (with error) %s.", +                [JOB_TIMEOUT]     = "Timed out stoppping %s.", +        }; +        static const char *const generic_finished_reload_job[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = "Reloaded %s.", +                [JOB_FAILED]      = "Reload failed for %s.", +                [JOB_TIMEOUT]     = "Timed out reloading %s.", +        }; +        /* When verify-active detects the unit is inactive, report it. +         * Most likely a DEPEND warning from a requisiting unit will +         * occur next and it's nice to see what was requisited. */ +        static const char *const generic_finished_verify_active_job[_JOB_RESULT_MAX] = { +                [JOB_SKIPPED]     = "%s is not active.", +        };          assert(u);          assert(t >= 0);          assert(t < _JOB_TYPE_MAX); -        format_table = &UNIT_VTABLE(u)->status_message_formats; -        if (!format_table) -                return NULL; +        if (t == JOB_START || t == JOB_STOP || t == JOB_RESTART) { +                format_table = &UNIT_VTABLE(u)->status_message_formats; +                if (format_table) { +                        format = t == JOB_START ? format_table->finished_start_job[result] : +                                                  format_table->finished_stop_job[result]; +                        if (format) +                                return format; +                } +        } +        /* Return generic strings */          if (t == JOB_START) -                return format_table->finished_start_job[result]; +                return generic_finished_start_job[result];          else if (t == JOB_STOP || t == JOB_RESTART) -                return format_table->finished_stop_job[result]; +                return generic_finished_stop_job[result]; +        else if (t == JOB_RELOAD) +                return generic_finished_reload_job[result]; +        else if (t == JOB_VERIFY_ACTIVE) +                return generic_finished_verify_active_job[result];          return NULL;  } -_pure_ static const char *job_get_status_message_format_try_harder(Unit *u, JobType t, JobResult result) { +static void job_print_status_message(Unit *u, JobType t, JobResult result) {          const char *format; +        static const char* const job_result_status_table[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = ANSI_GREEN_ON            "  OK  " ANSI_HIGHLIGHT_OFF, +                [JOB_TIMEOUT]     = ANSI_HIGHLIGHT_RED_ON    " TIME " ANSI_HIGHLIGHT_OFF, +                [JOB_FAILED]      = ANSI_HIGHLIGHT_RED_ON    "FAILED" ANSI_HIGHLIGHT_OFF, +                [JOB_DEPENDENCY]  = ANSI_HIGHLIGHT_YELLOW_ON "DEPEND" ANSI_HIGHLIGHT_OFF, +                [JOB_SKIPPED]     = ANSI_HIGHLIGHT_ON        " INFO " ANSI_HIGHLIGHT_OFF, +                [JOB_ASSERT]      = ANSI_HIGHLIGHT_YELLOW_ON "ASSERT" ANSI_HIGHLIGHT_OFF, +                [JOB_UNSUPPORTED] = ANSI_HIGHLIGHT_YELLOW_ON "UNSUPP" ANSI_HIGHLIGHT_OFF, +        };          assert(u);          assert(t >= 0);          assert(t < _JOB_TYPE_MAX);          format = job_get_status_message_format(u, t, result); -        if (format) -                return format; - -        /* Return generic strings */ -        if (t == JOB_START) { -                if (result == JOB_DONE) -                        return "Started %s."; -                else if (result == JOB_TIMEOUT) -                        return "Timed out starting %s."; -                else if (result == JOB_FAILED) -                        return "Failed to start %s."; -                else if (result == JOB_DEPENDENCY) -                        return "Dependency failed for %s."; -                else if (result == JOB_ASSERT) -                        return "Assertion failed for %s."; -                else if (result == JOB_UNSUPPORTED) -                        return "Starting of %s not supported."; -        } else if (t == JOB_STOP || t == JOB_RESTART) { -                if (result == JOB_DONE) -                        return "Stopped %s."; -                else if (result == JOB_FAILED) -                        return "Stopped (with error) %s."; -                else if (result == JOB_TIMEOUT) -                        return "Timed out stoppping %s."; -        } else if (t == JOB_RELOAD) { -                if (result == JOB_DONE) -                        return "Reloaded %s."; -                else if (result == JOB_FAILED) -                        return "Reload failed for %s."; -                else if (result == JOB_TIMEOUT) -                        return "Timed out reloading %s."; -        } - -        return NULL; -} +        if (!format) +                return; -static void job_print_status_message(Unit *u, JobType t, JobResult result) { -        const char *format; - -        assert(u); -        assert(t >= 0); -        assert(t < _JOB_TYPE_MAX); +        if (result != JOB_DONE) +                manager_flip_auto_status(u->manager, true);          DISABLE_WARNING_FORMAT_NONLITERAL; +        unit_status_printf(u, job_result_status_table[result], format); +        REENABLE_WARNING; -        if (t == JOB_START) { -                format = job_get_status_message_format(u, t, result); -                if (!format) -                        return; - -                switch (result) { - -                case JOB_DONE: -                        if (u->condition_result) -                                unit_status_printf(u, ANSI_GREEN_ON "  OK  " ANSI_HIGHLIGHT_OFF, format); -                        break; - -                case JOB_TIMEOUT: -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_RED_ON " TIME " ANSI_HIGHLIGHT_OFF, format); -                        break; - -                case JOB_FAILED: { -                        _cleanup_free_ char *quoted = NULL; - -                        quoted = shell_maybe_quote(u->id); - -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_RED_ON "FAILED" ANSI_HIGHLIGHT_OFF, format); -                        manager_status_printf(u->manager, STATUS_TYPE_NORMAL, NULL, "See 'systemctl status %s' for details.", strna(quoted)); -                        break; -                } - -                case JOB_DEPENDENCY: -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_YELLOW_ON "DEPEND" ANSI_HIGHLIGHT_OFF, format); -                        break; - -                case JOB_ASSERT: -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_YELLOW_ON "ASSERT" ANSI_HIGHLIGHT_OFF, format); -                        break; - -                case JOB_UNSUPPORTED: -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_YELLOW_ON "UNSUPP" ANSI_HIGHLIGHT_OFF, format); -                        break; - -                default: -                        ; -                } - -        } else if (t == JOB_STOP || t == JOB_RESTART) { - -                format = job_get_status_message_format(u, t, result); -                if (!format) -                        return; - -                switch (result) { - -                case JOB_TIMEOUT: -                        manager_flip_auto_status(u->manager, true); -                        unit_status_printf(u, ANSI_HIGHLIGHT_RED_ON " TIME " ANSI_HIGHLIGHT_OFF, format); -                        break; - -                case JOB_DONE: -                case JOB_FAILED: -                        unit_status_printf(u, ANSI_GREEN_ON "  OK  " ANSI_HIGHLIGHT_OFF, format); -                        break; - -                default: -                        ; -                } - -        } else if (t == JOB_VERIFY_ACTIVE) { +        if (t == JOB_START && result == JOB_FAILED) { +                _cleanup_free_ char *quoted = shell_maybe_quote(u->id); -                /* When verify-active detects the unit is inactive, report it. -                 * Most likely a DEPEND warning from a requisiting unit will -                 * occur next and it's nice to see what was requisited. */ -                if (result == JOB_SKIPPED) -                        unit_status_printf(u, ANSI_HIGHLIGHT_ON " INFO " ANSI_HIGHLIGHT_OFF, "%s is not active."); +                manager_status_printf(u->manager, STATUS_TYPE_NORMAL, NULL, +                                      "See 'systemctl status %s' for details.", strna(quoted));          } - -        REENABLE_WARNING;  }  static void job_log_status_message(Unit *u, JobType t, JobResult result) {          const char *format;          char buf[LINE_MAX]; +        sd_id128_t mid; +        static const int job_result_log_level[_JOB_RESULT_MAX] = { +                [JOB_DONE]        = LOG_INFO, +                [JOB_CANCELED]    = LOG_INFO, +                [JOB_TIMEOUT]     = LOG_ERR, +                [JOB_FAILED]      = LOG_ERR, +                [JOB_DEPENDENCY]  = LOG_WARNING, +                [JOB_SKIPPED]     = LOG_NOTICE, +                [JOB_INVALID]     = LOG_INFO, +                [JOB_ASSERT]      = LOG_WARNING, +                [JOB_UNSUPPORTED] = LOG_WARNING, +        };          assert(u);          assert(t >= 0); @@ -754,7 +728,7 @@ static void job_log_status_message(Unit *u, JobType t, JobResult result) {          if (log_on_console())                  return; -        format = job_get_status_message_format_try_harder(u, t, result); +        format = job_get_status_message_format(u, t, result);          if (!format)                  return; @@ -762,32 +736,40 @@ static void job_log_status_message(Unit *u, JobType t, JobResult result) {          snprintf(buf, sizeof(buf), format, unit_description(u));          REENABLE_WARNING; -        if (t == JOB_START) { -                sd_id128_t mid; - +        if (t == JOB_START)                  mid = result == JOB_DONE ? SD_MESSAGE_UNIT_STARTED : SD_MESSAGE_UNIT_FAILED; -                log_struct(result == JOB_DONE ? LOG_INFO : LOG_ERR, -                           LOG_MESSAGE_ID(mid), +        else if (t == JOB_STOP || t == JOB_RESTART) +                mid = SD_MESSAGE_UNIT_STOPPED; +        else if (t == JOB_RELOAD) +                mid = SD_MESSAGE_UNIT_RELOADED; +        else { +                log_struct(job_result_log_level[result],                             LOG_UNIT_ID(u),                             LOG_MESSAGE("%s", buf),                             "RESULT=%s", job_result_to_string(result),                             NULL); +                return; +        } -        } else if (t == JOB_STOP) -                log_struct(result == JOB_DONE ? LOG_INFO : LOG_ERR, -                           LOG_MESSAGE_ID(SD_MESSAGE_UNIT_STOPPED), -                           LOG_UNIT_ID(u), -                           LOG_MESSAGE("%s", buf), -                           "RESULT=%s", job_result_to_string(result), -                           NULL); +        log_struct(job_result_log_level[result], +                   LOG_MESSAGE_ID(mid), +                   LOG_UNIT_ID(u), +                   LOG_MESSAGE("%s", buf), +                   "RESULT=%s", job_result_to_string(result), +                   NULL); +} -        else if (t == JOB_RELOAD) -                log_struct(result == JOB_DONE ? LOG_INFO : LOG_ERR, -                           LOG_MESSAGE_ID(SD_MESSAGE_UNIT_RELOADED), -                           LOG_UNIT_ID(u), -                           LOG_MESSAGE("%s", buf), -                           "RESULT=%s", job_result_to_string(result), -                           NULL); +static void job_emit_status_message(Unit *u, JobType t, JobResult result) { + +        /* No message if the job did not actually do anything due to failed condition. */ +        if (t == JOB_START && result == JOB_DONE && !u->condition_result) +                return; + +        job_log_status_message(u, t, result); + +        /* Reload status messages have traditionally not been printed to console. */ +        if (t != JOB_RELOAD) +                job_print_status_message(u, t, result);  }  static void job_fail_dependencies(Unit *u, UnitDependency d) { @@ -825,8 +807,7 @@ int job_finish_and_invalidate(Job *j, JobResult result, bool recursive) {          log_unit_debug(u, "Job %s/%s finished, result=%s", u->id, job_type_to_string(t), job_result_to_string(result)); -        job_print_status_message(u, t, result); -        job_log_status_message(u, t, result); +        job_emit_status_message(u, t, result);          job_add_to_dbus_queue(j); diff --git a/src/core/mount.c b/src/core/mount.c index 851b41351e..bf8e52bf0e 100644 --- a/src/core/mount.c +++ b/src/core/mount.c @@ -1025,7 +1025,7 @@ static int mount_reload(Unit *u) {          assert(m->state == MOUNT_MOUNTED);          mount_enter_remounting(m); -        return 0; +        return 1;  }  static int mount_serialize(Unit *u, FILE *f, FDSet *fds) { @@ -1897,7 +1897,6 @@ const UnitVTable mount_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Mounted %s.",                          [JOB_FAILED]     = "Failed to mount %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                          [JOB_TIMEOUT]    = "Timed out mounting %s.",                  },                  .finished_stop_job = { diff --git a/src/core/service.c b/src/core/service.c index d72ff54daa..39a2507b6f 100644 --- a/src/core/service.c +++ b/src/core/service.c @@ -1974,7 +1974,7 @@ static int service_reload(Unit *u) {          assert(s->state == SERVICE_RUNNING || s->state == SERVICE_EXITED);          service_enter_reload(s); -        return 0; +        return 1;  }  _pure_ static bool service_can_reload(Unit *u) { @@ -3229,13 +3229,10 @@ const UnitVTable service_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Started %s.",                          [JOB_FAILED]     = "Failed to start %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.", -                        [JOB_TIMEOUT]    = "Timed out starting %s.",                  },                  .finished_stop_job = {                          [JOB_DONE]       = "Stopped %s.",                          [JOB_FAILED]     = "Stopped (with error) %s.", -                        [JOB_TIMEOUT]    = "Timed out stopping %s.",                  },          },  }; diff --git a/src/core/slice.c b/src/core/slice.c index e52bf71515..064eb5d933 100644 --- a/src/core/slice.c +++ b/src/core/slice.c @@ -297,7 +297,6 @@ const UnitVTable slice_vtable = {          .status_message_formats = {                  .finished_start_job = {                          [JOB_DONE]       = "Created slice %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                  },                  .finished_stop_job = {                          [JOB_DONE]       = "Removed slice %s.", diff --git a/src/core/socket.c b/src/core/socket.c index 693cbc6080..87631f8753 100644 --- a/src/core/socket.c +++ b/src/core/socket.c @@ -2722,7 +2722,6 @@ const UnitVTable socket_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Listening on %s.",                          [JOB_FAILED]     = "Failed to listen on %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                          [JOB_TIMEOUT]    = "Timed out starting %s.",                  },                  .finished_stop_job = { diff --git a/src/core/swap.c b/src/core/swap.c index 193c8c3767..0bc3827ff0 100644 --- a/src/core/swap.c +++ b/src/core/swap.c @@ -1505,7 +1505,6 @@ const UnitVTable swap_vtable = {                  .finished_start_job = {                          [JOB_DONE]       = "Activated swap %s.",                          [JOB_FAILED]     = "Failed to activate swap %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                          [JOB_TIMEOUT]    = "Timed out activating swap %s.",                  },                  .finished_stop_job = { diff --git a/src/core/target.c b/src/core/target.c index 8817ef21c4..b492a7c4c7 100644 --- a/src/core/target.c +++ b/src/core/target.c @@ -227,7 +227,6 @@ const UnitVTable target_vtable = {          .status_message_formats = {                  .finished_start_job = {                          [JOB_DONE]       = "Reached target %s.", -                        [JOB_DEPENDENCY] = "Dependency failed for %s.",                  },                  .finished_stop_job = {                          [JOB_DONE]       = "Stopped target %s.", diff --git a/src/core/unit.c b/src/core/unit.c index fac017c57d..dd5e801285 100644 --- a/src/core/unit.c +++ b/src/core/unit.c @@ -1318,42 +1318,28 @@ static bool unit_assert_test(Unit *u) {  }  _pure_ static const char* unit_get_status_message_format(Unit *u, JobType t) { -        const UnitStatusMessageFormats *format_table; - -        assert(u); -        assert(t >= 0); -        assert(t < _JOB_TYPE_MAX); - -        if (t != JOB_START && t != JOB_STOP) -                return NULL; - -        format_table = &UNIT_VTABLE(u)->status_message_formats; -        if (!format_table) -                return NULL; - -        return format_table->starting_stopping[t == JOB_STOP]; -} - -_pure_ static const char *unit_get_status_message_format_try_harder(Unit *u, JobType t) {          const char *format; +        const UnitStatusMessageFormats *format_table;          assert(u); -        assert(t >= 0); -        assert(t < _JOB_TYPE_MAX); +        assert(t == JOB_START || t == JOB_STOP || t == JOB_RELOAD); -        format = unit_get_status_message_format(u, t); -        if (format) -                return format; +        if (t != JOB_RELOAD) { +                format_table = &UNIT_VTABLE(u)->status_message_formats; +                if (format_table) { +                        format = format_table->starting_stopping[t == JOB_STOP]; +                        if (format) +                                return format; +                } +        }          /* Return generic strings */          if (t == JOB_START)                  return "Starting %s.";          else if (t == JOB_STOP)                  return "Stopping %s."; -        else if (t == JOB_RELOAD) +        else                  return "Reloading %s."; - -        return NULL;  }  static void unit_status_print_starting_stopping(Unit *u, JobType t) { @@ -1361,12 +1347,7 @@ static void unit_status_print_starting_stopping(Unit *u, JobType t) {          assert(u); -        /* We only print status messages for selected units on -         * selected operations. */ -          format = unit_get_status_message_format(u, t); -        if (!format) -                return;          DISABLE_WARNING_FORMAT_NONLITERAL;          unit_status_printf(u, "", format); @@ -1388,9 +1369,7 @@ static void unit_status_log_starting_stopping_reloading(Unit *u, JobType t) {          /* We log status messages for all units and all operations. */ -        format = unit_get_status_message_format_try_harder(u, t); -        if (!format) -                return; +        format = unit_get_status_message_format(u, t);          DISABLE_WARNING_FORMAT_NONLITERAL;          snprintf(buf, sizeof(buf), format, unit_description(u)); @@ -1413,6 +1392,15 @@ static void unit_status_log_starting_stopping_reloading(Unit *u, JobType t) {                     NULL);  } +void unit_status_emit_starting_stopping_reloading(Unit *u, JobType t) { + +        unit_status_log_starting_stopping_reloading(u, t); + +        /* Reload status messages have traditionally not been printed to console. */ +        if (t != JOB_RELOAD) +                unit_status_print_starting_stopping(u, t); +} +  /* Errors:   *         -EBADR:     This unit type does not support starting.   *         -EALREADY:  Unit is already started. @@ -1423,7 +1411,6 @@ static void unit_status_log_starting_stopping_reloading(Unit *u, JobType t) {  int unit_start(Unit *u) {          UnitActiveState state;          Unit *following; -        int r;          assert(u); @@ -1477,14 +1464,7 @@ int unit_start(Unit *u) {          unit_add_to_dbus_queue(u); -        r = UNIT_VTABLE(u)->start(u); -        if (r <= 0) -                return r; - -        /* Log if the start function actually did something */ -        unit_status_log_starting_stopping_reloading(u, JOB_START); -        unit_status_print_starting_stopping(u, JOB_START); -        return r; +        return UNIT_VTABLE(u)->start(u);  }  bool unit_can_start(Unit *u) { @@ -1508,7 +1488,6 @@ bool unit_can_isolate(Unit *u) {  int unit_stop(Unit *u) {          UnitActiveState state;          Unit *following; -        int r;          assert(u); @@ -1527,13 +1506,7 @@ int unit_stop(Unit *u) {          unit_add_to_dbus_queue(u); -        r = UNIT_VTABLE(u)->stop(u); -        if (r <= 0) -                return r; - -        unit_status_log_starting_stopping_reloading(u, JOB_STOP); -        unit_status_print_starting_stopping(u, JOB_STOP); -        return r; +        return UNIT_VTABLE(u)->stop(u);  }  /* Errors: @@ -1544,7 +1517,6 @@ int unit_stop(Unit *u) {  int unit_reload(Unit *u) {          UnitActiveState state;          Unit *following; -        int r;          assert(u); @@ -1571,12 +1543,7 @@ int unit_reload(Unit *u) {          unit_add_to_dbus_queue(u); -        r = UNIT_VTABLE(u)->reload(u); -        if (r <= 0) -                return r; - -        unit_status_log_starting_stopping_reloading(u, JOB_RELOAD); -        return r; +        return UNIT_VTABLE(u)->reload(u);  }  bool unit_can_reload(Unit *u) { diff --git a/src/core/unit.h b/src/core/unit.h index 9491ef64f9..e60168267f 100644 --- a/src/core/unit.h +++ b/src/core/unit.h @@ -544,6 +544,7 @@ int unit_add_node_link(Unit *u, const char *what, bool wants);  int unit_coldplug(Unit *u);  void unit_status_printf(Unit *u, const char *status, const char *unit_status_msg_format) _printf_(3, 0); +void unit_status_emit_starting_stopping_reloading(Unit *u, JobType t);  bool unit_need_daemon_reload(Unit *u); diff --git a/src/login/logind-dbus.c b/src/login/logind-dbus.c index 049e33e2a6..e6371ff04d 100644 --- a/src/login/logind-dbus.c +++ b/src/login/logind-dbus.c @@ -1774,7 +1774,7 @@ static int nologin_timeout_handler(          log_info("Creating /run/nologin, blocking further logins..."); -        r = write_string_file("/run/nologin", "System is going down.", WRITE_STRING_FILE_ATOMIC); +        r = write_string_file("/run/nologin", "System is going down.", WRITE_STRING_FILE_CREATE|WRITE_STRING_FILE_ATOMIC);          if (r < 0)                  log_error_errno(r, "Failed to create /run/nologin: %m");          else diff --git a/src/udev/ata_id/ata_id.c b/src/udev/ata_id/ata_id.c index 7ba0b7fc8f..a59d4c6d50 100644 --- a/src/udev/ata_id/ata_id.c +++ b/src/udev/ata_id/ata_id.c @@ -638,10 +638,20 @@ int main(int argc, char *argv[])                   * All other values are reserved.                   */                  word = identify.wyde[108]; -                if ((word & 0xf000) == 0x5000) +                if ((word & 0xf000) == 0x5000) { +                        uint64_t wwwn; + +                        wwwn   = identify.wyde[108]; +                        wwwn <<= 16; +                        wwwn  |= identify.wyde[109]; +                        wwwn <<= 16; +                        wwwn  |= identify.wyde[110]; +                        wwwn <<= 16; +                        wwwn  |= identify.wyde[111];                          printf("ID_WWN=0x%1$" PRIx64 "\n"                                 "ID_WWN_WITH_EXTENSION=0x%1$" PRIx64 "\n", -                               identify.octa[108/4]); +                               wwwn); +                }                  /* from Linux's include/linux/ata.h */                  if (identify.wyde[0] == 0x848a || diff --git a/src/udev/udevd.c b/src/udev/udevd.c index 0661f7be00..945845d72c 100644 --- a/src/udev/udevd.c +++ b/src/udev/udevd.c @@ -1358,6 +1358,7 @@ static int listen_fds(int *rctrl, int *rnetlink) {   *   udev.event-timeout=<number of seconds>    seconds to wait before terminating an event   */  static int parse_proc_cmdline_item(const char *key, const char *value) { +        const char *full_key = key;          int r;          assert(key); @@ -1377,26 +1378,29 @@ static int parse_proc_cmdline_item(const char *key, const char *value) {                  int prio;                  prio = util_log_priority(value); +                if (prio < 0) +                        goto invalid;                  log_set_max_level(prio);          } else if (streq(key, "children-max")) {                  r = safe_atou(value, &arg_children_max);                  if (r < 0) -                        log_warning("invalid udev.children-max ignored: %s", value); +                        goto invalid;          } else if (streq(key, "exec-delay")) {                  r = safe_atoi(value, &arg_exec_delay);                  if (r < 0) -                        log_warning("invalid udev.exec-delay ignored: %s", value); +                        goto invalid;          } else if (streq(key, "event-timeout")) {                  r = safe_atou64(value, &arg_event_timeout_usec);                  if (r < 0) -                        log_warning("invalid udev.event-timeout ignored: %s", value); -                else { -                        arg_event_timeout_usec *= USEC_PER_SEC; -                        arg_event_timeout_warn_usec = (arg_event_timeout_usec / 3) ? : 1; -                } +                        goto invalid; +                arg_event_timeout_usec *= USEC_PER_SEC; +                arg_event_timeout_warn_usec = (arg_event_timeout_usec / 3) ? : 1;          }          return 0; +invalid: +        log_warning("invalid %s ignored: %s", full_key, value); +        return 0;  }  static void help(void) { diff --git a/src/user-sessions/user-sessions.c b/src/user-sessions/user-sessions.c index ddeb310c3c..e80a7771de 100644 --- a/src/user-sessions/user-sessions.c +++ b/src/user-sessions/user-sessions.c @@ -65,7 +65,7 @@ int main(int argc, char*argv[]) {          } else if (streq(argv[1], "stop")) {                  int r; -                r = write_string_file("/run/nologin", "System is going down.", WRITE_STRING_FILE_ATOMIC); +                r = write_string_file("/run/nologin", "System is going down.", WRITE_STRING_FILE_CREATE|WRITE_STRING_FILE_ATOMIC);                  if (r < 0) {                          log_error_errno(r, "Failed to create /run/nologin: %m");                          return EXIT_FAILURE; | 
