int verb_kill(int argc, char *argv[], void *userdata) {
_cleanup_strv_free_ char **names = NULL;
- char *kill_whom = NULL;
+ const char *kill_whom;
sd_bus *bus;
int r, q;
polkit_agent_open_maybe();
- if (!arg_kill_whom)
- arg_kill_whom = "all";
+ kill_whom = arg_kill_whom ?: "all";
/* --fail was specified */
if (streq(arg_job_mode(), "fail"))
- kill_whom = strjoina(arg_kill_whom, "-fail");
+ kill_whom = strjoina(kill_whom, "-fail");
r = expand_unit_names(bus, strv_skip(argv, 1), NULL, &names, NULL);
if (r < 0)
STRV_FOREACH(name, names) {
_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
- q = bus_call_method(
- bus,
- bus_systemd_mgr,
- "KillUnit",
- &error,
- NULL,
- "ssi", *name, kill_whom ?: arg_kill_whom, arg_signal);
+ if (arg_kill_value_set)
+ q = bus_call_method(
+ bus,
+ bus_systemd_mgr,
+ "QueueSignalUnit",
+ &error,
+ NULL,
+ "ssii", *name, kill_whom, arg_signal, arg_kill_value);
+ else
+ q = bus_call_method(
+ bus,
+ bus_systemd_mgr,
+ "KillUnit",
+ &error,
+ NULL,
+ "ssi", *name, kill_whom, arg_signal);
if (q < 0) {
log_error_errno(q, "Failed to kill unit %s: %s", *name, bus_error_message(&error, q));
if (r == 0)
char **arg_wall = NULL;
const char *arg_kill_whom = NULL;
int arg_signal = SIGTERM;
+int arg_kill_value;
+bool arg_kill_value_set = false;
char *arg_root = NULL;
char *arg_image = NULL;
usec_t arg_when = 0;
" sleeping, or hibernating\n"
" -i Shortcut for --check-inhibitors=no\n"
" --kill-whom=WHOM Whom to send signal to\n"
+ " --kill-value=INT Signal value to enqueue\n"
" -s --signal=SIGNAL Which signal to send\n"
" --what=RESOURCES Which types of resources to remove\n"
" --now Start or stop unit after enabling or disabling it\n"
ARG_IMAGE,
ARG_NO_RELOAD,
ARG_KILL_WHOM,
+ ARG_KILL_VALUE,
ARG_NO_ASK_PASSWORD,
ARG_FAILED,
ARG_RUNTIME,
{ "force", no_argument, NULL, 'f' },
{ "no-reload", no_argument, NULL, ARG_NO_RELOAD },
{ "kill-whom", required_argument, NULL, ARG_KILL_WHOM },
+ { "kill-value", required_argument, NULL, ARG_KILL_VALUE },
{ "signal", required_argument, NULL, 's' },
{ "no-ask-password", no_argument, NULL, ARG_NO_ASK_PASSWORD },
{ "host", required_argument, NULL, 'H' },
arg_kill_whom = optarg;
break;
+ case ARG_KILL_VALUE: {
+ unsigned u;
+
+ if (isempty(optarg)) {
+ arg_kill_value_set = false;
+ return 0;
+ }
+
+ /* First, try to parse unsigned, so that we can support the prefixes 0x, 0o, 0b */
+ r = safe_atou_full(optarg, 0, &u);
+ if (r < 0)
+ /* If this didn't work, try as signed integer, without those prefixes */
+ r = safe_atoi(optarg, &arg_kill_value);
+ else if (u > INT_MAX)
+ r = -ERANGE;
+ else
+ arg_kill_value = (int) u;
+ if (r < 0)
+ return log_error_errno(r, "Unable to parse signal queue value: %s", optarg);
+
+ arg_kill_value_set = true;
+ break;
+ }
+
case 's':
r = parse_signal_argument(optarg, &arg_signal);
if (r <= 0)