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 0149604d2a4ef9fed18f8f15188b77a887502b98..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 {
@@
-74,7
+78,7
@@
enum bus_auth {
struct sd_bus {
unsigned n_ref;
enum bus_state state;
struct sd_bus {
unsigned n_ref;
enum bus_state state;
- int fd;
+ int
input_fd, output_
fd;
int message_version;
bool negotiate_fds:1;
int message_version;
bool negotiate_fds:1;
@@
-83,6
+87,12
@@
struct sd_bus {
bool ucred_valid:1;
bool is_server:1;
bool anonymous_auth:1;
bool ucred_valid:1;
bool is_server: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;
@@
-136,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) {