chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
bus: properly detect and handle if a callback is installed/removed from within a...
[elogind.git]
/
src
/
libsystemd-bus
/
bus-internal.h
diff --git
a/src/libsystemd-bus/bus-internal.h
b/src/libsystemd-bus/bus-internal.h
index feafed0876f63d5ea593ac463d738dd3524cde5d..6ff3163cfdbffe94975869c23b09219b71fd539a 100644
(file)
--- a/
src/libsystemd-bus/bus-internal.h
+++ b/
src/libsystemd-bus/bus-internal.h
@@
-46,6
+46,8
@@
struct filter_callback {
sd_bus_message_handler_t callback;
void *userdata;
sd_bus_message_handler_t callback;
void *userdata;
+ unsigned last_iteration;
+
LIST_FIELDS(struct filter_callback, callbacks);
};
LIST_FIELDS(struct filter_callback, callbacks);
};
@@
-55,6
+57,8
@@
struct object_callback {
char *path;
bool is_fallback;
char *path;
bool is_fallback;
+
+ unsigned last_iteration;
};
enum bus_state {
};
enum bus_state {
@@
-85,6
+89,10
@@
struct sd_bus {
bool anonymous_auth:1;
bool prefer_readv:1;
bool prefer_writev:1;
bool anonymous_auth:1;
bool prefer_readv:1;
bool prefer_writev:1;
+ bool processing:1;
+ bool match_callbacks_modified:1;
+ bool filter_callbacks_modified:1;
+ bool object_callbacks_modified:1;
void *rbuffer;
size_t rbuffer_size;
void *rbuffer;
size_t rbuffer_size;
@@
-138,6
+146,7
@@
struct sd_bus {
char **exec_argv;
uint64_t hello_serial;
char **exec_argv;
uint64_t hello_serial;
+ unsigned iteration_counter;
};
static inline void bus_unrefp(sd_bus **b) {
};
static inline void bus_unrefp(sd_bus **b) {