From: Lennart Poettering Date: Fri, 5 Apr 2013 01:15:10 +0000 (+0200) Subject: bus: don't allow recursive invocation of sd_bus_process() X-Git-Tag: v201~60 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=6807947e56d7d1b40ec4e984a5f631fb6d5a6834;p=elogind.git bus: don't allow recursive invocation of sd_bus_process() --- diff --git a/src/libsystemd-bus/bus-internal.h b/src/libsystemd-bus/bus-internal.h index feafed087..9cc1c9c89 100644 --- a/src/libsystemd-bus/bus-internal.h +++ b/src/libsystemd-bus/bus-internal.h @@ -85,6 +85,7 @@ struct sd_bus { bool anonymous_auth:1; bool prefer_readv:1; bool prefer_writev:1; + bool processing:1; void *rbuffer; size_t rbuffer_size; diff --git a/src/libsystemd-bus/sd-bus.c b/src/libsystemd-bus/sd-bus.c index 0964649e3..8daf922de 100644 --- a/src/libsystemd-bus/sd-bus.c +++ b/src/libsystemd-bus/sd-bus.c @@ -1845,6 +1845,10 @@ int sd_bus_process(sd_bus *bus, sd_bus_message **ret) { if (bus->input_fd < 0) return -ENOTCONN; + /* We don't allow recursively invoking sd_bus_process(). */ + if (bus->processing) + return -EBUSY; + switch (bus->state) { case BUS_UNSET: @@ -1870,7 +1874,11 @@ int sd_bus_process(sd_bus *bus, sd_bus_message **ret) { case BUS_RUNNING: case BUS_HELLO: - return process_running(bus, ret); + bus->processing = true; + r = process_running(bus, ret); + bus->processing = false; + + return r; } assert_not_reached("Unknown state"); diff --git a/src/systemd/sd-bus.h b/src/systemd/sd-bus.h index 122ec954c..b89394e97 100644 --- a/src/systemd/sd-bus.h +++ b/src/systemd/sd-bus.h @@ -34,7 +34,6 @@ extern "C" { /* TODO: * - allow registration/removl of callbacks from within callbacks - * - don't allow recursive processing * * - add page donation logic * - api for appending/reading fixed arrays