diff options
author | Martin Pitt <martinpitt@users.noreply.github.com> | 2017-02-03 18:44:42 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-03 18:44:42 +0100 |
commit | b4a8c5ddb1326d45c0965a5d1919650d14c3c814 (patch) | |
tree | 32d86f8548dbe74b638ed73dedc10ce42127819d /src/libsystemd/sd-event/sd-event.c | |
parent | 63927b9f4ce538cd4e730bff53fae2381df48e9e (diff) | |
parent | 95f1d6bfecde60b245fae1ab0313b550201e7880 (diff) |
Merge pull request #4973 from poettering/run-race
run: fix race for "systemd-run --wait"
Diffstat (limited to 'src/libsystemd/sd-event/sd-event.c')
-rw-r--r-- | src/libsystemd/sd-event/sd-event.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/libsystemd/sd-event/sd-event.c b/src/libsystemd/sd-event/sd-event.c index f94959adac..4816bd1f67 100644 --- a/src/libsystemd/sd-event/sd-event.c +++ b/src/libsystemd/sd-event/sd-event.c @@ -2226,11 +2226,16 @@ static int process_signal(sd_event *e, struct signal_data *d, uint32_t events) { } static int source_dispatch(sd_event_source *s) { + EventSourceType saved_type; int r = 0; assert(s); assert(s->pending || s->type == SOURCE_EXIT); + /* Save the event source type, here, so that we still know it after the event callback which might invalidate + * the event. */ + saved_type = s->type; + if (s->type != SOURCE_DEFER && s->type != SOURCE_EXIT) { r = source_set_pending(s, false); if (r < 0) @@ -2318,7 +2323,7 @@ static int source_dispatch(sd_event_source *s) { if (r < 0) log_debug_errno(r, "Event source %s (type %s) returned error, disabling: %m", - strna(s->description), event_source_type_to_string(s->type)); + strna(s->description), event_source_type_to_string(saved_type)); if (s->n_ref == 0) source_free(s); |