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: parse uid/gid/pid/tid meta data from kdbus messages
[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 a11dc8c8767705d8d24e2fdb2ba3f4bdc25431ee..7cca9998bba72c577cdd8c1d2871348231892966 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,15
+78,22
@@
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;
int message_version;
+ bool is_kernel:1;
bool negotiate_fds:1;
bool can_fds:1;
bool bus_client:1;
bool ucred_valid:1;
bool is_server:1;
bool anonymous_auth:1;
bool negotiate_fds:1;
bool can_fds:1;
bool bus_client: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;
@@
-112,7
+123,9
@@
struct sd_bus {
} sockaddr;
socklen_t sockaddr_size;
} sockaddr;
socklen_t sockaddr_size;
- sd_id128_t peer;
+ char *kernel;
+
+ sd_id128_t server_id;
char *address;
unsigned address_index;
char *address;
unsigned address_index;
@@
-136,6
+149,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) {