chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
core: replace OnFailureIsolate= setting by a more generic OnFailureJobMode= setting...
[elogind.git]
/
src
/
core
/
transaction.c
diff --git
a/src/core/transaction.c
b/src/core/transaction.c
index 5259a5b7ca94f9b3e4284ede38d87d7ce5e2fcc5..e2ff0bd1e5986fe0af05d4c9b0eeb06fe9150103 100644
(file)
--- a/
src/core/transaction.c
+++ b/
src/core/transaction.c
@@
-22,9
+22,10
@@
#include <unistd.h>
#include <fcntl.h>
#include <unistd.h>
#include <fcntl.h>
-#include "transaction.h"
#include "bus-errors.h"
#include "bus-errors.h"
-#include "dbus-common.h"
+#include "bus-util.h"
+#include "bus-error.h"
+#include "transaction.h"
static void transaction_unlink_job(Transaction *tr, Job *j, bool delete_dependencies);
static void transaction_unlink_job(Transaction *tr, Job *j, bool delete_dependencies);
@@
-231,7
+232,7
@@
static int delete_one_unmergeable_job(Transaction *tr, Job *j) {
return -EINVAL;
}
return -EINVAL;
}
-static int transaction_merge_jobs(Transaction *tr,
DBusE
rror *e) {
+static int transaction_merge_jobs(Transaction *tr,
sd_bus_e
rror *e) {
Job *j;
Iterator i;
int r;
Job *j;
Iterator i;
int r;
@@
-261,8
+262,9
@@
static int transaction_merge_jobs(Transaction *tr, DBusError *e) {
return -EAGAIN;
/* We couldn't merge anything. Failure */
return -EAGAIN;
/* We couldn't merge anything. Failure */
- dbus_set_error(e, BUS_ERROR_TRANSACTION_JOBS_CONFLICTING, "Transaction contains conflicting jobs '%s' and '%s' for %s. Probably contradicting requirement dependencies configured.",
- job_type_to_string(t), job_type_to_string(k->type), k->unit->id);
+ sd_bus_error_setf(
+ e, BUS_ERROR_TRANSACTION_JOBS_CONFLICTING, "Transaction contains conflicting jobs '%s' and '%s' for %s. Probably contradicting requirement dependencies configured.",
+ job_type_to_string(t), job_type_to_string(k->type), k->unit->id);
return r;
}
}
return r;
}
}
@@
-334,7
+336,7
@@
_pure_ static bool unit_matters_to_anchor(Unit *u, Job *j) {
return false;
}
return false;
}
-static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsigned generation,
DBusE
rror *e) {
+static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsigned generation,
sd_bus_e
rror *e) {
Iterator i;
Unit *u;
int r;
Iterator i;
Unit *u;
int r;
@@
-344,7
+346,7
@@
static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
assert(!j->transaction_prev);
/* Does a recursive sweep through the ordering graph, looking
assert(!j->transaction_prev);
/* Does a recursive sweep through the ordering graph, looking
- * for a cycle. If we find cycle we try to break it. */
+ * for a cycle. If we find
a
cycle we try to break it. */
/* Have we seen this before? */
if (j->generation == generation) {
/* Have we seen this before? */
if (j->generation == generation) {
@@
-371,7
+373,7
@@
static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
/* logging for j not k here here to provide consistent narrative */
log_info_unit(j->unit->id,
/* logging for j not k here here to provide consistent narrative */
log_info_unit(j->unit->id,
- "
Walked on cycle path to
%s/%s",
+ "
Found dependency on
%s/%s",
k->unit->id, job_type_to_string(k->type));
if (!delete &&
k->unit->id, job_type_to_string(k->type));
if (!delete &&
@@
-405,8
+407,8
@@
static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
log_error("Unable to break cycle");
log_error("Unable to break cycle");
-
dbus_set_error
(e, BUS_ERROR_TRANSACTION_ORDER_IS_CYCLIC,
- "Transaction order is cyclic. See system logs for details.");
+
sd_bus_error_setf
(e, BUS_ERROR_TRANSACTION_ORDER_IS_CYCLIC,
+
"Transaction order is cyclic. See system logs for details.");
return -ENOEXEC;
}
return -ENOEXEC;
}
@@
-445,7
+447,7
@@
static int transaction_verify_order_one(Transaction *tr, Job *j, Job *from, unsi
return 0;
}
return 0;
}
-static int transaction_verify_order(Transaction *tr, unsigned *generation,
DBusE
rror *e) {
+static int transaction_verify_order(Transaction *tr, unsigned *generation,
sd_bus_e
rror *e) {
Job *j;
int r;
Iterator i;
Job *j;
int r;
Iterator i;
@@
-490,7
+492,7
@@
rescan:
}
}
}
}
-static int transaction_is_destructive(Transaction *tr, JobMode mode,
DBusE
rror *e) {
+static int transaction_is_destructive(Transaction *tr, JobMode mode,
sd_bus_e
rror *e) {
Iterator i;
Job *j;
Iterator i;
Job *j;
@@
-508,7
+510,7
@@
static int transaction_is_destructive(Transaction *tr, JobMode mode, DBusError *
if (j->unit->job && (mode == JOB_FAIL || j->unit->job->irreversible) &&
!job_type_is_superset(j->type, j->unit->job->type)) {
if (j->unit->job && (mode == JOB_FAIL || j->unit->job->irreversible) &&
!job_type_is_superset(j->type, j->unit->job->type)) {
-
dbus_set_error
(e, BUS_ERROR_TRANSACTION_IS_DESTRUCTIVE, "Transaction is destructive.");
+
sd_bus_error_setf
(e, BUS_ERROR_TRANSACTION_IS_DESTRUCTIVE, "Transaction is destructive.");
return -EEXIST;
}
}
return -EEXIST;
}
}
@@
-635,7
+637,7
@@
rollback:
return r;
}
return r;
}
-int transaction_activate(Transaction *tr, Manager *m, JobMode mode,
DBusE
rror *e) {
+int transaction_activate(Transaction *tr, Manager *m, JobMode mode,
sd_bus_e
rror *e) {
Iterator i;
Job *j;
int r;
Iterator i;
Job *j;
int r;
@@
-677,7
+679,7
@@
int transaction_activate(Transaction *tr, Manager *m, JobMode mode, DBusError *e
break;
if (r != -EAGAIN) {
break;
if (r != -EAGAIN) {
- log_warning("Requested transaction contains an unfixable cyclic ordering dependency: %s", bus_error(e, r));
+ log_warning("Requested transaction contains an unfixable cyclic ordering dependency: %s", bus_error
_message
(e, r));
return r;
}
return r;
}
@@
-694,7
+696,7
@@
int transaction_activate(Transaction *tr, Manager *m, JobMode mode, DBusError *e
break;
if (r != -EAGAIN) {
break;
if (r != -EAGAIN) {
- log_warning("Requested transaction contains unmergeable jobs: %s", bus_error(e, r));
+ log_warning("Requested transaction contains unmergeable jobs: %s", bus_error
_message
(e, r));
return r;
}
return r;
}
@@
-713,7
+715,7
@@
int transaction_activate(Transaction *tr, Manager *m, JobMode mode, DBusError *e
/* Ninth step: check whether we can actually apply this */
r = transaction_is_destructive(tr, mode, e);
if (r < 0) {
/* Ninth step: check whether we can actually apply this */
r = transaction_is_destructive(tr, mode, e);
if (r < 0) {
- log_notice("Requested transaction contradicts existing jobs: %s", bus_error(e, r));
+ log_notice("Requested transaction contradicts existing jobs: %s", bus_error
_message
(e, r));
return r;
}
return r;
}
@@
-733,8
+735,11
@@
int transaction_activate(Transaction *tr, Manager *m, JobMode mode, DBusError *e
* feature for cosmetics, not actually useful for
* anything beyond that. */
* feature for cosmetics, not actually useful for
* anything beyond that. */
- if (m->idle_pipe[0] < 0 && m->idle_pipe[1] < 0)
+ if (m->idle_pipe[0] < 0 && m->idle_pipe[1] < 0 &&
+ m->idle_pipe[2] < 0 && m->idle_pipe[3] < 0) {
pipe2(m->idle_pipe, O_NONBLOCK|O_CLOEXEC);
pipe2(m->idle_pipe, O_NONBLOCK|O_CLOEXEC);
+ pipe2(m->idle_pipe + 2, O_NONBLOCK|O_CLOEXEC);
+ }
}
return 0;
}
return 0;
@@
-772,10
+777,10
@@
static Job* transaction_add_one_job(Transaction *tr, JobType type, Unit *unit, b
j->override = override;
j->irreversible = tr->irreversible;
j->override = override;
j->irreversible = tr->irreversible;
- LIST_PREPEND(
Job,
transaction, f, j);
+ LIST_PREPEND(transaction, f, j);
if (hashmap_replace(tr->jobs, unit, f) < 0) {
if (hashmap_replace(tr->jobs, unit, f) < 0) {
- LIST_REMOVE(
Job,
transaction, f, j);
+ LIST_REMOVE(transaction, f, j);
job_free(j);
return NULL;
}
job_free(j);
return NULL;
}
@@
-832,7
+837,7
@@
int transaction_add_job_and_dependencies(
bool conflicts,
bool ignore_requirements,
bool ignore_order,
bool conflicts,
bool ignore_requirements,
bool ignore_order,
-
DBusE
rror *e) {
+
sd_bus_e
rror *e) {
Job *ret;
Iterator i;
Unit *dep;
Job *ret;
Iterator i;
Unit *dep;
@@
-853,12
+858,12
@@
int transaction_add_job_and_dependencies(
unit->load_state != UNIT_ERROR &&
unit->load_state != UNIT_NOT_FOUND &&
unit->load_state != UNIT_MASKED) {
unit->load_state != UNIT_ERROR &&
unit->load_state != UNIT_NOT_FOUND &&
unit->load_state != UNIT_MASKED) {
-
dbus_set_error
(e, BUS_ERROR_LOAD_FAILED, "Unit %s is not loaded properly.", unit->id);
+
sd_bus_error_setf
(e, BUS_ERROR_LOAD_FAILED, "Unit %s is not loaded properly.", unit->id);
return -EINVAL;
}
return -EINVAL;
}
- if (type != JOB_STOP &&
(unit->load_state == UNIT_ERROR || unit->load_state == UNIT_NOT_FOUND)
) {
-
dbus_set_error
(e, BUS_ERROR_LOAD_FAILED,
+ if (type != JOB_STOP &&
unit->load_state == UNIT_ERROR
) {
+
sd_bus_error_setf
(e, BUS_ERROR_LOAD_FAILED,
"Unit %s failed to load: %s. "
"See system logs and 'systemctl status %s' for details.",
unit->id,
"Unit %s failed to load: %s. "
"See system logs and 'systemctl status %s' for details.",
unit->id,
@@
-867,13
+872,21
@@
int transaction_add_job_and_dependencies(
return -EINVAL;
}
return -EINVAL;
}
+ if (type != JOB_STOP && unit->load_state == UNIT_NOT_FOUND) {
+ sd_bus_error_setf(e, BUS_ERROR_LOAD_FAILED,
+ "Unit %s failed to load: %s.",
+ unit->id,
+ strerror(-unit->load_error));
+ return -EINVAL;
+ }
+
if (type != JOB_STOP && unit->load_state == UNIT_MASKED) {
if (type != JOB_STOP && unit->load_state == UNIT_MASKED) {
-
dbus_set_error(e, BUS_ERROR
_MASKED, "Unit %s is masked.", unit->id);
+
sd_bus_error_setf(e, BUS_ERROR_UNIT
_MASKED, "Unit %s is masked.", unit->id);
return -EADDRNOTAVAIL;
}
if (!unit_job_is_applicable(unit, type)) {
return -EADDRNOTAVAIL;
}
if (!unit_job_is_applicable(unit, type)) {
-
dbus_set_error
(e, BUS_ERROR_JOB_TYPE_NOT_APPLICABLE, "Job type %s is not applicable for unit %s.", job_type_to_string(type), unit->id);
+
sd_bus_error_setf
(e, BUS_ERROR_JOB_TYPE_NOT_APPLICABLE, "Job type %s is not applicable for unit %s.", job_type_to_string(type), unit->id);
return -EBADR;
}
return -EBADR;
}
@@
-905,10
+918,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-924,7
+937,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-935,7
+948,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-944,10
+957,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-956,10
+969,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-970,7
+983,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-979,10
+992,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
if (r < 0) {
log_full_unit(r == -EADDRNOTAVAIL ? LOG_DEBUG : LOG_WARNING, dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-993,7
+1006,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-1002,10
+1015,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-1020,7
+1033,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-1031,7
+1044,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-1042,7
+1055,7
@@
int transaction_add_job_and_dependencies(
goto fail;
if (e)
goto fail;
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
@@
-1055,10
+1068,10
@@
int transaction_add_job_and_dependencies(
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency reload job for unit %s, ignoring: %s",
if (r < 0) {
log_warning_unit(dep->id,
"Cannot add dependency reload job for unit %s, ignoring: %s",
- dep->id, bus_error(e, r));
+ dep->id, bus_error
_message
(e, r));
if (e)
if (e)
-
d
bus_error_free(e);
+
sd_
bus_error_free(e);
}
}
}
}
}
}