diff options
Diffstat (limited to 'src/libsystemd/sd-event/sd-event.c')
| -rw-r--r-- | src/libsystemd/sd-event/sd-event.c | 47 | 
1 files changed, 23 insertions, 24 deletions
| diff --git a/src/libsystemd/sd-event/sd-event.c b/src/libsystemd/sd-event/sd-event.c index ee4886700e..3191b458d1 100644 --- a/src/libsystemd/sd-event/sd-event.c +++ b/src/libsystemd/sd-event/sd-event.c @@ -34,6 +34,7 @@  #include "macro.h"  #include "missing.h"  #include "prioq.h" +#include "process-util.h"  #include "set.h"  #include "signal-util.h"  #include "string-util.h" @@ -415,11 +416,9 @@ _public_ int sd_event_new(sd_event** ret) {          e->original_pid = getpid();          e->perturb = USEC_INFINITY; -        e->pending = prioq_new(pending_prioq_compare); -        if (!e->pending) { -                r = -ENOMEM; +        r = prioq_ensure_allocated(&e->pending, pending_prioq_compare); +        if (r < 0)                  goto fail; -        }          e->epoll_fd = epoll_create1(EPOLL_CLOEXEC);          if (e->epoll_fd < 0) { @@ -436,7 +435,9 @@ fail:  }  _public_ sd_event* sd_event_ref(sd_event *e) { -        assert_return(e, NULL); + +        if (!e) +                return NULL;          assert(e->n_ref >= 1);          e->n_ref++; @@ -808,7 +809,7 @@ static void source_disconnect(sd_event_source *s) {                                  s->event->n_enabled_child_sources--;                          } -                        (void) hashmap_remove(s->event->child_sources, INT_TO_PTR(s->child.pid)); +                        (void) hashmap_remove(s->event->child_sources, PID_TO_PTR(s->child.pid));                          event_gc_signal_data(s->event, &s->priority, SIGCHLD);                  } @@ -1049,17 +1050,13 @@ _public_ int sd_event_add_time(          d = event_get_clock_data(e, type);          assert(d); -        if (!d->earliest) { -                d->earliest = prioq_new(earliest_time_prioq_compare); -                if (!d->earliest) -                        return -ENOMEM; -        } +        r = prioq_ensure_allocated(&d->earliest, earliest_time_prioq_compare); +        if (r < 0) +                return r; -        if (!d->latest) { -                d->latest = prioq_new(latest_time_prioq_compare); -                if (!d->latest) -                        return -ENOMEM; -        } +        r = prioq_ensure_allocated(&d->latest, latest_time_prioq_compare); +        if (r < 0) +                return r;          if (d->fd < 0) {                  r = event_setup_timer_fd(e, d, clock); @@ -1188,7 +1185,7 @@ _public_ int sd_event_add_child(          if (r < 0)                  return r; -        if (hashmap_contains(e->child_sources, INT_TO_PTR(pid))) +        if (hashmap_contains(e->child_sources, PID_TO_PTR(pid)))                  return -EBUSY;          s = source_new(e, !ret, SOURCE_CHILD); @@ -1201,7 +1198,7 @@ _public_ int sd_event_add_child(          s->userdata = userdata;          s->enabled = SD_EVENT_ONESHOT; -        r = hashmap_put(e->child_sources, INT_TO_PTR(pid), s); +        r = hashmap_put(e->child_sources, PID_TO_PTR(pid), s);          if (r < 0) {                  source_free(s);                  return r; @@ -1310,11 +1307,9 @@ _public_ int sd_event_add_exit(          assert_return(e->state != SD_EVENT_FINISHED, -ESTALE);          assert_return(!event_pid_changed(e), -ECHILD); -        if (!e->exit) { -                e->exit = prioq_new(exit_prioq_compare); -                if (!e->exit) -                        return -ENOMEM; -        } +        r = prioq_ensure_allocated(&e->exit, exit_prioq_compare); +        if (r < 0) +                return r;          s = source_new(e, !ret, SOURCE_EXIT);          if (!s) @@ -1338,7 +1333,9 @@ _public_ int sd_event_add_exit(  }  _public_ sd_event_source* sd_event_source_ref(sd_event_source *s) { -        assert_return(s, NULL); + +        if (!s) +                return NULL;          assert(s->n_ref >= 1);          s->n_ref++; @@ -2432,7 +2429,9 @@ _public_ int sd_event_prepare(sd_event *e) {          e->iteration++; +        e->state = SD_EVENT_PREPARING;          r = event_prepare(e); +        e->state = SD_EVENT_INITIAL;          if (r < 0)                  return r; | 
